Git & GitHub
Getting Started Workshop
originally by Gwen Lofman
modified by Greg Willard
Follow along with the slides at
polyhacks17.github.io/github-workshop
Shortened link: goo.gl/53L48V
Scope
- up and running with
git
git
as a standalone usergit
as a participant
Command Syntax
command subcommand -o --option
Navigating the file system
cd
- change directoryls
- list files & directoriesmkdir
- make directory
What is git
?
data:image/s3,"s3://crabby-images/0c3a0/0c3a0506f64e61e69a4496ace14ca666fc916925" alt="bad version control"
This is an example of bad version control.
data:image/s3,"s3://crabby-images/6455d/6455df661082e03fd7cae28522e62fc87dcaef77" alt="good version control"
This is an example of good version control.
Up and Running
Installation
Linux usually comes with git
installed
Linux
(Ubuntu/Debian)
data:image/s3,"s3://crabby-images/6eadd/6eadd7a5cbfa2ac8b3df49e9473a7ff7aab0b90e" alt="`sudo apt-get install git`"
Getting Help
git help
or documentation at git-scm.com/doc
data:image/s3,"s3://crabby-images/19b9a/19b9a83caa68513d34a36448c5069828efd3fa6b" alt="git help"
You can get help for individual commands withgit help [command]
data:image/s3,"s3://crabby-images/302fe/302fe119a640b58e454ca2b29184aed9a9db11c1" alt="git help status"
Git also has an extensive manual withman git
data:image/s3,"s3://crabby-images/32129/321293fd8f0a89540233a4e9e2e771c5659d9040" alt="man git"
Configuration
git
needs to know who you are.
![git config --global user.name [name] && git config --global user.email [email]](img/polyhacks_img/git-config-user.png)
Why does git
need my name?
Git associates every change with a name and email so you can tell who changed what.
Using git
as a standalone developer
A mental model for staging
You don't want to make a commitment until everything is ready.
The git commit
workflow
- Each commit is a patch
- You must prepare a commit before finalizing it
- Each commit is a unit of work, put related changes together.
A git repository is a directory on your computer.
data:image/s3,"s3://crabby-images/ae3cf/ae3cff8ced6b1efe31b53fcf3883b20e7984e350" alt="git init"
Your .git
folder holds the internals of git.
git status
shows the status of your repository.
data:image/s3,"s3://crabby-images/0f0a8/0f0a8bed670225601a951f794323865d56c08407" alt="git status"
git status
gives suggestions about what to do next.
data:image/s3,"s3://crabby-images/26caa/26caa6d563f986a21c8abc3a6b2bcb7c83cdb504" alt="git status suggestions"
git diff
shows untracked changes inside your files
data:image/s3,"s3://crabby-images/c7313/c7313c94d16063acba3853b80acd383e43ae0c98" alt="git diff"
git add
stages changes
data:image/s3,"s3://crabby-images/fb3c1/fb3c1e92e818a076650bce82e3d899042452b164" alt="git add"
Stage relevant changes together
git add -p
lets you add parts of a file.
data:image/s3,"s3://crabby-images/c5480/c5480d4915d7260af58cbc77345097bf38d19499" alt="git add -p"
git reset HEAD --
unstages changes
data:image/s3,"s3://crabby-images/acb40/acb408979d0ca2ed98e60d2f50aa9bb8a57795de" alt="git reset HEAD --"
git commit
adds a change to the history
data:image/s3,"s3://crabby-images/abc49/abc49f206fc73c7760cb7acd2d22bbfe1bc0f675" alt="git commit"
Apply all of your staged changes. esc :x
leaves the editor.
git commit
takes a message that describes the patch. Writing a good message is key:
- Write in present imperative, for example:
Add README.md to describe project
Implement improved error handling, fixes #13
- Think of commit messages like emails
- Describe not just what, but why
git log
shows your past changes.
data:image/s3,"s3://crabby-images/36a8d/36a8d06d4a9abb1fef1ceb05a9d9875fc212b1ad" alt="git log"
git revert
undoes changes
data:image/s3,"s3://crabby-images/cb280/cb2808bb1b1fd3051a8e9a2788d0498102e83562" alt="git revert"
Using git
as a participant
git
is distrubuted version control.
Different participants in a project can share changes between each-other
git branch
lets you work on changes in isolation
data:image/s3,"s3://crabby-images/a9410/a9410c61a39e8c3d8c4e214cf7ea18926d13eb65" alt="git branch"
One feature to rule them all!
A mental model for branches
Like a branch on a family tree.
NOTE: checking out a branch changes the files in your repository.
git stash
let's you save changes for later
data:image/s3,"s3://crabby-images/ca00a/ca00ac6572c21cad3712d93617e40e822841be99" alt="git stash"
To bring changes back from your stash: git stash apply
data:image/s3,"s3://crabby-images/19741/197411f86acdb99587fc4d4e55fbe253373d5760" alt="git stash apply"
Manipulating Branches
How do I get changes from one branch to another?
git merge
git rebase
data:image/s3,"s3://crabby-images/71b61/71b613516c2fbb5ebefc490a20ba016bd95e3cb3" alt="git merge meme"
This is typically what happens with a git merge.
A mental model for merging
Integrate changes
data:image/s3,"s3://crabby-images/d0a71/d0a712fe0910d8368147f7f8b843850cb790ff0f" alt=""
data:image/s3,"s3://crabby-images/2c1f4/2c1f44c0541ec018a3e8c545d58d009869b46c4a" alt=""
data:image/s3,"s3://crabby-images/8cfef/8cfefcd05a0ce0bebb418c2047ac2c3c07266293" alt=""
data:image/s3,"s3://crabby-images/a1baa/a1baa601db9d132dd1399db384c660331b38f68a" alt=""
Sometimes git can fast-forward
data:image/s3,"s3://crabby-images/f2ac0/f2ac09af4c7b2f5fcdf9d3946ecf88bee554adb0" alt=""
data:image/s3,"s3://crabby-images/2d329/2d3294e820e54856b37b972aa742fa3fe4781418" alt=""
Now to the GitHub part!
Let's get interactive!
Sign up at GitHub.com/join