Agent skill
create-skill
Guide creation of a new GAAI skill following the agentskills.io spec and GAAI best practices. Activate when adding a new skill to the .gaai/core/skills/ catalog.
Install this agent skill to your Project
npx add-skill https://github.com/Fr-e-d/GAAI-framework/tree/main/.gaai/core/skills/cross/create-skill
Metadata
Additional technical details for this skill
- id
- SKILL-CRS-016
- track
- cross-cutting
- author
- gaai-framework
- status
- stable
- version
- 1.0
- category
- cross
- updated at
- 1772064000
SKILL.md
Create Skill
Purpose / When to Activate
Activate when:
- A new capability is needed that no existing skill covers
- A skill is being extracted from agent logic that has become reusable
- Extending a forked GAAI installation with project-specific skills
This skill is self-referential: it uses the agentskills.io spec to author a spec-compliant skill.
Prerequisites
Before activating:
- Confirm no existing skill already covers the intended capability (check
README.skills.md) - Confirm the new skill is a pure execution unit — it executes, it does not reason
- Confirm the skill belongs to exactly one category (discovery / delivery / cross)
- Have a clear, one-sentence description of: WHAT it does and WHEN to activate it
If a skill "appears to think" in the design, it is wrongly scoped. Redesign or split.
Process
Step 1 — Name and classify
Derive the skill name from the action it performs:
- Use lowercase kebab-case
- Name should be a verb phrase:
generate-stories,qa-review,memory-compact - Category: discovery (produces artefacts) | delivery (implements/validates) | cross (shared utility)
Verify name does not conflict with an existing skill in README.skills.md.
Step 2 — Define inputs and outputs explicitly
List every input the skill requires. Be specific:
- What file paths does it read?
- What structured data does it receive from the invoking agent?
- What context is assumed to be present?
List every output the skill produces:
- File paths created or modified
- Structured data returned to the agent
- Side effects (backlog state changes, memory updates)
If inputs or outputs are unclear, the skill is not ready to be written. Clarify first.
Step 3 — Write the SKILL.md frontmatter
---
name: {skill-name} # matches directory name exactly
description: {one sentence} # WHAT it does + WHEN to activate
license: ELv2
compatibility: Works with any filesystem-based AI coding agent
metadata:
author: {author}
version: "1.0"
category: {discovery|delivery|cross}
track: {discovery|delivery|cross-cutting}
id: SKILL-{CAT}-{NNN}
updated_at: {YYYY-MM-DD}
status: stable|experimental # use experimental for new/unproven skills
inputs:
- {input_1}: {description}
- {input_2}: {description}
outputs:
- {output_path_or_description}
---
Description rule: Must be one sentence, ≤ 1024 characters. Format:
"{Verb phrase that describes the output} when {activation condition}."
Example: "Generate Stories from an Epic with testable acceptance criteria when Discovery is refining a new feature scope."
Step 4 — Write the skill body
Required sections:
# {Skill Title}
## Purpose / When to Activate
When and why an agent should invoke this skill. Be explicit.
## Process
Numbered steps. Each step produces a specific output or advances the state.
Steps must be deterministic: same inputs → same outputs.
## Quality Checks
What must be true for the output to be acceptable.
List as assertions, not descriptions.
## Outputs
Exact file paths or structured outputs produced.
## Non-Goals
What this skill must NOT do. Prevents scope creep.
Add a final line if applicable:
No silent assumptions. Every {X} becomes explicit and governed.
Step 5 — Create directory and file
.gaai/core/skills/{category}/{skill-name}/SKILL.md
SKILL.md filename is always uppercase (spec requirement).
Optional subdirectories (create only if needed):
references/— supporting documents the skill referencesassets/— templates or static files the skill produces
Step 6 — Update ALL relevant indices (MANDATORY)
This step is non-negotiable. A skill that is not indexed is invisible to agents.
6a. Skills index YAML:
- Invoke
build-skills-indexto regenerate both.gaai/core/skills/skills-index.yaml(core) and.gaai/project/skills/skills-index.yaml(project) - Verify the new skill appears in the generated index with correct
id,name,path, andtags
6b. Skills README:
- Core skills: update
.gaai/core/skills/README.skills.md— add the skill to the appropriate category section - Project skills: update
.gaai/project/skills/README.md— add the skill to the appropriate section
6c. Domain index (if domain-scoped skill):
- If the skill belongs to a domain (e.g.,
domains/content-production/), update the domain'sindex.mdin memory:.gaai/project/contexts/memory/domains/{domain}/index.md— add a row to the skills table
- This ensures domain sub-agents discover the skill when loading their domain context
Failure to update any of these indices means the skill is effectively invisible — agents cannot discover it, and it will not be loaded during delivery or discovery sessions.
Step 7 — Reference in agent file
If the skill is intended for a specific agent (Discovery or Delivery), add it to the agent's skill list in:
.gaai/core/agents/discovery.agent.md— Skills Used section.gaai/core/agents/delivery.agent.md— Skills Used section- Or neither, if it's a general cross skill invoked opportunistically
Quality Checks
- Skill name matches directory name exactly
SKILL.mdfrontmatter hasnameanddescriptionat top level (spec requirement)- Description is ≤ 1024 characters, one sentence
- All inputs are explicitly declared
- All outputs are explicitly declared with file paths where applicable
- Skill body has all 5 required sections
- Non-Goals section explicitly prevents scope creep
README.skills.mdupdatedhealth-check.shpasses after creation
Non-Goals
This skill must NOT:
- Design agent behavior or orchestration logic (that is an agent concern)
- Make decisions about when to activate the skill (the invoking agent decides)
- Merge or replace an existing skill (deprecation requires explicit human decision)
A skill that appears to think is wrongly designed. Redesign before authoring.
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
ci-watch-and-fix
Watch GitHub Actions CI after PR creation, detect failures, extract logs, apply minimal fixes, and re-push — keeping the delivery session alive until CI resolves or escalating after 3 cycles. Activate immediately after gh pr create and before marking the story done.
qa-review
Validate that implemented code fully satisfies Story acceptance criteria, respects rules, and introduces no regressions. This is the hard quality gate — no pass means no delivery. Activate after implementation is complete.
compose-team
Assemble the context bundles for each sub-agent based on evaluate-story output. Produces spawn-ready packages for Planning, Implementation, QA, or MicroDelivery sub-agents. Activate after evaluate-story, before spawning any sub-agent.
coordinate-handoffs
Validate sub-agent handoff artefacts, sequence phase transitions, and manage retry and escalation logic. Activate after each sub-agent terminates to determine next action.
implement
Generate correct, minimal, maintainable code that satisfies a validated Story's acceptance criteria against an execution plan. Activate when a Story is validated, a plan exists, and all prerequisites are unambiguous.
delivery-high-level-plan
Transform validated Stories into a clear, minimal, governed execution plan. Used by the Planning Sub-Agent as the first planning pass before prepare-execution-plan for Tier 2/3, or as the sole planning output for simple Stories.
Didn't find tool you were looking for?