plugins/skill-authoring/skills/creating-skills/SKILL.md
Guide for creating Claude Code skills following Anthropic's official best practices. Use when user wants to create a new skill, build a skill, write SKILL.md, update an existing skill, or needs skill creation guidelines. Provides structure, frontmatter fields, naming conventions, and new features like dynamic context injection and subagent execution.
npx skillsauth add fvadicamo/dev-agent-skills creating-skillsInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Guide for creating Claude Code skills following Anthropic's official best practices.
# 1. Create skill directory
mkdir -p ~/.claude/skills/<skill-name>
# 2. Create SKILL.md with frontmatter
cat > ~/.claude/skills/<skill-name>/SKILL.md << 'EOF'
---
name: <skill-name>
description: <What it does>. Use when <trigger phrases>. <Key capabilities>.
---
# <Skill title>
<Instructions for the skill workflow>
EOF
# 3. Add optional resources as needed
mkdir -p ~/.claude/skills/<skill-name>/{scripts,references,assets}
--- markers)| Field | Required | Description |
|-------|----------|-------------|
| name | No | Display name. Defaults to directory name. Lowercase, hyphens, max 64 chars. |
| description | Recommended | What + when + capabilities. Max 1024 chars. Determines when Claude activates the skill. |
| allowed-tools | No | Tools Claude can use without asking permission when skill is active. |
| argument-hint | No | Autocomplete hint for arguments. Example: [issue-number] |
| disable-model-invocation | No | true to prevent auto-invocation (manual /name only). |
| user-invocable | No | false to hide from / menu (background knowledge only). |
| model | No | Model override when skill is active. |
| context | No | fork to run in isolated subagent context. |
| agent | No | Subagent type when context: fork. Built-in: Explore, Plan, general-purpose. |
| hooks | No | Lifecycle hooks scoped to this skill. |
| Configuration | User can invoke | Claude can invoke |
|---------------|-----------------|-------------------|
| (defaults) | Yes | Yes |
| disable-model-invocation: true | Yes | No |
| user-invocable: false | No | Yes |
<What it does>. Use when <trigger phrases>. <Key capabilities>.
Include action verbs ("create", "handle"), user intent ("wants to", "needs to"), and domain keywords users would say.
skill-name/
├── SKILL.md # Required: instructions (keep under 500 lines)
├── scripts/ # Optional: executable code (deterministic, token-efficient)
├── references/ # Optional: docs loaded into context on demand
└── assets/ # Optional: files used in output, NOT loaded into context
# (templates, images, fonts, boilerplate)
Reference supporting files from SKILL.md so Claude knows they exist. Keep references one level deep. For files over 100 lines, include a table of contents.
| Type | Purpose | Loaded into context? |
|------|---------|---------------------|
| scripts/ | Deterministic operations, complex processing | No (executed via bash) |
| references/ | Documentation Claude reads while working | Yes, on demand |
| assets/ | Templates, images, fonts for output | No (copied/used in output) |
Only create scripts when they add value: complex multi-step processing, repeated code generation, deterministic reliability. Not for single-command wrappers.
Inject shell command output into skill content before loading:
## Recent commits
!`git log --oneline -5 2>/dev/null`
The output replaces the directive when the skill loads.
Pass arguments to skills invoked via /skill-name arg1 arg2:
| Variable | Value |
|----------|-------|
| $ARGUMENTS | Full argument string |
| $ARGUMENTS[0], $ARGUMENTS[1] | Individual arguments |
| $1, $2 | Shorthand for $ARGUMENTS[N] |
Run a skill in isolated context with context: fork:
---
name: deep-research
description: Research a topic thoroughly.
context: fork
agent: Explore
---
Match specificity to the task's fragility:
| Level | When to use | Example | |-------|-------------|---------| | High (text instructions) | Multiple valid approaches, context-dependent | "Analyze the code and suggest improvements" | | Medium (pseudocode/scripts with params) | Preferred pattern exists, some variation OK | Script with configurable parameters | | Low (specific scripts, few params) | Fragile operations, consistency critical | Exact sequence of API calls |
processing-pdfs), noun phrase (github-pr-creation), prefixed group (github-pr-*)references/official_best_practices.md - Principles, anti-patterns, quality checklist, testingreferences/skill_examples.md - Concrete skill examples with new featurestools
Handles PR review comments and feedback resolution. Use when user wants to resolve PR comments, handle review feedback, fix review comments, address PR review, check review status, respond to reviewer, verify PR readiness, review PR comments, analyze review feedback, evaluate PR comments, assess review suggestions, or triage PR comments. Fetches comments via GitHub CLI, classifies by severity, applies fixes with user confirmation, commits with proper format, replies to threads.
development
Merges GitHub Pull Requests after validating pre-merge checklist. Use when user wants to merge PR, close PR, finalize PR, complete merge, approve and merge, or execute merge. Runs pre-merge validation (tests, lint, CI, comments), confirms with user, merges with proper format, handles post-merge cleanup.
testing
Creates GitHub Pull Requests with automated validation and task tracking. Use when user wants to create PR, open pull request, submit for review, or check if ready for PR. Analyzes commits, validates task completion, generates Conventional Commits title and description, suggests labels. NOTE - for merging existing PRs, use github-pr-merge instead.
development
Creates git commits following Conventional Commits format with type/scope/subject. Use when user wants to commit changes, create commit, save work, or stage and commit. Enforces project-specific conventions from CLAUDE.md.