1
1

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 1 year has passed since last update.

【Git初心者向け】今更ながらGitをフレンチコースに見立てて解説してみた

Last updated at Posted at 2023-04-23

概要

嫁さん(初心者)にお酒を飲みながらGitを教えてたらこれってフレンチのコース料理に例えられるのでは!?と閃いたので作ってみました。
初学者の方にGitを難しいものと思わず、何か掴めるきっかけになれるよう解説していきます。

おことわり

  • ブランチの運用については明記しません。
  • mainブランチと作業ブランチのみで構成されているとします。
  • すでにリポジトリがある状態からの話です(リポジトリ作成には踏み込みません)。
  • 頭の中でのイメージ重視ですのでXXXについての記述が抜けてる!とかありますが必要があれば自分で付け加えて覚えてください。

概念的にコマンドの意味を知れますが、実際の現場では運用方法等が違うかもしれませんので詳しくは先輩に聞いてください。。。

前提条件

あらすじ

料理 シェフである私が新作コース「季節のお楽しみディナー」を考案中。
Git コーダーの私があるサイトに「お問い合わせフォーム」を追加したい。
料理 オーナーに試食してもらい合格が出たらお店に並べたいと思っています。
Git 先輩にプルリクエストを出し問題がなければ本番環境にリリースしたいと思っています。

レストラン

お品書き

# 季節のお楽しみディナー
オードブル
スープ
ポワソン
ソルベ
アントレ
デセール
カフェ・ブティフール

店内の図

79027724-8F50-499C-8E39-BD519106277C.png

1. 料理検討会を開く

新しいコースメニューをお店に並べる前に並べて良いかオーナーに確認が必要です。

料理 料理検討会を開きましょう。
Git 作業用のブランチを切りましょう。
git checkout -b <ブランチ名>
実際の流れ(開く)

ブランチを切るもとのブランチに今自分がいるか確認。
(main からブランチを切りたいとする)

$ git branch
* main

ブランチを切ります。
ブランチを切ると自動的にそのブランチに移ります。

$ git checkout -b seasonal_delight_dinner/20230412
Switched to a new branch 'seasonal_delight_dinner/20230412'

正しいブランチに移れたか念の為確認します。

$ git branch
  main
* seasonal_delight_dinner/20230412

ブランチ = 料理検討会

2.料理を作る

料理 厨房の中で料理を模索。
Git (Gitで管理している)ディレクトリでコードを書く。

詳しくみると、厨房(PC)には厨房台(ディレクトリ)があって、そこに食材(ファイル)が並んでいます。
その食材を調理(変更・コーディング)してお皿に盛り付けることで料理が完成すると考えます。
(混ぜるだけで料理はできないよ!という批判は無しで。。。)

変更(コーディング) = 調理
PC = 厨房
ディレクトリ = 厨房台
ファイル = 食材

3. いざ料理を提供する

3.1. 食材の調理の確認

料理 1つの食材が正しく調理されているか確認。
Git 1つのファイルが正しく変更(追加)されているか確認。

正しく料理できたか確認しますよね。(見た目の確認、海苔忘れてないかとか)
この作業ができていない人が多いと感じます。
料理を食べる人(オーナー、Gitで言えば先輩 = レビュワー)に迷惑かけたくないですよね。
正しい差分が入っているか、入れ忘れがないか、タイプミスがないか確認しましょう。

まずは今の厨房台の状況を確認しましょう。

$ git status

食材(差分ありのファイルの中身)を確認しましょう。

$ git diff <ファイル名>

# 引数にファイル名をつけないと全ファイルの差分が見れます
$ git diff

git diff = 調理の確認

※ 実際の流れは 3.2. でまとめて紹介します

3.2. お皿に盛り付け

料理 1品ごとにお皿に盛り付け。
Git 1機能分に必要な変更ファイルをステージングエリアにあげる。

3.1. で調理内容を確認して正しければ食材をお皿の上へ置きましょう。

$ git add <ファイル名>

このときにお皿が置いてあるところが配膳前のデシャップ台(ステージングエリア)です。
盛り付けが微妙だったらさらに食材を調理しなおして盛りつけ直すことができます。
git add は何度でも行うことができます。

実際の流れ(開く)

編集から git add まで

トマトケチャップと玉ねぎのみじん切りを新規に作成

$ touch chopped_onion.txt
$ touch tomato_sauce.txt
$ echo "適度に切る." > chopped_onion.txt
$ echo "トマト缶を利用." > tomato_sauce.txt

現状の確認。

$ git status
On branch seasonal_delight_dinner/20230412

Untracked files:  # 厨房台(新たな食材)
	chopped_onion.txt
	tomato_sauce.txt

デシャップ台に玉ねぎのみじん切りを追加

$ git add chopped_onion.txt
$ git status               
On branch seasonal_delight_dinner/20230412

Changes to be committed:  # デシャップ台
	new file:   chopped_onion.txt

Untracked files:  # 厨房台(新たな食材)
	tomato_sauce.txt

git add した後にさらに差分(修正)がある場合

料理名を決める(commit)前にさらに玉ねぎのみじん切りに手を加えたい場合

手を加える

$ echo "荒く5mm程度の大きさ." > chopped_onion.txt

現状の確認。

$ git status
On branch seasonal_delight_dinner/20230412

Changes to be committed:  # デシャップ台
	new file:   chopped_onion.txt

Changes not staged for commit:  # 厨房台(すでにある食材に対しての変更)
	modified:   chopped_onion.txt

Untracked files:  # 厨房台(新たな食材)
	tomato_sauce.txt

差分を確認

$ git diff  chopped_onion.txt
diff --git a/chopped_onion.txt b/chopped_onion.txt
index f0ff485..40c7ee7 100644
--- a/chopped_onion.txt
+++ b/chopped_onion.txt
@@ -1 +1 @@
-適度に切る.
+荒く5mm程度の大きさ.

上記の差分が必要な場合
変更をデシャップ台のものに適用する。

$ git add chopped_onion.txt

上記の差分が不要な場合
変更を無かったことにする。(破棄する)

$ git checkout chopped_onion.txt

ステージングエリアにあげる = お皿に盛り付け

3.3. お皿に料理名をつける

お皿に盛り付けが完了したら料理名をつけてあげましょう。

その前にくどいようですが念のため確認を。。。

料理 ちゃんと食材が全て入っているか再度確認しましょう。
Git 必要なファイルがステージングされていることを確認しましょう。
$ git status

正しければ

料理 お皿に料理名をつけましょう。
(季節感じるエビの和風パスタとか)
Git コミット名をつけましょう。
$ git commit -m "<料理名>"

コミット = 料理

注意点

このお皿の単位を作るときに気をつけたいことは下記になります。

  • なるべく変更点が少ないようにコミットする
  • 複数の作業を混ぜない

お口直しのソルベの中にフォアグラが入ってたら嫌ですよね。(嫌じゃなくても嫌と言うことにしてください)

メニュー名を間違えた時は...

あわてて料理名噛むことありますよね。

$ git commit -m "スズキのポワレ"

としたかったとき

$ git commit -m "佐々木のポワレ"

と言ってしまうかもしれません。訂正したいですよね。

$ git commit --amend

と打つとエディターが開きますのでコメント名を修正することができます。

4. テーブルへ配膳

料理が1品できて満足してはいけません。作った料理を配膳しましょう。
配膳しておかないと、間違えて廃棄してしまう(PCが壊れて何をしていたか忘れてしまう)可能性があります!

料理 ウエイターを使ってテーブルへ料理を配膳。
Git インターネット経由(SSH or HTTP)でリモートブランチへコミットを送信。
$ git push origin <ブランチ名>

リモートブランチ = テーブル
git push = (テーブルへ)配膳

5. コースの配膳が完了

料理 2-4を繰り返し全部の料理を配膳し終わりました。
Git 作成(修正)したい項目の作業が全て終わりました。

次に

料理 オーナーを呼び、コースの評価をしてもらうためにチェックシートを渡し食べてもらいましょう。
Git 先輩に変更内容が正しいか確認してもらうためにプルリクエストを作りレビューしてもらいましょう。

提供する予定ではなかった料理を配膳していないでしょうか。
評価してもらう前に一呼吸おいて自分でも一度確認しましょう。

GitHub を使っていれば下記のようになります。

料理 チェックシートを元に合格が出たら、晴れてそのコースはお客様に提供できます。
Git プルリクエストがapproveされたら、mainブランチにマージしリリースできる。

万が一NGが出た場合は修正して再度プルリクエストを見てもらいましょう。

プルリクエスト = オーナーが評価するためのチェックシート
approve = 合格
mainブランチにマージ = お店に並べる(厳密に言えばリリース作業が入ります)

注意点

料理 オーナーも100品連続で食べた後だと流石に1品目覚えていない。
Git プルリクエストも全体で見ればコミットの一つなのでできる限り小さい方がレビューしやすく喜ばれます。

6. コースの合格が出た後日談

このようにしてコースが出来上がり

... ->  季節のお楽しみディナー -> お手軽コース -> XXXコース -> ...

とコースが増えていきそのお店がより良くなっていくことでしょう。
ただし、直送野菜が届かなくなったときはコースを取り下げるかもしれません。
そのような変更もできてしまうのが Git です。
詳しくは調べていただきたいですが下記のようなコマンドがあったりします。

$ git revert <commit番号>

このほかにも便利 or 高度なコマンドがありますが必要に応じて調べて使ってみてください。

その他. テクニック

厨房を綺麗に保つ

厨房汚いと嫌ですよね。必要な包丁も食材も見つからないかもしれませんし、
他のコースで使う食材も混ざってしまってるかもしれません。

まずは

料理 自分がどのコースの料理検討会を行っているか逐一確認しましょう。
Git 自分がどのブランチで作業しているか逐一確認しましょう。
$ git branch
  main
* seasonal_delight_dinner/20230412

「*」マークがあるブランチ名で作業していることになります。

また、逐一下記をしましょう。困ったらこれです。

料理 厨房の中の厨房台・デシャップ台・食材庫のなかを確認。
Git 正しい変更が行われているかWorking Tree・ステージングエリア・Untracked fileを確認
$ git status

今作業中の厨房台に乗っている食材(ファイル)とデシャップ台(ステージングエリア)に乗っている食材が確認できます。

サンプルコード(開く)
$ git status
On branch main

Changes to be committed:  # デシャップ台
	new file:   chopped_onion.txt

Changes not staged for commit:  # 厨房台(すでにある食材に対しての変更)
	modified:   chopped_onion.txt

Untracked files:  # 厨房台(新たな食材)
	tomato_sauce.txt

料理のレシピをメモしておく

料理作っているときに、あれ、他の方法も試してみたいとなる時ありますよね。
そんな時は今作っていた料理のレシピをメモして別の作業をしても良いのです。

コマンドで言うと

$ git stash save "<料理名(仮)>"

となります。これを実行した後はまっさらな状態になりますので新たな作業が始められます。

$ git status

しても何もないはずです。

このレシピ本(保存した変更履歴)を確認するのは下記となります。

$ git stash list

料理を再度作成する(ローカルに保存した時点の状態を再現する)コマンドが下記となります。

$ git stash apply <stash番号>

# 例) 最新のstashを戻す
$ git stash apply stash@{0}

この時、厨房台(ローカルリポジトリ)が綺麗な状態で実行しないと変更が正しく反映されないこともあります。また、過去に履歴を保存した時点と現在の時点が異なっている場合「コンフリクト」が起こる場合があります。
※コンフリクトについて説明すると長くなるので起きたときに調べてください。

Gitとフレンチの相対表

ここまでの流れを元に GitHub に実際にリポジトリを作ってみました。

お店に並ぶメニュー

レストランのメニュー = mainブランチに含まれている変更内容

- 季節のお楽しみディナー = プルリクエスト後に作成されたmainブランチへのコミット
- お手軽コース = プルリクエスト後に作成されたmainブランチへのコミット

※プルリクエストがmainブランチにsquash mergeされている様子

お品書き

お問い合わせフォームの作成をお品書きに沿って並べてみると(空想)

# 季節のお楽しみディナー = お問い合わせフォーム作成
オードブル = 大枠デザインのコミット
スープ = バックグラウンドのコミット
ポワソン = フロントデザインのコミット
ソルベ = 文言修正のコミット
アントレ = テスト追加のコミット
デセール = テスト修正のコミット
カフェ・ブティフール = リファクタのコミット

店内の図

git に置き換えたら何になるかを記載しました。
DAC76EAD-1212-4039-B990-DBF00A6961F7.png

おわりに

Git と言われてもどうとっかかっていいものかわからないと思います。
なので頭にイメージがあればそのコマンドがどの役割をしているか考えやすいと思いますのでこのような例を挙げてみました。
参考になりましたら幸いです。

full dict

私自身のサイトでも日々思いついたこと学んだことをフランクに配信しています!

1
1
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
1
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?