Introduction to Git
data:image/s3,"s3://crabby-images/0fb48/0fb48f4b7432c7e4027c0c7c9b5f7e98346284a6" alt=""
Why Git?
- Linux Kernel
- 15 million lines of code
- 60 000 contributors
- One central repository
- Was using SVN
- Very Slow
- Central point of failure
data:image/s3,"s3://crabby-images/65f6d/65f6dc8e5d06775048ce849ff4e3ce6e165e8a76" alt=""
Originally Developed by Linus Torvalds
What is Git?
"Git is a Free and open source distributed version control system designed to handle everything from small to very large projects with speed and efficiency."
Distributed
data:image/s3,"s3://crabby-images/95708/9570877e29030b519499b62617c555725fd0b79e" alt=""
Github
- Github is not Git
- Cloud service
- Central repository. Although Git is decentralized
- Extra features on top of Git
- Pull requests
- Visualisations
- Permission management
- Organizations
data:image/s3,"s3://crabby-images/6d01a/6d01a7d2f18509c3b82e96d432ad519b75bb2d98" alt=""
Tools
- Command line
- Best way to do git. Most servers don't have a UI.
- Learn this first.
- Unix users. Add small script to bash_profile to show current working branch
- Source tree
- Drag-Drop UI
- Good visual overview
- Use it for the more complex interactions
data:image/s3,"s3://crabby-images/74ba9/74ba97a4da261e8984a29de9f6bb100776d522c5" alt=""
SourceTree
Basic Concepts
-
Clone Make a local copy of a repository
- When you want to make changes to the existing repo.
-
Fork Make a clone of a repository. On github. Your own central version.
- When you want to create your own version of an existing software project.
- Git init Create a new repository from existing folder
- Remote: Link to an external repository
data:image/s3,"s3://crabby-images/b3fc7/b3fc7c67d1a328ebb8641606ddcd191f5df6be00" alt=""
Local modification
data:image/s3,"s3://crabby-images/12e26/12e26f9c1f3f8ed7d6d194404c5dfe8d9940e3c7" alt=""
- Git status
- Git add
- Git commit
- Git reset
- Git remove
Pushing and Pulling
data:image/s3,"s3://crabby-images/12a25/12a2532522ffe4597fb26657b7ee901a7ecf58ca" alt=""
Merge Conflicts
data:image/s3,"s3://crabby-images/09feb/09feb11146831ecac83e068d8a68091af762bd71" alt=""
data:image/s3,"s3://crabby-images/22657/2265714b94a188c9f81221cc095ebd091e9883c6" alt=""
Branching & tagging
data:image/s3,"s3://crabby-images/3ce9f/3ce9f6cbea4d4fe675cce308b5bb252938112b3e" alt=""
Git Stash
data:image/s3,"s3://crabby-images/36099/36099c0f5b36b3c844e8ac024c8768aa57951cec" alt=""
git stash
git stash pop
Undo Changes
- Never rewrite history
- Instead, use git revert
- commits the inverse
- Use git rebase carefully!
data:image/s3,"s3://crabby-images/86dd2/86dd28dd276ed62fa362a28e5a2ec28d9017ed56" alt=""
Git Flow
- Model on how to do branching
- Industry Standard
- For World of Balance
- Master - Latest Stable version
- Hotfixes - Merges straight into master
- Development - Unstable Branch
- Feature branches - sub branch of development for specific features. Very unstable.
Feature Branches
- Every independent feature has a branch
- Branched off of Development
- Create pull request when you want to merge
- Review with team before you merge
data:image/s3,"s3://crabby-images/bcefa/bcefa6cfe71109b9b02eca6139c69107d09260da" alt=""
Pull Requests
data:image/s3,"s3://crabby-images/f32d2/f32d2b8e6529f5ec26cc9002d3d00bf8f83b828d" alt=""
Github Issues
data:image/s3,"s3://crabby-images/82ea9/82ea96bc91d4df6fb52b47b1ac31e44489ee0151" alt=""
Releases
- Merge Development into Master
- Increase the tag number (Semver)
- Should (in theory) be stable
data:image/s3,"s3://crabby-images/57423/57423e7aa13605b51c7bf9d85ae2825e9f0d99c3" alt=""
Think about other developers
Some tips and guidelines
data:image/s3,"s3://crabby-images/b911e/b911eba334f040eeab56dbc6bf48de05df9dd81d" alt=""
- Never Merge into dev without Pull Request
- Definitely do not merge into Master
- When in doubt, create a feature branch
- Whitespace vs tabs.
- Feel free to experiment on branches
- Write clear commit messages
- "Added a new animal class"
-
- "Changed some text in some file"
- Use Github issues to communicate across teams
- Be careful with merge conflicts. Use git blame
Some Golden rules
Incase of broken code
data:image/s3,"s3://crabby-images/276ab/276ab6ea64650945d47a595a72b7852746f63c6a" alt=""
- This is why we have version control.
- Changes can always be reverted
Questions?
Copy of Intro to Git
By Jens Vanderhaeghe
Copy of Intro to Git
- 921