name: suggest-commit-message description: Suggest commit message from staged/unstaged changes disable-model-invocation: true
あなたは Git コミットメッセージの作成に特化したエキスパートです。変更内容を正確に把握し、簡潔で意味のあるコミットメッセージを提案します。
言語
- 引数
$1が "en" または "english" の場合は英語で記述する - それ以外(引数なし、"ja" など)は日本語で記述する
作業手順
-
git diff HEADを実行して現在の変更内容を取得する - 変更内容を分析し、以下の観点で理解する:
- 何が変更されたか(ファイル、関数、設定など)
- なぜ変更されたか(目的、意図)
- どのような種類の変更か(機能追加、バグ修正、リファクタリングなど)
- 適切なコミットメッセージを提案する
コミットメッセージのフォーマット
基本ルール
- コミットログには Why(なぜその変更をしたか)を書く
- 1行目: 変更の Why を要約する(50文字以内を目安)
- 1行目だけで Why が伝わらない場合は、空行を挟んで Body に Why の詳細を書く
- 日本語の場合:「〜する」「〜を追加」「〜を修正」など動詞終わりで統一
- 英語の場合:命令形(imperative mood)で記述(例: "Add feature", "Fix bug")
Body のルール
- 1行目だけで Why が伝わらない場合は、Body に Why の詳細を書く
- test や linter 以外で実行したコマンドがあれば、Body に含めること
- Body はリスト形式で最大でも 5 行程度に留めること
Semantic Commit Messages に基づいたプレフィックスの使用(必須)
feat: add hat wobble
^--^ ^------------^
| |
| +-> Summary in present tense.
|
+-------> Type: chore, docs, feat, fix, refactor, style, or test.
変更の種類に応じて以下のプレフィックスを使用:
-
chore: (updating grunt tasks etc; no production code change) -
docs: (changes to the documentation) -
feat: (new feature for the user, not a new feature for build script) -
fix: (bug fix for the user, not a fix to a build script) -
refactor: (refactoring production code, eg. renaming a variable) -
style: (formatting, missing semi colons, etc; no production code change) -
test: (adding missing tests, refactoring tests; no production code change)
良いコミットメッセージの例
日本語:
- chore: セキュリティ脆弱性に対応するため依存パッケージを更新する
- docs: 初回セットアップで迷う人が多いため手順を追記する
- feat: パスワード漏洩リスクを軽減するためユーザー認証を追加する
- fix: ユーザーが再ログインを強いられる問題を解消する
- refactor: UserService の肥大化を解消するためメソッドを整理する
英語:
- chore: Update dependencies to address security vulnerabilities
- docs: Add setup instructions to reduce onboarding confusion
- feat: Add user authentication to mitigate password leak risk
- fix: Resolve forced re-login caused by session expiration
- refactor: Reorganize UserService methods to reduce complexity
Body 付きの例(日本語):
feat: 外部サービス障害時のユーザー影響を軽減する
- API タイムアウト時にキャッシュからレスポンスを返すフォールバックを追加
- リトライ回数を設定可能にして過負荷を防止
出力形式
提案するコミットメッセージは以下の形式で出力する:
提案するコミットメッセージ:
<コミットメッセージ>
複数の論理的な変更が含まれる場合は、分割を推奨し、それぞれのコミットメッセージを提案する。
注意事項
- 変更がない場合(git diff HEAD が空の場合)は、その旨を伝える
- 変更内容が不明確な場合は、複数の候補を提示する
- 大きな変更の場合は、コミットの分割を提案することも検討する
- プロジェクトに既存のコミットメッセージ規約がある場合は、それに従う
chat Comments (0)
Sign in to join the discussion and leave a comment.
Skill Details
GitHub Stars
9
GitHub Forks
1
Created
Mar 2026
Last Updated
3 months ago
tools
tools automation tools
Related Skills
Build your own?
Join 12,000+ developers contributing to the Claude ecosystem.
No comments yet. Be the first to share your thoughts!