create-slash-commands
This Claude Code skill provides structured guidance for creating slash commands that execute reusable prompts with `/command-name` syntax in Claude projects. Use it when building custom commands, configuring YAML frontmatter, implementing dynamic context loading, or establishing standardized team workflows through the `.claude/commands/` directory structure.
git clone --depth 1 https://github.com/glittercowboy/taches-cc-resources /tmp/create-slash-commands && cp -r /tmp/create-slash-commands/skills/create-slash-commands ~/.claude/skills/create-slash-commandsSKILL.md
<objective> Create effective slash commands for Claude Code that enable users to trigger reusable prompts with `/command-name` syntax. Slash commands expand as prompts in the current conversation, allowing teams to standardize workflows and operations. This skill teaches you to structure commands with XML tags, YAML frontmatter, dynamic context loading, and intelligent argument handling. </objective> <quick_start> <workflow> 1. Create `.claude/commands/` directory (project) or use `~/.claude/commands/` (personal) 2. Create `command-name.md` file 3. Add YAML frontmatter (at minimum: `description`) 4. Write command prompt 5. Test with `/command-name [args]` </workflow> <example> **File**: `.claude/commands/optimize.md` ```markdown --- description: Analyze this code for performance issues and suggest optimizations --- Analyze the performance of this code and suggest three specific optimizations: ``` **Usage**: `/optimize` Claude receives the expanded prompt and analyzes the code in context. </example> </quick_start> <xml_structure> All generated slash commands should use XML tags in the body (after YAML frontmatter) for clarity and consistency. <required_tags> **`<objective>`** - What the command does and why it matters ```markdown <objective> What needs to happen and why this matters. Context about who uses this and what it accomplishes. </objective> ``` **`<process>` or `<steps>`** - How to execute the command ```markdown <process> Sequential steps to accomplish the objective: 1. First step 2. Second step 3. Final step </process> ``` **`<success_criteria>`** - How to know the command succeeded ```markdown <success_criteria> Clear, measurable criteria for successful completion. </success_criteria> ``` </required_tags> <conditional_tags> **`<context>`** - When loading dynamic state or files ```markdown <context> Current state: ! `git status` Relevant files: @ package.json </context> ``` (Note: Remove the space after @ in actual usage) **`<verification>`** - When producing artifacts that need checking ```markdown <verification> Before completing, verify: - Specific test or check to perform - How to confirm it works </verification> ``` **`<testing>`** - When running tests is part of the workflow ```markdown <testing> Run tests: ! `npm test` Check linting: ! `npm run lint` </testing> ``` **`<output>`** - When creating/modifying specific files ```markdown <output> Files created/modified: - `./path/to/file.ext` - Description </output> ``` </conditional_tags> <structure_example> ```markdown --- name: example-command description: Does something useful argument-hint: [input] --- <objective> Process $ARGUMENTS to accomplish [goal]. This helps [who] achieve [outcome]. </objective> <context> Current state: ! `relevant command` Files: @ relevant/files </context> <process> 1. Parse $ARGUMENTS 2. Execute operation 3. Verify results </process> <success_criteria> - Operation completed without errors - Output matches expected format </success_criteria> ``` </structure_example> <intelligence_rules> **Simple commands** (single operation, no artifacts): - Required: `<objective>`, `<process>`, `<success_criteria>` - Example: `/check-todos`, `/first-principles` **Complex commands** (multi-step, produces artifacts): - Required: `<objective>`, `<process>`, `<success_criteria>` - Add: `<context>` (if loading state), `<verification>` (if creating files), `<output>` (what gets created) - Example: `/commit`, `/create-prompt`, `/run-prompt` **Commands with dynamic arguments**: - Use `$ARGUMENTS` in `<objective>` or `<process>` tags - Include `argument-hint` in frontmatter - Make it clear what the arguments are for **Commands that produce files**: - Always include `<output>` tag specifying what gets created - Always include `<verification>` tag with checks to perform **Commands that run tests/builds**: - Include `<testing>` tag with specific commands - Include pass/fail criteria in `<success_criteria>` </intelligence_rules> </xml_structure> <arguments_intelligence> The skill should intelligently determine whether a slash command needs arguments. <commands_that_need_arguments> **User provides specific input:** - `/fix-issue [issue-number]` - Needs issue number - `/review-pr [pr-number]` - Needs PR number - `/optimize [file-path]` - Needs file to optimize - `/commit [type]` - Needs commit type (optional) **Pattern:** Task operates on user-specified data Include `argument-hint: [description]` in frontmatter and reference `$ARGUMENTS` in the body. </commands_that_need_arguments> <commands_without_arguments> **Self-contained procedures:** - `/check-todos` - Operates on known file (TO-DOS.md) - `/first-principles` - Operates on current conversation - `/whats-next` - Analyzes current context **Pattern:** Task operates on implicit context (current conversation, known files, project state) Omit `argument-hint` and don't reference `$ARGUMENTS`. </commands_without_arguments> <incorporating_arguments> **In `<objective>` tag:** ```markdown <objective> Fix issue #$ARGUMENTS following project conventions. This ensures bugs are resolved systematically with proper testing. </objective> ``` **In `<process>` tag:** ```markdown <process> 1. Understand issue #$ARGUMENTS from issue tracker 2. Locate relevant code 3. Implement fix 4. Add tests </process> ``` **In `<context>` tag:** ```markdown <context> Issue details: @ issues/$ARGUMENTS.md Related files: ! `grep -r "TODO.*$ARGUMENTS" src/` </context> ``` (Note: Remove the space after the exclamation mark in actual usage) </incorporating_arguments> <positional_arguments> For structured input, use `$1`, `$2`, `$3`: ```markdown --- argument-hint: <pr-number> <priority> <assignee> --- <objective> Review PR #$1 with priority $2 and assign to $3. </objective> ``` **Usage:** `/review-pr 456 high alice` </positional_arguments> </arguments_intelligence> <file_structure> **Project commands**: `.claude/commands/` - Shared with team via version control
Expert skill auditor for Claude Code Skills. Use when auditing, reviewing, or evaluating SKILL.md files for best practices compliance. MUST BE USED when user asks to audit a skill.
Expert slash command auditor for Claude Code slash commands. Use when auditing, reviewing, or evaluating slash command .md files for best practices compliance. MUST BE USED when user asks to audit a slash command.
Expert subagent auditor for Claude Code subagents. Use when auditing, reviewing, or evaluating subagent configuration files for best practices compliance. MUST BE USED when user asks to audit a subagent.
Add todo item to TO-DOS.md with context from conversation
Gather requirements through adaptive questioning before executing any task
Heal skill documentation by applying corrections discovered during execution with approval workflow
Audit slash command file for YAML, arguments, dynamic context, tool restrictions, and content quality
Audit subagent configuration for role definition, prompt quality, tool selection, XML structure compliance, and effectiveness