Git - Operasi Stash

Misalkan Anda menerapkan fitur baru untuk produk Anda. Kode Anda sedang diproses dan tiba-tiba eskalasi pelanggan datang. Karena itu, Anda harus mengesampingkan fitur baru Anda untuk bekerja selama beberapa jam. Anda tidak dapat menggunakan kode parsial Anda dan juga tidak dapat membuang perubahan Anda. Jadi Anda memerlukan beberapa ruang sementara, di mana Anda dapat menyimpan sebagian perubahan Anda dan kemudian melakukan itu.

Di Git, operasi simpanan mengambil file terlacak Anda yang dimodifikasi, tahapan perubahan, dan menyimpannya di tumpukan perubahan yang belum selesai yang dapat Anda terapkan kembali kapan saja.

[jerry@CentOS project]$ git status -s
M string.c
?? string

Sekarang, Anda ingin beralih cabang untuk eskalasi pelanggan, tetapi Anda tidak ingin melakukan apa yang telah Anda kerjakan; jadi Anda akan menyembunyikan perubahan. Untuk mendorong simpanan baru ke tumpukan Anda, jalankangit stash perintah.

[jerry@CentOS project]$ git stash
Saved working directory and index state WIP on master: e86f062 Added my_strcpy function
HEAD is now at e86f062 Added my_strcpy function

Sekarang, direktori kerja Anda bersih dan semua perubahan disimpan di tumpukan. Mari kita verifikasi dengangit status perintah.

[jerry@CentOS project]$ git status -s
?? string

Sekarang Anda dapat dengan aman berpindah cabang dan bekerja di tempat lain. Kami dapat melihat daftar perubahan yang disimpan dengan menggunakangit stash list perintah.

[jerry@CentOS project]$ git stash list
stash@{0}: WIP on master: e86f062 Added my_strcpy function

Misalkan Anda telah menyelesaikan eskalasi pelanggan dan Anda kembali ke fitur baru mencari kode setengah jadi, cukup jalankan git stash pop perintah, untuk menghapus perubahan dari tumpukan dan menempatkannya di direktori kerja saat ini.

[jerry@CentOS project]$ git status -s
?? string

[jerry@CentOS project]$ git stash pop

Perintah di atas akan menghasilkan hasil sebagai berikut:

# On branch master
# Changed but not updated:
# (use "git add ..." to update what will be committed)
# (use "git checkout -- ..." to discard changes in working directory)
#
#
modified: string.c
#
# Untracked files:
# (use "git add ..." to include in what will be committed)
#
#
string
no changes added to commit (use "git add" and/or "git commit -a")
Dropped refs/stash@{0} (36f79dfedae4ac20e2e8558830154bd6315e72d4)

[jerry@CentOS project]$ git status -s
M string.c
?? string