# Other Available Languages: 1. [Chinese Git Cheat Sheet](https://github.com/ArslanBilal/Git-Cheat-Sheet/blob/master/other-sheets/git-cheat-sheet-zh.md) 2. [Turkish Git Cheat Sheet](https://github.com/ArslanBilal/Git-Cheat-Sheet/blob/master/other-sheets/git-cheat-sheet-tr.md)
PDF versions:
Git cheat sheet saves you from learning all the commands by heart.
Be free to contribute, update the grammar mistakes. You are also free to add your language file.
Git Cheat Sheet English
###Index
- Create
- Local Changes
- Search
- Commit History
- Branches & Tags
- Update & Publish
- Merge & Rebase
- Undo
- Git Flow
##Create
#####Clone an existing repository:
$ git clone ssh://user@domain.com/repo.git
#####Create a new local repository:
##Local Changes
#####Changed files in your working directory:
#####Changes to tracked files:
#####Add all current changes to the next commit:
#####Add some changes in <file> to the next commit:
#####Commit all local changes in tracked files:
#####Commit previously staged changes:
#####Commit with message:
$ git commit -m 'message here'
#####Commit to some previous date:
git commit --date="`date --date='n day ago'`" -am "Commit Message"
#####Change last commit:
Don't amend published commits!
#####Move uncommitted changes from current branch to some other branch:
git stash
git checkout branch2
git stash pop
#####Restore stashed changes back to current branch
##Search
#####A text search on all files in the directory:
#####In any version of a text search:
###Commit History
#####Show all commits, starting with newest (it'll show the hash, author information, date of commit and title of the commit):
#####Show all the commits(it'll show just the commit hash and the commit message):
#####Show all commits of a specific user:
$ git log --author="username"
#####Show changes over time for a specific file:
#####Who changed, what and when in <file>:
##Branches & Tags
#####List all local branches:
#####List all remote branches:
#####Switch HEAD branch:
#####Create and switch new branch:
$ git checkout -b <branch>
#####Create a new branch based on your current HEAD:
$ git branch <new-branch>
#####Create a new tracking branch based on a remote branch:
$ git branch --track <new-branch> <remote-branch>
#####Delete a local branch:
#####Mark the current commit with a tag:
#####Mark the current commit with a tag that includes a message:
##Update & Publish
#####List all current configured remotes:
#####Show information about a remote:
$ git remote show <remote>
#####Add new remote repository, named <remote>:
$ git remote add <remote> <url>
#####Download all changes from <remote>, but don't integrate into HEAD:
#####Download changes and directly merge/integrate into HEAD:
$ git remote pull <remote> <url>
#####Get all changes from HEAD to local repository:
#####Get all changes from HEAD to local repository without a merge:
git pull --rebase <remote> <branch>
#####Publish local changes on a remote:
$ git push remote <remote> <branch>
#####Delete a branch on the remote:
$ git push <remote> :<branch> (since Git v1.5.0)
or
git push <remote> --delete <branch> (since Git v1.7.0)
#####Publish your tags:
##Merge & Rebase
#####Merge into your current HEAD:
#####Rebase your current HEAD onto <branch>:
Don't rebase published commit!
#####Abort a rebase:
#####Continue a rebase after resolving conflicts:
#####Use your configured merge tool to solve conflicts:
#####Use your editor to manully solve conflicts and (after resolving) mark file as resolved:
$ git add <resolved-file>
##Undo
#####Discard all local changes in your working directory:
#####Get all the files out of the staging area(i.e. undo the last git add):
#####Discard local changes in a specific file:
$ git checkout HEAD <file>
#####Revert a commit (by producing a new commit with contrary changes):
#####Reset your HEAD pointer to a previous commit and discard all changes since then:
$ git reset --hard <commit>
#####Reset your HEAD pointer to a remote branch current state.
git reset --hard <remote/branch> e.g., upstream/master, origin/my-feature
#####Reset your HEAD pointer to a previous commit and preserve all changes as unstaged changes:
#####Reset your HEAD pointer to a previous commit and preserve uncommitted local changes:
$ git reset --keep <commit>
#####Remove files that were accidentally committed before they were added to .gitignore
$ git rm -r --cached .
$ git add .
$ git commit -m "remove xyz file"
##Git-Flow
###Index
###Setup ######You need a working git installation as prerequisite. Git flow works on OSX, Linux and Windows.
#####OSX Homebrew:
#####OSX Macports:
#####Linux (Debian-based):
$ apt-get install git-flow
#####Windows (Cygwin): ######You need wget and util-linux to install git-flow.
$ wget -q -O - --no-check-certificate https://github.com/nvie/gitflow/raw/develop/contrib/gitflow-installer.sh | bash
###Getting Started ######Git flow needs to be initialized in order to customize your project setup. Start using git-flow by initializing it inside an existing git repository: #####Initialize: ######You'll have to answer a few questions regarding the naming conventions for your branches. It's recommended to use the default values.
###Features ######Develop new features for upcoming releases. Typically exist in developers repos only. #####Start a new feature: ######This action creates a new feature branch based on 'develop' and switches to it.
git flow feature start MYFEATURE
#####Finish up a feature: ######Finish the development of a feature. This action performs the following: ######1)Merged MYFEATURE into 'develop'. ######2)Removes the feature branch. ######3)Switches back to 'develop' branch
git flow feature finish MYFEATURE
#####Publish a feature: ######Are you developing a feature in collaboration? Publish a feature to the remote server so it can be used by other users.
git flow feature publish MYFEATURE
#####Getting a published feature: ######Get a feature published by another user.
git flow feature pull origin MYFEATURE
#####Tracking a origin feature: ######You can track a feature on origin by using
git flow feature track MYFEATURE
###Make a Release ######Support preparation of a new production release. Allow for minor bug fixes and preparing meta-data for a release
#####Start a release: ######To start a release, use the git flow release command. It creates a release branch created from the 'develop' branch. You can optionally supply a [BASE] commit sha-1 hash to start the release from. The commit must be on the 'develop' branch.
git flow release start RELEASE [BASE]
######It's wise to publish the release branch after creating it to allow release commits by other developers. Do it similar to feature publishing with the command:
git flow release publish RELEASE
######(You can track a remote release with the: git flow release track RELEASE command)
#####Finish up a release: ######Finishing a release is one of the big steps in git branching. It performs several actions: ######1)Merges the release branch back into 'master' ######2)Tags the release with its name ######3)Back-merges the release into 'develop' ######4)Removes the release branch
git flow release finish RELEASE
######Don't forget to push your tags with git push --tags
###Hotfixes ######Hotfixes arise from the necessity to act immediately upon an undesired state of a live production version. May be branched off from the corresponding tag on the master branch that marks the production version.
#####Git flow hotfix start: ######Like the other git flow commands, a hotfix is started with
$ git flow hotfix start VERSION [BASENAME]
######The version argument hereby marks the new hotfix release name. Optionally you can specify a basename to start from.
#####Finish a hotfix: ######By finishing a hotfix it gets merged back into develop and master. Additionally the master merge is tagged with the hotfix version
git flow hotfix finish VERSION
###Commands

