Quick Access
Introduction
Like the ~
modifier, the ^
modifier also accepts
an optional number after it.
Rather than specifying the number of generations to go back (what ~
takes),
the modifier on ^
specifies which parent reference to follow from a merge commit.
Remember that merge commits have multiple parents, so the path to choose is ambiguous.
Git will normally follow the "first" parent upwards from a merge commit,
but specifying a number with ^
changes this default behavior.
Enough talking, let's see it in action with some examples.
Before the checkout
data:image/s3,"s3://crabby-images/f2aa9/f2aa9661b38370380c20f36c1d8a0257d44cdbd4" alt="Git before checkout"
Here we have a merge commit. If we checkout master^ without the modifier,
we will follow the first parent after the merge commit.
git checkout master^
After the checkout
data:image/s3,"s3://crabby-images/e90cb/e90cbaca41e48047a2dac96513e5558812f4afb7" alt="Git after checkout"
Easy -- this is what we are all used to.
Before the checkout
data:image/s3,"s3://crabby-images/f2aa9/f2aa9661b38370380c20f36c1d8a0257d44cdbd4" alt="Git before checkout"
Now let's try specifying the second parent instead...
git checkout master^2
After the checkout
data:image/s3,"s3://crabby-images/1afa2/1afa23b83cbb102b5829f60bc87d87f5eeac08e9" alt="Git after checkout"
See? We followed the other parent upwards.
Before the checkout
data:image/s3,"s3://crabby-images/ccd09/ccd091ba391a2a94fd1072e7c2145e4cc1fb0b7d" alt="Git before checkout"
The ^ and ~ modifiers can make moving around a commit tree very powerful.
Even crazier, these modifiers can be chained together! Check this out:
git checkout HEAD~^2~2
After the checkout
data:image/s3,"s3://crabby-images/09732/0973269a3821072b64c1a143d6d0749ac04c7733" alt="Git after checkout"
Lightning fast!
To complete this level, create a new branch at the specified destination. Obviously it would be easy to specify the commit directly (with something like C6), but I challenge you to use the modifiers we talked about instead!