Back to Skills

creating-skill

majiayu000
Updated Today
1 views
58
9
58
View on GitHub
Metaaidesign

About

This skill helps developers create and structure custom Claude Skills for reusable, portable expertise. It provides guidance on when skills are appropriate versus project-specific instructions or one-off tasks. The skill outlines required file structure and automatic activation based on trigger patterns.

Quick Install

Claude Code

Recommended
Plugin CommandRecommended
/plugin add https://github.com/majiayu000/claude-skill-registry
Git CloneAlternative
git clone https://github.com/majiayu000/claude-skill-registry.git ~/.claude/skills/creating-skill

Copy and paste this command in Claude Code to install this skill

Documentation

Creating Skills

Create portable, reusable expertise that extends Claude's capabilities across contexts.

When to Create Skills

Skills are appropriate when:

  • Capability needed across multiple projects/conversations
  • Procedural knowledge that applies broadly (not project-specific)
  • Instructions should activate automatically on trigger patterns
  • Want portable expertise that loads progressively on-demand

Not appropriate when:

  • Context is project-specific (use Project instructions instead)
  • One-off task (use standalone prompt instead)
  • See crafting-instructions skill for detailed decision framework

Skill Structure

Every skill is a directory containing:

  • SKILL.md (required): Frontmatter + imperative instructions
  • scripts/ (optional): Executable code for deterministic operations
  • references/ (optional): Detailed docs loaded on-demand
  • assets/ (optional): Templates/files used in output

Create this structure directly:

mkdir -p skill-name/{scripts,references,assets}

Delete unused directories before packaging.

Naming Convention

Use gerund form (verb + -ing):

  • processing-pdfs, analyzing-data, creating-reports
  • pdf-helper, data-tool, report-maker

Requirements:

  • Lowercase letters, numbers, hyphens only
  • Max 64 characters
  • No reserved words (anthropic, claude)

Frontmatter Requirements

---
name: skill-name
description: What it does. Use when [trigger patterns].
---

name: Follow naming convention above

description: (max 1024 chars)

  • Third person voice: "Processes files" not "I process files"
  • WHAT it does + WHEN to use it (trigger patterns)
  • Specify: file types, keywords, task types that should activate this skill
  • No XML tags

Good examples:

  • "Creates PowerPoint presentations. Use when users mention slides, .pptx files, or presentations."
  • "Analyzes SQL queries for performance. Use when debugging slow queries, optimization requests, or EXPLAIN output."

Ineffective examples:

  • "I can help create presentations" (first person, no triggers)
  • "Presentation creator" (no triggers, vague what)
  • "Advanced presentation creation with animations" (over-detailed implementation)

The description is critical—it determines when Claude activates this skill.

Writing Effective SKILL.md

Apply crafting-instructions principles:

Imperative Construction

Frame as direct commands:

  • ✅ "Extract text with pdfplumber" / "Validate output with script"
  • ❌ "Consider extracting..." / "You might want to validate..."

Strategic Over Procedural

Specify goals and decision frameworks, not step-by-step procedures:

  • ✅ "Create skill directory structure. Delete unused resource directories."
  • ❌ "Step 1: mkdir skill-name. Step 2: mkdir scripts. Step 3: mkdir references..."

Provide steps only when order is non-obvious or fragile.

Trust Base Behavior

Claude already knows:

  • Basic programming patterns, common tools, file operations
  • How to structure clear output, format markdown
  • General best practices for code quality

Only specify skill-specific deviations or domain expertise Claude lacks.

Positive Directive Framing

State what TO do, not what to avoid:

  • ✅ "Write in imperative voice with direct instructions"
  • ❌ "Don't use suggestive language or tentative phrasing"

Frame requirements positively because it's clearer and more actionable.

Provide Context

Explain WHY for non-obvious requirements:

  • ✅ "Keep SKILL.md under 500 lines to enable progressive loading—move detailed content to references/"
  • ❌ "Keep SKILL.md under 500 lines"

Context helps Claude make good autonomous decisions in edge cases.

Example Quality

Examples teach ALL patterns, including unintended ones. Ensure every aspect demonstrates desired behavior. Better to omit examples than include mixed signals.

For comprehensive prompting guidance, invoke crafting-instructions skill.

Bundled Resources Patterns

scripts/

Add when Claude would repeatedly write similar code:

  • Validation logic (schema checking, format verification)
  • Complex transformations (data normalization, format conversion)
  • Deterministic operations requiring exact consistency

Scripts should have explicit error handling and clear variable names.

references/

Add when:

  • SKILL.md approaching 500 lines
  • Detailed domain knowledge (API docs, schemas, specifications)
  • Content applies to specific use cases only, not core workflow

Keep references one level deep (avoid file1 → file2 → file3 chains).

assets/

Add for:

  • Templates users will receive in output
  • Files copied/referenced but not loaded into context
  • Images, fonts, static resources

Assets save tokens—they're used but not read into context.

Decision framework: Will Claude repeatedly generate similar code? → scripts/. Is there extensive domain knowledge? → references/. Are there output templates? → assets/. Otherwise SKILL.md only.

Progressive Disclosure

Skills load in three tiers:

  1. Metadata (name + description): Always loaded for all skills
  2. SKILL.md body: Loaded when skill activates
  3. Bundled resources: Loaded as Claude reads them

Keep SKILL.md focused on core workflows (~500 lines max). Move detailed content to references/ for on-demand loading. This enables context-efficient skill ecosystems.

Token Efficiency

Challenge each line: Does Claude really need this explanation? Can I assume Claude knows this? Does this justify its token cost?

Prefer concise patterns:

  • Code examples over verbose explanations
  • Decision frameworks over exhaustive lists
  • Strategic goals over procedural steps

Packaging & Delivery

Create ZIP archive:

cd /home/claude
zip -r /mnt/user-data/outputs/skill-name.zip skill-name/

Verify contents:

unzip -l /mnt/user-data/outputs/skill-name.zip

Show user the packaged structure:

tree skill-name/
# or
ls -lhR skill-name/

Provide download link:

[Download skill-name.zip](computer:///mnt/user-data/outputs/skill-name.zip)

Version Control (Optional)

For skills under active development, track changes:

cd /home/claude/skill-name
git init && git add . && git commit -m "Initial: skill structure"

After modifications:

git add . && git commit -m "Update: description of change"

See versioning-skills for advanced patterns (rollback, branching, comparison).

Best Practices

Structure:

  • Lead with clear overview of what skill enables
  • Group related instructions together
  • Use headings that describe goals, not procedures
  • Reference other skills/resources when appropriate

Instructions:

  • Write TO Claude (imperative commands) not ABOUT Claude (documentation)
  • Assume Claude's intelligence—avoid over-explaining basics
  • Show code examples for complex patterns
  • Specify success criteria, let Claude determine approach

Content:

  • Keep frequently-used guidance in SKILL.md
  • Move detailed/specialized content to references/
  • Include WHY context for non-obvious requirements
  • Use consistent terminology throughout

Resources:

  • Only add bundled resources that solve real problems
  • Scripts should have error handling and clear outputs
  • References should be focused and topic-specific
  • Delete unused directories before packaging

Testing:

  • Test with 3+ real scenarios (simple, complex, edge case)
  • Verify skill activates on expected trigger patterns
  • Confirm bundled resources are accessible and functional
  • Iterate based on actual usage, not assumptions

Quality Checklist

Before providing skill to user:

Metadata:

  • Name: lowercase, hyphens, gerund form, max 64 chars
  • Description: third person, includes WHAT + WHEN triggers, max 1024 chars, no XML

Structure:

  • SKILL.md under 500 lines (move extras to references/)
  • Unused directories deleted
  • References one level deep (no long chains)

Content:

  • Imperative voice throughout
  • Positive directives (not negative restrictions)
  • Strategic goals over procedural steps where possible
  • Context provided for non-obvious requirements
  • Examples perfectly demonstrate desired patterns
  • Consistent terminology

Resources:

  • Scripts solve actual problems (not punting to Claude)
  • Scripts have error handling and clear outputs
  • References are focused and topic-specific
  • Assets are templates/files for output

Testing:

  • Tested on 3+ real scenarios
  • Activates on expected triggers
  • Bundled resources accessible
  • Package structure verified

Advanced Topics

For complex skill patterns, see:

GitHub Repository

majiayu000/claude-skill-registry
Path: skills/creating-skill

Related Skills

content-collections

Meta

This skill provides a production-tested setup for Content Collections, a TypeScript-first tool that transforms Markdown/MDX files into type-safe data collections with Zod validation. Use it when building blogs, documentation sites, or content-heavy Vite + React applications to ensure type safety and automatic content validation. It covers everything from Vite plugin configuration and MDX compilation to deployment optimization and schema validation.

View skill

creating-opencode-plugins

Meta

This skill provides the structure and API specifications for creating OpenCode plugins that hook into 25+ event types like commands, files, and LSP operations. It offers implementation patterns for JavaScript/TypeScript modules that intercept and extend the AI assistant's lifecycle. Use it when you need to build event-driven plugins for monitoring, custom handling, or extending OpenCode's capabilities.

View skill

sglang

Meta

SGLang is a high-performance LLM serving framework that specializes in fast, structured generation for JSON, regex, and agentic workflows using its RadixAttention prefix caching. It delivers significantly faster inference, especially for tasks with repeated prefixes, making it ideal for complex, structured outputs and multi-turn conversations. Choose SGLang over alternatives like vLLM when you need constrained decoding or are building applications with extensive prefix sharing.

View skill

evaluating-llms-harness

Testing

This Claude Skill runs the lm-evaluation-harness to benchmark LLMs across 60+ standardized academic tasks like MMLU and GSM8K. It's designed for developers to compare model quality, track training progress, or report academic results. The tool supports various backends including HuggingFace and vLLM models.

View skill