アプリ開発において「Git」は必須スキルとなってきます。Gitの基本コマンドは知っているけど他のコマンドはよく知らない、Gitコマンドをもっと知って便利に使いたい!と思っている方、 特定のコミットにおけるコードの変更を具体的に見たい! という方向けに、この記事では「git show」の解説をします。
GitについてはエンベーダーのLinux応用コースで詳しく学ぶことができます。
https://envader.plus/course/5/scenario/1055
様々なGitコマンドを習得し、Gitマスターを目指しましょう!
「git show」でできること
- 指定したコミットの作成者、日時などの詳細内容を表示
- コミットに含まれるコードの変更差分を確認
- タグが指すコミットの詳細を表示(タグについての記事はこちら)
「git show」コマンドの開発現場での活用例
-
コミットの詳細確認
特定のバグが報告された際、
git show
を使用して、そのバグが導入されたコミットの変更内容を詳細に確認します。これにより、バグの原因を直接的に理解することが可能です。 -
コード変更の評価
新しいコードが導入された際、
git show
を使用してそのコミットの変更内容をレビューします。これにより、コードの変更が期待通りかを確認し、必要に応じてフィードバックを提供できます。 -
バージョン管理
リリース前の最終確認として、リリースに関わるタグで
git show
を実行して、リリースされるコンテンツを確認します。これにより、リリース準備の正確性を保証します。
「git show」の使い方
基本操作
指定したコミットまたはタグの詳細を表示します。
※ タグについては以下の記事を参照してください。
https://envader.plus/article/367
git show コミットID/タグ名
コマンド実行例
例として5a83...
コミットのgit show
を実行した結果です。(コミットIDは一意に特定できるのであれば、後半の大部分を省略可能です。)
git show 5a83
commit 5a8319e714707a2e8306c8d0f29dc7c1487ba164
Author: Fred <fred@example.com>
Date: Mon Apr 22 20:55:24 2024 +0900
[add]コンテナを起動するためのDockerfileを追加する
diff --git a/Dockerfile b/Dockerfile
index e69de29..c0f171f 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -0,0 +1,10 @@
+FROM python:3.11
+
+WORKDIR /app
+
+COPY requirements.txt .
+RUN pip install --no-cache-dir -r requirements.txt
+
+COPY . .
+
+CMD ["uvicorn", "app.main:app", "--host", "0.0.0.0", "--port", "8888", "--reload"]
出力内容の詳細
- コミットのメタデータ(コミットID、作者、日付など)
- コミットに含まれる各ファイルの変更差分
「git show」のオプション
git show
のオプションはいくつかありますが、今回は以下の3つを紹介します。
--stat
—-name-only
—-oneline
—-stat
変更されたファイル、追加された行数、削除された行数を表示します。
git show --stat 67151d
commit 67151de11443a2354e70a886b4a59edfeff5584e
Author: Risa <risa@example.com>
Date: Tue Apr 30 22:03:21 2024 +0900
[add]初期のReactコンポーネントを作成
src/App.js | 10 +++++++++-
src/components/Header.js | 8 ++++++++
src/components/Footer.js | 6 ++++++
src/index.js | 4 ++--
public/index.html | 2 +-
package.json | 3 ++-
6 files changed, 28 insertions(+), 5 deletions(-)
--name-only
変更されたファイルのリストのみを表示します。
git show --name-only 67151d
commit 67151de11443a2354e70a886b4a59edfeff5584e
Author: Risa <risa@example.com>
Date: Tue Apr 30 22:03:21 2024 +0900
[add]初期のReactコンポーネントを作成
src/App.js
src/components/Header.js
src/components/Footer.js
src/index.js
public/index.html
package.json
--oneline
結果表示の先頭にあるコミットメタデータを一行で簡潔に表示します。
git show --oneline 67151de
67151de [add]初期のReactコンポーネントを作成
// 以下はオプションなしの時と同様
まとめ
この記事ではGitコマンドの中のgit show
について学びました。git show
は、コミットの詳細や変更差分を確認するのに役立ちます。開発現場での活用シーンは多岐にわたります。オプションを使いこなすことで、より効率的にgit show
を活用できるようになるでしょう。実際にコマンドを実行して理解を深めていきましょう!
【番外編】USBも知らなかった私が独学でプログラミングを勉強してGAFAに入社するまでの話
プログラミング塾に半年通えば、一人前になれると思っているあなた。それ、勘違いですよ。「なぜ間違いなの?」「正しい勉強法とは何なの?」ITを学び始める全ての人に知って欲しい。そう思って書きました。是非読んでみてください。
「フリーランスエンジニア」
近年やっと世間に浸透した言葉だ。ひと昔まえ、終身雇用は当たり前で、大企業に就職することは一種のステータスだった。しかし、そんな時代も終わり「優秀な人材は転職する」ことが当たり前の時代となる。フリーランスエンジニアに高価値が付く現在、ネットを見ると「未経験でも年収400万以上」などと書いてある。これに釣られて、多くの人がフリーランスになろうとITの世界に入ってきている。私もその中の1人だ。数年前、USBも知らない状態からITの世界に没入し、そこから約2年間、毎日勉学を行なった。他人の何十倍も努力した。そして、企業研修やIT塾で数多くの受講生の指導経験も得た。そこで私は、伸びるエンジニアとそうでないエンジニアをたくさん見てきた。そして、稼げるエンジニア、稼げないエンジニアを見てきた。
「成功する人とそうでない人の違いは何か?」
私が出した答えは、「量産型エンジニアか否か」である。今のエンジニア市場には、量産型エンジニアが溢れている!!ここでの量産型エンジニアの定義は以下の通りである。
比較的簡単に学習可能なWebフレームワーク(WordPress, Rails)やPython等の知識はあるが、ITの基本概念を理解していないため、単調な作業しかこなすことができないエンジニアのこと。
多くの人がフリーランスエンジニアを目指す時代に中途半端な知識や技術力でこの世界に飛び込むと返って過酷な労働条件で働くことになる。そこで、エンジニアを目指すあなたがどう学習していくべきかを私の経験を交えて書こうと思った。続きはこちらから、、、、
エンベーダー編集部
エンベーダーは、ITスクールRareTECHのインフラ学習教材として誕生しました。 「遊びながらインフラエンジニアへ」をコンセプトに、インフラへの学習ハードルを下げるツールとして運営されています。
関連記事
2020.02.25
完全未経験からエンジニアを目指す爆速勉強法
USBも知らなかった私が独学でプログラミングを勉強してGAFAに入社するまでの話
- キャリア・学習法
- エンジニア
2024.05.06
Gitコマンドgit cherry-pickとは?かわいいコマンドに隠された便利な機能を解説!
cherry-pickは英語の慣用句で「良い所だけをつまみ食いする」という意味があります。その意味の通り、`git cherry-pick`は別ブランチから現在作業中のブランチへ、必要なコミットを取り込むことができます。
- git
2024.06.19
複数ブランチを同時に作業する方法を解説!git worktreeの使い方ガイド
開発作業をしている最中に、チームメンバーからプルリクの依頼をされるということは良くあります。この時、プルリクの内容を確認するためのブランチに移動する前に、作業中の変更をコミットして…という確定していない変更をコミットすることにモヤモヤした経験ありませんか?
- git
2024.06.02
Gitコマンド「git reflog」とは?「HEAD」も併せて解説!
git reflogはGitが保持する「reflog(リファレンスログ)」を表示するコマンドです。
- git