GIT
for beginners++
Krzysztof Szumny - noisy
git tips
- don't use fancy gui programs for git - use console!
- explicit over implicit
- learn how to work with multiple repositories
- draw your branches!
- git log --decorate
- be obsessed about your git status
- customized prompt
data:image/s3,"s3://crabby-images/9870b/9870b23f948d1fa04c3764e99aa3073248a0fd0d" alt=""
data:image/s3,"s3://crabby-images/bce9c/bce9cfd4150cb24f2b7816ac5732c4699ab1cc87" alt=""
-
Basic
-
Advanced
git prompt
data:image/s3,"s3://crabby-images/72f96/72f9694ade26d4a4cce96cf1982b2289bf084c24" alt=""
data:image/s3,"s3://crabby-images/e8888/e88883e0b63cb1ba587d0918fe7be16a7529a16e" alt=""
data:image/s3,"s3://crabby-images/bed6e/bed6e97f15ecac809ae8ccc129db5a99e16f4e17" alt=""
data:image/s3,"s3://crabby-images/c02d9/c02d9397d7ee0085fdbdc62db8957f9d37ca0851" alt=""
data:image/s3,"s3://crabby-images/7d798/7d79839e7a706edd0c82eb7a389699e492288bcf" alt=""
data:image/s3,"s3://crabby-images/e2aea/e2aead37394ee01d8ca9d93a6eb730d9ebb559a9" alt=""
Real live examples:
git log
git log --decorate --graph --oneline
git log
git log --decorate
git log --decorate --graph
the power of -p
data:image/s3,"s3://crabby-images/48b7b/48b7b6cb8d6e68da4d02cd8e6d382fb9604458a0" alt=""
Multiple repositories
local and remote
data:image/s3,"s3://crabby-images/2fe84/2fe84d1a2e42d74da35f460323804f59f5e3579e" alt=""
data:image/s3,"s3://crabby-images/566c3/566c359620579f94367e31fff222e45a5b6a3bf9" alt=""
data:image/s3,"s3://crabby-images/8d659/8d65944b29b19c5c3178fda4a22af5ecda823472" alt=""
Typical tasks which requires
counterintuitive solutions
- Modifying a commit
- Deleting a branch
- Deleting a commit
Modifying a commit
data:image/s3,"s3://crabby-images/642f6/642f6d94e9ef5972abcba918c6548714cf056fce" alt=""
data:image/s3,"s3://crabby-images/2d5f7/2d5f74012ea01c3606de463d88a27f583e4377ed" alt=""
data:image/s3,"s3://crabby-images/62be8/62be87d6eec2eae5aee6c533e66982470bd85fdb" alt=""
Push a branch
git push <repo> <remote_branch>
git push origin feature-8
data:image/s3,"s3://crabby-images/4a812/4a812446bcfe8a3486563335527422b35f4893c1" alt=""
data:image/s3,"s3://crabby-images/ce047/ce0477f526ba420c119a052098ba79e1d2b5a120" alt=""
data:image/s3,"s3://crabby-images/a161c/a161cf68de06326191bd5d2bb9f686cc49bb1abb" alt=""
data:image/s3,"s3://crabby-images/5e4f4/5e4f4b3ee19627f4f4c174cd278cacfdaaa4aa39" alt=""
git push <repo> <branch>:<remote_branch>
git push origin feature-8:feature-8
data:image/s3,"s3://crabby-images/ea1d7/ea1d781ff0bfc65ad34bf21d3cc2f1ebba586009" alt=""
git push <repo> <branch>:<remote_branch>
git push origin feature-8~1:feature-8
data:image/s3,"s3://crabby-images/43b7b/43b7b1019546169ee46e3b90e336e48bf8325e39" alt=""
Delete a branch
data:image/s3,"s3://crabby-images/e8952/e895228420eec5167b903bcea02439f3e161ec0f" alt=""
git push <repo> <branch>:<remote_branch>
git push origin :feature-8
git push <repo> --delete <remote_branch>
git push origin --delete feature-8
Reset a branch/delete a commit
git reset --hard <hash/branch>
data:image/s3,"s3://crabby-images/cd101/cd101c5c4ded1b7a37c9670742333b41ce501ccd" alt=""
git reset --hard HEAD~1
data:image/s3,"s3://crabby-images/4279b/4279b57f77bfdf5fad911fc5ddc074f769a8258c" alt=""
data:image/s3,"s3://crabby-images/7b0e4/7b0e4cf0ee5fecb578d9bad5ec69441c3685ea2b" alt=""
data:image/s3,"s3://crabby-images/f0496/f049617b512da2644b23bed9981c20d4c67d0bb9" alt=""
git reset --hard origin/feature-8
data:image/s3,"s3://crabby-images/4fda0/4fda07b9d8a9026b794d0871622f04f7df78376a" alt=""
data:image/s3,"s3://crabby-images/2049c/2049c270c842ecd1d5e7c136739a142e544c0709" alt=""
Rebase
- rebase - what is that?
- why rebase is needed
- lets imagine that there is no rebase...
- how to manually achieve this same result
- how git know what commits need to be rebased
- git rebase interactive
- git rebase --onto
When we need rebase?
data:image/s3,"s3://crabby-images/4e957/4e957067d6f9686fcfc7f1a11cfd7d79082784d5" alt=""
data:image/s3,"s3://crabby-images/0948b/0948bb22f9296c927bef28790d2f7c449f6a5795" alt=""
data:image/s3,"s3://crabby-images/34098/340988fe2763f04b3dea11e06c6b59bde0994acb" alt=""
1. New changes were pushed to base branch
When we need rebase?
2. when we want to delete a commit, which is not the last
data:image/s3,"s3://crabby-images/947c0/947c03f71172e4010cdf704d55193fb04e19e1dc" alt=""
data:image/s3,"s3://crabby-images/f30bc/f30bc345ece76d5d8de1a065946604c0c63c786e" alt=""
data:image/s3,"s3://crabby-images/e2b35/e2b35c16d8e8b9f6326d2da6ed2b9b23545b1121" alt=""
When we need rebase?
3. commits are on wrong branch
data:image/s3,"s3://crabby-images/ad31b/ad31ba0fcd6824f676ae0e182ec0290749ba22c5" alt=""
data:image/s3,"s3://crabby-images/7dce9/7dce936df1254de6a4f4fa40b315d696ac603f42" alt=""
*this is more difficult rebase, requires --onto
How rebasing works
rebase is like automated version of cherry-pick
so let's explain very quickly how git cherry-pick works...
$ git cherry-pick feature-7~1
data:image/s3,"s3://crabby-images/e0df1/e0df1940c4d50123b9d1ebe9da8781f1869e514a" alt=""
data:image/s3,"s3://crabby-images/84a0f/84a0f964da757a4cfee55355354919b964164104" alt=""
data:image/s3,"s3://crabby-images/358c5/358c55475bc550471230ae36d6c8a3a581b8bcab" alt=""
How rebasing works
data:image/s3,"s3://crabby-images/110ed/110ed52adf7a6b292df79251a96c19ee0e18e1fe" alt=""
data:image/s3,"s3://crabby-images/e7139/e7139954b78ca15a5cdf7ae6674c04fa43d53651" alt=""
data:image/s3,"s3://crabby-images/22cfc/22cfc5b351b433af954074a081ca2869b027cc94" alt=""
data:image/s3,"s3://crabby-images/c50ae/c50aefbe2dd1dea8fb38c2eca6d0a7a452255815" alt=""
$ git rebase master
Lets take a look on git rebase --interactive
demo: https://asciinema.org/a/bgau9swvdqz2jqx7fxyjq57tb
data:image/s3,"s3://crabby-images/aa58e/aa58ec5fd51b1867e54ca82bf481d19b38a1ee27" alt=""
How git knows which commits needs to be rebased
$ git merge-base master feature-8
C
git merge-base <branch> <branch>
data:image/s3,"s3://crabby-images/63bc8/63bc8cdfcfcab3220b012b1faa357d76a10e8b68" alt=""
data:image/s3,"s3://crabby-images/0b434/0b434d9df9b87cb26df8c29b7afe8b566b7a884d" alt=""
data:image/s3,"s3://crabby-images/1e476/1e476a30dfddb8efb8fe051069036a9d1c8b4bef" alt=""
data:image/s3,"s3://crabby-images/9d275/9d27508c8709360f16d9c397513a7787b6576df1" alt=""
data:image/s3,"s3://crabby-images/4c535/4c5352e35dceacd2bda5938791690acb541936af" alt=""
branch from another branch
data:image/s3,"s3://crabby-images/b0a9f/b0a9f17c7a2e1b7cfae581eb95d934609fe07218" alt=""
data:image/s3,"s3://crabby-images/c2ede/c2ede207aafbd0ff2cb8ccb89202e3e69dde4c1d" alt=""
data:image/s3,"s3://crabby-images/eb220/eb2207720ea8e0d593c9d3fb84c661f01f7a751b" alt=""
data:image/s3,"s3://crabby-images/356d9/356d93a16e85a6ebe7f19509dcf3d797701a42a0" alt=""
data:image/s3,"s3://crabby-images/96532/96532f3d712232e34cc84ca7c4395f74625696c1" alt=""
data:image/s3,"s3://crabby-images/9c104/9c104f07869b4e6354758d0e88e70d0ecb9351c3" alt=""
data:image/s3,"s3://crabby-images/ed1f2/ed1f26f9b2bb32de79b0c664c285e075041f743e" alt=""
data:image/s3,"s3://crabby-images/1dbc2/1dbc2d0dfe272ac7b8181fe865879bf435857851" alt=""
data:image/s3,"s3://crabby-images/dc693/dc693448ddb81bac9a79681a4593aa0c32b648d4" alt=""
data:image/s3,"s3://crabby-images/0f0c9/0f0c98ad544574c6851ee5d6b6e4695a501bf336" alt=""
data:image/s3,"s3://crabby-images/a62c2/a62c2ed15cf3ca6c457a6206a807161e0b288294" alt=""
data:image/s3,"s3://crabby-images/7bc3a/7bc3af1fbb6ae25ed0ef910db4e37e28e8f4e94d" alt=""
data:image/s3,"s3://crabby-images/908a3/908a3bff19a84f4e725fda34fe706cfd27426bcf" alt=""
data:image/s3,"s3://crabby-images/e0d40/e0d406b285c74c44b3bdec5e8a50e7de21e8a38c" alt=""
data:image/s3,"s3://crabby-images/ebf78/ebf787a2cae1406cf0160f1b1a43e02de1b1f439" alt=""
data:image/s3,"s3://crabby-images/67d6d/67d6d1040714da9e93b7eaf82e407c4b3df2a397" alt=""
data:image/s3,"s3://crabby-images/f7aae/f7aaea799ea0a02b2ddf50d8681e30395b3f3585" alt=""
data:image/s3,"s3://crabby-images/ed0b9/ed0b9bfcdcc313a1618d26cb8ab97ce8652a2226" alt=""
data:image/s3,"s3://crabby-images/c5c26/c5c26986df67274c66781323da062f4431f95910" alt=""
data:image/s3,"s3://crabby-images/990e8/990e8c71aeca3123078f9324c82771f4529a00f3" alt=""
data:image/s3,"s3://crabby-images/6ea02/6ea0293ccd974699ab58e28b3b9381d45772cf95" alt=""
data:image/s3,"s3://crabby-images/40fe7/40fe78b10ed5c89dd08d5c179d7224c0b8c63414" alt=""
data:image/s3,"s3://crabby-images/51ca5/51ca5cd947894575961d8be9905a8a95b58aa399" alt=""
data:image/s3,"s3://crabby-images/0e709/0e7094aef51f716ed838812698324b75e8bb8fe2" alt=""
data:image/s3,"s3://crabby-images/06841/06841108007228dad9a28deb5396ab0d64c8f754" alt=""
# being on feature-9
git rebase feature-8
# being on feature-8
git rebase master
# being on feature-9
git rebase feature-8 #???
# being on feature-9 git rebase --onto feature-8 feature-9~3 feature-9
Upcoming scheduled livestream:
Lecture: Git for beginners++
- Duration: 45 minutes + Q&A session
- Language: English
- When?
data:image/s3,"s3://crabby-images/b7432/b74322e80e5d6a6732895a9e61a00ea4c27e3f0b" alt=""
Q&A
GIT
By noisy
GIT
- 2,435