claude-code-command-author
SKILL.md
Claude Code Command Author
ユーザーの要望を Claude Code の Custom slash command(Markdownファイル) に落とし込み、再利用可能なコマンドとして追加できる状態にする。
Goals
- ユーザーの依頼から コマンドの目的・引数・出力を明確化する
- **正しいコマンドファイル(YAML frontmatter + Markdown本文)**を生成する
- 置き場所・命名・引数設計・事前コンテキストなどを適切に選定する
- ユーザーがそのまま
.claude/commands/または~/.claude/commands/に置ける形で出力する
Non-goals
- Skillの作成(それは
skill-skillsmithの役割) - コマンド自体を実行すること(生成・設計まで)
Inputs
- コマンドで何をしたいか(目的)
- コマンド名の候補(任意、なければ提案)
- スコープ(project / personal、任意)
- 引数の要件(任意)
- 事前に埋め込みたいコンテキスト(任意、git status/diff等)
Outputs
- 作成/更新するファイルパス(例:
.claude/commands/review-pr.md) - ファイル内容(完成版Markdown)
- 利用例&テスト手順(
/helpで確認、実行例)
Instructions
Step 0: 要件の最小セットを確定する
不足している場合は 最小限だけ 確認する(質問攻めにしない)。
確認項目:
- コマンド目的(何をしたい?何を出力したい?)
- コマンド名候補(
/review-pr的なやつ) - スコープ: project (
.claude/commands/) or personal (~/.claude/commands/) - 引数設計: フリーフォーム(
$ARGUMENTS) or 位置引数($1,$2, ...) - 事前コンテキスト: bash埋め込み(!) / ファイル参照(@)
- 安全性: 読み取り中心?書き換えあり?
デフォルト方針(ユーザーが指定しない場合):
- スコープ: project(
.claude/commands/) - コマンド性質: 読み取り中心(安全)
- 引数: 1つなら
$ARGUMENTS、複数の役割があるなら$1..
Step 1: パスと命名を決める
- コマンド名は ファイル名(
.md除く) で決まる - 命名は kebab-case(例:
review-pr.md→/review-pr) - namespacingしたい場合はサブディレクトリ
- 例:
.claude/commands/frontend/test.md - ※サブディレクトリはコマンド名に影響しない(表示上の区別)
- 例:
- 衝突回避: projectとpersonalが同名ならprojectが優先
Step 2: frontmatter を設計する
必須:
description: 何をするコマンドか(/helpで表示される)
推奨:
argument-hint: 補完時に出る引数ヒント(引数ありの場合)
必要に応じて:
allowed-tools: ! bash実行を使うなら必要(最小権限で)model: 特定モデル固定したい場合context: fork+agent: 会話を汚したくない/重い作業を分離disable-model-invocation: true: Skill toolからの自動呼び出しを避けたい
Step 3: 引数の受け取り設計
- まとめて扱う:
$ARGUMENTS - 役割がある:
$1,$2,$3(PR番号、優先度、担当など) argument-hintでユーザーが迷わない形にする
Step 4: コマンド本文を設計する
本文は「Claudeにやってほしいこと」を 手順+出力仕様 で書く。
推奨構造:
- 目的(何を達成するか)
- 入力(引数、参照ファイル、前提)
- 手順(箇条書き)
- 出力形式(Markdown、チェックリスト、差分提案など)
- 制約(例: 「ファイル編集は禁止」「提案のみ」など)
- 完了条件(DoD)
Step 5: 事前コンテキスト埋め込み(必要なら)
bash事前実行(!)
!`git status`
!`git diff HEAD`
allowed-toolsでBash(...)を許可する- 危険なコマンドは許可しない(
rm,curl,deploy等は原則不可)
ファイル参照(@path)
@src/...のように書くとファイル内容をコンテキストに含められる- コマンド目的に直結する最小限のファイルだけ参照する
Step 6: 最終アウトプットを生成する
以下の3点をユーザーに渡す:
- 作成/更新するファイルパス
- ファイル内容(完成版)
- 利用例&テスト手順
Output format (MUST)
## Files
- .claude/commands/<command-name>.md
## .claude/commands/<command-name>.md
\```md
---
description: <short description>
argument-hint: [optional-args]
---
# <Command Title>
## Your task
- ...
## Constraints
- ...
## Output
- ...
\```
## Usage
- `/command-name [args]`
- 確認: `/help` で description が表示されるか
Quality Checklist
- 置き場所は正しいか(project
.claude/commands// personal~/.claude/commands/) - ファイル名がコマンド名として適切か(
kebab-case) -
descriptionが入っているか(/helpで分かる) - 引数があるなら
argument-hintがあるか -
$ARGUMENTS/$1..の設計が目的に合っているか - ! を使うなら
allowed-toolsに Bash が適切に絞られているか -
@file参照は最小限か - 制約(編集禁止など)が明記されているか
-
/helpと実行例のテスト手順が書かれているか
Examples
Example 1
ユーザー: 「PRレビューを毎回同じ観点でやりたいから /review-pr 作って。引数はPR番号と優先度と担当。」
→ .claude/commands/review-pr.md を生成。$1.. + argument-hint あり。
Example 2
ユーザー: 「コミットメッセージ作成をコマンド化したい。実行前にgit statusとdiffを入れて。」
→ allowed-tools + ! を使うコマンドを生成(危険コマンドは許可しない)。
Example 3
ユーザー: 「このリポジトリの特定ファイルを説明する /explain-file を作って。パスを引数で渡す。」
→ $ARGUMENTS で受け、@参照を使う運用を提案。
Example 4(非対象)
ユーザー: 「このPRをレビューして」
→ これは "コマンド生成" ではなく "レビュー実行"。本Skillは発動せず、通常対応。
Guardrails
- 破壊的操作(削除/デプロイ/課金リソース作成など)を含むコマンドは、明示的なユーザー同意がある場合のみ設計する
allowed-toolsは最小権限。可能なら read-only(git status,git diff)に限定- ファイル編集を伴う用途では「編集範囲」「バックアップ方針」「確認ステップ」をコマンド本文に含める
References
- Slash commands - Claude Code Docs
- Agent Skills - Claude Code Docs
- 詳細仕様: @reference.md
- テンプレート: @templates/
Weekly Installs
2
Repository
superstone-han/dotfilesFirst Seen
Mar 1, 2026
Security Audits
Installed on
opencode2
gemini-cli2
codebuddy2
github-copilot2
codex2
kimi-cli2