Git 저장소에서 코드 작업을 하고 있는 상황을 가정해보자. 코드를 열심히 수정하던 중인데 아직 커밋은 하지 않았다. 갑작스럽게 핫픽스를 요청이 들어온다. 이럴 경우 어떻게 해야 할까 ?
git stash
는 변경사항을 임시로 저장할 수 있도록 도와주는 기능이다.
아직 마무리하지 않은 작업을 스택에 잠시 저장할 수 있도록 하는 명령어이다. 이를 통해 아직 완료하지 않은 일을 commit하지 않고 나중에 다시 꺼내와 마무리할 수 있다.
git stash에서 꼭 알아야 하는 건 두 가지.
git stash
명령어git stash pop
명령어git stash
나 git stash save
를 실행하면 스택에 새로운 stash
가 만들어진다. 이 과정을 통해 working directory
는 깨끗해진다.
pop
이라는 이름에서도 알 수 있지만, stash
는 기본적으로 스택처럼 동작한다. git stash
로 변경사항을 쌓아놓고, pop
으로 가장 최근에 저장한 변경사항을 꺼내고 그 내용은 삭제해버린다.
여러 번 stash를 했다면 위의 명령어를 통해 저장한 stash 목록을 확인할 수 있다.
stash@{0}: On development: prettier 수정
stash@{1}: On photoAwards: ~~~~ 작업중
stash@{2}: On photoAwards: meta.ts 추가
위의 명령어를 통해 했던 작업을 다시 가져온다.
// 가장 최근의 stash를 가져와 적용한다.
$ git stash apply
// stash 이름(ex. stash@{2})에 해당하는 stash를 적용한다.
$ git stash apply [stash 이름]
apply 옵션은 단순히 stash를 적용하는 것으로, 해당 stash는 스택에 여전히 남아있다. 스택에 남아 있는 stash는 위의 명령어을 사용하여 제거할 수 있다.
// 가장 최근의 stash를 제거한다.
$ git stash drop
// stash 이름(ex. stash@{2})에 해당하는 stash를 제거한다.
$ git stash drop [stash 이름]
https://gmlwjd9405.github.io/2018/05/18/git-stash.html
git stash show -p | git apply -R
실수로 잘못 stash 적용한 것을 되돌리고 싶으면 위의 명령어를 이용한다.
// 가장 최근의 stash를 사용하여 패치를 만들고 그것을 거꾸로 적용한다.
$ git stash show -p | git apply -R
// stash 이름(ex. stash@{2})에 해당하는 stash를 이용하여 거꾸로 적용한다.
$ git stash show -p [stash 이름] | git apply -R