OpenSpace skill-template-generator
Generate properly-formatted SKILL.md files from extracted architectural patterns. Turns raw pattern descriptions into reusable skills that OpenSpace can discover, select, and evolve.
git clone https://github.com/HKUDS/OpenSpace
T=$(mktemp -d) && git clone --depth=1 https://github.com/HKUDS/OpenSpace "$T" && mkdir -p ~/.claude/skills && cp -r "$T/showcase/skills/skill-template-generator" ~/.claude/skills/hkuds-openspace-skill-template-generator && rm -rf "$T"
showcase/skills/skill-template-generator/SKILL.mdSkill Template Generator
Given a structured pattern description (from
codebase-pattern-analyzer or manual analysis), generate a valid SKILL.md file that OpenSpace can register, select for tasks, and evolve over time.
When to Use
- After extracting a pattern from a reference codebase, you need to package it as a reusable skill
- You want to create a new skill that teaches an agent how to perform a specific kind of task
- You are converting informal documentation or code examples into the SKILL.md format
SKILL.md Format
Every skill is a directory containing at minimum a
SKILL.md file:
my-skill-name/ ├── SKILL.md # Required — the skill definition ├── scripts/ # Optional — helper scripts ├── references/ # Optional — reference data files └── assets/ # Optional — images, templates
Frontmatter (Required)
The file MUST start with YAML frontmatter containing exactly two fields:
--- name: my-skill-name description: One-sentence description of what this skill teaches. Must be specific enough for LLM skill selection to match it to relevant tasks. ---
Rules:
must match the directory name (kebab-case, lowercase)name
should be 15-40 words, include key terms an LLM would search fordescription- No other frontmatter fields — everything else goes in the markdown body
Body Structure
The markdown body follows this template:
# [Skill Title] [1-2 sentence summary of what this skill enables] ## When to Use - [Trigger condition 1] - [Trigger condition 2] - [Trigger condition 3] ## [Core Content Sections] [Step-by-step instructions, code templates, API references, etc.] ## Key Patterns 1. [Convention or best practice 1] 2. [Convention or best practice 2] ...
Step 1: Determine Skill Category
Match the pattern to one of three OpenSpace categories:
| Category | Use When | Example |
|---|---|---|
| The skill teaches how to use a specific tool or technique | "How to analyze a codebase", "How to use Finnhub API" |
| The skill prescribes an end-to-end procedure with ordered steps | "Create a panel component", "Set up API proxy endpoint" |
| The skill provides knowledge that informs decisions | "WorldMonitor architecture index", "News API comparison" |
The category affects how OpenSpace judges the skill during execution analysis:
- workflow: Was the agent able to follow the prescribed steps?
- tool_guide: Did the agent use the described tool/approach?
- reference: Did the knowledge influence agent decisions?
Step 2: Write the Description
The
description field is the most critical line — it determines whether OpenSpace selects this skill for a given task.
Good descriptions (specific, searchable):
- "Create a dashboard panel component using vanilla TypeScript DOM API, following the worldmonitor Panel architecture."
- "Integrate with Finnhub Stock API for real-time and historical stock market data."
- "CSS grid layout system for a responsive panel dashboard with dark theme."
Bad descriptions (vague, generic):
- "A useful skill for building things."
- "TypeScript patterns."
- "How to make a panel."
Formula:
[Action verb] + [specific subject] + [key technology/approach] + [context/project reference]
Step 3: Write Actionable Instructions
The body must be concrete enough that an AI agent can follow it without guessing.
For Workflow Skills
Include:
- File paths — exact paths where files should be created (
)src/components/MyPanel.ts - Code templates — complete, runnable code blocks (not pseudocode)
- Import statements — every import the code needs
- Interface definitions — typed data shapes
- Integration points — how this connects to other parts of the project
Use
{baseDir} for paths relative to the skill directory:
Read the reference file at {baseDir}/references/example.json
For Tool Guide Skills
Include:
- API endpoints — full URLs with parameter documentation
- Auth mechanism — how to authenticate (query param, header, etc.)
- Response shapes — JSON examples with field descriptions
- Rate limits — free tier limitations
- Error handling — common errors and how to handle them
For Reference Skills
Include:
- Structured index — tables, lists, or maps of the reference material
- Key file paths — where to find specific things in the reference codebase
- Architecture decisions — WHY certain patterns were chosen
- Comparison tables — alternatives and tradeoffs
Step 4: Add Dependency Hints
If the skill depends on patterns from other skills, mention them explicitly:
## Prerequisites This skill builds on: - `panel-component` — for the Panel base class - `data-service` — for the circuit breaker pattern - `api-proxy-endpoint` — for server-side API key isolation
This helps OpenSpace understand skill composition when DERIVING new skills.
Step 5: Validate the Skill
Before saving, verify:
- Frontmatter is valid YAML — no tabs, proper indentation, quotes around special chars
- Name matches directory —
lives inname: foo-barfoo-bar/SKILL.md - Code blocks are complete — every snippet can be copy-pasted and run
- No broken references — all file paths and URLs are valid
- Description is specific — would an LLM pick this skill for the right task?
Example: Converting a Pattern to a Skill
Input (from codebase-pattern-analyzer):
Pattern: Circuit Breaker Data Service Source: worldmonitor/src/services/*.ts Category: service Structure: Module-level CircuitBreaker instance, async fetch functions, typed interfaces Key code: createCircuitBreaker({ name, cacheTtlMs }), breaker.execute(fn, default)
Output (
data-service/SKILL.md):
--- name: data-service description: Create data fetching services with circuit breaker pattern for API resilience. Services handle fetch, cache, retry, and expose typed data to panel components. --- # Data Service Pattern Each panel's data comes from a dedicated service module in `src/services/`. ... ## Circuit Breaker [Full implementation code] ## Service Module Pattern [Template with typed interfaces, breaker usage, export functions] ## Key Patterns 1. One circuit breaker per API endpoint 2. Export typed interfaces for data shapes 3. Wrap fetch calls in breaker.execute(fn, defaultValue) ...
Evolution Hooks
Skills generated by this workflow are designed to evolve:
- FIX: When an API changes or code pattern breaks, OpenSpace updates the skill in-place
- DERIVED: When a new panel needs a similar service, OpenSpace derives a specialized version
- CAPTURED: When an agent discovers a novel pattern during execution, OpenSpace captures it as a new skill
The better the initial skill quality, the better the evolved descendants.