If you're using a Windows machine, download the following program: https://gitforwindows.org/
- We'll be using the 'Bash Emulator' from this package to mimic working on the command line
For Linux machines, follow this guide: http://guides.beanstalkapp.com/version-control/git-on-linux.html
For OSX/Mac users, here's a guide: https://www.atlassian.com/git/tutorials/install-git
- Command Line - The (typically) black screen/white text you see in the gifs below is refered to as the Command Line Interface.
- Repository (repo) - a directory that manages saved versions of code for collaboration and display
- Remote - the saved files for the code which are stored on GitHub
- Local - your physical computer that you are currently working on
- Branch - a self-contained version of the code. If this were a game like Skyrim, then the save file for Krognar the Obliterator would be the branch of the Skyrim game.
- Commit - saved code states. If this were Skyrim again, then the commit would be Krognar, lvl 2, outside of Whiterun.
- Push - Send code from your local computer to the remote repository
- Pull - downloading code from the remote repository to your local system
- Checkout - switch
- Rebase - rebuild commits in a given branch onto a new starting point. Best used to give feature branches a common ancestor
- pwdprint working directory. Shows which folder you're in.
- cd [PATH]change directory. Change working directory to the designated PATH- cd ..will go UP one directory in the tree
 
- lslist. List files within your current directory. (This can also be DIR in windows command prompts)
- cat [FILE NAME]concatenate. A fancy way to say 'read'. This will read the text of the FILE you designate.
- git fetchpulls all available branches from the remote repo and saves them on your computer- git fetch -pWill both bring down all available branchs and will remove local copies of deleted branches.
 
- git pull origin [BRANCH NAME]pulls a copy of the designated BRANCH NAME and attempts to merge it with the branch you are currently working in.- git pull origin HEADwill merge the remote version of your current branch with the local version you're working in
 
- git clone [REPO ADDRESS]downloads a repository to your machine. Best done when updating your STAGING and MASTER branches.
- git rebase [PREFERABLY A TRUNK]Rebase will effectively rewrite the commit history of your current branch, making it act as if your local commits were added to whatever commit history exists in the remote 'trunk' (Master/Develop/Production/Staging, etc) commit history. Because this resets your current branch's history, you must force push when updating the remote!!!!
git rebase is a better alternative to git merge, since it turns your commit history into a linear progression. You can clearly trace back each change to the code base and easily revert unwanted changes.
- git checkout [DESIRED BRANCH]switches from your branch to the DESIRED BRANCH- git checkout -b [DESIRED NAME]creates a new branch with the DESIRED NAME you input
 
- git statuslists changes you've made locally to the branch since your last commit
- git add .stages all files you've changed to be saved with the next commit- git add [PATH TO FILE]stages a copy of a particular file, e.g.- git add ./README.md
 
- git commit -m "[YOUR MESSAGE]"saves the staged changes to your branch. The Descriptive message you add will also be stored. Note that using single & double quotes may mess up your commit if you aren't careful. If you use contractions (can't, don't, won't), you're better off using double quotes like this:
git commit -m "I've made changes to some files you're not gonna believe!"
- git pushpushes the changes you've made locally to the remotely save version of your branch- The first time you do this on a branch, you'll need to tell git where you're sending your commits. You do this with the command: git push --set-upstream [REPOSITORY ADDRESS].git. E.g.git push --set-upstream https://www.github.com/DBombay/git_class.git
- After rebasing, you'll need to overwrite the remote copy of your branch with your local. To do so, you pass the -fargument togit pushto force a push. e.g.git push -f
 
- The first time you do this on a branch, you'll need to tell git where you're sending your commits. You do this with the command: 
- git pull origin [BRANCH]will pull the remote BRANCH you request and attempt to merge it with the local version of the branch you're working in
- git resetwill revert your files back to their last saved state. THIS WILL NOT DELETE ANY ADDITIONS YOU'VE MADE! Useful if you've deleted something you shouldn't've
- git reset --hardwill revert your branch to its exact last state. New files will be removed, deleted ones will be restored, and good/bad changes will completely disappear. GIT EQUIVALENT OF A NUKE FROM ORBIT
- git listhistoryshows, from most recent to oldest, a list of your commits. It'll look something like this
The series of letters and numbers after 'commit' can be used to reset DIRECTLY to that state, for example:
git reset --hard 7de3ab656ee21ae12dab025e023905afc98a1ca5
- David
- Barr
- Brian
- Mark
- Damien

