IntelliJ IDEA の Git Stash と Shelve
この記事では、IntelliJ IDEA を使用する際に、git stash
と git shelve
を区別します。作業中にいくつかのタスクを切り替えて、後でそれらに戻りたい場合、2つはクラッチになります。
IntelliJ IDEA を使用すると、進行状況を失うことなく、さまざまな機能に取り組むことができます。隠しておくことも棚に置くこともできます。
この 2つには多くの共通点があります。パッチを生成して適用する場合、大きな違いが生じます。
隠しておくと、Git がパッチを生成し、IntelliJ IDEA または別の IDE を使用してパッチを適用できます。一方、棚上げすると、パッチは IntelliJ IDEA 内で生成および適用されます。
スタッシュはコミットされていないすべての変更を保存しますが、シェルフを使用すると、何をシェルフするかを選択できます。
Git での変更の棚上げ
変更を棚上げするとき、別のタスクに切り替える必要がある場合に後で処理するために、コミットされていない変更を一時的に保存します。IntelliJ IDEA を使用すると、個別のファイルまたはすべての変更を棚上げできます。
生成されたパッチは何度でも適用できます。これが典型的なワークフローです。
-
IDE で、コミットツールに移動します。そこに到達したら、保存する変更リストまたはファイルを右クリックして、[変更の保存]を選択します。
- 次に、リストを確認し、
コミットメッセージ
でシェルフに名前を付け、シェルフの変更
をクリックしてシェルフを保存します。
別の方法は、サイレント
オプションを使用することです。IDE には、ダイアログを表示せずにシェルフできる Shelve Silently
オプションがあります。
Git の棚上げされていない変更
変更の保留を解除するには、次の手順に従います。
-
IDE の[シェルフ]タブに移動し、ファイルを選択するか、シェルフを解除する必要のあるリストを変更します。
-
メニューから[保留解除]をタップし、保留された変更を復元するリストを選択します。既存の変更リストに復元したくない場合は、新しいリストを作成することもできます。
新しいリストに
アクティブ
のマークを付けることを忘れないでください。 -
または、
Unshelve Silently
アイコンを使用して、変更をアクティブな変更リストに移動することもできます。
Git のスタッシュ変更
隠し場所は、現在の作業ディレクトリと HEAD
コミットの違いの単なる記録です。ブランチパッチは必要に応じて何度でも適用できます。
それを念頭に置いて:
- スタッシュを適用しているときに競合に直面する可能性があります。
- コミットされていない変更を含む作業コピーにスタッシュを適用することはできません。
IntelliJ IDEA で変更を隠しておくには、次の手順に従ってください。
Git
>コミットされていない変更
>Stash Changes
に移動します。- 正しいディレクトリを選択し、正しいブランチに切り替えます。
メッセージ
フィールドに隠し場所を簡単に説明することは常に良いことです。スタッシュの作成
をクリックします。
Git に Stash を適用する
スタッシュを適用するには、次の手順に従います。
-
Git
>UncommitedChanges
>Unstash Changes
に移動します。 -
正しいディレクトリを選択し、正しいブランチに切り替えます。
-
スタッシュを選択し、
表示
をクリックしてパッチの適用後に変更されるファイルを確認し、ポップスタッシュ
を選択してパッチの適用後にパッチを破棄します。 -
[新しいブランチとして]フィールドにブランチの名前を入力することで、新しいブランチを作成してパッチを適用できます。
John is a Git and PowerShell geek. He uses his expertise in the version control system to help businesses manage their source code. According to him, Shell scripting is the number one choice for automating the management of systems.
LinkedIn