GUI 툴도 좋지만 CLI로 하는 것이 작업 전환시에 속도가 더 높은 느낌을 받아서 VScode에 터미널을 이용해서 git 작업을 하고 있습니다. 그걸 기록하고자 합니다.
# 전반적인 옵션
# 아래의 옵션을 주게 되면 다른 브렌치와의 충돌을 기준에 맞춰서 해결할 수 있다.
-X ${ours|theirs}
# 브랜치 목록 확인
git branch
# 브랜치 삭제
git branch -d ${branch_name}
# 원격 삭제 브랜치 제거
git remote update --prune
# 해당 브랜치로 HAED 변경
git switch ${branch_name}
# 현재 브랜치에서 파생된 브랜치를 만들면서 HEAD 변경
git switch -c ${branch_name}
# 원격의 브랜치 정보를 불러온다.
git fetch -a
# log의 옵션을 편하게 쓰기 위해서 전역 설정
git config --global alias.adog "log --all --decorate --oneline --graph"
# git 로그를 그래프로 보기 위해서 쓴다.
git adog
# 커밋에서 다른 부분을 확인하기 위해 사용한다.
git diff ${commitA} ${commitB}
# 특정 커밋의 전체 내용을 보기 위해 사용한다.
git show ${commit}
# 특정 커밋의 특정 파일의 내용을 보기 위해 사용한다.
git show ${commit}:${file_path}
# git config pull.rebase false 로 rebase 여부를 끄고 사용한다.
# 해당 브랜치의 최신 변경 사항을 가져온다.
git pull origin ${branch_name}
# 변경사항을 강제로 초기화 할 때 쓴다.
git reset --hard ${branch_name | commit_id}
# 브랜치 안의 커밋을 하나로 합칠 때 주로 쓴다.
# 기능 개발이 완료된 브랜치에서 주로 쓴다.
git reset --soft HEAD~${commit_count}
# 해당 커밋부터 몇개의 커밋이 있는지 확인할 때 쓴다.
# <commit_count>에 해당 값을 주로 쓴다.
git rev-list --count ${commit}..HEAD
# 병합 커밋을 남기지 않고 그래프 관리할 때 쓴다.
# 보통 기능에 대한 커밋을 하나로 합쳐서 rebase한다.
git rebase ${branch_name}
# 커밋 사항들을 뭉쳐서 병합할 때 쓴다.
git merge --squash ${branch}
# 특정 커밋만 적용하기 위해 사용한다.
git cherry-pick ${commit}