Agent skill
skill-composer
DAG-based multi-skill orchestration with dependency resolution.
Install this agent skill to your Project
npx add-skill https://github.com/notque/claude-code-toolkit/tree/main/skills/skill-composer
SKILL.md
Skill Composer
Overview
Orchestrate complex workflows by chaining multiple skills into validated execution DAGs. This skill discovers applicable skills, resolves dependencies, validates compatibility, presents execution plans, and manages skill-to-skill context passing. Use when a task requires 2+ skills chained together, parallel skill execution, or conditional branching between skills. Invoke the single skill directly when it can handle the request alone, or for simple sequential invocation that needs no dependency management.
Core principle: Minimize composition overhead. Prefer simple 2-3 skill chains. Add only skills directly needed or "nice to have" additions without explicit user request.
Instructions
Phase 1: DISCOVER
Goal: Analyze the task and find applicable skills.
Step 1: Analyze the user's request
Identify:
- Primary goals (what needs to be accomplished)
- Quality requirements (testing, verification, documentation)
- Domain constraints (language, framework, standards)
- Execution constraints (sequential vs parallel, conditionals)
Step 2: Discover available skills
Before building any DAG, scan skills/*/SKILL.md for available skills:
# TODO: scripts/discover_skills.py not yet implemented
# Manual alternative: scan skills directory for SKILL.md files
find ./skills -name "SKILL.md" -exec grep -l "^name:" {} \; | sort
Review the discovered skills. Categorize by type (workflow, testing, quality, documentation, code-analysis, debugging) with dependency metadata.
Step 3: Select skills (Apply minimum-skills principle)
Choose only skills directly needed for the stated goals. This prevents over-composition and unnecessary failure points:
- Can a single skill handle this? If yes, invoke it directly. Invoke it directly.
- Can 2 skills handle this? Prefer that over 3+.
- Is a skill being added "for quality" or "just in case"? Remove it.
Cross-reference selections against references/compatibility-matrix.md to confirm chaining is valid before proceeding.
Gate: Task goals identified. Available skills indexed. Selected skills directly address stated goals with no extras. Proceed only when gate passes.
Phase 2: PLAN
Goal: Build a validated execution DAG.
Step 1: Build the DAG
Construct the execution DAG as a JSON structure with nodes (skills) and edges (dependencies) based on the task analysis:
# TODO: scripts/build_dag.py not yet implemented
# Manual alternative: structure the DAG in your reasoning before presenting it
Step 2: Validate the DAG (MANDATORY before execution)
ALWAYS validate the execution graph is acyclic before moving to execution. Validation checks:
- Acyclic: No circular dependencies exist between skills
- Compatibility: Output types from each skill match input requirements of downstream skills (consult
references/compatibility-matrix.md) - Availability: All referenced skills exist in the skill index
- Ordering: Dependencies satisfy topological ordering
If validation fails, fix the issue and re-validate. Common fixes:
- Circular dependency: Remove one edge or split into two independent compositions
- Type mismatch: Choose different skill or add transformation step
- Missing skill: Check spelling, re-run discovery
- Ordering violation: Reorder phases to satisfy dependencies
Step 3: Present the execution plan (Dry run is MANDATORY)
ALWAYS show the execution plan and get user confirmation before running skills. This prevents wasting time on composition errors:
=== Execution Plan ===
Phase 1 (Sequential):
-> skill-name
Purpose: [what it does in this context]
Output: [what it produces]
Phase 2 (Parallel):
-> skill-a
Purpose: [what it does]
Input: [from Phase 1]
-> skill-b
Purpose: [what it does]
Input: [from Phase 1]
Phase 3 (Sequential):
-> skill-c
Purpose: [what it does]
Input: [from Phase 2]
Skills: N | Phases: N | Parallel phases: N
Proceed? [Y/n]
Gate: DAG is acyclic. All skills exist. Input/output types are compatible. Topological ordering is valid. User has seen the plan. Proceed only when gate passes.
Phase 3: EXECUTE
Goal: Run skills in topological order, passing context between them.
Step 1: Execute each phase
For sequential phases:
- Invoke skill with context from previous phases
- Capture output
- Verify output/input compatibility between chained skills
- Proceed to next phase
For parallel phases:
- Launch all independent skills using Task tool (execute independent skills concurrently when no shared resources or dependencies exist)
- Wait for all to complete
- Aggregate results for next phase
Step 2: Pass context between skills
ALWAYS verify output/input compatibility between chained skills before passing context:
- Capture output from completed skill
- Transform to format expected by next skill (validate using
references/compatibility-matrix.md) - Inject as context when invoking next skill
- Verify transformation succeeded
Step 3: Report progress
After each phase completes, report:
- Phase number and skills completed
- Output summary
- Overall progress (e.g., "Phase 2/3 complete")
Show command output rather than describing it. Be concise but informative.
Step 4: Handle failures during execution
ALWAYS catch skill failures and determine if remaining chain can continue. If a skill fails mid-chain:
-
Assess impact: Does this block downstream skills?
- Critical (blocks all downstream): Stop chain, report what completed
- Isolated (blocks one branch): Continue other branches
- Recoverable (transient failure): Retry with adjusted parameters (max 2 attempts)
-
Report failure context:
Skill failed: [skill-name]
Phase: N
Error: [error message]
Downstream impact: [list blocked skills]
Continuing branches: [list unaffected skills]
Recovery options:
1. Fix error and retry
2. Skip skill and continue (if non-critical)
3. Abort entire workflow
- Execute recovery: Based on user selection or automatic policy (if auto-retry enabled)
Gate: All phases executed. All skill outputs captured. Context passed successfully between all transitions. Proceed only when gate passes.
Phase 4: REPORT
Goal: Collect results and clean up.
Step 1: Generate results summary
=== Composition Results ===
Execution Summary:
Total phases: N
Skills executed: N
Duration: X minutes
Phase Results:
Phase 1: [skill-name] - [status]
Output: [summary]
Phase 2: [skill-a] - [status]
[skill-b] - [status]
Output: [summary]
Phase 3: [skill-c] - [status]
Output: [summary]
Final Output:
[Key deliverables with file paths]
Step 2: Clean up temporary files
Remove temporary files at task completion. Keep only files explicitly needed for final output:
/tmp/skill-index.json/tmp/execution-dag.json- Any intermediate output files created during composition
Gate: Results reported. Temporary files cleaned up. Composition complete.
Error Handling
Error: "Circular dependency detected"
Cause: Skills reference each other cyclically in the DAG Solution:
- Review dependency graph for cycles
- Remove or reorder the problematic dependency
- Consider splitting into independent compositions
- Re-validate DAG before proceeding
Error: "Skill output incompatible with next skill input"
Cause: Output type from one skill does not match expected input of the next Solution:
- Consult
references/compatibility-matrix.mdfor valid chains - Add an intermediate transformation skill if one exists
- Choose a different skill combination that has compatible types
- Re-validate after changes
Error: "Skill failed during execution"
Cause: A skill in the chain encountered an error Solution:
- Determine failure impact: critical (blocks downstream), isolated (one branch), or recoverable
- If isolated: continue other branches, report partial results
- If recoverable: retry with adjusted parameters (max 2 attempts)
- If critical: abort chain, report what completed, suggest recovery options
Error: "Skill not found in index"
Cause: Referenced skill does not exist or name is misspelled Solution:
- Check spelling against skill index output
- Re-run discovery script to refresh the index
- Verify the skill directory exists under skills/
- Use the suggested alternative from the discovery output if the name was close
References
${CLAUDE_SKILL_DIR}/references/composition-patterns.md: Proven multi-skill composition patterns with duration estimates${CLAUDE_SKILL_DIR}/references/compatibility-matrix.md: Skill input/output compatibility and valid chains${CLAUDE_SKILL_DIR}/references/skill-patterns.md: Common skill patterns with sequential/parallel decision trees
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
voice-writer
Unified voice content generation pipeline with mandatory validation and joy-check. 9-phase pipeline: LOAD, GROUND, GENERATE, VALIDATE, REFINE, JOY-CHECK, OUTPUT, CLEANUP. Use when writing articles, blog posts, or any content that uses a voice profile. Use for "write article", "blog post", "write in voice", "generate content", "draft article", "write about".
image-auditor
Non-destructive image validation for accessibility and health.
video-editing
Video editing pipeline: cut footage, assemble clips via FFmpeg and Remotion.
comment-quality
Review and fix temporal references in code comments.
e2e-testing
Playwright-based end-to-end testing workflow.
anti-ai-editor
Remove AI-sounding patterns from content.
Didn't find tool you were looking for?