95
108

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

TigがWindowsにやってきたのでチュートリアルをまとめる

Last updated at Posted at 2018-05-19

はじめに

今年の新入社員向けの研修でGitの担当になったのですが,研修で使う環境をどうするかで迷っていました.Git本来の基本を押さえやすいように通常のCLIでGitを教えるか,とっつきやすいように何らかのGUIツールでGitを教えるか悩ましいところです.ちなみに研修自体はWindowsで行いますが,業務ではLinuxデスクトップ環境で開発しているグループもあるので,どちらでも使えるつぶしのきく環境がベストです。

そんな中ネットをあさっていると**「Git for WindowsにTigが組み込まれたよ!」**との情報を見つけました.
Release Git for Windows 2.14.2 · git-for-windows/git

そこで今回はWindowsでもLinuxでも使えて,コミットツリーやDiff等の情報も見やすく,本来のGitコマンドともあわせて使いやすいCUIツールであるTigを採用しました.

Tigについて基本的な操作を一通りまとめていきます.
以降は[Emacs] magitチュートリアル - Qiitaの内容を参考にして,magitでの操作をTigに置き換えたものになります.

Tigとは

CUIのGitクライアントツールです.特徴として以下のようなものがあげられます.

  • コミット履歴がツリー構造で確認しやすいです.
  • ツリーからファイルの差分も表示できます.
  • 情報表示だけでなく,add や commitなどの操作にも対応しています.
  • Tig上で外部のコマンドの実行ができ,それにキーバインドを設定することもできます.
image.png

インストール

Windowsの場合は「Git for Windows」に同梱されています.インストーラをダウンロードしてインストールしてください.(Git for Windows 2.14.2以降のバージョンに組み込まれています.)
Git for Windows

Linuxの場合はパッケージマネージャからインストールしてください.以下はDebianの場合です.

$ sudo apt install tig

以降の内容はWindows環境でGit Bash上で動作を確認しながらまとめています.

  • Windows 10 Pro
  • git version 2.16.2.windows.1
  • tig version 2.3.3

リポジトリ作成

Tigは基本的にGitのリポジトリに移動してから立ち上げて使います.そこでまずGit Bashからリポジトリを作成します.ここではリポジトリの初期化を行ったあとに,foo.txtファイルを作成して初回コミットを行っています.

$ mkdir tig_tut
$ cd tig_tut/
$ git init
$ touch foo.txt
$ git add foo.txt
$ git commit -m "初回コミット"

Tigへの入り口

GitリポジトリができたらtigコマンドでTigを起動します.対象のディレクトリに移動して操作してください.(上記からの流れだとそのままの場所でOKです.)

$ tig

Tigが立ち上がるとまずは「main view」が立ち上がってコミットツリーが表示されます.ここがTigへの入り口となります.

image.png

また,デフォルトでは「main view」にはチェックアウトしているブランチのみを表示しますが,--allオプションを指定すると全てのブランチが表示されます.

$ tig --all

Tigを終了する場合はQキーを押します.また後述するようにTigでは様々なViewを表示することができますが,そのViewを閉じる(前のViewに戻る)にはqキーを押します.

hから始める

hキーを押すとショートカット一覧が表示されます.「迷ったらまずh」を覚えておくとよいです。

image.png

コミットしてみる

foo.txtを開いて以下の編集を行います.

foo.txt
A

保存した後にsキーで「status view」を表示します.そこからカーソルを移動してfoo.txtを選択しEnterキーで「diff view」が表示されます.

image.png

この状態でのカーソル移動まわりのキーバインドは以下のようになっています.ちなみに画面が1画面表示の場合はどちらのキーでもカーソル移動できます.

Key 内容
Ctrl + n 画面左側のstatus viewのカーソルを下方向に移動
Ctrl + p 画面左側のstatus viewのカーソルを上方向に移動
j 画面右側のdiff viewのカーソルを下方向に移動
k 画面右側のdiff viewのカーソルを上方向に移動

「status view」でfoo.txtを選択しuキーでstagingされます.取り消す場合はもう一度uキーです.

image.png

stagingした状態からCキーでコミットメッセージを入力するためのエディタが起動します.

image.png

コミットメッセージの入力後Enterキーでコミットが完了します.

コミットログを見る

mキーで「main view」を表示すると先ほどのコミットログが確認できるはずです.コミットを選択してEnterキー押すと「diff view」が表示されます.

image.png

この状態でのカーソル移動まわりのキーバインドはコミット時のものと同じです.「main view」でのカーソルを移動すると「diff view」の表示も追従して更新されます.

Key 内容
Ctrl + n 画面左側のmain viewのカーソルを下方向に移動
Ctrl + p 画面左側のmain viewのカーソルを上方向に移動
j 画面右側のdiff viewのカーソルを下方向に移動
k 画面右側のdiff viewのカーソルを上方向に移動

ブランチを作成する

現在のmasterからブランチを作成してみます.ですがTigにはブランチを作成する機能は標準で用意されていないようです.そこでブランチの作成は通常のgitコマンドを使用します.ただしTig上から外部のコマンドの実行が可能なのでターミナルを切り替える必要はありません.:キーを押すと画面下部でコマンドを受け付けてくれます.:!<command>の形式でコマンドを実行します.

:!git checkout -b <作成するブランチ名>
image.png

rキーで「refs view」を表示すると作成したブランチが確認できます.新しいブランチが表示されない場合はRキーで画面を更新してください.ここではnew-branchブランチを作成しています.

image.png

また.tigrcファイルに,上記のような操作に対してキーバインドを設定することができます.例えば以下のように設定すると「refs view」上で作成元となるブランチを選択している状態でnキーを押して新しいブランチ名を入力すると,その場所にブランチが作成されます.?git checkoutとすることで実行前に確認メッセージを出すようにしています.
.tigrcの置き場はWindowsの場合は%USERPROFILE%,Linuxの場合は$HOMEになります.ファイルを作成した後にTigを再起動して設定を反映させてください.

.tigrc
bind refs n ?git checkout -b "%(prompt Enter new branch name: )" %(branch)

ブランチをマージする

前準備として作成したブランチ上でコミットを行います.ここでは2件コミットしています.

  1. foo.txtにBを追記(add B)
  2. foo.txtにCを追記(add C)

mキーで「main view」を表示すると以下のようになっています.

image.png

この状態からmasterにnew-branchの内容をマージします.

まずはmasterに切り替えます.(チェックアウトします.)
rキーで「refs view」を表示して,masterを選択した状態でCキーを押してチェックアウトします.(本当に切り替えるかY/Nで聞かれるのでyキーを押します.)

切り替えに成功すると「refs view」でmasterが一番上に来ているはずです.(masterがチェックアウトされた状態です.)

image.png

マージ機能も標準では用意されていません.:キーから下記のコマンドを入力してマージします.

:!git merge new-branch

.tigrcに登録する場合は下記のようにするとよいです.「refs view」でMキーを押すと現在のブランチにカーソルが当たっているブランチをマージします.

.tigrc
bind refs M ?git merge %(branch)

コンフリクト等が起きなければこれでマージが完了します.mキーで「main view」を見るとマージできていることがわかります.

image.png

不要ブランチの削除

マージして不要になったnew-branchブランチの削除を行います.まずrキーで「refs view」を表示して削除するブランチを選択します.

image.png

その状態で!キーを押すと本当に削除するかY/Nで聞かれるので,yキーを押して削除します.また現在チェックアウトしているブランチの削除はできません.その場合はあらかじめCキーで別ブランチをチェックアウトしておく必要があります.

new-branchを削除すると「main view」と「refs view」の表示は以下のようになります.更新されない場合はRキーを押して表示の更新を行ってください.

main view
image.png

refs view
image.png

プッシュする

ここまでの作業をリモートのリポジトリにプッシュしてみます.今回はGitHubにtig_tutリポジトリを作成したものとして話を進めます.またSSH keyの登録なども事前に完了しているものとします.リモートの追加は:キーからGitのコマンドを使って行います.ちなみにoriginとは慣習的に使用されるリモートのデフォルトの名前です.

:!git remote add origin git@github.com:<アカウント名>/tig_tut.git

プッシュ機能も標準では用意されていません.:キーから下記のコマンドを入力してプッシュします.

:!git push -u origin master

また.tigrcに登録する例も載せておきます.rキーで「refs view」を表示して,Pキーを押すとカーソルが当たっているブランチをoriginにプッシュします.

.tigrc
bind refs P ?git push -u origin %(branch)

プッシュに成功すると,rキーの「refs view」にorigin/masterが追加されています.

image.png

mキーの「main view」でもorigin/masterが確認できます.

image.png

ログからのブランチ作成

「main view」のツリーの任意のコミットにブランチを作成します.そのための前準備としてコミットIDが表示されるように設定します.

.tigrc
set main-view = id date author commit-title:graph=yes,refs=yes

各コミットの左にコミットIDが表示されるようになります.

image.png

:キーから下記のコマンドを入力して任意の場所に新しいブランチを作成できます.

:!git checkout -b <作成するブランチ名> <ブランチを作成する場所のID>

また「main view」で選択している行のコミットIDをクリップボードにコピーするキーバインドの設定例を載せておきます.xキーに割り当ててあります.

.tigrc
bind main x @bash -c "echo -n '%(commit)' | clip"

下図ではnew-branch-2ブランチを133f12dに作成しています.表示されない場合はRキーを押して表示の更新を行ってください.

image.png

マージコンフリクトに対処する

new-branch-2ブランチでfoo.txtの内容を更新してコミットします.この編集内容が「add C」コミットとコンフリクトします.

foo.txt
A
B
D

mキーから「main view」を表示すると,以下のようになっているはずです.

image.png

masterに戻ってnew-branch-2ブランチをマージしてみます.
rキーで「refs view」を表示して,masterを選択した状態でCキーを押してチェックアウトします.
チェックアウトに成功すると「refs view」でmasterが一番上に来ているはずです.(masterがチェックアウトされた状態です.)

image.png

ここから,前回と同様に:キーから下記のコマンドを入力するか,「refs view」でnew-branch-2ブランチを選択し,登録したキーバインドであるMキーを押します.

:!git merge new-branch-2

するとコンフリクトしたとのメッセージが表示されます.

image.png

Enterキーを押してTigに戻り,sキーで「status view」を表示するとfoo.txtファイルにUの目印がついておりマージが完了していない状態です.foo.txtファイルを選択した状態でEnterキーを押すと「diff view」が表示されコンフリクトしている様子が見えます.

image.png

foo.txtファイルを選択した状態でMキーを押すとマージツールが起動します.またはeキーを押すとエディタが立ち上がります.お好みのほうを立ち上げて手動で修正を行いコンフリクトを解消します.

今回は以下のように修正します.

image.png  ↓ image.png

修正後「status view」に戻ってfoo.txtファイルを選択しuキーでstagingします.

image.png

stagingした状態からCキーでコミットを行います.

image.png

mキーから「main view」を表示するとマージされていることが確認できます.

image.png

編集の一部をコミット

masterで作業を続けます.foo.txtの内容を下記のように更新します.

foo.txt
A
HOGE
PIYO
B
C
D
E

sキーで「status view」を表示します.foo.txtを選択してEnterキーを押して「diff view」を表示します.

image.png

「diff view」でコミットしたい行(今回は+E)を選択した状態で1キーを押すとその行のみがstagingされます.

image.png

この状態でCキーでコミットすると「E」の追加だけをコミットすることができます.

image.png

不要な編集を戻す

先ほどコミットしなかった編集を削除します.sキーで「status view」を表示し,foo.txtを選択してEnterキーを押して「diff view」を表示します.コミットしなかった「HOGE」と「PIYO」が残っています.

image.png

この状態で!キーを押すと本当に破棄するかY/Nで聞かれるので,yキーを押して変更を戻します.
sキーで「status view」を表示すると,編集内容が破棄されています.

image.png

ここまでをプッシュ

ここまでの状態を前回と同様の手順でプッシュしておきます..tigrcにキーバインドを登録していれば,rキーで「refs view」を表示して,Pキーを押すとカーソルが当たっているブランチをoriginにプッシュします.

image.png

フェッチ・プルする

前準備としてGitHub側でファイルの編集を行います.GitHubでfoo.txtを表示して鉛筆マークから編集画面を開いて,最終行にFを追加します.

image.png

フェッチ機能はTigには標準では用意されていません.:キーから下記のコマンドを入力してフェッチします.

!git fetch

.tigrcに登録する場合は下記のようにするとよいです.「main view」でFキーを押すとフェッチします.

.tigrc
bind generic F none
bind main F ?git fetch

GitHubでの変更が取り込まれています.この時点ではローカルのmasterブランチには反映されていません.

image.png

プル機能もTigには標準では用意されていません.:キーから下記のコマンドを入力してプルします.

!git pull origin master

.tigrcに登録する場合は下記のようにするとよいです.「refs view」で対象のブランチを選択した状態でLキーを押すとプルします.

.tigrc
bind refs L ?git pull origin %(branch)

GitHubでの変更がローカルのmasterに取り込まれました.

image.png

今回はフェッチしてプルという流れでしたが,フェッチせずいきなりプルしても問題ありません.

おまけ

ここまでの手順で出てこなかったものについて付け加えておきます.

クローンする

今回の説明ではローカルで作成したリポジトリをリモートのGitHubにプッシュする流れでしたが,すでにリモートに存在しているリポジトリをローカルにクローンすることもできます.

$ git clone git@github.com:<アカウント名>/tig_tut.git

ツリービューを見る

tキーで「tree view」を表示することができます.「main view」から移動する場合は,選択しているコミット時点のディレクトリ・ファイルの一覧が表示されます.

image.png

「tree view」でファイルを選択している状態からeキーを押すとテキストエディタでファイルを開くことができます.

各行ごとの変更履歴を見る

tキーの「tree view」でファイルを選択している状態からbキーを押すと「blame view」が表示されます.ファイルの各行ごとのコミット履歴を確認することができます.

image.png

スタッシュする

作業中のファイルの編集を,いったん退避しておきたいときにスタッシュが便利です.
foo.txtの内容を下記のように「G」を追加して更新します.

foo.txt
A
B
C
D
E
F
G

スタッシュする機能は標準では用意されていません.:キーから下記のコマンドを入力してスタッシュします.

:!git stash save <スタッシュコメント>

.tigrcに登録する場合は下記のようにするとよいです.「main view」でSキーを押すと現在の作業中の内容がスタッシュされます.

.tigrc
bind main S ?git stash save "%(prompt Enter stash comment: )"
image.png

「status view」を確認すると編集途中のファイルがなくなっています.

image.png

スタッシュされている中身はyキーから「stash view」を表示して確認することができます.

image.png

「stash view」からは以下の操作が標準で用意されています.

Key 内容
A 選択しているスタッシュを適用します.(git stash apply)
P 選択しているスタッシュを適用して削除します.(git stash pop)
! 選択しているスタッシュを削除します.(git stash drop)

直前のコミットを取り消す

コミットを取り消す系の操作はいろいろとありますが,ここでは直前のコミットIDに対してgit resetすることで,最新のコミットを取り消す方法を例にあげます.
以下の.tigrcの設定は,ファイルの編集などはそのままでstagingされたプッシュする直前の状態に戻すキーバインドを「main view」に!キーで割り当てています.

.tigrc
bind main ! ?git reset --soft HEAD^

Gitの管理から特定のファイルを除外する

除外設定を行いたいディレクトリ(トップでもOK)に.gitignoreという名前でファイルを作成し,除外したいファイルの情報を記述しておくと,Gitの管理対象から外れます.
.gitignore自体をコミットしておくと,複数人で開発をするときに同じ除外ルールでGit管理をすることができます.
設定パターンの一例を下記に載せておきます.

.gitignore
# 拡張子が.exeのファイルを除外する
*.exe
# Bin/binディレクトリとその中身を除外する
[Bb]in/
# 特定のディレクトリの中の特定の拡張子のファイルを除外する
out/*.log

Tigのカスタマイズ

ここまでの説明で出てきた.tigrcの設定内容についてまとめておきます.

.tigrc
bind generic F none
bind main F ?git fetch
bind main S ?git stash save "%(prompt Enter stash comment: )"
bind main ! ?git reset --soft HEAD^
bind main x @bash -c "echo -n '%(commit)' | clip"
bind refs n ?git checkout -b "%(prompt Enter new branch name: )" %(branch)
bind refs M ?git merge %(branch)
bind refs P ?git push -u origin %(branch)
bind refs L ?git pull origin %(branch)
set main-view = id date author commit-title:graph=yes,refs=yes

おわりに

Git(Tig)を使いながら開発を進めるにあたって,必要最小限の操作は説明できたと思います.また.tigrcをカスタマイズすることでさらに便利に使っていけるようになると思うので,ぜひ使いこなしていってほしいです.

95
108
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
95
108

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?