User Tools

Site Tools


git_cheat_sheet

This is an old revision of the document!


Git Cheat Sheet

Resources

Install

Run the following to create the user config file:

git config --global user.name "Stephen Heise"

Run the following to find where the .gitconfig file is:

git config --list --show-origin

Replace it with this:

[core]
	editor = 'C:/Program Files (x86)/Notepad++/notepad++.exe' -multiInst -notabbar -nosession
	pager = cat
 
[user]
	name = Stephen Heise
	email = Stephen@tallguyracing.com
 
[mergetool]
	prompt = false
	keepBackup = false
	keepTemporaries = false
 
[merge]
	tool = winmerge
 
[mergetool "winmerge"]
	name = WinMerge
	trustExitCode = true
	cmd = "/c/Program\\ Files\\ \\(x86\\)/WinMerge/WinMergeU.exe" -u -e -dl \"Local\" -dr \"Remote\" $LOCAL $REMOTE $MERGED
 
[diff]
	tool = winmerge
 
[difftool "winmerge"]
	name = WinMerge
	trustExitCode = true
	cmd = "/c/Program\\ Files\\ \\(x86\\)/WinMerge/WinMergeU.exe" -u -e $LOCAL $REMOTE
 
[alias]
	st = status
	ci = commit -m
	ca = commit --amend
	br = branch
	ba = branch -a
	co = checkout
	di = diff
	dt = difftool
	fa = fetch -a
	md = merge origin/develop
	cd = checkout develop
	pp = !git pull && git push
	ln = !git --no-pager log -n50 '--pretty=format:"%Cred%h%Creset %ad %Cgreen%<(10,trunc)%an%Creset %<(80,trunc)%s"' '--date=format:"%Y%m%d %H%M%S"'
 
[winUpdater]
	recentlySeenVersion = 2.15.1.windows.2
 
[remote "origin"]
	prune = true

Project Specific Settings

If you need project specific settings, like You Just Go, append this:

[includeIf "gitdir:C:/Dev/YouJustGo/"]
	path = .gitconfig-youjustgo

Then create a C:\Users\God\.gitconfig-youjustgo file with this:

[user]
	name = Stephen Heise
	email = stephen.heise@youjustgo.com

Verify the settings are correct by running the following. Last one wins.

git config --list --show-origin

Try Git

git init
git config --global core.editor "atom --wait" Make Atom the default editor.
git config --global user.name "Stephen Heise"
git config --global user.email "Stephen@tallguyracing.com"
git status
git add filename.txt
git commit -m “Commit message”
git log
git remote add origin https://whatever.com
git push -u origin master -u means remember these settings
git pull origin master
git diff head
git diff --staged
git reset octofamily/octodog.txt unstages a file
git checkout -- octocat.txt go back to last checkout / undo
git reset --hard origin/master Throw away all local commits.
git branch -a Show local and remote branches.
git branch clean_up Create new branch.
git checkout clean_up Switch branches.
git checkout -b new_branch Checkout and create branch at the same time.
git checkout filename.txt Undo local (unstaged) modification.
git rm '*.txt' Remove local files and include the removal in the staging area.
git rm -r folder_of_cats Recursively remove all folders and files from the given directory.
git commit -a Include the deletion of local files to staging area, do the commit.
git merge clean_up
git push origin --delete <branch_name> Delete a remote branch.
git branch -d <branch name> Delete a branch.
git branch -D <branch name> Force delete a branch. Use if branch not merged.
git remote prune origin Clean up remote branch list.
git branch -r --merged develop List remote branches that have been merged with develop.
git branch -r --no-merged develop List remote branches that have not been merged with develop.
git push
git push origin <hash>:<branch> Push up to a certain commit.
git push origin HEAD~10:<branch> Push up to the last 10 commits.
gitk A commit viewer.
gitk 'stash@{0}' View the contents of the first stash.
git tag -a tagname -m “commit comment” Annotated tag (preferred over lightweight tags).
git tag tagname Lightweight tag (good for temporary tags).
git rebase --interactive 44447348... Fix up unpushed commit messages. '44447348…' = parent commit hash.
git log --no-merges --oneline develop.. Show all commits on the current branch.

Copy commits from one branch to another

git cherry-pick <commit hash> Copy a single commit to current branch.
git merge <source branch> Merge everything, then delete what isn't required.
git rebase -i
git cherry-pick <branch> -i Try this, maybe it will work.

Workflows

Start new branch

git checkout -b branch-name Create new branch and checkout. Unstaged changes are retained.
git push --set-upstream origin branch-name Push and create branch on remote.

Get new remote branch

git pull Make sure git knows about the remote branch.
git checkout --track origin/branch_name Grab the remote branch.

Merge branch

git checkout master
git merge branch-name

Delete branch

git push origin --delete branch-name Delete the remote branch.
git branch -d branch-name Delete the local branch.

Rename branch

git branch -m <newname> Rename the current branch.
git branch -m <oldname> <newname> Rename any branch.
git push origin --delete <oldname>
git push origin -u <newname>
Update remote branch.

Undo last commit

git reset HEAD~ Reverts last commit, but does not change files. Only do if commit is not pushed.
git reset –hard HEAD~1 Reverts last commit and reverts changed files. Only do if commit is not pushed.

Reset tag position

git co develop Get on the correct branch.
git ls-remote –tags List remote tags.
git push –delete origin tagname Delete the remote tag.
git tag -d tagname Delete the local tag.
git tag tagname Create the local tag.
git push origin tagname Create the remote tag.
git ls-remote –tags Check you got it right.

Commit some stuff workflow

git add . Stage everything.
git stash push –keep-index Stash and keep staged changes.
git reset Unstage everything.
Hack, stage, commit…
git stash pop or git stash apply Get back original. Use apply for multi-commits. Will create merge conflicts.
VS, Take theirs Resolve conflicts.
git reset Unstage everything.

Remove last two commits from master

git co HEAD~2
git co -b masterfixed
git push –delete origin master
git br -D master
git br -m masterfixed master
git push origin –set-upstream master

Merge specific commit from another branch

git co <source-branch>
git rebase -i
Copy the commits you want to clipboard.
Delete all text, save, close. Aborts the rebase.
git co <target-branch>
git rebase -i Add HEAD if you only want to append commits.
Paste the commits. Delete ones you don't want.
Save, close.

Import from SVN

git svn clone https://ares/svn/SVNRepository/Presentations --no-metadata --tags=Tags --trunk=Trunk --branches=Branches --authors-file=..\users.txt
git_cheat_sheet.1597264092.txt.gz · Last modified: 2020/08/13 21:28 (external edit)

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki