Tan Li Hau
@lihautan
https://lihautan.com
Web Frontend - Platform
GIT GUDDER
data:image/s3,"s3://crabby-images/626aa/626aa889ae2103bb30c1f1e28095784d40659b65" alt=""
https://youtu.be/vpFKAV1Zy5Y
data:image/s3,"s3://crabby-images/042f6/042f6d0c4c364658ad7633074190b1be5335a093" alt=""
GIT
- git merge
- git reset
- git cherry-pick
- git revert
- git rebase
- git log
- git reflog
- git bisect
GIT MERGE
"Fast Forward"
data:image/s3,"s3://crabby-images/98344/9834490ec33b1d7c6518a4b9ad15b4bafdd57484" alt=""
"Fast Forward"
data:image/s3,"s3://crabby-images/47ac1/47ac1e5ade0d36c116b01262a7e648e3544d6763" alt=""
"Fast Forward"
data:image/s3,"s3://crabby-images/47ac1/47ac1e5ade0d36c116b01262a7e648e3544d6763" alt=""
# in Branch A
git checkout branch-a
git merge master
# or
git merge --ff master
"Non-Fast Forward"
data:image/s3,"s3://crabby-images/18aea/18aeaa58d15e155a430bb8813129efcf32ca71dd" alt=""
"Non-Fast Forward"
data:image/s3,"s3://crabby-images/7f968/7f968228b0012cb62853ff550060aa1cb918fe85" alt=""
"Non-Fast Forward"
data:image/s3,"s3://crabby-images/7f968/7f968228b0012cb62853ff550060aa1cb918fe85" alt=""
# in Branch A
git checkout branch-a
git merge master
# or
git merge --no-ff master
GIT PULL
= git fetch origin branch-a
+ git merge origin/branch-a
data:image/s3,"s3://crabby-images/5c6be/5c6bec3dc0e8d5045c95af03f51d324f4ab2be09" alt=""
GIT PULL
= git fetch origin branch-a
+ git merge origin/branch-a
data:image/s3,"s3://crabby-images/5c6be/5c6bec3dc0e8d5045c95af03f51d324f4ab2be09" alt=""
data:image/s3,"s3://crabby-images/5bae6/5bae677456d152037ad9dd246555e0710398a748" alt=""
GIT PULL
= git fetch origin branch-a
+ git merge origin/branch-a
data:image/s3,"s3://crabby-images/fd94b/fd94b06513ac72880ef1d21efe901d6c0ecf20ee" alt=""
git push origin branch-a
GIT RESET
GIT RESET --HARD
data:image/s3,"s3://crabby-images/c5456/c5456f70662c39850381df629b6b33e57ff7deaf" alt=""
GIT RESET --HARD
data:image/s3,"s3://crabby-images/c5456/c5456f70662c39850381df629b6b33e57ff7deaf" alt=""
git reset --hard branch-a
GIT RESET --HARD
git reset --hard branch-a
data:image/s3,"s3://crabby-images/57740/57740acbdc09191ee0d0695bb28a18273afeab64" alt=""
GIT RESET --HARD
data:image/s3,"s3://crabby-images/c5456/c5456f70662c39850381df629b6b33e57ff7deaf" alt=""
git reset --hard #d
GIT RESET --HARD
git reset --hard #d
data:image/s3,"s3://crabby-images/15f4f/15f4f2cc297835918f75f47e153dc9b75f46209c" alt=""
GIT CHERRY-PICK
GIT CHERRY-PICK
data:image/s3,"s3://crabby-images/82bd3/82bd3382282f02770576fb78da80d440e8249a3b" alt=""
GIT CHERRY-PICK
data:image/s3,"s3://crabby-images/82bd3/82bd3382282f02770576fb78da80d440e8249a3b" alt=""
git cherry-pick branch-a
GIT CHERRY-PICK
git cherry-pick branch-a
data:image/s3,"s3://crabby-images/8856d/8856d964c97ad47acaeecd28ec418601485290f2" alt=""
GIT CHERRY-PICK
data:image/s3,"s3://crabby-images/82bd3/82bd3382282f02770576fb78da80d440e8249a3b" alt=""
git cherry-pick branch-c
GIT CHERRY-PICK
data:image/s3,"s3://crabby-images/3afe1/3afe19edacc541438b4aaf3d3ba7cf5afc4718de" alt=""
git cherry-pick branch-c
GIT REVERT
GIT REVERT
data:image/s3,"s3://crabby-images/654a7/654a7de4df63fd8576304ccb37a739b03e766564" alt=""
GIT REVERT
data:image/s3,"s3://crabby-images/654a7/654a7de4df63fd8576304ccb37a739b03e766564" alt=""
git revert #1
GIT REVERT
data:image/s3,"s3://crabby-images/52932/52932d598b7adef2b2d27439fad4e0c11bab7c39" alt=""
git revert #1
GIT REVERT
data:image/s3,"s3://crabby-images/74ebc/74ebc7c4b9213880ee9247fe8b4600033bf31cdb" alt=""
GIT REVERT
data:image/s3,"s3://crabby-images/91e02/91e02043bb1746e21c977b6d089ce8d30fdcbaf8" alt=""
GIT REVERT
data:image/s3,"s3://crabby-images/91e02/91e02043bb1746e21c977b6d089ce8d30fdcbaf8" alt=""
master: git revert #1
GIT REVERT
master: git revert #1
data:image/s3,"s3://crabby-images/91a16/91a169ee6005cdd1cedad7cbc0df67550567996c" alt=""
GIT REVERT
data:image/s3,"s3://crabby-images/91a16/91a169ee6005cdd1cedad7cbc0df67550567996c" alt=""
feat/a: git merge master
GIT REVERT
data:image/s3,"s3://crabby-images/740da/740da15956ef47e58a90f155bb3233574d5a0db7" alt=""
feat/a: git merge master
GIT REVERT
data:image/s3,"s3://crabby-images/edade/edade3905a66efa78ebffe1a3a6b93ccc1ff69ab" alt=""
GIT REVERT
data:image/s3,"s3://crabby-images/edade/edade3905a66efa78ebffe1a3a6b93ccc1ff69ab" alt=""
master: git merge feat/a
GIT REVERT
data:image/s3,"s3://crabby-images/7c657/7c6574c6e234fd5f76a4306d8806e467ce991330" alt=""
master: git merge feat/a
GIT REVERT
data:image/s3,"s3://crabby-images/91a16/91a169ee6005cdd1cedad7cbc0df67550567996c" alt=""
GIT REVERT
data:image/s3,"s3://crabby-images/91a16/91a169ee6005cdd1cedad7cbc0df67550567996c" alt=""
feat/a: git merge master
GIT REVERT
data:image/s3,"s3://crabby-images/740da/740da15956ef47e58a90f155bb3233574d5a0db7" alt=""
feat/a: git merge master
GIT REVERT
data:image/s3,"s3://crabby-images/740da/740da15956ef47e58a90f155bb3233574d5a0db7" alt=""
feat/a: git revert ~#1
GIT REVERT
data:image/s3,"s3://crabby-images/e53ca/e53ca2b4a25e259b568964dd0f0217aa705fd594" alt=""
feat/a: git revert ~#1
GIT REVERT
data:image/s3,"s3://crabby-images/e53ca/e53ca2b4a25e259b568964dd0f0217aa705fd594" alt=""
master: git merge feat/a
GIT REVERT
data:image/s3,"s3://crabby-images/d2054/d20546f170706ff85d3287602f64393bfa294c26" alt=""
master: git merge feat/a
GIT REBASE
data:image/s3,"s3://crabby-images/a0aa9/a0aa9b8da896fc7653a7571fff2f151964cb85c8" alt=""
data:image/s3,"s3://crabby-images/3316a/3316a6461678783c6224b8516043e56a4bd773d3" alt=""
git rebase
branch-a branched out from master
data:image/s3,"s3://crabby-images/3316a/3316a6461678783c6224b8516043e56a4bd773d3" alt=""
data:image/s3,"s3://crabby-images/da12e/da12ea0f53d37db09ed462bd9bfa443534602bef" alt=""
git rebase
data:image/s3,"s3://crabby-images/3316a/3316a6461678783c6224b8516043e56a4bd773d3" alt=""
data:image/s3,"s3://crabby-images/da12e/da12ea0f53d37db09ed462bd9bfa443534602bef" alt=""
git rebase
# in Branch A
git checkout branch-a
git rebase master
git rebase
data:image/s3,"s3://crabby-images/961aa/961aae3dbc63112f5c766d2db2cea16b608b77ea" alt=""
git rebase
data:image/s3,"s3://crabby-images/961aa/961aae3dbc63112f5c766d2db2cea16b608b77ea" alt=""
data:image/s3,"s3://crabby-images/dec3c/dec3c87257c59cc2f926fa7f04a37541e8481c82" alt=""
git rebase
data:image/s3,"s3://crabby-images/961aa/961aae3dbc63112f5c766d2db2cea16b608b77ea" alt=""
data:image/s3,"s3://crabby-images/dec3c/dec3c87257c59cc2f926fa7f04a37541e8481c82" alt=""
# in Branch A
git checkout branch-a
git rebase --onto branch-b master branch-a
git rebase
data:image/s3,"s3://crabby-images/961aa/961aae3dbc63112f5c766d2db2cea16b608b77ea" alt=""
data:image/s3,"s3://crabby-images/dec3c/dec3c87257c59cc2f926fa7f04a37541e8481c82" alt=""
# in Branch A
git checkout branch-a
git rebase --onto branch-b master
git rebase
data:image/s3,"s3://crabby-images/961aa/961aae3dbc63112f5c766d2db2cea16b608b77ea" alt=""
data:image/s3,"s3://crabby-images/dec3c/dec3c87257c59cc2f926fa7f04a37541e8481c82" alt=""
# in Branch A
git checkout branch-a
git rebase --onto branch-b #1
#1
data:image/s3,"s3://crabby-images/3316a/3316a6461678783c6224b8516043e56a4bd773d3" alt=""
git rebase
# in Branch A
git checkout branch-a
git rebase --onto #1 #1
#1
data:image/s3,"s3://crabby-images/3316a/3316a6461678783c6224b8516043e56a4bd773d3" alt=""
git rebase
# in Branch A
git checkout branch-a
git rebase #1
#1
git rebase --interactive
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
#1
git rebase --interactive
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
#1
git rebase -i #1
#2 pick commit msg 2
#3 pick commit msg 3
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
git rebase --interactive
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
#1
git rebase -i #1
# Rebase #1..#6 onto #1 (5 commands)
#
# Commands:
# p, pick = use commit
# r, reword = use commit, but edit the commit message
# e, edit = use commit, but stop for amending
...
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 drop commit msg 3
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 drop commit msg 3
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/0af2f/0af2f245c65ab64f11df9bc418425c0ddf91f10a" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 squash commit msg 3
#4 pick commit msg 4
#5 fixup commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 squash commit msg 3
#4 pick commit msg 4
#5 fixup commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/62f2c/62f2c0ca42a530d276c2f0cdf67963f47301fff7" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 pick commit msg 3
break
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 pick commit msg 3
break
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/6c568/6c56829cfca80d10b1c54216cdd8cb285d6473df" alt=""
git rebase --interactive
#1
git rebase -i #1
Stopped at #3... commit msg 3
$ git status
interactive rebase in progress; onto 594531e
Last commands done (2 commands done):
...
(see more in file .git/rebase-merge/done)
Next commands to do (3 remaining commands):
...
data:image/s3,"s3://crabby-images/6c568/6c56829cfca80d10b1c54216cdd8cb285d6473df" alt=""
git rebase --interactive
#1
git rebase -i #1
...
$ git add .
$ git commit -m "commit msg 3.1"
data:image/s3,"s3://crabby-images/6c568/6c56829cfca80d10b1c54216cdd8cb285d6473df" alt=""
git rebase --interactive
#1
git rebase -i #1
...
$ git add .
$ git commit -m "commit msg 3.1"
data:image/s3,"s3://crabby-images/81ff7/81ff7a49964f929baed7a6247d1d79da4fe79ab7" alt=""
git rebase --interactive
#1
git rebase -i #1
$ git rebase --continue
data:image/s3,"s3://crabby-images/81ff7/81ff7a49964f929baed7a6247d1d79da4fe79ab7" alt=""
git rebase --interactive
#1
git rebase -i #1
$ git rebase --continue
data:image/s3,"s3://crabby-images/c5455/c54553fef30bc24fce2cedef69a50f3e46e5ccda" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 edit commit msg 3
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
git rebase --interactive
#1
git rebase -i #1
...
$ git add .
$ git rebase --continue
data:image/s3,"s3://crabby-images/6c568/6c56829cfca80d10b1c54216cdd8cb285d6473df" alt=""
git rebase --interactive
#1
git rebase -i #1
...
$ git add .
$ git rebase --continue
data:image/s3,"s3://crabby-images/c9e91/c9e912425432b1f223420bf2fe9a17c961712ecb" alt=""
git rebase --interactive
#1
git rebase -i #1
#2 pick commit msg 2
#3 reword commit msg 3
#4 pick commit msg 4
#5 pick commit msg 5
#6 pick commit msg 6
data:image/s3,"s3://crabby-images/4a56f/4a56f0990ed05874be5d3c9eced145340c3fe82a" alt=""
git rebase --interactive
#1
git rebase -i #1
data:image/s3,"s3://crabby-images/6c568/6c56829cfca80d10b1c54216cdd8cb285d6473df" alt=""
# abort
$ git rebase --abort
# continue
$ git rebase --continue
GIT PULL
= git fetch origin branch-a
+ git merge origin/branch-a
data:image/s3,"s3://crabby-images/5c6be/5c6bec3dc0e8d5045c95af03f51d324f4ab2be09" alt=""
GIT PULL --REBASE
= git fetch origin branch-a
+ git rebase origin/branch-a
data:image/s3,"s3://crabby-images/5c6be/5c6bec3dc0e8d5045c95af03f51d324f4ab2be09" alt=""
GIT PULL --REBASE
= git fetch origin branch-a
+ git rebase origin/branch-a
data:image/s3,"s3://crabby-images/4cf8c/4cf8ce97ee14946829cc6df8d06e350a753845c5" alt=""
git rebase
data:image/s3,"s3://crabby-images/d5e3e/d5e3ed451e0e14002785c17a7345f4bc8679dbb2" alt=""
git rebase
data:image/s3,"s3://crabby-images/9e859/9e8590744a99a5998789555273f7ba336a227245" alt=""
git rebase
data:image/s3,"s3://crabby-images/d47b4/d47b4befd8a2803690ca10f69ec7cbe45dc48a86" alt=""
git rebase
data:image/s3,"s3://crabby-images/3b769/3b7695ba3e9a8e28bdd21e9cf3e07eb5b585cf25" alt=""
git rebase
data:image/s3,"s3://crabby-images/10022/100221e541311bc3387f2b7aed0f0e7754a1f802" alt=""
git rebase
data:image/s3,"s3://crabby-images/e6a0d/e6a0d0ac15a4e065d097578e62ad4adb59497335" alt=""
git rebase
data:image/s3,"s3://crabby-images/d47b4/d47b4befd8a2803690ca10f69ec7cbe45dc48a86" alt=""
git rebase
data:image/s3,"s3://crabby-images/67741/67741e93a85887c1c5384835df7c84dfcf5b4a53" alt=""
GIT LOG
git log --graph --pretty='%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit
aliased to glol
--since=<date>
--after=<date>
--until=<date>
--before=<date>
--grep=<pattern>
--invert-grep
--all-match
--min-parents=<number>
--max-parents=<number>
--merges
--no-merges
--first-parent
GIT REFLOG
GIT BISECT
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
Bisecting: 675 revisions left to test after this (roughly 10 steps)
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
Bisecting: 675 revisions left to test after this (roughly 10 steps)
$ git bisect good
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
Bisecting: 675 revisions left to test after this (roughly 10 steps)
$ git bisect good
Bisecting: 337 revisions left to test after this (roughly 9 steps)
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
Bisecting: 675 revisions left to test after this (roughly 10 steps)
$ git bisect good
Bisecting: 337 revisions left to test after this (roughly 9 steps)
$ git bisect bad
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
Bisecting: 675 revisions left to test after this (roughly 10 steps)
$ git bisect good
Bisecting: 337 revisions left to test after this (roughly 9 steps)
$ git bisect bad
Bisecting: 168 revisions left to test after this (roughly 8 steps)
$ git bisect start $ git bisect bad v2.5.1 $ git bisect good v2.6.13
Bisecting: 675 revisions left to test after this (roughly 10 steps)
$ git bisect good
Bisecting: 337 revisions left to test after this (roughly 9 steps)
$ git bisect bad
Bisecting: 168 revisions left to test after this (roughly 8 steps)
$ git bisect reset
good / bad
old / new
good / bad
old / new
git bisect start --term-old fast --term-new slow
data:image/s3,"s3://crabby-images/f760f/f760ff1003b185ca28cb9e8ab548f21be04fd5bf" alt=""
THANK YOU
GIT: Manipulating your history
By Li Hau Tan
GIT: Manipulating your history
- 2,159