-
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 リセットの解説
- 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 Refspec
- 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 内部コマンド
A1.1 付録A: その他の環境におけるGit - グラフィカルインターフェース
本書全体を読み終えたあなたは、コマンドラインでGitを使用する方法について多くのことを学びました。ローカルファイルの操作、ネットワークを介した他のリポジトリとの接続、そして他のユーザーとの効果的な共同作業を行うことができます。しかし、話はここで終わりではありません。Gitは通常、より大きなエコシステムの一部として使用され、ターミナルが常に最良の作業方法とは限りません。ここでは、Gitが役立つ可能性のあるその他の環境の種類と、他のアプリケーション(あなた自身のアプリケーションを含む)がGitとどのように連携するかを見ていきます。
グラフィカルインターフェース
Gitのネイティブ環境はターミナルです。新しい機能は最初にそこに表示され、コマンドラインでのみGitの全機能を完全に利用できます。しかし、プレーンテキストがすべてのタスクに最適な選択肢とは限りません。場合によっては、視覚的な表現が必要であり、一部のユーザーはポイントアンドクリックインターフェースの方がはるかに快適です。
さまざまなインターフェースは、さまざまなワークフローに合わせて調整されていることに注意することが重要です。一部のクライアントは、著者が効果的と考える特定の作業方法をサポートするために、Git機能の厳選されたサブセットのみを公開します。このように見ると、これらのツールのいずれも他のツールよりも「優れている」とは言えず、単に目的の用途に適しているだけです。また、これらのグラフィカルクライアントができることは、コマンドラインクライアントでもすべて行うことができることに注意してください。リポジトリを操作する際には、コマンドラインの方が依然として最も強力で制御力があります。
gitk
とgit-gui
Gitをインストールすると、そのビジュアルツールであるgitk
とgit-gui
も入手できます。
gitk
は、グラフィカルな履歴ビューアーです。git log
とgit grep
の上にある強力なGUIシェルと考えてください。これは、過去に発生した何かを見つけたり、プロジェクトの履歴を視覚化しようとしたりする場合に使用するツールです。
Gitkはコマンドラインから起動するのが最も簡単です。Gitリポジトリにcd
して、以下を入力します。
$ gitk [git log options]
Gitkは多くのコマンドラインオプションを受け付けますが、そのほとんどは基礎となるgit log
アクションに渡されます。おそらく最も便利なものの1つは--all
フラグで、これによりgitk
はHEADだけでなく、任意の参照から到達可能なコミットを表示します。Gitkのインターフェースは以下のようになります。

gitk
履歴ビューア上部にはgit log --graph
の出力を少し想起させるものがあります。各点はコミットを表し、線は親の関係を表し、参照は色付きのボックスで表示されます。黄色の点はHEADを表し、赤色の点はコミットになる前の変更を表します。下部には選択されたコミットのビューが表示され、左側にコメントとパッチ、右側にサマリービューが表示されます。その間には、履歴を検索するためのコントロールのコレクションがあります。
一方、git-gui
は主にコミットを作成するためのツールです。これもコマンドラインから起動するのが最も簡単です。
$ git gui
そして、それはこのような見た目です。

git-gui
コミットツール左側はインデックスです。ステージングされていない変更は上に、ステージングされた変更は下にあります。アイコンをクリックすることでファイル全体を2つの状態間で移動したり、ファイル名をクリックすることでファイルを選択して表示したりできます。
右上には差分ビューがあり、現在選択されているファイルの変更が表示されます。この領域で右クリックすることで、個々のハンク(または個々の行)をステージングできます。
右下にはメッセージとアクションの領域があります。テキストボックスにメッセージを入力し、「コミット」をクリックすると、git commit
と同様の操作が行われます。「修正」ラジオボタンを選択すると、直前のコミットを修正することもできます。これにより、「ステージング済み変更」領域に直前のコミットの内容が更新されます。その後、いくつかの変更をステージングまたはアンステージングし、コミットメッセージを変更して、「コミット」をもう一度クリックすると、古いコミットが新しいコミットで置き換えられます。
gitk
とgit-gui
は、タスク指向ツールの例です。それぞれ特定の目的(履歴の表示とコミットの作成)に合わせて調整されており、そのタスクに不要な機能は省略されています。
macOSおよびWindows用GitHub
GitHubは、2つのワークフロー指向のGitクライアントを作成しました。1つはWindows用、もう1つはmacOS用です。これらのクライアントは、ワークフロー指向ツールの良い例です。Gitのすべての機能を公開するのではなく、連携して動作する一般的に使用される機能の厳選されたセットに焦点を当てています。それらの見た目は以下のようになります。


これらは非常に似たように見えるように設計されているため、この章では単一の製品として扱います。これらのツールの詳細な説明は行いません(独自のドキュメントがあります)。ただし、「変更」ビュー(大部分の時間を費やす場所)の簡単なツアーは必要です。
-
左側は、クライアントが追跡しているリポジトリのリストです。この領域の上部にある「+」アイコンをクリックすることで、リポジトリを追加できます(クローンまたはローカル接続のいずれか)。
-
中央にはコミット入力領域があり、コミットメッセージを入力し、どのファイルを含めるかを選択できます。Windowsでは、コミット履歴はこのすぐ下に表示されます。macOSでは、別のタブにあります。
-
右側は差分ビューで、作業ディレクトリで変更された内容、または選択したコミットに含まれていた変更が表示されます。
-
最後に注目すべき点は、右上にある「同期」ボタンで、ネットワークとやり取りする主な方法です。
注記
|
これらのツールを使用するためにGitHubアカウントは必要ありません。GitHubのサービスと推奨されるワークフローを強調するように設計されていますが、任意のリポジトリで問題なく動作し、任意のGitホストでネットワーク操作を実行します。 |
インストール
WindowsおよびmacOS用GitHubはhttps://desktop.github.com/からダウンロードできます。アプリケーションを初めて実行すると、名前やメールアドレスの設定など、初回のGit設定に関するすべてのガイドが表示され、資格情報キャッシュやCRLF動作など、多くの一般的な構成オプションに対して適切なデフォルトが設定されます。
どちらも「常緑」です。アプリケーションが開いている間にバックグラウンドで更新がダウンロードおよびインストールされます。これにはGitのバインドバージョンも含まれているため、手動で更新する心配をする必要はほとんどありません。Windowsでは、クライアントにPosh-gitを使用するPowerShellを起動するためのショートカットが含まれています。これについては、この章の後半で詳しく説明します。
次のステップは、ツールに操作するリポジトリを提供することです。クライアントは、GitHubでアクセスできるリポジトリのリストを表示し、ワンステップでクローンを作成できます。ローカルリポジトリが既に存在する場合は、そのディレクトリをFinderまたはWindowsエクスプローラーからGitHubクライアントウィンドウにドラッグするだけで、左側のリポジトリリストに含まれます。
推奨ワークフロー
インストールと構成が完了したら、GitHubクライアントを使用して多くの一般的なGitタスクを実行できます。このツールの目的のワークフローは、「GitHubフロー」と呼ばれることがあります。GitHubフローで詳細に説明していますが、要約すると、(a)ブランチにコミットし、(b)リモートリポジトリと定期的に同期するというものです。
ブランチ管理は、2つのツールが異なる領域の1つです。macOSでは、ウィンドウの上部に新しいブランチを作成するためのボタンがあります。

Windowsでは、ブランチ切り替えウィジェットに新しいブランチの名前を入力して行います。

ブランチが作成されたら、新しいコミットを作成するのは非常に簡単です。作業ディレクトリでいくつかの変更を行い、GitHubクライアントウィンドウに切り替えると、変更されたファイルが表示されます。コミットメッセージを入力し、含めるファイルを選択して、「コミット」ボタン(ctrl-enterまたは⌘-enter)をクリックします。
ネットワーク経由で他のリポジトリとやり取りする主な方法は、「同期」機能です。Gitには内部的にプッシュ、フェッチ、マージ、リベースの個別の操作がありますが、GitHubクライアントはこれらをすべて1つの複数ステップ機能に統合しています。「同期」ボタンをクリックすると、次のことが行われます。
-
git pull --rebase
。マージの競合のために失敗した場合は、git pull --no-rebase
にフォールバックします。 -
.git push
これはこのスタイルで作業する場合に最も一般的なネットワークコマンドのシーケンスであるため、これらを1つのコマンドにまとめることで多くの時間を節約できます。
概要
これらのツールは、設計されたワークフローに非常に適しています。開発者と非開発者の両方が数分以内にプロジェクトで共同作業でき、この種のワークフローのベストプラクティスの多くがツールに組み込まれています。ただし、ワークフローが異なる場合、またはネットワーク操作の方法やタイミングをより詳細に制御したい場合は、別のクライアントまたはコマンドラインを使用することをお勧めします。
その他のGUI
他にも多くのグラフィカルなGitクライアントがあり、特殊な単一目的のツールから、Gitが実行できるすべての機能を公開しようとするアプリまで多岐にわたります。公式Git Webサイトには、最も人気のあるクライアントの厳選されたリストがhttps://git.dokyumento.jp/downloads/guisにあります。より包括的なリストは、Git Wikiサイトのhttps://archive.kernel.org/oldwiki/git.wiki.kernel.org/index.php/Interfaces,_frontends,_and_tools.html#Graphical_Interfacesにあります。