
git branch checkout 시 작업한 정보를 저장해야 한다는 명령어가 나왔고,
commit 하기에는 아직 작업 중이었기에, git stash를 이용하기로 했다.
들어가기 전
자신이 어떤 작업을 하던 중에 다른 요청이 들어와 하던 작업을 멈추고 잠시 브랜치를 변경해야 할 일이 있다고 하자. 이때, 아직 완료하지 않은 일을 commit하는 것은 껄끄럽다. 어떻게 해야 될까?
git stash 란?
아직 마무리하지 않은 작업을 스택에 잠시 저장할 수 있도록 하는 명령어이다. 이를 통해 아직 완료하지 않은 일을 commit하지 않고 나중에 다시 꺼내와 마무리할 수 있다.
git stash 명령을 사용하면 워킹 디렉토리에서 수정한 파일들만 저장한다.
git stashgit stash 나 git stash save 를 실행하면 스택에 새로운 stash가 만들어진다. 이 과정을 통해 working directory는 깨끗해진다.
$ git stash
$ git stash save
이제 새로운 작업을 위한 다른 브랜치로 변경할 수 있다.
git stash list$ git stash list
stash@{0}: WIP on master: 049d078 added the index file
stash@{1}: WIP on master: c264051 Revert "added file_size"
stash@{2}: WIP on master: 21d80a5 added number to log
git stash apply// 가장 최근의 stash를 가져와 적용한다.
$ git stash apply
// stash 이름(ex. stash@{2})에 해당하는 stash를 적용한다.
$ git stash apply [stash 이름]
위의 명령어로는 Staged 상태였던 파일을 자동으로 다시 Staged 상태로 만들어 주지 않는다. –index 옵션을 주어야 Staged 상태까지 복원한다. 이를 통해 원래 작업하던 파일의 상태로 돌아올 수 있다.
// Staged 상태까지 저장
$ git stash apply --index
–index옵션 유무의 차이
git stash apply
git stash apply –index
수정했던 파일들을 복원할 때 반드시 stash했을 때와 같은 브랜치일 필요는 없다. 만약 다른 작업 중이던 브랜치에 이전의 작업들을 추가했을 때 충돌이 있으면 알려준다.
이때, 현재 브랜치에서 stash를 한 후 체크아웃 하려는 브랜치로 가서 git stash apply를 생각없이 했다가, 전의 작업한거랑 충돌이 났는데 자동병합 을 당해서(?) 파일의 코드 내용이 없어진거다..
그러고 자동병합하는데, 코드가 온전히 수정이 안되서 <<<, ===, >>> 와 같은 특수기호들이 코드 중간중간 보였다.
깃에서 현재 수정된 코드와 전의 코드를 보여주는 듯 했는데 해석이 어려웠다.
그래서 공부했고, 그게 전 포스팅이다.
git stash drop// 가장 최근의 stash를 제거한다.
$ git stash drop
// stash 이름(ex. stash@{2})에 해당하는 stash를 제거한다.
$ git stash drop [stash 이름]
만약 적용과 동시에 스택에서 해당 stash를 제거하고 싶으면 git stash pop 명령을 사용하면 된다.
// apply + drop의 형태
$ git stash pop
git stash show -p | git apply -R// 가장 최근의 stash를 사용하여 패치를 만들고 그것을 거꾸로 적용한다.
$ git stash show -p | git apply -R
// stash 이름(ex. stash@{2})에 해당하는 stash를 이용하여 거꾸로 적용한다.
$ git stash show -p [stash 이름] | git apply -R
TIP alias로 편리하게 사용하자.
stash-unapply라는 명령어를 등록하여 간단하게 사용할 수 있다.
$ git config --global alias.stash-unapply '!git stash show -p | git apply -R'
$ git stash apply
$ #... work work work
// alias로 등록한 stash 되돌리기 명령어
$ git stash-unapply
References
https://git-scm.com/book/ko/v2/Git-%EB%8F%84%EA%B5%AC-Stashing%EA%B3%BC-Cleaning
https://wayhome25.github.io/git/2017/05/16/git-07-stashing-cleaning/
https://code.tutsplus.com/tutorials/quick-tip-leveraging-the-power-of-git-stash–cms-22988
https://gmlwjd9405.github.io/2018/05/18/git-stash.html