[git] 커밋하지 않고 임시 저장git stash

양주영·2022년 7월 27일
0

git

목록 보기
3/4

커밋하지 않고 변경사항 저장하는 방법

Git 저장소에서 코드 작업을 하고 있는 상황을 가정해보자. 코드를 열심히 수정하던 중인데 아직 커밋은 하지 않았다. 갑작스럽게 핫픽스를 요청이 들어온다. 이럴 경우 어떻게 해야 할까 ?

1. 하던 작업 커밋하지 않고 임시 저장

git stash는 변경사항을 임시로 저장할 수 있도록 도와주는 기능이다.

아직 마무리하지 않은 작업을 스택에 잠시 저장할 수 있도록 하는 명령어이다. 이를 통해 아직 완료하지 않은 일을 commit하지 않고 나중에 다시 꺼내와 마무리할 수 있다.

git stash에서 꼭 알아야 하는 건 두 가지.

  • 변경사항을 임시로 저장하는 git stash 명령어
  • 이렇게 저장한 임시 변경 사항을 꺼내오는 git stash pop 명령어

git stash

git stashgit stash save 를 실행하면 스택에 새로운 stash가 만들어진다. 이 과정을 통해 working directory는 깨끗해진다.

git stash pop

pop 이라는 이름에서도 알 수 있지만, stash는 기본적으로 스택처럼 동작한다. git stash로 변경사항을 쌓아놓고, pop으로 가장 최근에 저장한 변경사항을 꺼내고 그 내용은 삭제해버린다.

2. stash 목록 확인하기

git stash list

여러 번 stash를 했다면 위의 명령어를 통해 저장한 stash 목록을 확인할 수 있다.

stash@{0}: On development: prettier 수정
stash@{1}: On photoAwards: ~~~~ 작업중
stash@{2}: On photoAwards: meta.ts 추가

3. stash 적용하기 (했던 작업을 다시 가져오기)

git stash apply

위의 명령어를 통해 했던 작업을 다시 가져온다.

// 가장 최근의 stash를 가져와 적용한다.
$ git stash apply
// stash 이름(ex. stash@{2})에 해당하는 stash를 적용한다.
$ git stash apply [stash 이름]

4. stash 제거하기

git stash drop

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

5. stash 되돌리기

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


참고
https://gmlwjd9405.github.io/2018/05/18/git-stash.html

profile
뚜벅뚜벅

0개의 댓글