Introduction
This is a guide on how to rebase a branch called “featureA” over “main” branch.
---
title: before
---
%%{init: { 'logLevel': 'debug', 'theme': 'base' } }%%
gitGraph
   commit id: "main-1"
   commit id: "main-2"
   branch featureA
   checkout featureA
   commit id: "feat-1"
   checkout main
   commit id: "main-3" type: HIGHLIGHT
   checkout featureA
   commit id: "feat-2"
   checkout main
   commit id: "main-4" type: HIGHLIGHT
---
title: after
---
%%{init: { 'logLevel': 'debug', 'theme': 'base' } }%%
gitGraph
   commit id: "main-1"
   commit id: "main-2"
   commit id: "main-3" type: HIGHLIGHT
   commit id: "main-4" type: HIGHLIGHT
   branch featureA
   checkout featureA
   commit id: "feat-1"
   commit id: "feat-2"
Lazygit
- Go to the 3. Local Branches panel.
- Press 3.
 
- Press 
- Hover over the “featureA” branch.
- Use the ↓/↑keys or asingle click.
 
- Use the 
- Checkout the “featureA” branch.
- Press spaceor use adouble click.
 
- Press 
- Hover over the “main” branch.
- Use the ↓/↑keys or asingle click.
 
- Use the 
- Rebase the “featureA” branch over the “main” branch.
- Press r.
 
- Press 
- When prompted for confirmation, continue by pressing enteror cancel withesc.- Add#screenshot of rebase confirmation prompt.
 
- If there are any merge conflicts, resolve them.
- Add#screenshot of Auto-merge failed notification
 
Basic Terminal
- First checkout the feature branch that you want to rebase
git checkout featureA- Then rebase it over main branch
git rebase main- If there are conflicts, you will need to resolve them before you can continue the rebase.
# To select changes done in base `main` branch
git checkout --ours <file>
 
# To select changes done in `featureA` branch
git checkout --theirs <file>
 
# or Manually edit the file to resolve the conflict
vim <file>- Once conflicts are resolved for a file, stage the file
git add <file>- Once all conflicts are resolved, continue the rebase
git rebase --continue