User Tools

Site Tools


git_cheat_sheet

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revisionPrevious revision
Next revision
Previous revision
git_cheat_sheet [2020/08/12 20:37] stephengit_cheat_sheet [2024/06/17 09:49] (current) – external edit 127.0.0.1
Line 21: Line 21:
  editor = 'C:/Program Files (x86)/Notepad++/notepad++.exe' -multiInst -notabbar -nosession  editor = 'C:/Program Files (x86)/Notepad++/notepad++.exe' -multiInst -notabbar -nosession
  pager = cat  pager = cat
 + longpaths = true
  
 [user] [user]
  name = Stephen Heise  name = Stephen Heise
  email = Stephen@tallguyracing.com  email = Stephen@tallguyracing.com
 +
 +[init]
 + defaultBranch = main
  
 [mergetool] [mergetool]
Line 47: Line 51:
  cmd = "/c/Program\\ Files\\ \\(x86\\)/WinMerge/WinMergeU.exe" -u -e $LOCAL $REMOTE  cmd = "/c/Program\\ Files\\ \\(x86\\)/WinMerge/WinMergeU.exe" -u -e $LOCAL $REMOTE
  
 +[push]
 + default = current
 + autoSetupRemote = true
 + 
 [alias] [alias]
  st = status  st = status
  ci = commit -m  ci = commit -m
- ca = commit --amend+ ca = commit --amend --no-edit
  br = branch  br = branch
  ba = branch -a  ba = branch -a
Line 57: Line 65:
  dt = difftool  dt = difftool
  fa = fetch -a  fa = fetch -a
- md merge origin/develop + tf !git reset && git checkout -- . && git clean -df 
- cd checkout develop + as !git add . && git stash 
- pp = !git pull && git push+ pr = !git stash pop && git reset 
 + brdr = push --delete origin 
 + fp = push --force 
 + cp = cherry-pick
  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"'  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"'
 + ro2m = !echo 'Rebasing onto master' && git fetch origin master:master && git rebase --onto master master && git pull -r origin master
 + ro2mfp = !git ro2m && echo 'Force pushing' && git fp
  
 [winUpdater] [winUpdater]
Line 90: Line 103:
 ===== Try Git ===== ===== Try Git =====
  
-| git init | | +''<nowiki>git init</nowiki>'' | | 
-| <nowiki>git config --global core.editor "atom --wait"</nowiki> | Make Atom the default editor. | +''<nowiki>git config --global core.editor "atom --wait"</nowiki>'' | Make Atom the default editor. | 
-| <nowiki>git config --global user.name "Stephen Heise"</nowiki> | | +''<nowiki>git config --global user.name "Stephen Heise"</nowiki>'' | | 
-| <nowiki>git config --global user.email "Stephen@tallguyracing.com"</nowiki> | | +''<nowiki>git config --global user.email "Stephen@tallguyracing.com"</nowiki>'' | | 
-| git status | | +''<nowiki>git status</nowiki>'' | | 
-| git add filename.txt | | +''<nowiki>git add filename.txt</nowiki>'' | | 
-| git commit -m "Commit message" | | +''<nowiki>git commit -m "Commit message"</nowiki>'' | | 
-| git log | | +''<nowiki>git log</nowiki>'' | | 
-| git remote add origin https://whatever.com | | +''<nowiki>git remote add origin https://whatever.com</nowiki>'' | | 
-| git push -u origin master | -u means remember these settings | +''<nowiki>git push -u origin master</nowiki>'' ''<nowiki>-u</nowiki>'' means remember these settings | 
-| git pull origin master | | +''<nowiki>git pull origin master</nowiki>'' | | 
-| git diff head | | +''<nowiki>git diff head</nowiki>'' | | 
-| <nowiki>git diff --staged</nowiki> | | +''<nowiki>git diff --staged</nowiki>'' | | 
-| git reset octofamily/octodog.txt | unstages a file  | +''<nowiki>git reset octofamily/octodog.txt</nowiki>'' Unstages a file | 
-| <nowiki>git checkout -- octocat.txt</nowiki>go back to last checkout / undo | +''<nowiki>git checkout -- octocat.txt</nowiki>'' Go back to last checkout / undo
-| <nowiki>git reset --hard origin/master</nowiki> | Throw away all local commits. | +''<nowiki>git reset --hard origin/master</nowiki>'' | Throw away all local commits. | 
-| git branch -a | Show local and remote branches. | +''<nowiki>git branch -a</nowiki>'' | Show local and remote branches. | 
-| git branch clean_up | Create new branch. | +''<nowiki>git branch clean_up</nowiki>'' | Create new branch. | 
-| git checkout clean_up | Switch branches. | +''<nowiki>git checkout clean_up</nowiki>'' | Switch branches. | 
-| git checkout -b new_branch | Checkout and create branch at the same time. | +''<nowiki>git checkout -b new_branch</nowiki>'' | Checkout and create branch at the same time. | 
-| git checkout filename.txt | Undo local (unstaged) modification. | +''<nowiki>git checkout filename.txt</nowiki>'' | Undo local (unstaged) modification. | 
-| git rm '*.txt' | Remove local files and include the removal in the staging area. | +''<nowiki>git rm '*.txt'</nowiki>'' | 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. | +''<nowiki>git rm -r folder_of_cats</nowiki>'' | 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. | +''<nowiki>git commit -a</nowiki>'' | Include the deletion of local files to staging area, do the commit. | 
-| git merge clean_up | | +''<nowiki>git merge clean_up</nowiki>'' | | 
-| <nowiki>git push origin --delete <branch_name></nowiki> | Delete a **remote** branch. | +''<nowiki>git push origin --delete <branch_name></nowiki>'' | Delete a **remote** branch. | 
-| git branch -d <branch name>  | Delete a branch. | +''<nowiki>git branch -d <branch name></nowiki>''  | Delete a branch. | 
-| git branch -D <branch name>  | Force delete a branch. Use if branch not merged. | +''<nowiki>git branch -D <branch name></nowiki>''  | Force delete a branch. Use if branch not merged. | 
-| git remote prune origin | Clean up remote branch list. | +''<nowiki>git remote prune origin</nowiki>'' | Clean up remote branch list. | 
-| <nowiki>git branch -r --merged develop</nowiki> | List remote branches that have been merged with develop. | +''<nowiki>git branch -r --merged develop</nowiki>'' | List remote branches that have been merged with develop. | 
-| <nowiki>git branch -r --no-merged develop</nowiki> | List remote branches that have not been merged with develop. | +''<nowiki>git branch -r --no-merged develop</nowiki>'' | List remote branches that have not been merged with develop. | 
-| git push | | +''<nowiki>git push</nowiki>'' | | 
-| git push origin <hash>:<branch> | Push up to a certain commit. | +''<nowiki>git push origin <hash>:<branch></nowiki>'' | Push up to a certain commit. | 
-| git push origin HEAD~10:<branch> | Push up to the last 10 commits. | +''<nowiki>git push origin HEAD~10:<branch></nowiki>'' | Push up to the last 10 commits. | 
-| gitk | A commit viewer. | +''<nowiki>git push origin HEAD~10:$(git rev-parse --abbrev-ref HEAD)</nowiki>'' | Push up to the last 10 commits. | 
-| <nowiki>gitk 'stash@{0}'</nowiki> | View the contents of the first stash. | +| ''<nowiki>git push --force origin HEAD~10:$(git rev-parse --abbrev-ref HEAD)</nowiki>'' | Force push up to the last 10 commits. | 
-| git tag -a tagname -m "commit comment" | Annotated tag (preferred over lightweight tags). | +| ''<nowiki>gitk</nowiki>'' | A commit viewer. | 
-| git tag tagname | Lightweight tag (good for temporary tags). | +''<nowiki>gitk 'stash@{0}'</nowiki>'' | View the contents of the first stash. | 
-| <nowiki>git rebase --interactive 44447348...</nowiki> | Fix up unpushed commit messages. '44447348...' = parent commit hash. | +''<nowiki>gitk --all $(git fsck --no-reflog | Select-String "(dangling commit )(.*)" | %{ $_.Line.Split(' ')[2] })</nowiki>'' | Find a dropped stash. | 
-| <nowiki>git log --no-merges --oneline develop..</nowiki> | Show all commits on the current branch. |+| ''<nowiki>git tag -a <tagname-m "commit comment"</nowiki>'' | Annotated tag (preferred over lightweight tags). | 
 +''<nowiki>git tag <tagname></nowiki>''\\ ''<nowiki>git push origin <tagname></nowiki>'' | Lightweight tag (good for temporary tags). | 
 +''<nowiki>git rebase --interactive 44447348...</nowiki>'' | Fix up unpushed commit messages. '44447348...' = parent commit hash. | 
 +''<nowiki>git log --no-merges --oneline develop..</nowiki>'' | Show all commits on the current branch. | 
 +| ''<nowiki>git cherry-pick ebe6942^..905e279</nowiki>'' | Cherry-pick an //inclusive// commit range. | 
 +| ''<nowiki>git remote -v</nowiki>'' | View remote / origin URL. | 
 + 
 +===== Workflows =====
  
 ==== Copy commits from one branch to another ==== ==== Copy commits from one branch to another ====
  
-| <nowiki>git cherry-pick <commit hash> </nowiki>Copy a single commit to current branch. +''<nowiki>git co <source-branch></nowiki>'' | | 
-| <nowiki>git merge <source branch></nowiki>Merge everythingthen delete what isn't required. | +''<nowiki>git rebase -i</nowiki>'' 
-| <nowiki>git rebase -i</nowiki>::: +| // Copy the commits you want to clipboard. // | | 
-| <nowiki>git cherry-pick <branch-i</nowiki>Try this, maybe it will work. | +| // Delete all textsave, close. // | Aborts the rebase. | 
- +''<nowiki>git co <target-branch></nowiki>'' | | 
-===== Workflows =====+''<nowiki>git rebase -i</nowiki>'' | Add ''<nowiki>HEAD</nowiki>'' if you only want to append commits. | 
 +| // Paste the commitsDelete ones you don't want. // | 
 +| // Save, close. // | |
  
 ==== Start new branch ==== ==== Start new branch ====
  
-| git checkout -b branch-name | Create new branch and checkout. Unstaged changes are retained. | +''<nowiki>git checkout -b branch-name</nowiki>'' | Create new branch and checkout. Unstaged changes are retained. | 
-| <nowiki>git push --set-upstream origin branch-name</nowiki> | Push and create branch on remote. |+''<nowiki>git push --set-upstream origin branch-name</nowiki>'' | Push and create branch on remote. |
  
 ==== Get new remote branch ==== ==== Get new remote branch ====
  
-| <nowiki>git pull</nowiki> | Make sure git knows about the remote branch. | +''<nowiki>git pull</nowiki>'' | Make sure git knows about the remote branch. | 
-| <nowiki>git checkout --track origin/branch_name</nowiki> | Grab the remote branch. |+''<nowiki>git checkout --track origin/branch_name</nowiki>'' | Grab the remote branch. |
  
 ==== Merge branch ==== ==== Merge branch ====
  
-| git checkout master | | +''<nowiki>git checkout master</nowiki>'' | | 
-| git merge branch-name | |+''<nowiki>git merge <branch-name></nowiki>'' | |
  
 ==== Delete branch ==== ==== Delete branch ====
Line 200: Line 222:
 | ''<nowiki>git push origin --set-upstream master</nowiki>'' | | | ''<nowiki>git push origin --set-upstream master</nowiki>'' | |
  
-==== Merge specific commit from another branch ====+==== Rebase onto master ==== 
 + 
 +| ''<nowiki>git fetch origin master:master</nowiki>'' | Update the master branch. | 
 +| ''<nowiki>git rebase --onto master <source-branch></nowiki>'' | For example, <source-branch> = '2021.3.7946'. | 
 +| ''<nowiki>git pull -r origin master</nowiki>'' | | 
 +| ''<nowiki>git push --force</nowiki>'' | | 
 + 
 +==== Split up an existing commit ====
  
-| ''<nowiki>git co <source-branch></nowiki>'' | | 
 | ''<nowiki>git rebase -i</nowiki>'' | | | ''<nowiki>git rebase -i</nowiki>'' | |
-// Copy the commits you want to clipboard. // | | +Mark commit to be split with 'e' | | 
-// Delete all text, save, close. // Aborts the rebase. | +Save & close | 
-| ''<nowiki>git co <target-branch></nowiki>'' | | +| When the rebasing has stopped... | 
-| ''<nowiki>git rebase -i</nowiki>''Add ''<nowiki>HEAD</nowiki>'' if you only want to append commits. +| ''<nowiki>git reset HEAD~</nowiki>'' | | 
-| // Paste the commits. Delete ones you don't want. /| | +| Edit & commit. | | 
-// Save, close. // | |+| ''<nowiki>git rebase --continue</nowiki>''
 + 
 +==== Set up a bare repo ==== 
 + 
 +''<nowiki>git init --bare BareRepo</nowiki>'' 
 +''<nowiki>git clone .\BareRepo\ LocalRepo</nowiki>'' | URL will be something like ''<nowiki>file:///C:/Temp/BareRepo</nowiki>'' | 
 +| ''<nowiki>git ci "Initial commit." --allow-empty</nowiki>'' If you need an initial commit. 
 + 
 +==== Create a test repo ==== 
 + 
 +<code powershell> 
 +$scriptpath = Split-Path $MyInvocation.MyCommand.Path 
 +Push-Location $scriptpath 
 + 
 +$remoteRepoName = 'RemoteRepo' 
 +$localRepoName = 'LocalRepo' 
 + 
 +mkdir $remoteRepoName 
 +git init --bare $remoteRepoName 
 +git clone $remoteRepoName $localRepoName 
 + 
 +# Create an initial commit - optional 
 +git --git-dir "$localRepoName/.git" commit --allow-empty -m 'Initial commit.' 
 +git --git-dir "$localRepoName/.git" push 
 + 
 +Pop-Location 
 +</code>
  
 ===== Import from SVN ===== ===== Import from SVN =====
Line 216: Line 270:
 git svn clone https://ares/svn/SVNRepository/Presentations --no-metadata --tags=Tags --trunk=Trunk --branches=Branches --authors-file=..\users.txt git svn clone https://ares/svn/SVNRepository/Presentations --no-metadata --tags=Tags --trunk=Trunk --branches=Branches --authors-file=..\users.txt
 </code> </code>
 +
 +===== Who needs to clean up =====
 +
 +Lists the author and date of the last commit on each remote branch. Need to run it on bash.
 +
 +<code>
 +for branch in `git branch -r | grep -v HEAD`;do echo -e `git show --format="%ai %ar by %an" $branch | head -n 1` \\t$branch; done | sort -r
 +</code>
 +
 +===== How PRs work =====
 +
 +When you create a PR on GitHub, it also creates some other refs for you. Different providers put these in different locations.
 +
 +GitHub puts them under ''refs/pulls''. I don’t believe that git has any rules around these refs, providers can define them however they want.
 +
 +If you run ''git ls-remote <remote-name>'' on a repo, you’ll see all of these other magic refs coming through.
 +
 +On a GitHub repo with some active and completed pull requests, I see these ones (PR #2 has been closed, PR #1 is still open):
 +
 +  5003f86523fa07e325d28f50a749685b93dffcf3 refs/pull/1/head
 +  57c72505a9beed608fe73f474e77b70cd182616f refs/pull/1/merge
 +  622ba67a9d1279984dc763eb078d0e5d92ae790f refs/pull/2/head
 +
 +I believe that ''pull/1/head'' points to the head of the source branch. Source branch is ''dev'', and it’s pointing at the same commit, so that seems correct ''5003f86523fa07e325d28f50a749685b93dffcf3 refs/heads/dev''.
 +
 +''pull/1/merge'' is what I think they’re referring to as the ‘merge branch’. It’s what the target branch will look like once the PR has merged.
 +
 +Note that it’s a different commit hash to main ''7adb1c92faa0ef0065e3aedb95fcdc4f523d79e3 refs/heads/main'' because it’s a different commit.
 +
 +Now… to show when and how this changes I’ll need to create a new PR because there are conflicts on that example PR that I’m using.
 +
 +As a side note: It seems as though these ''refs/pulls/<number>/merge'' refs just stay where they are if there are conflicts. They don’t go away, they just don’t update. Anyway…
 +
 +Say we have a default branch ''main'' and some branch with some changes called ''some-changes''. Here is what the refs look like on the remote.
 +
 +  a94afcad87e765e18d590cc4090a835e210acca6 refs/heads/main
 +  e6317c4e97a465fe2f024e5a3cd5ff3f12c5f6a6 refs/heads/some-changes
 +  
 +Once I create a PR to merge ''some-changes'' into ''main'' two more refs are added:
 +
 +  a94afcad87e765e18d590cc4090a835e210acca6 refs/heads/main
 +  e6317c4e97a465fe2f024e5a3cd5ff3f12c5f6a6 refs/heads/some-changes
 +  e6317c4e97a465fe2f024e5a3cd5ff3f12c5f6a6 refs/pull/3/head
 +  6b33d262276e1e5d520ffb8063dedffd6296664d refs/pull/3/merge
 +  
 +Note ''pull/3/head'' is the same as ''heads/some-changes''. ''pull/3/merge'' is pointing to some other magic commit that doesn’t really exist anywhere. That’s GitHub merging it in the background and creating a ref of what it will look like.
 +
 +If I push changes to ''main'', here is what our refs look like:
 +
 +  442fcf2d421c26f75339a82bd364d5fcc3bc0a52 refs/heads/main
 +  e6317c4e97a465fe2f024e5a3cd5ff3f12c5f6a6 refs/heads/some-changes
 +  e6317c4e97a465fe2f024e5a3cd5ff3f12c5f6a6 refs/pull/3/head
 +  3a58fb072ff48e8bebf2c66491332556f3f935ef refs/pull/3/merge
 +
 +''heads/main'' has changed because I made a commit there. ''pull/3/merge'' has changed because the merge of those two branches now looks different. ''heads/some-changes'' and ''pull/3/head'' are the same because they haven’t moved.
 +
 +As for what these branches are used for: This is very useful for making sure that your code will still be valid after the merge is complete (not just in your branch).
 +If there are any changes to the source or target branches, ''refs/pull/<number>/merge'' will update. Useful for stopping poison merges.
 +
  
git_cheat_sheet.1597264666.txt.gz · Last modified: 2020/08/13 21:37 (external edit)

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki