章 ▾ 第2版

2.1 Gitの基本 - Gitリポジトリの取得

Gitを始めるにあたって、もし1つの章しか読めないとしたら、この章がそれです。この章では、Gitで最終的に行うことのほとんどをこなすために必要なすべての基本的なコマンドについて説明します。この章の終わりには、リポジトリの設定と初期化、ファイルの追跡の開始と停止、変更のステージングとコミットができるようになるはずです。また、特定のファイルやファイルパターンを無視するようにGitを設定する方法、誤りをすばやく簡単に元に戻す方法、プロジェクトの履歴を閲覧しコミット間の変更を表示する方法、リモートリポジトリからのプッシュとプルを行う方法も紹介します。

Gitリポジトリの取得

Gitリポジトリを取得する方法は、通常、以下の2つです。

  1. 現在バージョン管理されていないローカルディレクトリをGitリポジトリに変換するか、

  2. 他の場所にある既存のGitリポジトリをクローンすることができます。

どちらの場合でも、作業準備が整ったGitリポジトリがローカルマシンに作成されます。

既存のディレクトリでのリポジトリの初期化

現在バージョン管理されていないプロジェクトディレクトリがあり、Gitで管理を開始したい場合は、まずそのプロジェクトのディレクトリに移動する必要があります。これまでにこの操作を行ったことがない場合、実行しているシステムによって少し見た目が異なります。

Linuxの場合

$ cd /home/user/my_project

macOSの場合

$ cd /Users/user/my_project

Windowsの場合

$ cd C:/Users/user/my_project

と入力します。

$ git init

これにより、必要なすべてのリポジトリファイル(Gitリポジトリのスケルトン)を含む.gitという名前の新しいサブディレクトリが作成されます。この時点では、プロジェクト内の何もまだ追跡されていません。作成したばかりの.gitディレクトリにどのようなファイルが正確に含まれているかについての詳細は、Gitの内部構造を参照してください。

既存のファイル(空のディレクトリではなく)のバージョン管理を開始したい場合は、それらのファイルの追跡を開始し、最初のコミットを行うべきです。これには、追跡したいファイルを指定するいくつかのgit addコマンドの後に、git commitを実行することで達成できます。

$ git add *.c
$ git add LICENSE
$ git commit -m 'Initial project version'

これらのコマンドが何をするのかはすぐに説明します。この時点で、追跡されたファイルと最初のコミットを含むGitリポジトリができました。

既存リポジトリのクローン

既存のGitリポジリのコピーを取得したい場合(例えば、貢献したいプロジェクトなど)、必要なコマンドはgit cloneです。Subversionのような他のVCSに慣れているなら、このコマンドが「checkout」ではなく「clone」であることに気づくでしょう。これは重要な違いです。作業コピーだけを取得するのではなく、Gitはサーバーが持つほぼすべてのデータの完全なコピーを受け取ります。git cloneを実行すると、プロジェクトの履歴におけるすべてのファイルのすべてのバージョンがデフォルトでダウンロードされます。実際、サーバーのディスクが破損した場合でも、クライアント上のほぼすべてのクローンを使用して、サーバーをクローン作成時の状態に戻すことができます(サーバー側のフックなどが失われる可能性はありますが、すべてのバージョン管理されたデータはそこにあります — 詳細についてはサーバーにGitを導入するを参照してください)。

リポジトリはgit clone <url>でクローンします。例えば、libgit2というGitのリンカブルライブラリをクローンしたい場合は、次のように実行します。

$ git clone https://github.com/libgit2/libgit2

これにより、libgit2という名前のディレクトリが作成され、その中に.gitディレクトリが初期化され、そのリポジトリのすべてのデータがダウンロードされ、最新バージョンの作業コピーがチェックアウトされます。作成された新しいlibgit2ディレクトリに入ると、そこにプロジェクトファイルがあり、作業や使用の準備ができています。

リポジトリをlibgit2以外の名前のディレクトリにクローンしたい場合は、新しいディレクトリ名を追加の引数として指定できます。

$ git clone https://github.com/libgit2/libgit2 mylibgit

このコマンドは前のコマンドと同じことを行いますが、ターゲットディレクトリはmylibgitという名前になります。

Gitには、いくつかの異なる転送プロトコルがあります。前の例ではhttps://プロトコルを使用しましたが、git://や、SSH転送プロトコルを使用するuser@server:path/to/repo.gitを目にすることもあるでしょう。サーバーにGitを導入するでは、サーバーがGitリポジトリにアクセスするために設定できるすべての利用可能なオプションと、それぞれの長所と短所を紹介します。

scroll-to-top