Skip to content

Latest commit

 

History

History
129 lines (80 loc) · 4.01 KB

README.md

File metadata and controls

129 lines (80 loc) · 4.01 KB

Git Cheat Sheet

Clone

  • Clone repository git clone <repo_url>

  • Clone single branch git clone -b <branch_name> --single-branch git://<repo_url>

Branch

  • Show all branch $ git branch -a

  • Show remote branch $ git branch -r

  • Show local branch $ git branch

  • Create new Branch $ git branch <branch_name>

  • Create branch from commit $ git branch <branch_name> <sha1-of-commit>

  • Switch branch $ git checkout <branch_name>

  • Create new and checkout $ git checkout -b <branch_name>

  • Delete local branch $ git branch -d <branch_name>

  • Delete remote-tracking branch $ git branch -d -r <remote_branch_name>

  • Delete remote branch $ git push -d <branch_to_delete>

  • Force delete branch $ git branch -D <-r> <branch_name>

  • Clean outdated branch: $ git remote prune <remote_name>

Pull

  • Pull a branch from remote server to a branch in local git pull <remote> <r-branch>:<l-branch>

  • Pull a branch from remote server to the current local branch $ git pull <remote_name> <local_branch_name>

Stash

  • Save all changes of the current branch $ git stash

  • Show the stashed change history $ git stash list

  • Show a change $ git stash show stash@{<index>}

  • Apply a change $ git stash apply stash@{<index>}

  • Delete a change $ git stash drop stash@{<index>}

  • Delete all changes $ git stash clear

Commit

  • Commit the change of branch

    $ git add ...
    $ git commit -m <message>
    $ git push <remote_name> <branch_name>
    
  • To change the last commit message use --amend

    $ git commit --amend -m "New commit message"

  • Open editor to edit the message

    git commit --amend

  • To undo commit

    $ git commit -m "Something terribly misguided"              (1)
    $ git reset HEAD~                                           (2)
    << edit files as necessary >>                               (3)
    $ git add ...                                               (4)
    $ git commit -c ORIG_HEAD                                   (5)
    

This is what you want to undo This leaves your working tree (the state of your files on disk) unchanged but undoes the commit and leaves the changes you committed unstaged (so they'll appear as "Changes not staged for commit" in git status and you'll need to add them again before committing). If you only want to add more changes to the previous commit, or change the commit message, you could use git reset --soft HEAD~ instead, which is like git reset HEAD~ but leaves your existing changes staged. Make corrections to working tree files. git add anything that you want to include in your new commit. Commit the changes, reusing the old commit message. reset copied the old head to .git/ORIG_HEAD; commit with -c ORIG_HEAD will open an editor, which initially contains the log message from the old commit and allows you to edit it. If you do not need to edit the message, you could use the -C option.

  • Delete a commit (1 - delete only the commit_id) $ git revert <commit_id>

  • Delete a commit (2 - Delete all newer commit than the commit_id)

    $ git reset --hard <commit_id>
    $ git push <remote_name> -f <branch_name>
    
  • Git reset commit to the same as remote branch $ git reset --hard origin/<remote_branch>

Push

  • To push single tag $ git push origin <tag_name>

  • To push all tags $ git push --tags

  • Push branch to remote $ git push <remote_name> <local_branch_name>

Tag

  • Add tag $ git tag -a <tag_name> -m <Tag description at here>

  • Add tag from a commit $ git tag -a <tag_name> <commit_sha> -m <Tag description at here>

  • Push all tags $ git push --tags

  • Push one tag $ git push origin <tag_name>

  • List all tags $ git tag

File

  • Remove a file $ git rm --cached <file_name>

  • Remove a folder in repository without remove on local repository $ git rm --cached -r <folder_name>