-
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 スマート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ツール
- 7.1 リビジョン選択
- 7.2 インタラクティブステージング
- 7.3 スタッシュとクリーン
- 7.4 作業の署名
- 7.5 検索
- 7.6 履歴の書き換え
- 7.7 resetコマンド詳解
- 7.8 高度なマージ
- 7.9 rerere
- 7.10 Gitを使ったデバッグ
- 7.11 サブモジュール
- 7.12 バンドリング
- 7.13 置換
- 7.14 認証情報の保存
- 7.15 まとめ
-
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 内部コマンドと外部コマンド
- 10.2 Gitオブジェクト
- 10.3 Gitリファレンス
- 10.4 パックファイル
- 10.5 リファレンス指定
- 10.6 転送プロトコル
- 10.7 メンテナンスとデータ復旧
- 10.8 環境変数
- 10.9 まとめ
-
付録A. 付録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 まとめ
-
付録B. 付録B: アプリケーションへのGitの埋め込み
- A2.1 コマンドラインGit
- A2.2 Libgit2
- A2.3 JGit
- A2.4 go-git
- A2.5 Dulwich
-
付録C. 付録C: Gitコマンド
- A3.1 設定と構成
- A3.2 プロジェクトの取得と作成
- A3.3 基本的なスナップショット
- A3.4 ブランチとマージ
- A3.5 プロジェクトの共有と更新
- A3.6 検査と比較
- A3.7 デバッグ
- A3.8 パッチ
- A3.9 メール
- A3.10 外部システム
- A3.11 管理
- A3.12 内部コマンド
A3.4 付録C: Gitコマンド - ブランチとマージ
ブランチとマージ
Gitのブランチとマージ機能の大部分は、少数のコマンドで実装されています。
git branch
git branch
コマンドは、実際にはブランチ管理ツールです。既存のブランチのリスト表示、新規ブランチの作成、ブランチの削除、ブランチの名前変更を行うことができます。
大部分のGitブランチはbranch
コマンドに特化しており、この章全体で使用されています。新規ブランチの作成で最初に紹介され、その他の機能(リスト表示と削除)の大部分はブランチの管理で説明されています。
追跡ブランチでは、git branch -u
オプションを使用して追跡ブランチを設定します。
最後に、バックグラウンドで行われる処理の一部については、Gitリファレンスで説明します。
git checkout
git checkout
コマンドは、ブランチを切り替え、作業ディレクトリにコンテンツをチェックアウトするために使用します。
このコマンドは、git branch
コマンドと共にブランチの切り替えで最初に登場します。
追跡ブランチでは、--track
フラグを使用して追跡ブランチを開始する方法を示しています。
競合のチェックアウトでは、--conflict=diff3
を使用してファイルの競合を再導入する方法を示しています。
resetコマンド詳解では、git reset
との関係について詳しく説明します。
最後に、HEADとの関係について実装の詳細を説明します。
git merge
git merge
ツールは、1つ以上のブランチを現在チェックアウトしているブランチにマージするために使用します。その後、現在のブランチはマージの結果に進みます。
git merge
コマンドは、基本的なブランチで最初に紹介されました。この書籍では様々な場所で使用されていますが、merge
コマンドのバリエーションはほとんどありません。一般的には、マージしたい単一のブランチ名を指定してgit merge <branch>
を使用します。
フォークされた公開プロジェクトの最後に、圧縮マージ(Gitが作業をマージしますが、マージしているブランチの履歴を記録せずに、単なる新しいコミットであるかのように見せかける)を行う方法について説明しています。
高度なマージでは、マージプロセスとコマンドについて詳しく説明し、-Xignore-space-change
コマンドと、問題のあるマージを中止するための--abort
フラグについても説明しています。
コミットの署名では、プロジェクトでGPG署名を使用している場合に、マージ前に署名を検証する方法について説明しています。
最後に、サブツリーマージについて説明します。
git mergetool
git mergetool
コマンドは、Gitでマージに問題が発生した場合に、外部マージヘルパーを起動します。
基本的なマージコンフリクトについては基本的なマージコンフリクトで簡単に触れ、独自の外部マージツールの作成方法については外部マージおよび差分ツールで詳しく説明します。
git log
git log
コマンドは、最新のコミットスナップショットから遡って、プロジェクトの到達可能な記録された履歴を表示するために使用されます。デフォルトでは、現在作業中のブランチの履歴のみを表示しますが、異なるヘッドや複数のヘッド、またはトラバースするブランチを指定することもできます。また、コミットレベルで2つ以上のブランチ間の違いを表示するためにも頻繁に使用されます。
このコマンドは、プロジェクトの履歴を示すために、本書のほぼすべての章で使用されています。
コミット履歴の表示では、このコマンドを紹介し、詳細に解説しています。ここでは、各コミットで追加された内容を把握するための-p
オプションと--stat
オプション、履歴をより簡潔に表示するための--pretty
オプションと--oneline
オプション、いくつかの簡単な日付と作成者によるフィルタリングオプションについて説明します。
新規ブランチの作成では、ブランチポインタの位置を容易に視覚化するために--decorate
オプションを使用し、--graph
オプションを使用して、異なる履歴がどのように見えるかを示します。
少人数のプライベートチームとコミット範囲では、branchA..branchB
構文を使用してgit log
コマンドで、あるブランチに対して別のブランチに固有のコミットを表示する方法を説明します。コミット範囲では、これをかなり詳細に説明します。
マージログとトリプルドットでは、branchA…branchB
形式と--left-right
構文を使用して、一方のブランチにはあるが、両方のブランチにはないコミットを表示する方法を説明します。マージログでは、マージコンフリクトのデバッグに役立つ--merge
オプションの使用方法と、履歴内のマージコミットコンフリクトを確認するための--cc
オプションの使用方法についても説明します。
RefLog ショートネームでは、ブランチのトラバーサルではなく、-g
オプションを使用してこのツールでGit reflogを表示する方法を説明します。
検索では、関数の履歴など、コードの履歴で発生したものをかなり高度に検索するための-S
オプションと-L
オプションの使用方法を説明します。
コミットの署名では、有効に署名されたかどうかによって、git log
出力の各コミットに検証文字列を追加するための--show-signature
の使用方法を示します。
git stash
git stash
コマンドは、未完了の作業をコミットせずに作業ディレクトリをクリーンアップするために、コミットされていない作業を一時的に保存するために使用されます。
これは基本的にスタッシュとクリーンアップで完全に網羅されています。