blob: 59d1a64458bee108b74f42b71572b99f5f849f0d (
plain) (
tree)
|
|
# git
------------------------------------------------------------------------------------------------------------------------
# toc
|remote|
|branching|
|resetting|
|tags|
|diff|
|log|
|patching|
|revision_range|
- *remote*
git remote -v ............................... list remotes verbose (with URLs)
git remote show [-n] <remote> ............... list info for <remote> (like remote HEAD, remote branches,
tracking mapping)
- *branching*
git branch [-a] ............................. list available branches; -a to include remote branches
git branch -vv .............................. list branch & annotate with head sha1 & remote tracking branch
git branch <bname> .......................... create branch with name <bname>
git checkout <bname> ........................ switch to branch with name <bname>
git push -u origin <rbname> ................. push branch to origin (or other remote), and setup <rbname> as
tracking branch
- *resetting*
git reset [opt] <ref|commit>
opt:
--mixed ................................. resets index, but not working tree
--hard .................................. matches the working tree and index to that of the tree being
switched to any changes to tracked files in the working tree since
<commit> are lost
git reset HEAD <file> ....................... remove file from staging
git reset --soft HEAD~1 ..................... delete most recent commit but keep work
git reset --hard HEAD~1 ..................... delete most recent commit and delete work
- *tags*
git tag -a <tname> -m "descr" ............... creates an annotated tag (full object containing tagger, date, ...)
git tag -l .................................. list available tags
git checkout tag/<tname> .................... checkout specific tag
git checkout tag/<tname> -b <bname> ......... checkout specific tag in a new branch
- *diff*
git diff HEAD:<fname> origin/HEAD:<fname> ... diff files for different refs
git diff -U$(wc -l <fname>) <fname> ......... shows complete file with diffs instead of usual diff snippets
- *log*
git log --oneline ........................... shows log in single line per commit -> alias for '--pretty=oneline
--abbrev-commit'
git log --graph ............................. text based graph of commit history
git log --decorate .......................... decorate log with REFs
- *patching*
git format-patch <opt> <since>/<revision range>
opt:
-N ...................................... use [PATCH] even with multiple patches (default is [PATCH n/m]
where n is current commit num and m is total commit num in patch)
--start-number <n> ...................... start output file generation with <n> as start number instead '1'
since spcifier:
-3 ...................................... e.g: create a patch from last three commits
<comit hash> ............................ create patch with commits starting after <comit hash>
git am <patch> .............................. apply patch and create a commit for it
git apply --stat <PATCH> .................... see which files the patch would change
git apply --check <PATCH> ................... see if the patch can be applied cleanly
git apply <PATCH> ........................... apply the patch locally without creating a commit
# eg: generate patches for each commit from initial commit on
git format-patch -N $(git rev-list --max-parents=0 HEAD)
# generate single patch file from a certain commit/ref
git format-patch <COMMIT/REF> --stdout > my-patch.patch
- *revision_range*
HEAD ........................................ last commit
HEAD~1 ...................................... last commit-1
HEAD~N ...................................... last commit-N (linear backwards when in tree structure, check
difference between HEAD^ and HEAD~)
git rev-list --max-parents=0 HEAD ........... first commit
------------------------------------------------------------------------------------------------------------------------
vim:sts=2:et:tw=120:cc=120:fo+=t:ft=help:
|