Magit tutorial - Rebase (Part II)
How to use Magit in Emacs to do rebase in Git
data:image/s3,"s3://crabby-images/c59de/c59de9e42c5bad30681177170702a9b8a3f2d05a" alt="Git rebase with Magit"
In part I we went through how to use git rebase to modify commit history, things like reword a commit, squash multiple commits, split commit. In this part, we will talk about another common use case of rebase: rebase before merging branches.
Let’s first create a new repo and add one file.txt
as the first commit.
apple
pear
peach
cat
dog
snake
Now we create a feature
branch from master
branch. To create a new branch, press b
(Branching) and c
(Checkout new branch).
Now that we are on the feature
branch, lets add a new file file2.txt
with the folloing content:
TODOs:
1. Go to supermarket
2. Pick up dog
Commit the changes with message add todos
.
Then let’s modify the file.txt
to the following:
apple
pear
peach
cat
dog
pig
Then commit with the message change snake to pig
.
Now let’s switch back to master
branch.
To make things more interesting, let’s also modify the file.txt
to replace snake
with panda
, then commit.
To recap, now the history looks like this:
data:image/s3,"s3://crabby-images/5ba6f/5ba6fd86e3bb1e00723d4681771cfbdb2910b034" alt=""
Note that the last commits in master
and feature
are conflicting each other.
Suppose now the feature
branch has finished, and we want to merge it back to master
.
First, let’s rebase it against master.
Checkout feature
, and press r
(Rebasing), and e
(elsewhere) and choose master
. Since there is conflict, Magit will show the following page indicating that we have to solve the conflicts.
data:image/s3,"s3://crabby-images/a9553/a9553be901dbcc6719a188de61bbdeb39aa0c37e" alt=""
This is as we expected, let’s now use the Ediff dwimming
(do what I mean) to resolve the conflict. Put the cursor on the conflicting file, and press e
.
Now we are entering the Ediff
buffer.
data:image/s3,"s3://crabby-images/2465b/2465bc8184b54321ef28eed8e3c8bf665eed7827" alt=""
Let’s say that we decided to take the changes in feature
branch, then we can press n
to select the diff, and b
to choose variant B. If everything goes right, we should see that the C Section should now contain the correct text.
data:image/s3,"s3://crabby-images/1431c/1431c4a81ab8a0b724f4a5bb771b72a6bb0e1ddb" alt=""
Now press q
to quit Ediff
and also choose save the file when prompted.
Now we should be back at the main Magit screen, press g
to refresh should show the following.
data:image/s3,"s3://crabby-images/9975e/9975e9a45efe58a23a99e9964a09ef2274f97af2" alt=""
Looks everything is good, we can press r
and continue rebasing.
After done, the log should show the following:
data:image/s3,"s3://crabby-images/0e5da/0e5daea07ad3cf0842df05993b574f19181950b8" alt=""
See that now the history looks very clean and as if changes were done in a linear fashion.
~The End~
Twitter
Google+
Facebook
Reddit
LinkedIn
StumbleUpon
Email