個人学習メモ。
1.Git for Windowsダウンロード
GUIよりCUIで使いたいのでGit for Windowsをダウンロードする。
64bitの最新版をダウンロードするにはここをクリック、をクリック(2022/02/26時点でVersion 2.35.1)
Git-2.35.1.2-64-bit.exe
がダウンロードされたら、実行。
2.Gitインストールウィザード
これ以降の設定項目はセットアップ後に設定ファイルから変更可能なので、間違えても大丈夫。
2-1.GNUライセンスについて
2-2.Gitインストールフォルダ設定
2-3.コンポーネントの選択
デスクトップにアイコンが欲しいので、Additional icons
にチェックしてNext。
2-4.スタートメニューフォルダの設定
2-5.デフォルトのエディタの選択
Gitで使うデフォルトのエディタを選べと言われている。
Vimは慣れてないと使うのが難しいよ、歴史的な理由でデフォルトのエディタはVimになってるけど、慣れてないならGUIを選択してね(意訳)
と注釈がある。プルダウンを展開すると以下のようになる。
ここで選択したエディタは後から設定ファイル (/etc/gitconfig もしくは ~/.gitconfig で後者が優先) から変更もできる。vimに慣れたい気持ちもあるし後から変更もできるので、デフォルトのままNext。
2-6.最初のメインブランチ名の設定
新しいローカルリポジトリの最初のブランチ名を設定する箇所で、デフォルトだとmaster
というブランチ名が使用される。大体本番環境のブランチ名でもmaster
を使うのでこのままNext。
2-7.環境変数の設定
環境変数の設定をする画面。デフォルトで選択されている「Git from the command line and also from 3rd-party software」は他のコマンドラインツールでgitコマンドを使用できるようにするために必要な最小限の環境変数を設定するよ
と注釈がついている。デフォルトのままNext。
2-8.SSH実行可能ファイル
Gitに付属のssh.exeを使用するか、外部のssh.exeを使用するか選択する。Gitに付属のssh.exeを使用するでいいので、デフォルトのままNext。
2-8.HTTPS接続に使用するSSLライブラリの選択
Git for Windows (の中のMSYS2) に含まれるOpenSSLライブラリを利用する(ルート証明書は「C:/Program Files/Git/mingw64/ssl/certs/ca-bundle.crt)か、Windows標準のSSLライブラリが利用する(ルート証明書は「certmgr.msc」に入っている)か選択する。あとから変更したくなったら/etc/gitconfig
(C:\Program Files\Git\etc\gitconfig
) を編集すればよいので、デフォルト「Use the OpenSSL library」のままNext。
2-9.改行コードの設定
改行コードの変換に関する設定。
Windowsは他のOSと異なる改行コード(CRLF)が使用されているため、他のOSとファイルを共有した場合に改行コードの違いが影響する場合がある。
デフォルトで選択されている「Checkout Windows-style, commit Unix-style line endings」はファイルをWindowsに取り込む(チェックアウトする)ときはWindows用(改行コード(CRLF))に変換し、ファイルをバージョンに追加(コミット)するときはUnix用(改行コード(LF))に自動変換する
と説明がある。これがWindows推奨設定で、このままNext。
2-10.Git Bashのターミナルの選択
Git Bashで使用するターミナルエミュレータを選択する。
Git BashはGitと一緒にインストールされるコマンドラインツールで、Unix系シェルであるBashを搭載しているためUnix系のコマンドが使用できる。
この設定では、Git Bashを開く時に「MinTTY」か「コマンドプロンプト」のどちらを使用するかを選択する。
Minttyはコマンドプロンプトに比べて高機能であるため今回はこのままNext。
※MinTTYでは一部のプログラム(インタラクティブなやり取りのあるプログラム)が正常に動作しないことがあり、その場合は、winpty
コマンドを頭に付けてを実行するか、Git CMDで実行すればよい。
2-11.git pull実行時の挙動設定
git pull
コマンドを実行した時の動作について設定する。
デフォルトの「Default (fast-forward or merge)」のままNext。
※fetch、merge、fast-forward、rebaseの概念を理解してからでないと理解できないので、いったんデフォルトで進める。1
2-12.認証情報ヘルパーの設定
ローカルリポジトリからGitHubなどのリモートリポジトリに接続する際の認証方法を設定する。
Git Credential Manager(GCM)はこの認証をサポートするもので、ローカルリポジトリからGitHubなどのリモートリポジトリに接続する際に手動での認証を毎回登録すことなく、安全にクレデンシャル情報を管理してくれるもの。もちろん後から設定変更もできるのでこのままNext。2
2-13.その他オプション設定
その他のオプション設定。
デフォルトでチェックがついている「Enable file system caching」はファイルの変更情報などをメモリにキャッシュする。
「Enable symbolic links」はシンボリックリンク(別の場所のファイルの場所情報を持つファイル)を有効化する。デフォルトのままNext。
2-14.実験的オプション設定
実験的オプション機能の有効か設定。何も選択せずこのままInstall。
インストールが開始される。
数秒で終了。
Git Bashを起動する、リリースノートを見る、というチェックボックスがあるが、今回はチェックはせずにFinish。
これでGit for Windowsのインストールが完了。
3.Gitコマンド試行
Git Bashを開いて、Gitコマンドが使えるか試してみる。
スタートメニューもしくはデスクトップのGit BashアイコンをクリックしてGit Bashを立ち上げる。
次のコマンドを実行して、Gitのバージョン確認コマンドを実行してみる。
git --version
バージョンが確認できたらOK。
exit
コマンドでGit Bashを閉じる。
4.ここまでの個人的つまずきポイント
- インストールウィザードが長い
- 全部英語で解読に苦労
- 英語が解読できてもGitに関する動きや用語について詳しくないので挙動のイメージがつかない
- なるべく調べたり注釈をつけたりした
参考
Windows10でGitHubを始める~⓪Gitの概念とインストールソフトの種類
Windows10でGitHubを始める~①Gitインストール
Windows10でGitHubを始める~①'おまけGitホームディレクトリ変更
Windows10でGitHubを始める~②GitHubアカウント作成
Windows10でGitHubを始める~③GitHubでのメールアドレス設定とGitクライアントでのユーザ名・メールアドレス設定
Windows10でGitHubを始める~③'おまけユーザ名・メールアドレス設定について詳細
Windows10でGitHubを始める~④リモートリポジトリの作成(GitHub)
Windows10でGitHubを始める~⑤Githubにプッシュする
Windows10でGitHubを始める~⑥-0.Git~GitHub間の認証について
Windows10でGitHubを始める~⑥-1.Git操作時のGitHub認証HTTPS(Git Credential Manager)
Windows10でGitHubを始める~⑥-2.Git操作時のGitHub認証HTTPS(Personal access token)
Windows10でGitHubを始める~⑥-3.Git操作時のGitHub認証SSH編
Windows10でGitHubを始める~⑦GitHubへのPullRequest
詳しくてありがたい↓
-
Default(fast-forward or merge)
デフォルト(fast-forward または merge)
This is the standard behavior ofgit pull
:fast-forward the current branch to the fetched branch when possible, otherwise create a merge commit.
これはgit pull
の標準的な動作です。可能な場合は現在のブランチをフェッチされたブランチにfast-forwardします。それ以外の場合は、マージコミットを作成します。
Rebase
リベース
Rebase the current branch onto the fetched branch. If there are no local commits to rebase, this is equivalent to a fast-forward.
現在のブランチをフェッチされたブランチにRebaseします。 Rebaseするローカルコミットがない場合、これはfast-forwardと同等です。
Only ever fast-forward
fast-forwardのみ
Fast-forward to the fetched branch. Fail if that is not possible.
フェッチされたブランチにfast-forwardします。 それが不可能な場合は失敗します。 ↩ -
別の記事で執筆予定。 ↩