-
1. 使い始める
- 1.1 バージョン管理について
- 1.2 Gitの短い歴史
- 1.3 Gitとは何か?
- 1.4 コマンドライン
- 1.5 Gitのインストール
- 1.6 Gitを初めて設定する
- 1.7 ヘルプの利用
- 1.8 まとめ
-
2. Gitの基本
- 2.1 Gitリポジトリの取得
- 2.2 リポジトリに変更を記録する
- 2.3 コミット履歴の表示
- 2.4 元に戻す
- 2.5 リモートの操作
- 2.6 タグ付け
- 2.7 Git エイリアス
- 2.8 まとめ
-
3. Git ブランチ
- 3.1 ブランチの基本
- 3.2 ブランチの作成とマージの基本
- 3.3 ブランチの管理
- 3.4 ブランチのワークフロー
- 3.5 リモートブランチ
- 3.6 リベース
- 3.7 まとめ
-
4. サーバー上のGit
- 4.1 プロトコル
- 4.2 サーバーにGitをセットアップする
- 4.3 SSH公開鍵の生成
- 4.4 サーバーのセットアップ
- 4.5 Gitデーモン
- 4.6 Smart HTTP
- 4.7 GitWeb
- 4.8 GitLab
- 4.9 サードパーティのホストオプション
- 4.10 まとめ
-
5. 分散Git
- 5.1 分散ワークフロー
- 5.2 プロジェクトへの貢献
- 5.3 プロジェクトの管理
- 5.4 まとめ
-
6. GitHub
- 6.1 アカウントのセットアップと設定
- 6.2 プロジェクトへの貢献
- 6.3 プロジェクトの管理
- 6.4 組織の管理
- 6.5 GitHubのスクリプト化
- 6.6 まとめ
-
7. Git ツール
-
8. Gitのカスタマイズ
- 8.1 Gitの設定
- 8.2 Git属性
- 8.3 Gitフック
- 8.4 Gitによるポリシー適用例
- 8.5 まとめ
-
9. Gitとその他のシステム
- 9.1 クライアントとしてのGit
- 9.2 Gitへの移行
- 9.3 まとめ
-
10. Gitの内側
- 10.1 PlumbingとPorcelain
- 10.2 Gitオブジェクト
- 10.3 Git参照
- 10.4 パックファイル
- 10.5 Refspec
- 10.6 転送プロトコル
- 10.7 メンテナンスとデータ復旧
- 10.8 環境変数
- 10.9 まとめ
-
A1. 付録A: その他の環境におけるGit
- A1.1 グラフィカルインターフェース
- A1.2 Visual StudioでのGit
- A1.3 Visual Studio CodeでのGit
- A1.4 IntelliJ / PyCharm / WebStorm / PhpStorm / RubyMineでのGit
- A1.5 Sublime TextでのGit
- A1.6 BashでのGit
- A1.7 ZshでのGit
- A1.8 PowerShellでのGit
- A1.9 まとめ
-
A2. 付録B: アプリケーションにGitを組み込む
- A2.1 コマンドラインGit
- A2.2 Libgit2
- A2.3 JGit
- A2.4 go-git
- A2.5 Dulwich
-
A3. 付録C: Gitコマンド
- A3.1 セットアップと設定
- A3.2 プロジェクトの取得と作成
- A3.3 基本的なスナップショット取得
- A3.4 ブランチとマージ
- A3.5 プロジェクトの共有と更新
- A3.6 検査と比較
- A3.7 デバッグ
- A3.8 パッチ適用
- A3.9 Eメール
- A3.10 外部システム
- A3.11 管理
- A3.12 Plumbingコマンド
7.2 Gitツール - 対話型ステージング
対話型ステージング
このセクションでは、ファイルの特定の部分だけをコミットに含めるようにコミットを作成するのに役立つ、いくつかの対話型Gitコマンドを見ていきます。これらのツールは、多数のファイルを広範囲にわたって変更し、それらの変更を一つの大きな雑然としたコミットではなく、いくつかの焦点を絞ったコミットに分割したい場合に役立ちます。このようにすることで、コミットが論理的に分離された変更セットとなり、共同作業を行う開発者によって簡単にレビューされることを保証できます。
git add
コマンドを-i
または--interactive
オプションで実行すると、Gitは対話型シェルモードに入り、次のような表示をします
$ git add -i
staged unstaged path
1: unchanged +0/-1 TODO
2: unchanged +1/-1 index.html
3: unchanged +5/-1 lib/simplegit.rb
*** Commands ***
1: [s]tatus 2: [u]pdate 3: [r]evert 4: [a]dd untracked
5: [p]atch 6: [d]iff 7: [q]uit 8: [h]elp
What now>
このコマンドは、おそらく慣れているgit status
で得られる情報と基本的に同じですが、より簡潔で情報量の多いステージングエリアのビューを表示します。左側にはステージされた変更が、右側にはステージされていない変更がリストされます。
その後に「Commands(コマンド)」セクションがあり、ファイルのステージングやステージ解除、ファイルの一部をステージング、追跡されていないファイルの追加、ステージされた差分の表示など、様々なことができます。
ファイルのステージングとステージ解除
What now>
プロンプトでu
または2
(updateの場合)と入力すると、どのファイルをステージしたいか尋ねられます
What now> u
staged unstaged path
1: unchanged +0/-1 TODO
2: unchanged +1/-1 index.html
3: unchanged +5/-1 lib/simplegit.rb
Update>>
TODO
ファイルとindex.html
ファイルをステージするには、数字を入力します
Update>> 1,2
staged unstaged path
* 1: unchanged +0/-1 TODO
* 2: unchanged +1/-1 index.html
3: unchanged +5/-1 lib/simplegit.rb
Update>>
各ファイルの隣にある*
は、そのファイルがステージ対象として選択されていることを意味します。Update>>
プロンプトで何も入力せずにEnterを押すと、Gitは選択されたものをすべてステージします
Update>>
updated 2 paths
*** Commands ***
1: [s]tatus 2: [u]pdate 3: [r]evert 4: [a]dd untracked
5: [p]atch 6: [d]iff 7: [q]uit 8: [h]elp
What now> s
staged unstaged path
1: +0/-1 nothing TODO
2: +1/-1 nothing index.html
3: unchanged +5/-1 lib/simplegit.rb
これで、TODO
ファイルとindex.html
ファイルがステージされ、simplegit.rb
ファイルはまだステージされていないことがわかります。この時点でTODO
ファイルをステージ解除したい場合は、r
または3
(revertの場合)オプションを使用します
*** Commands ***
1: [s]tatus 2: [u]pdate 3: [r]evert 4: [a]dd untracked
5: [p]atch 6: [d]iff 7: [q]uit 8: [h]elp
What now> r
staged unstaged path
1: +0/-1 nothing TODO
2: +1/-1 nothing index.html
3: unchanged +5/-1 lib/simplegit.rb
Revert>> 1
staged unstaged path
* 1: +0/-1 nothing TODO
2: +1/-1 nothing index.html
3: unchanged +5/-1 lib/simplegit.rb
Revert>> [enter]
reverted one path
もう一度Gitの状態を見ると、TODO
ファイルがステージ解除されていることがわかります
*** Commands ***
1: [s]tatus 2: [u]pdate 3: [r]evert 4: [a]dd untracked
5: [p]atch 6: [d]iff 7: [q]uit 8: [h]elp
What now> s
staged unstaged path
1: unchanged +0/-1 TODO
2: +1/-1 nothing index.html
3: unchanged +5/-1 lib/simplegit.rb
ステージされた差分を確認するには、d
または6
(diffの場合)コマンドを使用します。これにより、ステージされたファイルの一覧が表示され、ステージされた差分を見たいファイルを選択できます。これはコマンドラインでgit diff --cached
を指定するのとよく似ています
*** Commands ***
1: [s]tatus 2: [u]pdate 3: [r]evert 4: [a]dd untracked
5: [p]atch 6: [d]iff 7: [q]uit 8: [h]elp
What now> d
staged unstaged path
1: +1/-1 nothing index.html
Review diff>> 1
diff --git a/index.html b/index.html
index 4d07108..4335f49 100644
--- a/index.html
+++ b/index.html
@@ -16,7 +16,7 @@ Date Finder
<p id="out">...</p>
-<div id="footer">contact : support@github.com</div>
+<div id="footer">contact : email.support@github.com</div>
<script type="text/javascript">
これらの基本的なコマンドを使えば、対話型追加モードでステージングエリアをより簡単に扱うことができます。
パッチのステージング
Gitでは、ファイルの一部のみをステージし、残りをステージしないことも可能です。たとえば、simplegit.rb
ファイルに2つの変更を加え、そのうちの1つだけをステージし、もう1つをステージしたくない場合、Gitでは非常に簡単に行えます。前のセクションで説明した対話型プロンプトから、p
または5
(patchの場合)と入力します。Gitは、どのファイルを部分的にステージしたいか尋ね、その後、選択されたファイルの各セクションについて、ファイル差分のハンクを表示し、それらを1つずつステージするかどうか尋ねます
diff --git a/lib/simplegit.rb b/lib/simplegit.rb
index dd5ecc4..57399e0 100644
--- a/lib/simplegit.rb
+++ b/lib/simplegit.rb
@@ -22,7 +22,7 @@ class SimpleGit
end
def log(treeish = 'master')
- command("git log -n 25 #{treeish}")
+ command("git log -n 30 #{treeish}")
end
def blame(path)
Stage this hunk [y,n,a,d,/,j,J,g,e,?]?
この時点で多くのオプションがあります。?
と入力すると、できることのリストが表示されます
Stage this hunk [y,n,a,d,/,j,J,g,e,?]? ?
y - stage this hunk
n - do not stage this hunk
a - stage this and all the remaining hunks in the file
d - do not stage this hunk nor any of the remaining hunks in the file
g - select a hunk to go to
/ - search for a hunk matching the given regex
j - leave this hunk undecided, see next undecided hunk
J - leave this hunk undecided, see next hunk
k - leave this hunk undecided, see previous undecided hunk
K - leave this hunk undecided, see previous hunk
s - split the current hunk into smaller hunks
e - manually edit the current hunk
? - print help
一般的に、各ハンクをステージしたい場合はy
またはn
と入力しますが、特定のファイル内のすべてのハンクをステージしたり、ハンクの決定を後回しにしたりすることも役立ちます。ファイルの一部をステージし、別の部分をステージしないままにした場合、ステータス出力は次のようになります
What now> 1
staged unstaged path
1: unchanged +0/-1 TODO
2: +1/-1 nothing index.html
3: +1/-1 +4/-0 lib/simplegit.rb
simplegit.rb
ファイルのステータスは興味深いものです。数行がステージされ、数行がステージされていないことを示しています。このファイルを部分的にステージしたことになります。この時点で、対話型追加スクリプトを終了し、git commit
を実行して部分的にステージされたファイルをコミットできます。
また、ファイルの部分的なステージングを行うために、対話型追加モードである必要はありません。コマンドラインでgit add -p
またはgit add --patch
を使用することで、同じスクリプトを開始できます。
さらに、git reset --patch
コマンドでファイルの一部をリセットしたり、git checkout --patch
コマンドでファイルの一部をチェックアウトしたり、git stash save --patch
コマンドでファイルの一部を一時保存したりするのにパッチモードを使用できます。これらのコマンドのより高度な使用法に到達するにつれて、それぞれの詳細を説明していきます。