Last Updated: August 01, 2022
·
834
· kenju

Tutorial of Git

Tutorial Git

Config

Username/email

This is the first thing you have to do after installing git. Sets your name and email into config file.


# Sets user name
$ git config --global user.name "David Brown"
# Sets user email
$ git config --global user.email davidbrown@example.com

Additional setting


# Sees config help
$ git config --help

# Sees all config settings
$ git config --list

# Sets editor (default = vi/vim)
# when you input something while using git
$ git config --global core.editor emacs

# Sets pager (default = less)
$ git config --global core.pager 'more'
$ git config --global core.pager ''     # this disables any pager

# Enables autocorrect
$ git config --global help.autocorrect = 1 # enabled

# Color settings
$ git config --global color.ui true     # Git defines colour pattern ( not terminal's default colour pattern)
$ git config --global color.ui false    # No-colour

Basic

Initialize


$ cd projectDirectory

# Initializes as a git repository
$ git init

# Adds all local files in the directory
$ git add -A

# Sees the status and check files in staging
$ git status

# Commits with commit message
$ git commit -m "first commit"

# Sees the log of changes
$ git log

Push to Github

Here we use Github client because it is easy to setup and begin.


# Adds Github repository as a remote origin
$ git remote add origin https://github.com/Username/projectName.git

# Pushes to the remote orgin
$ git push -u origin master

Clone

By cloning, you can use exsiting repository.
Here is all available repository URL.

  • ssh :ssh//[user@]host.xz[:port]/path/to/repo.git
  • git :git//host.xz[:port]/path/to/repo.git
  • http[s] :http[s]://host.xz[:port]/path/to/repo.git
  • ftp[s] :ftp[s]://host.xz[:port]/path/to/repo.git
  • rsync :rsync://host.xz/path/to/repo.git

$ git clone git@github.com:username/repositoryname.git

Add/Reset


# By `add` command, files can be added to a staging area
$ git add .

# Adds by seeing each files one by one
$ git add -p .
$ git add -patch .

# Adds only files which have been already managed by git
$ git add -u .
$ git add -update .

If you want to goes back to working directory from staging areas, then use reset commands.


$ git reset

Remove/Rename

Just deleting your files in Finder.app or explorer does not mean that those files would be deleted from Git. You have to user git rm command to delete those files info from Git as well. This is also the same when you rename files.


# Removes files
$ git rm sample.txt

# Renames files
$ git mv sample.txt renamed.txt

Clean

You can delete files which are not managed by Git by git clean.


# Firstly, check which files would be deleted by `git clean -f`
$ git clean -n

# Then, delete those files
$ git clean -f

Intermediate

Stash

Use git stash when you want to temporary go back to the clean working directory without losing the current state. Git offers stash, some kind of temporal stages for saving changes but you do not want to add them yet.


# adds the current state to stash with stash message
$ git stash save "stash: stash test"

# lists stashed
$ git stash list

# reflects stash by stash index
$ git stash pop stash@{0} --index

# removes stash
$ git stash drop stash@{0}

# shows stash contents
$ git stash show stash@{0} -p

# clears all stash
$ git stash clear

Reset/Reflog

Reset


# Firstly, checks commit ID
# * commit ID is a SHA-1 hashed string
$ git log

# then you can see commit logs like belows
...
commit 7a16aed234ef71f9a0d021cf9319a8783256a7e1
Author: WagatsumaKenju <ken901waga@gmail.com>
Date:   Sat Jul 18 16:29:17 2015 +0900

    done Remove/Rename
...

# then go backs to the commit point by the commit id
$ git reset 7a16aed234ef71f9a0d021cf9319a8783256a7e1

Reset Options

||git reset --soft|git reset --mixed|git reset --hard|
|---|---|---|---|
|Git directory |Reset |Reset |Reset|
|Staging area |Unchanged|Reset |Reset|
|Working directory |Unchanged|Unchanged|Reset|

Reflog

However how about you want to "reset the reset"? Then use git reflog to see changed history of HEAD branch.


$ git reflog
d46f725 HEAD@{0}: reset: moving to 7a16aed234ef71f9a...
2a2d92b HEAD@{1}: commit: ...commit messages... # you want to go back to this HEAD
338fbb3 HEAD@{2}: commit: ...commit messages...
7a16aed HEAD@{3}: commit: ...commit messages...
cfa988e HEAD@{4}: commit: ...commit messages...
8389e8c HEAD@{5}: commit: ...commit messages...
...

# then go backs to the HEAD@{1}
$ git reset --hard 2a2d92b

Filter Branch


# remove all commits of sample.txt (including all commit points)
$ git filter-branch --tree-filter 'rm -f sample.txt'

Branch

Branch - Basic


# lists all branch
$ git branch        # shows local repository
$ git branch -r # shows remote repository
$ git branch -a # shows both local and remote repository

# creates new branch (named 'topic-branch')
$ git branch topic-branch

# creates & move to a new branch
$ git checkout -b topic-branch

# renames branch
$ git branch -m topic-branch new-branch

# changes the current branch
$ git checkout master

# deletes branch
$ git branch -d new-branch

Branch - Merge/Rebase


# merge
$ git merget topic-branch

# rebase
$ git rebase topic-branch

# cherry-pick (in short, partially-merge)
$ git cherry-pick [commitID]

Merge vs Rebase?

Merge

Let's say you have created a branch for the purpose of developing a single feature. When you want to bring those changes back to master, you probably want merge (you don't care about maintaining all of the interim commits).

Rebase

A second scenario would be if you started doing some development and then another developer made an unrelated change. You probably want to pull and then rebase to base your changes from the current version from the repo.

@see
http://stackoverflow.com/questions/804115/when-do-you-use-git-rebase-instead-of-git-merge

Tag


#############
# local
#############

# shows tag list
$ git tag

# adds simple tag
$ git tag v1.0

# adds tag with annotation
$ git tag v1.0.1 -a
$ git tag v1.0.1 --annotation

# adds tag with message
$ git tag v1.0.2 -m <msg>
$ git tag v1.0.2 --message=<msg>

# deltes tag
$ git tag -d v1.0.2

#############
# remote
#############

# shows tags in remote repository
$ git ls-remote --tags

# deletes tags in remote repository
$ git push origin :v1.0

# with `-n` option, you can check the result of the command
$ git push -n origin :v1.0

Remote

Basic


# shows the name of remote repository
$ git remote

# shows the detail of remote repository
$ git remote -v

# adds remote repository
$ git remote add repoName git@github.com/name/reponame.git

# deltes remote repository
$ git remote remove repoName

# renames repository name
$ git remote rename origin neworigin

# updates repository url
$ git remote set-url github https://github.com/user/reponame.git

Push/Pull


# pulls from origin's master branch
$ git pull origin master

# pushes from origin's master branch
$ git push origin master

Pull/Fetch

This is the golden rule of pull and fetch.


pull = fetch + (merge or rebase)

You can do a git fetch at any time to update your remote-tracking branches under refs/remotes/<remote>/. This operation never changes any of your own local branches under refs/heads, and is safe to do without changing your working copy. I have even heard of people running git fetch periodically in a cron job in the background (although I wouldn't recommend doing this).

A git pull is what you would do to bring a local branch up-to-date with its remote version, while also updating your other remote-tracking branches.

@see
http://stackoverflow.com/questions/292357/what-are-the-differences-between-git-pull-and-git-fetch


# fetches
$ git fetch
$ git fetch --all   # useful when the repo is connected with multiple remote repositories
$ git fetch --tags  # gets tag info at the same time
$ git fetch --prune # remobe branchs in local repository which were deleted in remote repository

# merge
$ git merge origin/master

# pull (fetch + merge)
$ git pull origin

# pull (fetch + rebase)
$ git pull --rebase origin

Tips

Commit


# ammends the latest commit message
$ git commit --amend -m "Added the correct message"

git log

@see http://git-scm.com/docs/git-log
There are a lot of options for git log and most of them are very useful. It is worth remembering some of them.


#############
# basic
#############

# shows git log in one line
$ git log --oneline

# shows git log with decorated apperance
$ git log --graph

# shows git log with decorated apperance in one line
$ git log --oneline --graph

# prints out the ref names of any commits that are shown
$ git log --decorete=short
$ git log --decorate=full
$ git log --decorate=no

# shows sizes of each commits
$ git log --log-size

# shows with diff
$ git log -p

# shows with diffstat
$ git log --stat

# shows with changed file name and status
$ git log --name-status

#############
# limit
#############

# By max count
$ git log --max-count=2

# By author name
$ git log --author=AuthorName

# By log message
$ git log --grep=MatchedText

# Prints only merge commits
$ git log --merges

# By tags
$ git log --tags=Tag

.gitignore

@see
https://github.com/github/gitignore

When you want to delete some files which are already managed in Git, then follow below steps.


# Adds files which you want to remove from Git
$ echo ".DS_Store" >> .gitignore

# Removes target file from cache
$ git rm --cached .DS_Store

Alias


# `checkout` can be called by `co`
$ git config --global alias.co checkout

# `commit` can be called by `ci`
$ git config --global alias.co commit

Blame


# You can find where bugs are injected.
#
# `git blame` shows...
# 1: file name
# 2: author
# 3: modified time
# 4: line number
# 5: file contents
#
$ git blame src/base.js

Grep


# You can search repository with grep
$ git grep "<h1>"
$ git grep -n "<h1>"        # shows with line number
$ git grep -i "test"        # ignore cases(small/capital)
$ git grep -E "<img.*>" # can use POSIX Regexp

1 Response
Add your response

This is a nice guide, but for beginners it is a little too much. For beginners, this article (https://www.cloudways.com/blog/git-tutorial-for-beginners-version-control/ ) is easy to understand as it first explains version control and then basic git commands.

over 1 year ago ·