Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
コミットするタイミングについて
Search
宮田勉
December 28, 2023
Programming
0
200
コミットするタイミングについて
コミットの粒度を適切にしようとする時のポイントをまとめてみました
宮田勉
December 28, 2023
Tweet
Share
More Decks by 宮田勉
See All by 宮田勉
コミットメッセージを書く時に気をつけていること
tmiyata
2
370
Other Decks in Programming
See All in Programming
CSC307 Lecture 01
javiergs
PRO
0
690
AIと一緒にレガシーに向き合ってみた
nyafunta9858
0
240
生成AIを使ったコードレビューで定性的に品質カバー
chiilog
1
270
Fragmented Architectures
denyspoltorak
0
160
Data-Centric Kaggle
isax1015
2
780
今から始めるClaude Code超入門
448jp
8
8.9k
高速開発のためのコード整理術
sutetotanuki
1
400
AIエージェント、”どう作るか”で差は出るか? / AI Agents: Does the "How" Make a Difference?
rkaga
4
2k
並行開発のためのコードレビュー
miyukiw
0
230
AI & Enginnering
codelynx
0
110
Fluid Templating in TYPO3 14
s2b
0
130
AgentCoreとHuman in the Loop
har1101
5
240
Featured
See All Featured
SEOcharity - Dark patterns in SEO and UX: How to avoid them and build a more ethical web
sarafernandez
0
120
First, design no harm
axbom
PRO
2
1.1k
Statistics for Hackers
jakevdp
799
230k
BBQ
matthewcrist
89
10k
Typedesign – Prime Four
hannesfritz
42
2.9k
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
190
Skip the Path - Find Your Career Trail
mkilby
0
57
Why You Should Never Use an ORM
jnunemaker
PRO
61
9.7k
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
590
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
31
2.7k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7k
Stop Working from a Prison Cell
hatefulcrawdad
273
21k
Transcript
コミットするタイミングについて 宮田 勉
注意事項 • あくまで一個人の考えです • 正解はありません • 私が普段考えていることの共有です
今日の内容 • 導入 • コミットの粒度とは? • コミットするタイミング
コミットとコミットログ • コミット ◦ 変更をバージョン管理ツールに保存されたもの • コミットログ ◦ コミットの集合体
コミットログで出来ること • 過去の変更を振り返れる • 問題があったら、1つ以上前の変更まで戻れる • 既にコミット済みの内容を後から修正できる • 複数のコミットを1つにまとめられる
便利だが、何も考えずにコミットすると... • 1つのコミットの中で色々な変更が入って何をしたいのかがわからない • 1つ1つのコミットが細か過ぎて、繋がりがわからない • 不具合があってコミットを切り戻したいけど、不具合と関係ない所まで切り 戻されてしまう • 日常生活で例えると整理整頓せずに収納しているイメージ
今日の話 • 整理整頓されていれば、探すときに時間かかからない • 保守しやすくなったり、レビューしやくなったりする、という話
コミットの粒度とは? • コミットするときの変更の度合いや規模
コミットの粒度が大きすぎる • 切り戻ししづらい ◦ 一部にバグがあっても、コミットのリバートができない • 修正内容がわかりづらい ◦ 差分が大きくなると、情報量も増える ◦
修正内容がわかりづらくなったり、見落としが発生しやすい 保守しづらく、レビューもしにくい!
コミットの粒度が小さすぎる • コミットが多くなる ◦ 1つ1つのコミットを見た時に、他のコミットとの繋がりがわかりづらい • 切り戻しの数が多くなる 細か過ぎても保守しづらく、レビューもしにくい!
コミットの粒度が適切であると • コミット単位で切り戻しがしやすい • コミット単位での差分が見やすくなる その結果 保守しやすく、レビューもしやすい!!
コミットするタイミング • 1つの作業単位 • 正常に動くタイミング
1つの作業単位の例:コマンド実行 • コマンドやツール等によって自動的に作成や変更が加わる単位でコミット • 以下が区別できる ◦ 人による変更 ◦ コマンド実行による変更
コマンド実行と手動変更が混ざっている例 • コードのフォーマット修正(自動で修正)されたもの • statusがcompletedだったらメールを送らない
コマンド実行と手動変更を分けた例 人の手とそうでない変更が区別つきやすいので見やすい 片方の変更だけ切り戻すこともできる
1つの作業単位の例:ファイル移動やリネーム • ファイルの移動やリネームといった機械的な変更のみでコミット • 上記以外の変更も混ぜると移動やリネームによってクラス名やファイル名な どの修正漏れかどうかがわかりづらくなる ※ファイルの移動やリネームする時に、コマンド実行で変更する場合もあるが、 クラス名の変更と同じコミットにする →1つの作業単位でコミットすることを意識する
1つの作業単位の例:TODOリスト • タスク単位でコミットする • コミットを見ただけで対応内容が想像つく
正常に動くタイミング • エラーが起きない状態でコミットする • エラーが起きる状態だと切り戻せない • アプリのコード修正とテストコードの修正がセットで1つのコミットになっ ていると動作が担保されているので尚良い
まとめ • 保守しやすさ、レビューしやすさもコミットの粒度次第で変わります • コミットする時は、紹介したポイント意識してみてください
参考 • https://qiita.com/jnchito/items/40e0c7d32fde352607be • https://www.codegrid.net/articles/git-tech-1 • https://qiita.com/chihiro/items/04482caebc702e75e84d