Git & GitHub
- git initinitializes a local git directory
- rm -fr .gitremoves a local git directory
- git statusstatus of staging area
- git logshow log of changes
- git diff filename.txtsee recent changes made to code
Navigate
- git branchlists all branches
- git checkout -b branchNamecreates a new branch and moves into it
- git checkout branchNamemove into branch
Commit
- git add <filename>add file to staging area
- git add .add all files that aren’t currently staged
- git resetremoves all files from git status staging area
- git commit -m “change message”commits files locally
- git commit -m “title” -m “longer description”add a description of changes
- git commit --amend -m "change message"amend a commit and change the commit message
- git commit --amend --no-editadd to a commit without changing the commit message
How to write a good commit message
Local branches
- git checkout mainthen- git branch -D <branchname>delete local branch
- git checkout -b clean-branch-name origin/maincreate a clean branch from main
- git branch -m old-branch-name new-branch-namerename a branch
Remote branches
Origins
- git remote add origin <repository-url>add remote origin
- git remote remove originremove remote origin
- git remote set-url origin urlupdate remote origin
- git remote -vview connected remote repositories
Pull and push
- git pull origin mainpull remote main branch into local branch
- git push origin branchNamepush branch to the remote repo feature branch or
- git push -u origin branchNamepush feature branch to the remote repo and set it as the upstream branch, then- git pushwill push to that branch
- git checkout -b new-branch origin/branchnamecheckout remote branch, good for testing PRs
Problems / Solutions
Wont push to a remote repo that has a README
git fetch --all
git rebase origin/mainWont push because file is too large (remote hung up)
Increase file size limit to 1GB
git config http.postBuffer 1048576000Merge conflicts
git pull origin main
git checkout feature-branch
git rebase main
 
# fix conflict
git add .
git rebase --continue
# repeat until conflicts are resolved
 
git push origin feature-branch --force