Git
目次 ▾ 第2版

A1.1 付録A: その他の環境におけるGit - グラフィカルインターフェース

本書全体を読み終えたあなたは、コマンドラインでGitを使用する方法について多くのことを学びました。ローカルファイルの操作、ネットワークを介した他のリポジトリとの接続、そして他のユーザーとの効果的な共同作業を行うことができます。しかし、話はここで終わりではありません。Gitは通常、より大きなエコシステムの一部として使用され、ターミナルが常に最良の作業方法とは限りません。ここでは、Gitが役立つ可能性のあるその他の環境の種類と、他のアプリケーション(あなた自身のアプリケーションを含む)がGitとどのように連携するかを見ていきます。

グラフィカルインターフェース

Gitのネイティブ環境はターミナルです。新しい機能は最初にそこに表示され、コマンドラインでのみGitの全機能を完全に利用できます。しかし、プレーンテキストがすべてのタスクに最適な選択肢とは限りません。場合によっては、視覚的な表現が必要であり、一部のユーザーはポイントアンドクリックインターフェースの方がはるかに快適です。

さまざまなインターフェースは、さまざまなワークフローに合わせて調整されていることに注意することが重要です。一部のクライアントは、著者が効果的と考える特定の作業方法をサポートするために、Git機能の厳選されたサブセットのみを公開します。このように見ると、これらのツールのいずれも他のツールよりも「優れている」とは言えず、単に目的の用途に適しているだけです。また、これらのグラフィカルクライアントができることは、コマンドラインクライアントでもすべて行うことができることに注意してください。リポジトリを操作する際には、コマンドラインの方が依然として最も強力で制御力があります。

gitkgit-gui

Gitをインストールすると、そのビジュアルツールであるgitkgit-guiも入手できます。

gitkは、グラフィカルな履歴ビューアーです。git loggit grepの上にある強力なGUIシェルと考えてください。これは、過去に発生した何かを見つけたり、プロジェクトの履歴を視覚化しようとしたりする場合に使用するツールです。

Gitkはコマンドラインから起動するのが最も簡単です。Gitリポジトリにcdして、以下を入力します。

$ gitk [git log options]

Gitkは多くのコマンドラインオプションを受け付けますが、そのほとんどは基礎となるgit logアクションに渡されます。おそらく最も便利なものの1つは--allフラグで、これによりgitkはHEADだけでなく、任意の参照から到達可能なコミットを表示します。Gitkのインターフェースは以下のようになります。

The `gitk` history viewer
図177. gitk履歴ビューア

上部にはgit log --graphの出力を少し想起させるものがあります。各点はコミットを表し、線は親の関係を表し、参照は色付きのボックスで表示されます。黄色の点はHEADを表し、赤色の点はコミットになる前の変更を表します。下部には選択されたコミットのビューが表示され、左側にコメントとパッチ、右側にサマリービューが表示されます。その間には、履歴を検索するためのコントロールのコレクションがあります。

一方、git-guiは主にコミットを作成するためのツールです。これもコマンドラインから起動するのが最も簡単です。

$ git gui

そして、それはこのような見た目です。

The `git-gui` commit tool
図178. git-guiコミットツール

左側はインデックスです。ステージングされていない変更は上に、ステージングされた変更は下にあります。アイコンをクリックすることでファイル全体を2つの状態間で移動したり、ファイル名をクリックすることでファイルを選択して表示したりできます。

右上には差分ビューがあり、現在選択されているファイルの変更が表示されます。この領域で右クリックすることで、個々のハンク(または個々の行)をステージングできます。

右下にはメッセージとアクションの領域があります。テキストボックスにメッセージを入力し、「コミット」をクリックすると、git commitと同様の操作が行われます。「修正」ラジオボタンを選択すると、直前のコミットを修正することもできます。これにより、「ステージング済み変更」領域に直前のコミットの内容が更新されます。その後、いくつかの変更をステージングまたはアンステージングし、コミットメッセージを変更して、「コミット」をもう一度クリックすると、古いコミットが新しいコミットで置き換えられます。

gitkgit-guiは、タスク指向ツールの例です。それぞれ特定の目的(履歴の表示とコミットの作成)に合わせて調整されており、そのタスクに不要な機能は省略されています。

macOSおよびWindows用GitHub

GitHubは、2つのワークフロー指向のGitクライアントを作成しました。1つはWindows用、もう1つはmacOS用です。これらのクライアントは、ワークフロー指向ツールの良い例です。Gitのすべての機能を公開するのではなく、連携して動作する一般的に使用される機能の厳選されたセットに焦点を当てています。それらの見た目は以下のようになります。

GitHub for macOS
図179. macOS用GitHub
GitHub for Windows
図180. Windows用GitHub

これらは非常に似たように見えるように設計されているため、この章では単一の製品として扱います。これらのツールの詳細な説明は行いません(独自のドキュメントがあります)。ただし、「変更」ビュー(大部分の時間を費やす場所)の簡単なツアーは必要です。

  • 左側は、クライアントが追跡しているリポジトリのリストです。この領域の上部にある「+」アイコンをクリックすることで、リポジトリを追加できます(クローンまたはローカル接続のいずれか)。

  • 中央にはコミット入力領域があり、コミットメッセージを入力し、どのファイルを含めるかを選択できます。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では、ウィンドウの上部に新しいブランチを作成するためのボタンがあります。

“Create Branch” button on macOS
図181. macOSの「ブランチの作成」ボタン

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

Creating a branch on Windows
図182. Windowsでのブランチの作成

ブランチが作成されたら、新しいコミットを作成するのは非常に簡単です。作業ディレクトリでいくつかの変更を行い、GitHubクライアントウィンドウに切り替えると、変更されたファイルが表示されます。コミットメッセージを入力し、含めるファイルを選択して、「コミット」ボタン(ctrl-enterまたは⌘-enter)をクリックします。

ネットワーク経由で他のリポジトリとやり取りする主な方法は、「同期」機能です。Gitには内部的にプッシュ、フェッチ、マージ、リベースの個別の操作がありますが、GitHubクライアントはこれらをすべて1つの複数ステップ機能に統合しています。「同期」ボタンをクリックすると、次のことが行われます。

  1. git pull --rebase。マージの競合のために失敗した場合は、git pull --no-rebaseにフォールバックします。

  2. 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にあります。

scroll-to-top