Cheat sheet for Git: log, diff, branch, switch, checkout, restore, commit, reset etc.
Index
- Git Cheat Sheet
Git Cheat Sheet
make annotated tag
1
|
git tag -a v1.0.0 -m "leave message here for tag"
|
git log
1
2
3
4
5
6
7
8
|
# show log with one line
git log --oneline
# show log with graph tree
git log --graph
# show log with both
git log --oneline --graph
|
compare file between two branches
1
2
3
|
git diff branch1..branch2 -- "file_name"
ex) diff 2021_0405_user..master -- build.gradle
|
change branch name
1
|
git branch -m "branch_name"
|
making branch with specific commit
1
2
3
|
git branch branch_name commit_version
ex) git branch 2021_0422_add a9f5fc39c52dd362f99eb58fc1a011a6a12f9b1a
|
switching branch hack
Going back to previous branch with one second.
Show branches
1
2
3
4
5
6
|
# local
git branch
# remote
git branch -r
# all
git branch -a
|
Check merged branch in Local
1
2
3
4
|
git branch --merged
# check no merged branch in Local
git branch --no-merged
|
Check merged branch in Remote
Delete local branch
1
2
3
4
5
6
7
8
9
|
git branch -d branch_name
# delete non merged branch
git branch -D branch_name
# delete merged branches (no specific command, have to use pipe
# egrep is grep with regex expression
# egpre -v find reverse result with regex. it will return without string contains master, tpi, gov
git branch --merged | egrep -v "(^\*|master|tpi|gov)" | xargs git branch -d
|
Delete remote branch
1
2
3
|
(1) git push repo_name --delete branch_name
(2) git branch -d branch_name
git push orign branch_name
|
원격 저장소 branch 가져오기
1
2
3
4
|
# 1. 일단 pull 하고 local 과 remote에 있는 branch 확인하기
git branch -a
# 2. remote에 있다고 표기된 branch 가져오기
git checkout -t origin/0921_excel
|
git switch 로 브랜치 작업하기
1
2
3
4
5
6
|
# 1. 브랜치 변경하기
git switch master
# 2. 브랜치 새로 만들어서 변경하기
git switch -c master
# 3. 특정 버전 commit 에서 브랜치 새로 만들어서 변경하기
git switch -c master commit-number
|
restore 로 unstaged 파일 작업 되돌리기
1
2
3
4
5
|
# 브랜치에서 작업했던 파일 작업 전으로 날려버리기 (add 하기 전)
git restore src/path/sample.java
# 브랜치에서 작업했던 파일 작업 전으로 날려버리기 (add 한 후)
git resotre --staged src/path/sample.java
|
현재 브랜치에 없는 파일 가져오기
1
2
3
4
5
|
# commit 을 안 해서 없는 (새로 생성한) 파일은 그냥 cherry-pick으로 가져오자.
# 이 커맨드 써서 가져오려면 꼬이기만 한다.
# 얘는 현재의 브랜치에서는 삭제되어 없는 파일을 과거 브랜치에서 가져오는 용으로
git restore --source branchName src/file/you/delete/before.java
|
commit 취소하기
1
2
3
4
5
|
#1. commit 취소하고 add 파일까지 unstaged 하기
git reset --mixed HEAD^
#2. commit 취소하나 add 파일은 여전히 staged 하기
git reset --softed HEAD^
|
commit message 변경하기
1
2
|
#1. 제일 최근에 한 commit의 message 변경
git commit --amend
|
제일 최근에 한 commit에 새로운 파일 추가하기
1
2
|
git add src/file/you/want/to/add.java
git commit --amend
|
commit 날짜 바꾸기 aka 인공 잔디 심기
1
2
3
|
#1. 제일 최근에 한 commit의 날짜 변경
# 마지막에 +0900 은 KST 시간대 설정
git commit --amend --no-edit --date "Fri Oct 23 11:11:11 2020 +0900"
|
working directory를 remote repo의 마지막 commit으로 되돌리기
1
2
|
# 내가 이전까지 작업했던 파일들이 몽땅 날아가니 주의!
git reset --hard HEAD^
|
add 취소하기
remote push 취소하기
1
2
3
4
5
6
7
8
9
10
|
# remote에 올라간 push를 취소하고, local에서 수정을 한 다음 다시 push를 한다
# 취소한 commit이 remote에서도, local에서도 이전의 모습으로 돌아간다.
# 여러명과 작업할 때 버젼 문제가 있으니 조심해서 쓰자.
(for local)
git reset HEAD^ # 커밋 취소
git reset 커밋아이디 # 내가 원하는 시점의 commit으로 이동
git commit -m "Commit to unpush"
(for remote)
git push origin 브랜치이름 -f
|
merge 취소
1
2
3
4
|
#1. local에서 진행한 merge 취소하기
git reset --merge ORIG_HEAD
#2. 더 쉬운 방법 (Conflict 발생했을 때 쓴다)
git merge --abort
|
특정 브랜치의 commit 가져오기: git cherry-pick 🍒
1
2
3
4
|
git cherry-pick 커밋아이디
# 가끔 cherry-pick으로 commit 가져오다가 branch끼리 conflict 가 난다. 그때는 cherry-pick을 취소하자
git cherry-pick --abort
|
get removed file back
1
2
3
4
5
|
# 1.When you didn't commit
# Freshly made file will be tracked after adding,
# but in terms of removing, nothing will remain. I cannot even add the change. I can only commit the removing.
git checkout HEAD file_you_removed
|
reset(revert) file to specific commit version
Let’s say you wrote something on A file
but you were supposed to write the thing on B file
.
So you just copy the content in A to B. Now B is fine. How about A? You should get the previous content back to A.
This command will be lifesaver.
1
2
3
4
5
|
# 1. Want to revert the file to specific commit version
git checkout commit_number -- file_you_should_revert
# 2. Want to revert the file to before the specific commit version
git checkout commit_number~1 -- file_you_should_revert
|
The second way works like this. If you change a file a lot in the latest commit and before that, the file was modified age ago.
Then you can just revert the file before the latest commit.
브랜치에서 작업했던 파일 작업 전으로 날려버리기 (add 하기 전)
1
|
git checkout src/path/sample.java
|
git 기본 편집기 vim 으로 설정하기
1
|
git config --global core.editor "vim"
|
git 계정 등록
1
2
|
git config --global user.name "absinthe4902"
git config --global user.email "absinthe4902@naver.com"
|
CRLF 개행문자 설정
1
2
|
# 맨날 LF Warning이 떠서 쓰기는 하는데 사실 먹히는지 모르겠다.
git config --global core.autocrlf true
|
working directory 에서 local 계정 만들기
git hub에서 내 commit으로 허용이 되려면 git hub에 등록된 이메일을 사용해야 한다. 개인용 컴퓨터는 상관이 없는데 회사에는 git에 회사 이메일이 등록되어있어 가끔 이메일을 바꿔줘야 하는데 매번 바꿀 필요 없이 commit하려는 디렉토리에만 local 계정을 만들어주면 된다.
1
2
3
4
5
6
|
git config --local user.name "local_absinthe4902"
git config --local user.email "local_absinthe4902@naver.com"
# working directory 에 적용된 config 확인하기 (이 이름으로 push 된다고 생각하면 된다)
# id name check
git config user.name
|
연결된 remote url 변경하기
1
2
3
4
|
# 1. check name of remote branch
git remote -v
# 2. change url of remote branch
git remote set-url origin https://github.com/leeleelee3264/leeleelee3264.github.io.git
|
.gitginore 가 안 먹힐 때 AKA tracking 하지 말아야 할 파일을 트래킹 할 때 git cached 삭제하기
1
2
3
|
git rm -r --cached .
git add .
git commit -m "RESOLVED: .gitignore is not working"
|
I saw this error when I had tried to change commit with –amend but didn’t finish properly.
People say it will show up when trying to merge two different projects with no history about each others.
1
|
git pull origin branch_name --allow-unrelated-histories
|
git init cancel
1
2
3
4
|
# sometimes I make wrong directory to git repo. Then I have to cancel it.
# It's all about .git directory. When I init directory, I'll get git repo and it works like that.
# Just remove the file and it will become normal directory
rm -r .git
|
git version update
1
2
3
4
5
|
# 1.version check
git --version
# 2. git version update
git update-git-for-windows
|