data:image/s3,"s3://crabby-images/fb641/fb641a0cf885b853d74d1eaa7fc1f8bb98e1f5f7" alt="A stick figure smiling"
If you want to see more comics like this, sign up for my saturday comics newsletter or browse more comics!
data:image/s3,"s3://crabby-images/c3a19/c3a1938accfd3b841245adb27bd50022edec2dc0" alt="Image of a comic. To read the full HTML alt text, click "read the transcript"."
read the transcript!
you might expect git to enforce some rules about branches
some rules you might imagine:
- you can’t remove commits from a branch, only add them
- the
main
branch has to stay more less in sync withorigin/main
But there are no rules.
git character with demon hat: want to do something horrible to your branch? no problem!
there are literally no rules
commands that you can use to do weird stuff to a branch:
git reset
git rebase
instead of rules, we have conventions
for example:
- run
git pull
often to keep yourmain
up to date - if you’re working with a big team, don’t commit to
main
directly
Illustration of the git demon talking to a nonplussed stick figure with curly hair.
git demon: you’ve just gotta be really careful to not do the wrong thing and not mess up your branch
person: um… thanks?
our only saviour: the reflog
git reflog BRANCHNAME
will show you the history of every change to the branch, so you can always undo
the reflog is a VERY unfriendly UI, but it’s always there.
Saturday Morning Comics!
Want another comic like this in your email every Saturday? Sign up here!