data:image/s3,"s3://crabby-images/8e4cc/8e4cc3df84ba1e880cf3cb566547d3faa4e6852c" alt=""
How to rebase on a single branch
How to rebase on a single branch 관련
You can also use git rebase
while looking at a history of a single branch.
Let's see if you can help me here.
Say I worked from feature_branch_2
, and specifically edited the file code.py
. I started by changing all strings to be wrapped by double quotes rather than single quotes:
data:image/s3,"s3://crabby-images/dd43c/dd43c89101156f1fc21856b817a51c12b860acf1" alt="Changing into in <FontIcon icon="fa-brands fa-youtube"/><br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
'
into "
in code.py
<Source: Brief>
Then, I staged and committed:
git add code.py
git commit -m "Commit 17"
I then decided to add a new function at the beginning of the file:
data:image/s3,"s3://crabby-images/9bb5b/9bb5b10dd5fea5f9c46ebbde8a912e229d9767af" alt="Adding the function <br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
another_feature
<Source: Brief>
Again, I staged and committed:
git add code.py
git commit -m "Commit 18"
And now I realized I actually forgot to change the single quotes to double quotes wrapping the __main__
(as you might have noticed), so I did that too:
data:image/s3,"s3://crabby-images/ec186/ec18659d373e1a6b99c6d716bb0c36055c3f0d66" alt="Changing into <br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
'__main__'
into "__main__"
<Source: Brief>
Of course, I staged and committed this change:
git add code.py
git commit -m "Commit 19"
Now, consider the history:
data:image/s3,"s3://crabby-images/bfe93/bfe931bc9cf025de0493004e96cb005ec46daa9a" alt="The commit history after introducing "Commit 19"<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
<Source: Brief>
It isn't really nice, is it? I mean, I have two commits that are related to one another, "Commit 17" and "Commit 19" (turning '
s into "
s), but they are split by the unrelated "Commit 18" (where I added a new function). What can we do? 🤔 Can you help me?
Intuitively, I want to edit the history here:
data:image/s3,"s3://crabby-images/31c50/31c50955a747818c9e55af1c6ddc5fd6810ac0db" alt="These are the commits I want to edit<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
<Source: Brief>
So, what would you do?
You are right! 👏🏻
I can rebase the history from "Commit 17" to "Commit 19", on top of "Commit 15". To do that:
git rebase --interactive --onto <SHA_OF_COMMIT_15> <SHA_OF_COMMIT_15>
Notice I specified "Commit 15" as the beginning of the range of commits, excluding this commit. And I didn't need to explicitly specify HEAD
as the last parameter.
data:image/s3,"s3://crabby-images/648b7/648b791e03c7214cce67d8f383481862a724782c" alt="Using on a single branch<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
rebase --onto
on a single branch<Source: Brief>
After following your advice and running the rebase
command (thanks! 😇) I get the following screen:
data:image/s3,"s3://crabby-images/4dcd8/4dcd8953bb760e594bbfd6a78a0b5b3741862962" alt="Interactive rebase<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
<Source: Brief>
So what would I do? I want to put "Commit 19" before "Commit 18", so it comes right after "Commit 17". I can go further and squash them together, like so:
data:image/s3,"s3://crabby-images/edf87/edf8794fae5c53c09c4f42d6ead48d4929baf951" alt="Interactive rebase - changing the order of commit and squashing<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
<Source: Brief>
Now when I get prompted for a commit message, I can provide the message "Commit 17+19":
data:image/s3,"s3://crabby-images/d8011/d801117469fc92c0370c7151ef8a535ab044f307" alt="Providing a commit message<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
<Source: Brief>
And now, see our beautiful history:
data:image/s3,"s3://crabby-images/9ce95/9ce95df6ceb5839303bfa0805968ded4860f9ade" alt="The resulting history<br/><Source: <FontIcon icon="fa-brands fa-youtube"/>Brief>"
<Source: Brief>
Thanks again! 🙌🏻