ํน์ ๋ธ๋์น์์ ์์ ์ ํ๋ ์ค ๋ค๋ฅธ ์์ฒญ์ผ๋ก ํ๋ ์์ ์ ๋ฉ์ถ๊ณ ๋ค๋ฅธ ๋ธ๋์น๋ก ๋ณ๊ฒฝํด์ผ ํ๋ ์ํฉ์ด ์๋ค.
๊ทธ๋ฅ ๋ณ๊ฒฝํ๋ ค๊ณ ํ๋ ์ค๋ฅ๊ฐ ๋ฐ์ํ์๋ค.
error: Your local changes to the following files would be overwritten by checkout:
...
Please commit your changes or stash them before you switch branches.
Aborting
์์ง ๋ง๋ฌด๋ฆฌํ์ง ์์ ์์ ์ ์คํ์ ์ ์ ์ ์ฅํ ์ ์๋๋ก ํ๋ ๋ช ๋ น์ด์ธ git stash๋ฅผ ์ฌ์ฉํ์ฌ ํด๊ฒฐํ ์ ์์๋ค.
git stash๋ฅผ ์ฌ์ฉํ์ฌ ์์ง ์๋ฃํ์ง ์์ ์ผ์ commit ํ์ง ์๊ณ ๋์ค์ ๋ค์ ๊บผ๋ด์ ๋ง๋ฌด๋ฆฌํ ์ ์๋ค.
01. git stash๋?
Git์์ git stash๋ ํ์ฌ ์์ ์ค์ธ ๋ณ๊ฒฝ ์ฌํญ์ ์์๋ก ์ ์ฅํด ๋๊ณ , ์์ ๋๋ ํฐ๋ฆฌ๋ฅผ ๊นจ๋ํ๊ฒ ๋น์ธ ์ ์๊ฒ ํ๋ ๋ช ๋ น์ด์ด๋ค.
์ดํ์ ์ ์ฅํด ๋ ๋ณ๊ฒฝ ์ฌํญ์ ๋ค์ ์ ์ฉํ ์ ์๋ค. ์ฃผ๋ก ๋ธ๋์น๋ฅผ ๋ณ๊ฒฝํ๊ฑฐ๋ ๊ธด๊ธํ ๋ฒ๊ทธ ์์ ์ ํด์ผ ํ ๋ ์ ์ฉํ๋ค.
- git stash ๋ช ๋ น์ ์ฌ์ฉํ๋ฉด ์ํน ๋๋ ํ ๋ฆฌ์์ ์์ ํ ํ์ผ๋ค๋ง ์ ์ฅํ๋ค.
- stash๋ ์๋์ ํด๋นํ๋ ํ์ผ๋ค์ ๋ณด๊ดํด๋๋ ์ฅ์์ด๋ค.
- Modified์ด๋ฉด์ Tracked ์ํ์ธ ํ์ผ
- Tracked ์ํ์ธ ํ์ผ์ ์์ ํ ๊ฒฝ์ฐ
- Tracked: ๊ณผ๊ฑฐ์ ์ด๋ฏธ commitํ์ฌ ์ค๋ ์ท์ ๋ฃ์ด์ง ๊ด๋ฆฌ ๋์ ์ํ์ ํ์ผ
- Staging Area์ ์๋ ํ์ผ(Staged ์ํ์ ํ์ผ)
- git add ๋ช ๋ น์ ์คํํ ๊ฒฝ์ฐ
- Staged ์ํ๋ก ๋ง๋ค๋ ค๋ฉด git add ๋ช ๋ น์ ์คํํด์ผ ํ๋ค.
- git add๋ ํ์ผ์ ์๋ก ์ถ์ ํ ๋๋ ์ฌ์ฉํ๊ณ ์์ ํ ํ์ผ์ Staged ์ํ๋ก ๋ง๋ค ๋๋ ์ฌ์ฉํ๋ค.
- Modified์ด๋ฉด์ Tracked ์ํ์ธ ํ์ผ
02. ์ฃผ์ ๋ช ๋ น์ด
๋ณ๊ฒฝ ์ฌํญ ์์ ์ ์ฅ
git stash
์ ์ฅ๋ ๋ณ๊ฒฝ ์ฌํญ ๋ชฉ๋ก ํ์ธ
git stash list
์ ์ฅ๋ ๋ณ๊ฒฝ ์ฌํญ ์ ์ฉ
git stash apply
์ ์ฅ๋ ํน์ ๋ณ๊ฒฝ ์ฌํญ ์ ์ฉ
git stash apply stash@{index}
์ ์ฅ๋ ๋ณ๊ฒฝ ์ฌํญ ์ญ์
git stash drop
์ ์ฅ๊ณผ ๋์์ ๋ธ๋์น ์ ํ
git stash push -m "์์
์ค๋ช
"
git checkout ๋ค๋ฅธ_๋ธ๋์น
์ ์ฅ๋ ๋ณ๊ฒฝ ์ฌํญ ์ ์ฉ ํ ์ญ์
git stash pop
03. git stash ์ฌ์ฉ
stash๋ก ํน์ ํ์ผ๋ง ์์์ ์ฅํ์ stash ๋ชฉ๋ก ๋ณด๊ธฐ
git stash push -m "description" ๊ฒฝ๋ก
ex) git stash push -m "๋๊ฐ ํ์ผ ์์ ์ ์ฅ" /src/one.tsx /src/two.tsx
ex) git stash push -m "src ํ์ ํ์ผ ํ๋ฒ์ ์ ์ฅํ๊ธฐ" /src/*
git stash list
stash ์ ์ฉํ๊ธฐ(์ด์ ์ ํ๋ ์์ ์ ๋ค์ ๊ฐ์ ธ์ค๊ธฐ)
// ๊ฐ์ฅ ์ต๊ทผ์ stash๋ฅผ ๊ฐ์ ธ์ ์ ์ฉํ๋ค.
$ git stash apply
// stash ์ด๋ฆ(ex. stash@{2})์ ํด๋นํ๋ stash๋ฅผ ์ ์ฉํ๋ค.
$ git stash apply [stash ์ด๋ฆ]
์์ ๋ช ๋ น์ด๋ฅผ ํตํด ํ๋ ์ด์ ์ ์ ์ฅํ๋ ์์ ์ ๋ค์ ๊ฐ์ ธ์จ๋ค.
์์ ํ๋ ํ์ผ๋ค์ ๋ณต์ํ ๋ ๋ฐ๋์ stash ํ์ ๋์ ๊ฐ์ ๋ธ๋์น์ผ ํ์๋ ์๋ค.
๋ง์ฝ ๋ค๋ฅธ ์์ ์ค์ด๋ ๋ธ๋์น์ ์ด์ ์ ์์ ๋ค์ ์ถ๊ฐํ์ ๋ ์ถฉ๋์ด ์์ผ๋ฉด ์๋ ค์ค๋ค.
stash ์ ๊ฑฐํ๊ธฐ
apply ์ต์ ์ ๋จ์ํ stash๋ฅผ ์ ์ฉํ๋ ๊ฒ์ผ๋ก, ํด๋น stash๋ ์คํ์ ์ฌ์ ํ ๋จ์์๋ค.
์คํ์ ๋จ์ ์๋ stash๋ ์๋ ๋ช ๋ น์ด์ ์ฌ์ฉ ํ์ฌ ์ ๊ฑฐํ ์ ์๋ค.
// ๊ฐ์ฅ ์ต๊ทผ์ stash๋ฅผ ์ ๊ฑฐํ๋ค.
$ git stash drop
// stash ์ด๋ฆ(ex. stash@{2})์ ํด๋นํ๋ stash๋ฅผ ์ ๊ฑฐํ๋ค.
$ git stash drop [stash ์ด๋ฆ]
stash ๋๋๋ฆฌ๊ธฐ
์ค์๋ก ์๋ชป stash ์ ์ฉํ ๊ฒ์ ๋๋๋ฆฌ๊ณ ์ถ์ผ๋ฉด ์์ ๋ช ๋ น์ด๋ฅผ ์ด์ฉํ๋ค.
// ๊ฐ์ฅ ์ต๊ทผ์ stash๋ฅผ ์ฌ์ฉํ์ฌ ํจ์น๋ฅผ ๋ง๋ค๊ณ ๊ทธ๊ฒ์ ๊ฑฐ๊พธ๋ก ์ ์ฉํ๋ค.
$ git stash show -p | git apply -R
// stash ์ด๋ฆ(ex. stash@{2})์ ํด๋นํ๋ stash๋ฅผ ์ด์ฉํ์ฌ ๊ฑฐ๊พธ๋ก ์ ์ฉํ๋ค.
$ git stash show -p [stash ์ด๋ฆ] | git apply -R
TIP. alias
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
04. vscode ui๋ก ์ฌ์ฉํ๊ธฐ
์ฐ์ธก source control ํญ์ผ๋ก ์ด๋ํ์ฌ ... ๋ฒํผ์ ๋๋ฌ์ค๋ค. stash ๋ฉ๋ด์์ ์ํ๋ ๋ฉ๋ด๋ฅผ ์ ํํ๋ฉด ๋๋ค.
stage์ ์ฌ๋ผ๊ฐ ๋ณ๊ฒฝ์ฌํญ์ stash ํด๋ณด์.
view stash ๋ฉ๋ด๋ฅผ ํด๋ฆญํ๋ฉด ์๋์ ๊ฐ์ด ์ ์ฅํด๋ ๋ณ๊ฒฝ ์ฌํญ์ ํ์ธํ ์ ์๋ค.
์ ์ฉ๊ณผ ๋์์ ์คํ์์ ํด๋น stash๋ฅผ ์ ๊ฑฐํ๊ธฐ ์ํด pop stash ๋ฉ๋ด๋ฅผ ์ฌ์ฉํด ๋ณด์
pop ํ stash ๋ชฉ๋ก์ ์ ํํ๋ค.
์ด์ ์ ์ ์ฅํด ๋ ์์ ์ฌํญ์ ๋ค์ ๊ฐ์ง๊ณ ๋์จ ๊ฒ์ ํ์ธํ ์ ์๋ค.
'๐ ์ด๊ฒ์ ๊ฒ > Git' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
[Git] Git ๋ธ๋์น ์กฐํ ๋ฐ ์ญ์ ํ๊ธฐ (1) | 2024.01.18 |
---|