この記事のインストール方法や環境設定はWindowsユーザ向けです。Macユーザは各自、調べてください。(Windowよりかなり簡単にインストール・設定できます)
※各種設定等はオススメであり、各自で自由に変更してください。
##1. GitHubとは
GitHubとは、ソフトウェア開発プロジェクトのためのソースコード管理サービスです。
ソースコードを管理する時に、各プログラムが入ったディレクトリを更新するたびにコピーして、複数のディレクトリで管理している人がいるかもしれません。しかし、この方法では、以前のコードに戻ったり、差を比較するのが不便な時があります。(何よりダサいしスマートじゃない)
GitHubは公開されているソースコードの閲覧や簡単なバグ管理機能、SNSの機能を備えており、開発者にとって無くてはならないサービスです。
##2. インストール・環境設定
下記サイトからGit For WindowsのインストーラーをDLし、インストールします。
インストーラーをクリックしてインストールを開始します。
ライセンスを確認して「Next」をクリック
インストール先ディレクトリを確認されるので、Gitをクライアントとしてのみ使う場合にはできるだけこのままで進めます。
Additional IconsはBashを起動するためのショートカットをどこに置くかなので、好みでに決めて下さい。DesktopにBashのショートカットを置くかはお好みです。
Use a TrueType font in all console windowsにチェックを入れてしまうと、bash以外の全てのコンソールウインドウのフォントがLucida Consoleに変更されてしまい、漢字などの多バイト文字は文字化けしてしまうので、チェックを入れてはいけません。
スタートメニューを追加されるか確認されるので、通常はこのままNextをクリックして先に進めます。
通常は「Use Git from Windows Command Prompt」を選択して「Next」をクリックします。
レポジトリへのチェックイン、チェックアウト時の改行の取り扱いについてのオプションを選択します。
ここでは、Checkout as-is, commit as-isを選択して「Next」をクリックします。
次にGit出使用するコンソールをCygwinで使用されているPuttyを使用するか、Windowsの標準コンソールを使用するか選択します。特にこだわりが無ければMinttyを選択しておくのが無難です。
上のEnable file system cachingはPCのリソースは多少消費する代わりにgit status時などでの応答速度を改善するfscacheキャッシュを有効にするかしないかオプションです。マシンリソースに余裕のある人はチェックを入れましょう。またON/OFFは以下の要領で可能です。
git config --global core.fscache true
##3. 初期設定
####3-1. ユーザ情報の設定
Gitを使う前にユーザの情報をGitに設定しましょう。
コマンドプロンプトを立ち上げgitが正常にインストールされていることを確認します。
下記のコマンドを入力することで、gitにユーザ情報を設定します。プロジェクトで開発する際は必ず設定しておかないと、誰が更新したのかわからなくなります。
git config --global user.name "Kenta Okuda"
git config --global user.email "kenta.okuda@example.com"
1行目は名前を入力します。(ローマ字)
2行目には連絡先メールアドレスを入力します。(普段使うアドレスを入力するようにしましょう)
####3-2. エディタの設定
コミットログを記述するエディタを設定します。
git config --global core.editor 'vim -c "set fenc=utf-8"'
####3-3. カラーの設定
カラーを設定することでGitが見やすくなります。
git config --global color.diff auto
git config --global color.status auto
git config --global color.branch auto
####3-4. Gitの初期化
Gitを導入するディレクトリに移動して、下記のコマンドを入力することで対象ディレクトリに.gitディレクトリが生成され、Gitが使えるようになります。この.gitディレクトリに管理するリポジトリデータが格納されます。
git init
##4. Gitの基本操作
###4-1. add
add
は編集したファイルをステージ領域(インデックス)ステージングするためのコマンドです。
Gitでは基本的に、ファイルをステージ領域と呼ばれる場所にファイルを登録します。ステージ領域とは、コミットする前の一時領域のことを示します。
git add 'プッシュしたいファイル名'
ディレクトリに存在する全てのファイルをプッシュする場合は
git add .
**.(コロン)**をファイル名に指定することでディレクトリ内の全ファイルを示します。
###4-2. commit
add
によってステージングされたファイルをコミットという操作をすることで、リポジトリに記録されます。
コミットを実行すると、リポジトリの内では、前回コミットした時の状態から現在の状態までの差分を記録したコミット(またはリビジョン)と呼ばれるものが作成されます。
基本的にコミットは下記のコマンドで行います。
git commit -m "commit message"
コミットメッセージには好きなメッセージを書くことができますが、変更の内容が分かりやすいメッセージを付けるようにしましょう。
コミットメッセージに詳細を書きたい場合は、コミット時に-m
のコマンドを入力しないで、vimなどのエディタでコミットメッセージを書きます。コミットメッセージの基本的なフォーマットは以下の通りです。
git commit
//Enter
1行目:変更内容の要約(タイトル、概要)
2行目 :空行
3行目以降:変更した理由(内容、詳細)
日本語でも大丈夫ですが、リポジトリで統一するのがいいでしょう。
1行目のコミットの要約の前にコミット種別と呼ばれるものを書きます。これは、このコミットがどのような変更を加えたコミットなのかを把握するためのものです。
- add : ファイルの追加
- fix : バグ修正
- hotfix : クリティカル(致命的)なバグの修正
- update : 機能修正(バグではない)
- change : 仕様変更
- clean : 整理(リファクタリングなど)
- remove : ファイルの削除
- upgrade : バージョンアップ
例
[fix] Aボタンが反応しないバグを修正
コンポーネントの関連付けができていなかったのを修正
これらのadd
とcommit
はローカルリポジトリでバージョン管理をするときのコマンドです。これはGitHubを使わなくてもできます。次はローカルリポジトリをリモートリポジトリ(GitHub)にプッシュする方法です。
###4-3. pushコマンド
リモートリポジトリで自分の手元のローカルリポジトリの変更履歴を共有するには、ローカルリポジトリ内の変更履歴をアップロードする必要があります。
そのために、Gitではプッシュ(Push)という操作を行います。 Pushを実行すると、リモートリポジトリ(GitHub)に自分の変更履歴がアップロードされて、リモートリポジトリ内の変更履歴がローカルリポジトリの変更履歴と同じ状態になります。
リモートリポジトリにプッシュする前にリモートリポジトリに対してadd
を実行しファイルをステージングしなければなりません。リモートリポジトリへのaddは下記のコマンドで実行します。
git remote add origin https://github.com/'ユーザID'/'リポジトリ名'.git
リモートリポジトリにはorigin
という名前を付けるのが一般的です。
ステージングが終わったら、いよいよプッシュをします。プッシュのコマンドは以下の通りです。この際、GitHubのユーザ名やパスワードを聞かれることがありますので、登録通りに入力してください。
git push -u origin master
origin
という名のリモートリポジトリにmaster
ブランチの内容をプッシュします。ブランチについては後述しますが、ここではmaster
ブランチにしています。
これで、ローカルリポジトリの内容がリモートリポジトリにもコピーされました。
ちなみに、2回目以降のリモートリポジトリへのプッシュをする際
git add
git commit -m "コミットメッセージ"
git push origin 'ブランチ名'
の3つのコマンドだけで大丈夫です。
##5. クローン
既存のリモートリポジトリをローカルに落とすために使うコマンドです。
例えば、GitHubに公開されているリポジトリを自分のコンピュータへ落とすときに使います。
git clone https://github.com/'ユーザID リポジトリ名'.git 'クローン先のディレクトリ名'
##6. プル
最新のリモートリポジトリを取得するために使うコマンドです。
以下の例では、ローカルリポジトリのmasterブランチにリモートリポジトリoriginのmasterブランチを取り込みます。
git checkout master // masterブランチに移動
git pull origin master // masterブランチにリモートリポジトリのmasterブランチをマージ
##7. フォーク
##8. プルリクエスト
##9. ブランチ
ブランチは別々の作業を並行して行うために利用します。各ブランチはmasterブランチから分岐させ、それぞれのブランチでは、全く別の作業を同時に実施できます。それぞれのブランチでの作業が終了したら、masterブランチにマージします。
###9-1. ブランチの作成
ブランチは branch コマンドで作成することができます。
git branch <branchname>
引数を指定せずにbranchコマンドを実行すると、ブランチの一覧を表示することができます。頭に * のついているのが現在のブランチです。
git branch
issue1
* master
###9-2. ブランチの切り替え
新しく作成したissue1ブランチにコミットを追加していくには、issue1ブランチをチェックアウトする必要があります。
ブランチのチェックアウトはcheckoutコマンドで行います。
git checkout <branch>
※ checkoutコマンドに -b オプションを指定して実行すると、ブランチの作成とチェックアウトをまとめて行うことができます。
git checkout -b <branch>
###9-2. ブランチの削除
ブランチを削除するには、branchコマンドに -d オプションを指定して実行します。
git branch -d <branchname>
##10. マージ
現在のブランチに対して、他のブランチで行った変更を取り込むために使うコマンドです。
以下の例では、ブランチbug-fixをmasterブランチにマージします。
git checkout master // masterブランチに移動
git merge bug-fix // masterブランチにbug-fixブランチをマージ
##11. Issue
##12. その他のよく使うコマンド
###13. logコマンド
###14. statusコマンド