diff --git a/docs/misc/git.md b/docs/misc/git.md index ccf27b2..669c0ba 100644 --- a/docs/misc/git.md +++ b/docs/misc/git.md @@ -81,8 +81,7 @@ def load_reference(name_or_id): ## Commands -`git -h`: get help for a git command -`git --help`: get man page for a git command +`git -h|--help`: get help for a git command `git -C `: execute a git commend in the specified path `git ^`: operate on commit *before* the provided commit hash @@ -100,31 +99,31 @@ def load_reference(name_or_id): `git status`: shows the status of changes as untracked, modified, or staged `git add `: add files to the staging area -`git add -p `: interactively stage chunks of a file +`git add -p|--patch `: interactively stage chunks of a file `git blame `: show who last edited which line `git commit`: save the snapshot to the project history -`git commit -m "message"`: commit and provide a message -`git commit -a`: automatically notice any modified (but not new) files and commit +`git commit -m|--message "message"`: commit and provide a message +`git commit -a|--all`: automatically notice any modified (but not new) files and commit `git commit -v|--verbose`: show unified diff between the HEAD commit and what would be committed `git commit --amend`: modify latest commit with the new changes `git commit --no-verify`: commit without executing hooks `git commit --fixup `: mark commit as correction to another -`git commit --signoff`: Add a `Signed-off-by` trailer by the committer at the end of the commit log message +`git commit -s|--signoff`: Add a `Signed-off-by` trailer by the committer at the end of the commit log message `git diff `: show difference since the last commit `git diff `: show differences in a file since a particular snapshot `git diff `: show differences in a file between two snapshots `git diff --cached`: show what is about to be committed `git diff ...`: show content diff between two branches -`git diff -w`: show diff ignoring whitespace differences +`git diff -w|--ignore-all-space`: show diff ignoring whitespace differences `git bisect`: binary search history (e.g. for regressions) ### Stashes -`git stash [push -m|--message]`: add all changes to the stash (and provide message) +`git stash [push] [-m|--message]`: add all changes to the stash (and provide message) `git stash list` list all stashes `git stash show []`: show changes in the stash `git stash pop`: restore last stash @@ -134,19 +133,19 @@ def load_reference(name_or_id): ### Remotes `git remote`: list remotes -`git remote -v`: list remotes names and URLs +`git remote -v|--verbose`: list remotes names and URLs `git remote show `: inspect the remote `git remote add `: add a remote `git remote remove `: remove the specified remote `git remote rename `: rename a remote -`git branch --set-upstream-to=/`: set up correspondence between local and remote branch +`git branch -u|--set-upstream-to=/`: set up correspondence between local and remote branch `git push`: send objects to default remote on current branch `git push `: send objects to remote `git push :`: send objects to remote, and update remote reference -`git push --force`: overwrite remote with local version +`git push -f|--force`: overwrite remote with local version `git push --force-with-lease`: overwrite remote with local version if remote has not been modified `git push --force-with-lease --force-if--includes`: will verify if updates from the remote that may have been implicitly updated in the background are integrated locally before allowing a forced update @@ -154,8 +153,8 @@ def load_reference(name_or_id): `git pull`: update the local branch with updates from its remote counterpart, same as `git fetch; git merge` `git pull --ff`: when possible resolve the merge as a fast-forward (only update branch pointer, don't create merge commit). Otherwise create a merge commit. -`git fetch|pull --prune`: remove any remote-tracking references that no longer exist on the remote -`git fetch|pull --tags`: fetch all tags from the remote +`git fetch|pull -p|--prune`: remove any remote-tracking references that no longer exist on the remote +`git fetch|pull -t|--tags`: fetch all tags from the remote `git clone []`: download repository and repo history from remote `git clone --shallow`: clone only repo files, not history of commits @@ -165,7 +164,7 @@ def load_reference(name_or_id): ### Viewing Project History `git log`: show history of changes -`git log -p`: show history of changes and complete differences +`git log -p|--patch`: show history of changes and complete differences `git log --stat --summary`: show overview of the change `git log --follow `: list version history fo file, including renames `git log --all --graph --decorate`: visualizes history as a DAG @@ -196,12 +195,12 @@ It's generally recommended creating annotated tags so it's possible to have all `git tag -l|--list `: list existing tags matching a wildcard or pattern `git tag []`: create a *lightweight* tag on the commit -`git tag -a [ -m ]`: create am *annotated* tag on the commit +`git tag -a|--annotate [ -m ]`: create am *annotated* tag on the commit `git push `: push a tag to the remote `git push --tags`: push commits and their tags (both types) to the remote -`git tag -d `: delete a tag +`git tag -d|--delete `: delete a tag `git push :refs/tags:`: remove a tag from the remote `git push --delete `: remove a tag from the remote @@ -214,13 +213,12 @@ It's generally recommended creating annotated tags so it's possible to have all `git branch`: shows branches `git branch -vv`: show branch + last commit + remote status `git branch --merged [--remote]`: show branches (remote) that have been merged into current one (needs same history, merge squash/rebase break history) - -`git branch `: create new branch -`git checkout -b `: create a branch and switches to it, same as `git branch ; git checkout ` `git branch`: show list of all existing branches (* indicates current) +`git branch `: create new branch +`git branch -d|--delete `: delete specified branch +`git branch -m|--move `: rename a branch without affecting the branch's history +`git checkout -b `: create a branch and switches to it, same as `git branch ; git checkout ` `git checkout `: change current branch (update HEAD) and update working directory -`git branch -d `: delete specified branch -`git branch -m `: rename a branch without affecting the branch's history `git merge `: merges into current branch `git merge --continue`: continue previous merge after solving a merge conflict @@ -254,9 +252,9 @@ It's generally recommended creating annotated tags so it's possible to have all `git restore --source `: revert file to commit version `git restore `: recover deleted file if previously committed -`git rebase -i`: modify (reword, edit, drop, squash, merge, ...) current branch commits -`git rebase -i HEAD~`: modify (reword, edit, drop, squash, merge, ...) *n* commits -`git rebase -i `: modify (reword, edit, drop, squash, merge, ...) *from* commit to latest +`git rebase -i|--interactive`: modify (reword, edit, drop, squash, merge, ...) current branch commits +`git rebase -i|--interactive HEAD~`: modify (reword, edit, drop, squash, merge, ...) *n* commits +`git rebase -i|--interactive `: modify (reword, edit, drop, squash, merge, ...) *from* commit to latest `git rebase --autostash`: automatically create a temporary stash entry before rebasing `git rebase --autosquash`: automatically apply "squash!" or "fixup!" or "amend!" commits