Version control with
Git and GitHub
Szymon Grabia
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Version Control System
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
System that records changes to a set of files over time
- restoration of files back to a previous state
- comparison of changes over time
- transparent cooperation
data:image/s3,"s3://crabby-images/75591/755919557371ef5cc47ae9bdd95db94a6cf65393" alt=""
What is Git?
Distributed Version Control System
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Main features:
- branching system for non-linear development
- primarily local repositories
- preservation and integrity of change history
- 3 stages of files
Centralized VCS
shared
repository
developer
developer
developer
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Distributed VCS
shared
repository
developer
developer
developer
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
The Three Stages
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Working
directory
Staging area
Repository
Local
Remote
Repository
git add
git commit
git push
git pull
git checkout
Git commits
data:image/s3,"s3://crabby-images/7af7a/7af7a2b370f447a716bd46cd43d9c939e1d4edbf" alt=""
data:image/s3,"s3://crabby-images/23bad/23bad6c67d28bbe9385174f7f03ac0ffdadef6e4" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Git identity
git config --global user.name "John Doe"
git config --global user.email "johndoe@example.com"
data:image/s3,"s3://crabby-images/9e690/9e690e6bc5c0448eeb1479c2a4f36b24b476a02e" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Initialize git repository
git init
data:image/s3,"s3://crabby-images/0cfab/0cfab03abe1c8af5b93c6d4afcb4ab524f1b4261" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Show the working tree status
git status
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/306a9/306a9c11e1a5e17d03258a419885db3130d665db" alt=""
data:image/s3,"s3://crabby-images/a529c/a529c2bdaf9abd3582b0a9224f9dcb336b40fb00" alt=""
Add files to staging area
git add FILE
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/f7b4b/f7b4b5a195d8af46fcd862d74018ae0fa4e03647" alt=""
Commit files
git commit -m "MESSAGE"
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/0a066/0a06602503c9dd8ecef675be71c1aca2eb281744" alt=""
Commit messages
data:image/s3,"s3://crabby-images/b0d46/b0d460fb2899078bf48436770e556e632f359fad" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
The seven rules of a great Git commit message
- Separate subject from body with a blank line
- Limit the subject line to 50 characters
- Capitalize the subject line
- Do not end the subject line with a period
- Use the imperative mood in the subject line
- Wrap the body at 72 characters
- Use the body to explain what and why vs. how
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Show changes in tracked files
git diff
Exit with "q"
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/bb822/bb822ae9ba8bc3414161d3c00268243bc1b07baa" alt=""
Git Branching
Branching
C1
C2
master
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
C2
master
test
git branch test
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
test
C2
master
git checkout test
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
test
C2
C3
master
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
test
C2
C3
C4
master
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
test
C2
C3
C4
C5
master
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
test
C2
C3
C4
C5
C6
master
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Branching
C1
master
test
C2
C3
C4
C5
C7
C6
git checkout master
git merge test
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Show commit history
git log [--graph]
Exit with "q"
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/3bbb4/3bbb4e8ea4d6874ce90f4f1382051a2c21b764ef" alt=""
data:image/s3,"s3://crabby-images/f01e4/f01e42f71bbe754681a5ae2053840230bc4690ff" alt=""
Branching
data:image/s3,"s3://crabby-images/22e49/22e49f0075ac5a30e51223ece42215ea42087439" alt=""
data:image/s3,"s3://crabby-images/af38b/af38b0173f9c0e1261523f8cb005bb1a741b5cc5" alt=""
GitFlow
data:image/s3,"s3://crabby-images/d101f/d101f7514d2044a848ab77ad0b5e07166901bb97" alt=""
Merge conflicts
data:image/s3,"s3://crabby-images/8eb0f/8eb0fd2c5c0309a387372e413c3bf4f173786d84" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Merge conflicts
git merge test
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/3fbee/3fbee1b28290b138e864e57a218d0f9b341f2c40" alt=""
data:image/s3,"s3://crabby-images/c83a2/c83a262d2c37f76254759a866fc6492e0eba01f6" alt=""
Ignore files
# .gitignore
# ignore all files ending with ".log"
*.log
# BUT don't ignore "important.log"
!important.log
# ignore all directories named "data"
data/
# ignore directories named "data" in the project root
/data/
A collection of useful .gitignore templates:
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Don't store data in repositories!
Git stash
git stash
git stash apply
OR
git stash pop
git stash list
git stash show -a
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Much more...
git tag
git rebase
git rm
git reset
git blame
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
The Three Stages
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Working
directory
Staging area
Repository
Local
Remote
Repository
git add
git commit
git push
git pull
git checkout
Repository hosting
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/30659/306592fd3d953864156ee1daf00caed2cd9d1e6a" alt=""
data:image/s3,"s3://crabby-images/c1f43/c1f43f8645dab4d01affadc5c2d0171c10cd3b2d" alt=""
data:image/s3,"s3://crabby-images/75123/75123adf6c4b7516a0319991df1cbeb8168a52d3" alt=""
data:image/s3,"s3://crabby-images/7115c/7115c34b636c893bcb5740f788d67a89d30d411f" alt=""
data:image/s3,"s3://crabby-images/75123/75123adf6c4b7516a0319991df1cbeb8168a52d3" alt=""
data:image/s3,"s3://crabby-images/7115c/7115c34b636c893bcb5740f788d67a89d30d411f" alt=""
GitHub flow
data:image/s3,"s3://crabby-images/9500c/9500cefac9265ae44e038d0f003a617ea11c4b21" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
SSH keys
ssh-keygen -t rsa -b 4096 -C "szymon.grabia@gmail.com"
eval "$(ssh-agent -s)"
ssh-add ~/.ssh/id_rsa
cat ~/.ssh/id_rsa.pub
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Clone remote repository
git clone https://github.com/LaVestima/ngseminar-git-github.git
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/d350e/d350eb3b8238c748f2770e46abefabe0deeb0d5f" alt=""
Clone remote repository
git remote -v
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
data:image/s3,"s3://crabby-images/b0820/b082092eae3e7484eeb6d281d9839cbea8deb7b2" alt=""
Push changes to remote
git push [<repository> [<refspec>...]]
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
git push origin master
Pull changes from remote
git pull [<repository> [<refspec>...]]
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
git pull origin master
data:image/s3,"s3://crabby-images/0882d/0882d0b625d9d91d91476d1dc1a404d8af77d23e" alt=""
data:image/s3,"s3://crabby-images/8310b/8310b8e8bd97e9383a6b85d7d48c8e5b36f97169" alt=""
Awesome lists about all kinds of interesting topics
data:image/s3,"s3://crabby-images/23def/23def0bfed5b737a40f3c68386b678df6ba4d020" alt=""
NGSeminar: Version control with git and github
By Szymon Grabia
NGSeminar: Version control with git and github
https://www.youtube.com/watch?v=XYnHWGPnvNM&ab_channel=NGSchool
- 1,146