Quick Access
Introduction
Say you want to move a lot of levels up in the commit tree. It might be tedious to type ^ several times, so Git also has the tilde (~) operator.
Command | Description |
---|---|
^ |
Move upwards one commit at a time |
~n |
Move upwards a number of times. |
The tilde operator (optionally) takes in a trailing number that specifies the number of parents you would like to ascend. Let's see it in action.
Tilde (~) operator
Before moving
data:image/s3,"s3://crabby-images/48c57/48c5726e987c0c867f685a5b5bf014c3a83e9901" alt="Git before checkout HEAD"
Let's specify a number of commits back with ~.
git checkout HEAD~4
After moving
data:image/s3,"s3://crabby-images/27d40/27d40b12814bc79b71d0367cafeb6375526d0172" alt="Git after checkout HEAD"
Boom! So concise -- relative refs are great.
Branch Forcing
You're an expert on relative refs now, so let's actually use them for something. You can directly reassign a branch to a commit with the -f option. So something like:
git branch -f master HEAD~3
moves (by force) the master branch to three parents behind HEAD.
Before branch --force
data:image/s3,"s3://crabby-images/4ec06/4ec06f3a6075503eeb71573f52d7df94de7cfa40" alt="Git before force branch"
git branch -f master HEAD~3
After branch --force
data:image/s3,"s3://crabby-images/49fa2/49fa2bbc7a46affbf10bf4f66e4addfe126b85db" alt="Git after force branch"
There we go! Relative refs gave us a concise way to refer to C1 and branch forcing (-f)
gave us a way to quickly move a branch to that location.
Now that you have seen relative refs and branch forcing in combination, let's use them to solve the challenge.