Set Global config (Omit --global
to lit config to current repo)
These will be reflected as Author details in each commit you make
Command
Description
git config --global user.name "your_username"
Author
git config --global user.email "your_email"
Author email
Command
Description
git config --global core.editor "vim"
Change editor to vim
git config --global core.ignorecase false
Detect changes in filename case change
git config --global init.templatedir '~/.git_template
Set git template dir (to configure hooks )
git config --global push.autoSetupRemote true
Skip git branch --set-upstream
while pusing new branch to remote
Git alias to create custom command shortcuts
Command
Description
git config --global alias.<short-alias> 'full command'
Create a new git alias in the form of a new git command
git config --global alias.ucc 'commit --amend --no-edit'
Run git ucc
instead of git commit --amend --no-edit
Command
Description
git config --global --unset <config-key>
Unset global config ex: git config --global --unset user.name
git config --unset <config-key>
Unset local config ex: git config --unset user.name
Command
Description
git config --list --show-origin
List all the configs and their location
More operations on config
Adding git to the project:
Command
Description
git init .
Initialize git inside the project root directory.
git add .
Stage all files for commit when run from the root directory
git commit -m "commit-message"
Commit staged files to git.
Adding Remote repo to Project:
Command
Description
git remote add <remote_name> <remote_address>
Add remote repository where remote_name: origin,upstream etc remote_address:(URL) Github, Bitbucket etc
git remote set-url origin <remote_address>
Update remote address
git remote rename origin upstream
Rename remote from origin to upstream
git remote remove <remote_name>
Delete remote
git remote rename origin upstream
Rename remote
git push <remote_name> <branch-name>
Push all the commits to remote default branch name master
Synchronizing local with remote (upstream):
Command
Description
git fetch
Download changes from remote (default origin
) without making any changes to files in the working directory.
git pull
Download remote commits from the origin repository configured as upstream for the current branch.
git push
Upload local commits to remote.
Command
Description
git branch -a
Show all branches.
git branch <new_branch_name>
Create a new branch (Will not switch working tree to new branch).
git checkout -b <new_branch_name>
Create a new branch out of the current branch and switch to the new branch.
git checkout --orphan <new_branch_name>
Create a new branch without any parent commit (empty branch)
git branch -m <old_branch_name> <new_branch_name>
Rename branch.
git push <remote_name> <branch_name>
Push local branch to remote.
git checkout <branch_name>
Switch to specified branch.
git branch -d <branch_name>
Delete local branch (replace -d by -D for force delete)
git push <remote_name> :<branch_name>
Delete remote branch.
git branch --contains <commit_id>
Search branches containing the given commit id
Save current changes without committing before doing pull and checkout to another branch
Command
Description
git stash save "message"
Save changes with give message after running git add <path>
git stash list
Show stash list
git stash pop
Apply the last stash to the current branch and delete stash
git stash apply stash@{n}
Apply n
th stash without deleting from stash
git checkout stash@{n} -- <filename>
check out a file from n
th stash
git stash clear
Clear all stash
git stash show -p
view last stash content
git stash show -p stash@{n}
view n
th stash content
Command
Description
git commit --amend
Edit last commit message.
git commit --author="First Last <[email protected] >" --amend --no-edit
Edit the author info of the last commit.
git revert <commit_id>
Rollback to the commit specified by commit_id
git rebase -i HEAD~n
Opens list of the last n commits, replace "pick" by "reword" to alter the commit message of those commits.
git reset --soft HEAD~n
Uncommit the last n commits without overwriting the working directory files.
git reset --hard HEAD~n
Uncommit last n changes and overwrite the working directory files
git cherry-pick <commit_id>
Pull commit from any branch by its commit id into the current branch
git rev-parse --short HEAD
Print last commit id
git commit --all --amend --no-edit
Add current changes to last commit
git merge-base <branch A> <branch B>
Get the latest common commit ID between branch A
and branch B
Command
Description
git merge <branch_name>
Merge any branch into current branch
git merge <branch-name> --no-commit
Merge without merge commit.
git pull <remote_name> <branch_name>
Pull from remote branch and merge
git checkout <branch_name> -- <file_name>
Checkout single file from any branch
git checkout <branch_name> -- .
Checkout all the files from any branch
Option
Command
1
git rebase
2
git rebase <remote_name>/<branch_name>
Run these commands after updating the .gitignore file and then commit the changes.
Command
Description
git rm --cached <filename>
Remove specific file from git cache
git rm -r --cached .
Remove all files from git cache
Taggign is widely used to create releases and mark milestones
Command
Description
git tag -l
List all the tags
git tag -a <tagname> -m <message>
Create an annotated tag, with detailed info about the tagger
git tag <tagname>
Create a lightweight tag, tag with only a reference to commit
git tag -l "v1.0.*"
List all the tags matching given pattern
git show <tagname>
View tag details
git push origin <tagname>
Transfer tag to remote
git push origin --tags
Transfer all local tags to remote
git tag -d <tagname>
Delete local tag
git push origin --delete <tagname>
Delete remote tag
Upstream is used when we have multiple repositories for a single project
Command
Description
git branch --set-upstream-to=<remote_name>/<remote_branch_name> <local_branch_name>
Set new upstream for the branch.
git branch --set-upstream-to=<remote_name>/<remote_branch_name>
Set new upstream for the current branch.
git push -u <remote_name> <branch_name>
Push to remote branch and set as upstream
List commits in git (log):
Command
Description
git log
List all commits (comprehensive)
git log --oneline
Lit all commits (brief)
git log -n
The n is number of commits to list
git log --all --grep='<message content>'
List/Find commits by message content
git log master..newBranch
List commits that newBranch
has but master
doesn't
Note: ref1 and ref2 could be branchNames
, remoteName/branchName
, commit SHAs
, etc
Command
Description
git diff ref1:path/to/file1 ref2:path/to/file2
Show difference between two references
git diff -- path/to/file ... origin
Show file difference between the local file and remote file of the current branch
git diff branch_name:path/to/file
Simplified version of the above command
git diff -- /dev/null path/to/file
Show contents of the untracked file in diff style
without author info:
Command
Description
git diff > my_changes.patch
Create patch file
git apply my_changes.patch
Applying patch file
List file activity since the last commit:
Command
Description
git status
List all created/modified/deleted/staged files
git status . -- ':!dir1' ':!dir2'
skip status result for the given directories
Command
Description
git ls-files --others --exclude-standard
List all untracked files.
git ls-files --modified --exclude-standard
List all modified files.
git update-index --assume-unchanged <ignore file>
Ignore file modification.
git update-index --no-assume-unchanged <ignored file>
Revert above action.
git show <branch>:<file>
Peek into file from different branch.
It is useful when working on multiple branches simultaneously without maintaining multiple clones for each branch.
Command
Description
git worktree add ../myProject-master master
Master branch code can be accessed at ../myProject-master
git worktree list
list all worktrees from project directory
git worktree remove ../myProject-master
Delete worktree (folder will still be there)
git worktree repair ../new/worktree/path
Repair worktree after moving worktree or bare repository locally to a different location
Commands to manage submodules.
Command
Description
git submodule add <repo_address> <submodule_path>
Add new submodule at submodule_path
git submodule update --init
Download all the submodules after cloning the main repo and also reset the submodule commit to the parent commit
Commands to copy the directory.
Command
Description
git restore --source <branch> dirname
Copy the directory from any branch without git history
Commands keep the local repo clean and faster.
Command
Description
git prune
Clean up orphaned objects/commits
Update the last commit which is already pushed to remote.
git add . && git commit --amend --no-edit && git push --force
Merge multiple local commits into a single commit before pushing to remote
git rebase -i HEAD~10
replace pick
with fixup
for the commits you want to merge.
Note: The oldest commit is at the top.
Disable terminal screen (oh-my-zsh)
Add the below line to ~/.zshrc
for permanent change.