skillup

技術ブログ

Git

git stash ~一時的な内容の保存~

投稿日:

gitでコミットせずに、作業を保存したいときがあるとおもいます。

例えばあるブランチで作業していて、実は今の作業内容が別のブランチでの反映が必要になったときなどです。

gitはブランチの切り替え(git checkout)を使うと、コミットしていない保存内容は全て消えてしまいます。

そのため、コミットしなければある作業内容を移行することはできません。

そんなときに一時的に作業を保存することができればとても便利ですね。

そんな時に使えるのがgit stashです。

作業の保存

保存方法はとても簡単で現状のブランチで作業中にgit stashと打ちます。(この時点で保存され、下記のようなメッセージが出力されます。)

Saved working directory and index state WIP on ブランチ名: リビジョン コメント
HEAD is now at リビジョン番号 コメント

内容の確認

git stash listで保存データの日にちなどを見ることができます。

git show -pで具体的なソースの内容を見ることができます。

stashの内容を現ブランチに吐き出す

この後、ブランチを切り替えましょう。

git stash popで保存されていた内容が現ブランチに吐き出されます。一時領域に保存されていたstashは消滅します。(git stash applyでもいけます。その場合はstashの内容が一時領域から消滅しないようです。)

 

-Git
-

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

最新版のgitをソースから&git diffおさらい

Contents1 gitをソースから2 git diff gitをソースから gitはyumから入れてもいいんですが、バージョンが古かったりすると機能がいろいろと制限されるなどのデメリットもあります …

no image

Gitでのbranch 新ブランチの作成&リモート反映&別環境反映

gitを使っているとわけのわからないことは多いのですが(爆)、その中の1つがbranch(ブランチ)でしょう。 これも説明をきいてもわからないのですが、自分でそのケースを学習してみればすぐにわかると思 …

no image

Gitのブランチについて

ちょっといろいろと触っているGitに関して。 前回は作業ディレクトリ、インデックス、コミットについて説明したのですが、今回はブランチについて行います。 Contents1 ブランチとは?2 ブランチに …

no image

gitの作業ディレクトリ・インデックス・HEADに関して

gitを使い始めてしばらくたちますが、まだ明確なイメージがつかめていないです(汗) みようみまねでやっていて、ポイント、ポイントで困ったことは検索してなんとか対応してきましたが、体系的な理解ができてい …

no image

git reset vs git checkout

gitの小ネタです。 現状のソースから履歴をもどしたいときgit resetとgit checkoutがあると思います。 いまいち、違いがわかりませんでしたが、 git resetはファイル単位でなく …