opencode-metis 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (156) hide show
  1. package/README.md +140 -0
  2. package/dist/cli.cjs +63 -0
  3. package/dist/mcp-server.cjs +51 -0
  4. package/dist/plugin.cjs +4 -0
  5. package/dist/worker.cjs +224 -0
  6. package/opencode/agent/the-analyst/feature-prioritization.md +66 -0
  7. package/opencode/agent/the-analyst/market-research.md +77 -0
  8. package/opencode/agent/the-analyst/project-coordination.md +81 -0
  9. package/opencode/agent/the-analyst/requirements-analysis.md +77 -0
  10. package/opencode/agent/the-architect/compatibility-review.md +138 -0
  11. package/opencode/agent/the-architect/complexity-review.md +137 -0
  12. package/opencode/agent/the-architect/quality-review.md +67 -0
  13. package/opencode/agent/the-architect/security-review.md +127 -0
  14. package/opencode/agent/the-architect/system-architecture.md +119 -0
  15. package/opencode/agent/the-architect/system-documentation.md +83 -0
  16. package/opencode/agent/the-architect/technology-research.md +85 -0
  17. package/opencode/agent/the-chief.md +79 -0
  18. package/opencode/agent/the-designer/accessibility-implementation.md +101 -0
  19. package/opencode/agent/the-designer/design-foundation.md +74 -0
  20. package/opencode/agent/the-designer/interaction-architecture.md +75 -0
  21. package/opencode/agent/the-designer/user-research.md +70 -0
  22. package/opencode/agent/the-meta-agent.md +155 -0
  23. package/opencode/agent/the-platform-engineer/ci-cd-pipelines.md +109 -0
  24. package/opencode/agent/the-platform-engineer/containerization.md +106 -0
  25. package/opencode/agent/the-platform-engineer/data-architecture.md +81 -0
  26. package/opencode/agent/the-platform-engineer/dependency-review.md +144 -0
  27. package/opencode/agent/the-platform-engineer/deployment-automation.md +81 -0
  28. package/opencode/agent/the-platform-engineer/infrastructure-as-code.md +107 -0
  29. package/opencode/agent/the-platform-engineer/performance-tuning.md +82 -0
  30. package/opencode/agent/the-platform-engineer/pipeline-engineering.md +81 -0
  31. package/opencode/agent/the-platform-engineer/production-monitoring.md +105 -0
  32. package/opencode/agent/the-qa-engineer/exploratory-testing.md +66 -0
  33. package/opencode/agent/the-qa-engineer/performance-testing.md +81 -0
  34. package/opencode/agent/the-qa-engineer/quality-assurance.md +77 -0
  35. package/opencode/agent/the-qa-engineer/test-execution.md +66 -0
  36. package/opencode/agent/the-software-engineer/api-development.md +78 -0
  37. package/opencode/agent/the-software-engineer/component-development.md +79 -0
  38. package/opencode/agent/the-software-engineer/concurrency-review.md +141 -0
  39. package/opencode/agent/the-software-engineer/domain-modeling.md +66 -0
  40. package/opencode/agent/the-software-engineer/performance-optimization.md +113 -0
  41. package/opencode/command/analyze.md +149 -0
  42. package/opencode/command/constitution.md +178 -0
  43. package/opencode/command/debug.md +194 -0
  44. package/opencode/command/document.md +178 -0
  45. package/opencode/command/implement.md +225 -0
  46. package/opencode/command/refactor.md +207 -0
  47. package/opencode/command/review.md +229 -0
  48. package/opencode/command/simplify.md +267 -0
  49. package/opencode/command/specify.md +191 -0
  50. package/opencode/command/validate.md +224 -0
  51. package/opencode/skill/accessibility-design/SKILL.md +566 -0
  52. package/opencode/skill/accessibility-design/checklists/wcag-checklist.md +435 -0
  53. package/opencode/skill/agent-coordination/SKILL.md +224 -0
  54. package/opencode/skill/api-contract-design/SKILL.md +550 -0
  55. package/opencode/skill/api-contract-design/templates/graphql-schema-template.md +818 -0
  56. package/opencode/skill/api-contract-design/templates/rest-api-template.md +417 -0
  57. package/opencode/skill/architecture-design/SKILL.md +160 -0
  58. package/opencode/skill/architecture-design/examples/architecture-examples.md +170 -0
  59. package/opencode/skill/architecture-design/template.md +749 -0
  60. package/opencode/skill/architecture-design/validation.md +99 -0
  61. package/opencode/skill/architecture-selection/SKILL.md +522 -0
  62. package/opencode/skill/architecture-selection/examples/adrs/001-example-adr.md +71 -0
  63. package/opencode/skill/architecture-selection/examples/architecture-patterns.md +239 -0
  64. package/opencode/skill/bug-diagnosis/SKILL.md +235 -0
  65. package/opencode/skill/code-quality-review/SKILL.md +337 -0
  66. package/opencode/skill/code-quality-review/examples/anti-patterns.md +629 -0
  67. package/opencode/skill/code-quality-review/reference.md +322 -0
  68. package/opencode/skill/code-review/SKILL.md +363 -0
  69. package/opencode/skill/code-review/reference.md +450 -0
  70. package/opencode/skill/codebase-analysis/SKILL.md +139 -0
  71. package/opencode/skill/codebase-navigation/SKILL.md +227 -0
  72. package/opencode/skill/codebase-navigation/examples/exploration-patterns.md +263 -0
  73. package/opencode/skill/coding-conventions/SKILL.md +178 -0
  74. package/opencode/skill/coding-conventions/checklists/accessibility-checklist.md +176 -0
  75. package/opencode/skill/coding-conventions/checklists/performance-checklist.md +154 -0
  76. package/opencode/skill/coding-conventions/checklists/security-checklist.md +127 -0
  77. package/opencode/skill/constitution-validation/SKILL.md +315 -0
  78. package/opencode/skill/constitution-validation/examples/CONSTITUTION.md +202 -0
  79. package/opencode/skill/constitution-validation/reference/rule-patterns.md +328 -0
  80. package/opencode/skill/constitution-validation/template.md +115 -0
  81. package/opencode/skill/context-preservation/SKILL.md +445 -0
  82. package/opencode/skill/data-modeling/SKILL.md +385 -0
  83. package/opencode/skill/data-modeling/templates/schema-design-template.md +268 -0
  84. package/opencode/skill/deployment-pipeline-design/SKILL.md +579 -0
  85. package/opencode/skill/deployment-pipeline-design/templates/pipeline-template.md +633 -0
  86. package/opencode/skill/documentation-extraction/SKILL.md +259 -0
  87. package/opencode/skill/documentation-sync/SKILL.md +431 -0
  88. package/opencode/skill/domain-driven-design/SKILL.md +509 -0
  89. package/opencode/skill/domain-driven-design/examples/ddd-patterns.md +688 -0
  90. package/opencode/skill/domain-driven-design/reference.md +465 -0
  91. package/opencode/skill/drift-detection/SKILL.md +383 -0
  92. package/opencode/skill/drift-detection/reference.md +340 -0
  93. package/opencode/skill/error-recovery/SKILL.md +162 -0
  94. package/opencode/skill/error-recovery/examples/error-patterns.md +484 -0
  95. package/opencode/skill/feature-prioritization/SKILL.md +419 -0
  96. package/opencode/skill/feature-prioritization/examples/rice-template.md +139 -0
  97. package/opencode/skill/feature-prioritization/reference.md +256 -0
  98. package/opencode/skill/git-workflow/SKILL.md +453 -0
  99. package/opencode/skill/implementation-planning/SKILL.md +215 -0
  100. package/opencode/skill/implementation-planning/examples/phase-examples.md +217 -0
  101. package/opencode/skill/implementation-planning/template.md +220 -0
  102. package/opencode/skill/implementation-planning/validation.md +88 -0
  103. package/opencode/skill/implementation-verification/SKILL.md +272 -0
  104. package/opencode/skill/knowledge-capture/SKILL.md +265 -0
  105. package/opencode/skill/knowledge-capture/reference/knowledge-capture.md +402 -0
  106. package/opencode/skill/knowledge-capture/reference.md +444 -0
  107. package/opencode/skill/knowledge-capture/templates/domain-template.md +325 -0
  108. package/opencode/skill/knowledge-capture/templates/interface-template.md +255 -0
  109. package/opencode/skill/knowledge-capture/templates/pattern-template.md +144 -0
  110. package/opencode/skill/observability-design/SKILL.md +291 -0
  111. package/opencode/skill/observability-design/references/monitoring-patterns.md +461 -0
  112. package/opencode/skill/pattern-detection/SKILL.md +171 -0
  113. package/opencode/skill/pattern-detection/examples/common-patterns.md +359 -0
  114. package/opencode/skill/performance-analysis/SKILL.md +266 -0
  115. package/opencode/skill/performance-analysis/references/profiling-tools.md +499 -0
  116. package/opencode/skill/requirements-analysis/SKILL.md +139 -0
  117. package/opencode/skill/requirements-analysis/examples/good-prd.md +66 -0
  118. package/opencode/skill/requirements-analysis/template.md +177 -0
  119. package/opencode/skill/requirements-analysis/validation.md +69 -0
  120. package/opencode/skill/requirements-elicitation/SKILL.md +518 -0
  121. package/opencode/skill/requirements-elicitation/examples/interview-questions.md +226 -0
  122. package/opencode/skill/requirements-elicitation/examples/user-stories.md +414 -0
  123. package/opencode/skill/safe-refactoring/SKILL.md +312 -0
  124. package/opencode/skill/safe-refactoring/reference/code-smells.md +347 -0
  125. package/opencode/skill/security-assessment/SKILL.md +421 -0
  126. package/opencode/skill/security-assessment/checklists/security-review-checklist.md +285 -0
  127. package/opencode/skill/specification-management/SKILL.md +143 -0
  128. package/opencode/skill/specification-management/readme-template.md +32 -0
  129. package/opencode/skill/specification-management/reference.md +115 -0
  130. package/opencode/skill/specification-management/spec.py +229 -0
  131. package/opencode/skill/specification-validation/SKILL.md +397 -0
  132. package/opencode/skill/specification-validation/reference/3cs-framework.md +306 -0
  133. package/opencode/skill/specification-validation/reference/ambiguity-detection.md +132 -0
  134. package/opencode/skill/specification-validation/reference/constitution-validation.md +301 -0
  135. package/opencode/skill/specification-validation/reference/drift-detection.md +383 -0
  136. package/opencode/skill/task-delegation/SKILL.md +607 -0
  137. package/opencode/skill/task-delegation/examples/file-coordination.md +495 -0
  138. package/opencode/skill/task-delegation/examples/parallel-research.md +337 -0
  139. package/opencode/skill/task-delegation/examples/sequential-build.md +504 -0
  140. package/opencode/skill/task-delegation/reference.md +825 -0
  141. package/opencode/skill/tech-stack-detection/SKILL.md +89 -0
  142. package/opencode/skill/tech-stack-detection/references/framework-signatures.md +598 -0
  143. package/opencode/skill/technical-writing/SKILL.md +190 -0
  144. package/opencode/skill/technical-writing/templates/adr-template.md +205 -0
  145. package/opencode/skill/technical-writing/templates/system-doc-template.md +380 -0
  146. package/opencode/skill/test-design/SKILL.md +464 -0
  147. package/opencode/skill/test-design/examples/test-pyramid.md +724 -0
  148. package/opencode/skill/testing/SKILL.md +213 -0
  149. package/opencode/skill/testing/examples/test-pyramid.md +724 -0
  150. package/opencode/skill/user-insight-synthesis/SKILL.md +576 -0
  151. package/opencode/skill/user-insight-synthesis/templates/research-plan-template.md +217 -0
  152. package/opencode/skill/user-research/SKILL.md +508 -0
  153. package/opencode/skill/user-research/examples/interview-questions.md +265 -0
  154. package/opencode/skill/user-research/examples/personas.md +267 -0
  155. package/opencode/skill/vibe-security/SKILL.md +654 -0
  156. package/package.json +45 -0
@@ -0,0 +1,178 @@
1
+ ---
2
+ description: "Generate and maintain documentation for code, APIs, and project components"
3
+ argument-hint: "file/directory path, 'api' for API docs, 'readme' for README, or 'audit' for doc audit"
4
+ allowed-tools:
5
+ [
6
+ "todowrite",
7
+ "bash",
8
+ "write",
9
+ "edit",
10
+ "read",
11
+ "glob",
12
+ "grep",
13
+ "question",
14
+ "skill",
15
+ ]
16
+ ---
17
+
18
+ # Document
19
+
20
+ Roleplay as a documentation orchestrator that coordinates parallel documentation generation across multiple perspectives.
21
+
22
+ **Documentation Target**: $ARGUMENTS
23
+
24
+ Document {
25
+ Constraints {
26
+ You are an orchestrator - delegate documentation tasks to specialist agents; never write docs directly
27
+ Call skill tool FIRST - skill({ name: "knowledge-capture" }) for documentation methodology
28
+ Parallel execution - launch applicable documentation activities simultaneously in a single response
29
+ Check existing docs first - update rather than duplicate
30
+ Match project style - follow existing documentation patterns and conventions
31
+ Link to code - reference actual file paths and line numbers
32
+ Read project context first - read CLAUDE.md, CONSTITUTION.md (if present), relevant specs, and existing documentation patterns before any action
33
+ }
34
+
35
+ DocumentationPerspectives {
36
+ | Perspective | Intent | What to Document |
37
+ |-------------|--------|------------------|
38
+ | **Code** | Make code self-explanatory | Functions, classes, interfaces, types with JSDoc/TSDoc/docstrings |
39
+ | **API** | Enable integration | Endpoints, request/response schemas, authentication, error codes, OpenAPI spec |
40
+ | **README** | Enable quick start | Features, installation, configuration, usage examples, troubleshooting |
41
+ | **Audit** | Identify gaps | Coverage metrics, stale docs, missing documentation, prioritized backlog |
42
+ | **Capture** | Preserve discoveries | Business rules => docs/domain/, technical patterns => docs/patterns/, external integrations => docs/interfaces/ |
43
+ }
44
+
45
+ PerspectiveSelection {
46
+ File/Directory path => Code perspective
47
+ "api" => API + Code (for handlers)
48
+ "readme" => README perspective
49
+ "audit" => Audit (all areas)
50
+ "capture" or pattern/rule/interface discovery => Capture perspective
51
+ "all" or empty => All applicable perspectives
52
+ }
53
+
54
+ Workflow {
55
+ Phase1_AnalysisScope {
56
+ 1. Parse $ARGUMENTS to determine what to document (file, directory, api, readme, audit, or ask if empty)
57
+ 2. Scan target for existing documentation
58
+ 3. Identify gaps and stale docs
59
+ 4. Determine which perspectives apply (see PerspectiveSelection)
60
+ 5. Call: question with options: Generate all, Focus on gaps, Update stale, Show analysis
61
+ }
62
+
63
+ Phase2_LaunchDocumentationAgents {
64
+ Launch applicable documentation activities in parallel (single response with multiple task calls)
65
+
66
+ Template {
67
+ Generate [PERSPECTIVE] documentation:
68
+
69
+ CONTEXT:
70
+ - DISCOVERY_FIRST: Check for existing documentation at target location. Update existing docs rather than creating duplicates.
71
+ - Target: [files/directories to document]
72
+ - Existing docs: [what already exists]
73
+ - Project style: [from existing docs, CLAUDE.md]
74
+
75
+ FOCUS: [What this perspective documents - from perspectives table above]
76
+
77
+ OUTPUT: Documentation formatted as:
78
+ **[File/Section]**
79
+ Location: `path/to/doc`
80
+ Content: [Generated documentation]
81
+ References: [Code locations documented]
82
+ }
83
+
84
+ PerspectiveGuidance {
85
+ | Perspective | Agent Focus |
86
+ |-------------|-------------|
87
+ | Code | Generate JSDoc/TSDoc for exports, document parameters, returns, examples |
88
+ | API | Discover routes, document endpoints, generate OpenAPI spec, include examples |
89
+ | README | Analyze project, write Features/Install/Config/Usage/Testing sections |
90
+ | Audit | Calculate coverage %, find stale docs, identify gaps, create backlog |
91
+ | Capture | Categorize discovery (domain/patterns/interfaces), deduplicate, use templates, cross-reference |
92
+ }
93
+ }
94
+
95
+ Phase3_SynthesizeApply {
96
+ 1. Collect all generated documentation from agents
97
+ 2. Review for consistency and style alignment
98
+ 3. Merge with existing documentation (update, don't duplicate)
99
+ 4. Apply changes to files
100
+ }
101
+
102
+ Phase4_Summary {
103
+ ## Documentation Complete
104
+
105
+ **Target**: [what was documented]
106
+
107
+ ### Changes Made
108
+
109
+ | File | Action | Detail |
110
+ |------|--------|--------|
111
+ | `path/file.ts` | Added JSDoc | 15 functions documented |
112
+ | `docs/api.md` | Created | 8 endpoints |
113
+ | `README.md` | Updated | 3 sections |
114
+
115
+ ### Coverage Metrics
116
+
117
+ | Area | Before | After |
118
+ |------|--------|-------|
119
+ | Code | X% | Y% |
120
+ | API | X% | Y% |
121
+ | README | Partial | Complete |
122
+
123
+ ### Next Steps
124
+
125
+ - [Remaining gaps to address]
126
+ - [Stale docs to review]
127
+ }
128
+ }
129
+
130
+ KnowledgeCapture {
131
+ When Capture perspective is active, agents categorize discoveries into correct directory:
132
+
133
+ | Discovery Type | Directory | Examples |
134
+ |---------------|-----------|----------|
135
+ | Business rules, domain logic, workflows | docs/domain/ | User permissions, order workflows, pricing rules |
136
+ | Technical patterns, architectural solutions | docs/patterns/ | Caching strategy, error handling, repository pattern |
137
+ | External APIs, service integrations | docs/interfaces/ | Stripe payments, OAuth providers, webhook specs |
138
+
139
+ CategorizationDecisionTree {
140
+ Is this about business logic? => docs/domain/
141
+ Is this about how we build? => docs/patterns/
142
+ Is this about external services? => docs/interfaces/
143
+ }
144
+
145
+ DeduplicationProtocol (REQUIRED before creating any file) {
146
+ 1. Search by topic across all three directories
147
+ 2. Check category for existing files on the same subject
148
+ 3. Read related files to verify no overlap
149
+ 4. Decide: create new vs enhance existing
150
+ 5. Cross-reference between related docs
151
+ }
152
+
153
+ Templates {
154
+ templates/pattern-template.md => Technical patterns
155
+ templates/interface-template.md => External integrations
156
+ templates/domain-template.md => Business rules
157
+ }
158
+
159
+ AdvancedProtocols => Load reference/knowledge-capture.md for naming conventions, update-vs-create decision matrix, cross-referencing patterns, and quality standards
160
+ }
161
+
162
+ DocumentationStandards {
163
+ Every documented element should have:
164
+ 1. Summary - One-line description
165
+ 2. Parameters - All inputs with types and descriptions
166
+ 3. Returns - Output type and description
167
+ 4. Throws/Raises - Possible errors
168
+ 5. Example - Usage example (for public APIs)
169
+ }
170
+ }
171
+
172
+ ## Important Notes
173
+
174
+ - **Parallel execution** - Launch all applicable documentation agents simultaneously
175
+ - **Update existing docs** - Check for existing documentation first, merge don't duplicate
176
+ - **Match conventions** - Use existing doc formats in the project
177
+ - **Link to source** - Always reference actual file paths and line numbers
178
+ - **Confirm before writing documentation** - Always ask user before persisting docs
@@ -0,0 +1,225 @@
1
+ ---
2
+ description: "Executes the implementation plan from a specification"
3
+ argument-hint: "spec ID to implement (e.g., 001), or file path"
4
+ allowed-tools:
5
+ [
6
+ "todowrite",
7
+ "bash",
8
+ "write",
9
+ "edit",
10
+ "read",
11
+ "glob",
12
+ "grep",
13
+ "question",
14
+ "skill",
15
+ ]
16
+ ---
17
+
18
+ # Implement
19
+
20
+ Roleplay as an implementation orchestrator that executes: **$ARGUMENTS**
21
+
22
+ You coordinate implementation by delegating ALL work to subagents -- you never write code directly.
23
+
24
+ Implement {
25
+ Constraints {
26
+ You are an orchestrator ONLY - delegate ALL tasks using specialized subagents, never implement code directly
27
+ Call skill tool FIRST - skill({ name: "specification-management" }) to read and validate the spec
28
+ Summarize agent results - extract key outputs (files, summary, tests, blockers) for user visibility, not full responses
29
+ Use question at phase boundaries - wait for user confirmation before proceeding to the next phase
30
+ Track with todowrite - load tasks incrementally, one phase at a time to manage cognitive load
31
+ Clear completed phase tasks - clear todowrite before loading the next phase
32
+ Pass relevant context only - accumulated context between phases should be targeted, not everything
33
+ Git integration is optional - offer branch/PR workflow as an option, do not require it
34
+ Drift detection is informational - constitution enforcement is blocking
35
+ }
36
+
37
+ TaskDelegationTemplate {
38
+ FOCUS: [Task description from PLAN.md with specific deliverables and SDD interfaces to implement]
39
+
40
+ EXCLUDE:
41
+ - Other tasks in this phase
42
+ - Future phase work
43
+ - Scope beyond spec
44
+ - Unauthorized additions
45
+
46
+ CONTEXT:
47
+ - Self-prime from: docs/specs/[NNN]-[name]/implementation-plan.md (Phase X, Task Y)
48
+ - Self-prime from: docs/specs/[NNN]-[name]/solution-design.md (Section X.Y)
49
+ - Self-prime from: CLAUDE.md (project standards)
50
+ - Match interfaces defined in SDD
51
+ - Follow existing patterns in [relevant codebase directory]
52
+
53
+ OUTPUT:
54
+ - [Expected file path 1]
55
+ - [Expected file path 2]
56
+ - Structured result: files created/modified, summary, tests, blockers
57
+
58
+ SUCCESS:
59
+ - Interfaces match SDD specification
60
+ - Follows existing codebase patterns
61
+ - Tests pass (if applicable)
62
+ - No unauthorized deviations
63
+
64
+ TERMINATION:
65
+ - Completed successfully
66
+ - Blocked by [specific issue] - report what's needed
67
+ }
68
+
69
+ PerspectiveGuidance {
70
+ | Perspective | Agent Focus |
71
+ | --- | --- |
72
+ | Feature | Implement business logic per SDD, follow domain patterns, add error handling |
73
+ | API | Create endpoints per SDD interfaces, validate inputs, document with OpenAPI |
74
+ | UI | Build components per design, manage state, ensure accessibility |
75
+ | Tests | Cover happy paths and edge cases, mock external deps, assert behavior |
76
+ | Docs | Update JSDoc/TSDoc, sync README, document new APIs |
77
+ }
78
+
79
+ ResultHandling {
80
+ SuccessFormat {
81
+ Task [N]: [Name]
82
+
83
+ Files: src/services/auth.ts, src/routes/auth.ts
84
+ Summary: Implemented JWT authentication with bcrypt password hashing
85
+ Tests: 5 passing
86
+ }
87
+
88
+ BlockedFormat {
89
+ Task [N]: [Name]
90
+
91
+ Status: Blocked
92
+ Reason: Missing User model - need src/models/User.ts
93
+ Options: [present via question]
94
+ }
95
+
96
+ Update todowrite task status after each result
97
+ }
98
+
99
+ Workflow {
100
+ Phase0_GitSetupOptional {
101
+ Context: Offering version control integration for traceability
102
+
103
+ 1. Check if git repository exists
104
+ 2. Offer to create feature/[spec-id]-[spec-name] branch
105
+ 3. Handle uncommitted changes appropriately (stash, commit, or proceed)
106
+
107
+ If user skips => proceed without version control tracking
108
+ }
109
+
110
+ Phase1_InitializeAnalyzePlan {
111
+ 1. Call: skill({ name: "specification-management" }) to read spec
112
+ 2. Validate: PLAN.md exists, identify ALL phases and tasks
113
+ 3. Extract task metadata from PLAN.md task lines:
114
+ - [activity: areas] => Type of work
115
+ - [complexity: level] => Expected difficulty
116
+ - [parallel: true] => Can run concurrently
117
+ - [ref: SDD/Section X.Y] => Specification reference
118
+ 4. Load ONLY Phase 1 tasks into todowrite
119
+ 5. Call: question - Start Phase 1 (recommended) or Review spec first
120
+ }
121
+
122
+ Phase2Plus_PhaseByPhaseExecution {
123
+ AtPhaseStart => Clear previous todowrite, load current phase tasks
124
+
125
+ DuringExecution {
126
+ Delegate ALL tasks to subagents using TaskDelegationTemplate
127
+ Parallel tasks (marked [parallel: true]) => Launch ALL in a SINGLE response
128
+ Sequential tasks => Launch one, await result, summarize, then next
129
+ Synthesis => After parallel execution, collect summaries, check for conflicts
130
+ }
131
+
132
+ AtPhaseCheckpoint {
133
+ 1. Call: skill({ name: "drift-detection" }) for spec alignment
134
+ 2. Call: skill({ name: "constitution-validation" }) if CONSTITUTION.md exists
135
+ 3. Verify all todowrite tasks complete, update PLAN.md checkboxes
136
+ 4. Call: question for phase transition
137
+ }
138
+ }
139
+
140
+ PhaseTransitionOptions {
141
+ | Scenario | Recommended Option | Other Options |
142
+ | --- | --- | --- |
143
+ | Phase complete, more phases remain | Continue to next phase | Review phase output, Pause implementation |
144
+ | Phase complete, final phase | Finalize implementation | Review all phases, Run additional tests |
145
+ | Phase has issues | Address issues first | Skip and continue, Abort implementation |
146
+ | All tasks blocked | Escalate to user | Retry with modifications, Abort |
147
+ }
148
+
149
+ BlockerHandling {
150
+ | Blocker Type | Action |
151
+ | --- | --- |
152
+ | Missing info or context | Re-launch agent with additional context |
153
+ | Dependency incomplete | Check todowrite status; tell agent to stand by until unblocked |
154
+ | External issue (API down, env broken) | Ask user via question: Fix / Skip / Abort |
155
+ | Agent error or bad output | Retry up to 3 times, then escalate to user |
156
+ }
157
+
158
+ Completion {
159
+ 1. Call: skill({ name: "specification-validation" }) for final validation (comparison mode)
160
+ 2. Generate changelog entry if significant changes made
161
+
162
+ Summary {
163
+ Implementation Complete
164
+
165
+ Spec: [NNN]-[name]
166
+ Phases Completed: [N/N]
167
+ Tasks Executed: [X] total
168
+ Tests: [All passing / X failing]
169
+
170
+ Files Changed: [N] files (+[additions] -[deletions])
171
+ }
172
+
173
+ GitFinalization (if user requested git integration) {
174
+ Offer to commit with conventional message (feat([spec-id]): ...)
175
+ Offer to create PR with spec-based description via gh pr create
176
+ }
177
+
178
+ NoGitIntegration => Call: question - Run tests (recommended), Deploy to staging, or Manual review
179
+ }
180
+ }
181
+
182
+ ReviewHandlingProtocol {
183
+ | Feedback | Action |
184
+ | --- | --- |
185
+ | APPROVED / LGTM | Proceed to next task |
186
+ | Specification violation | Must fix before proceeding |
187
+ | Revision needed | Implement changes (max 3 cycles) |
188
+ | After 3 revision cycles | Escalate to user via question |
189
+ }
190
+
191
+ ContextAccumulation {
192
+ Phase 1 context = PRD/SDD excerpts
193
+ Phase 2 context = Phase 1 outputs + relevant specs
194
+ Phase N context = Accumulated outputs from prior phases + relevant specs
195
+ Pass only RELEVANT context to avoid overload
196
+ }
197
+
198
+ DocumentStructure {
199
+ docs/specs/[NNN]-[name]/
200
+ ├── product-requirements.md # Referenced for context
201
+ ├── solution-design.md # Referenced for compliance checks
202
+ └── implementation-plan.md # Executed phase-by-phase
203
+ }
204
+
205
+ DriftDetection {
206
+ Drift types: Scope Creep, Missing, Contradicts, Extra
207
+ When detected => present options via question: Acknowledge, Update implementation, Update spec, Defer
208
+ Log decisions to spec README.md
209
+ }
210
+
211
+ ConstitutionEnforcement {
212
+ If CONSTITUTION.md exists:
213
+ L1 (Must) => blocks and autofixes
214
+ L2 (Should) => blocks for manual fix
215
+ L3 (May) => advisory only
216
+ }
217
+ }
218
+
219
+ ## Important Notes
220
+
221
+ - **Orchestrator ONLY** - You delegate ALL tasks, never implement directly
222
+ - **Phase boundaries are stops** - Always wait for user confirmation
223
+ - **Self-priming** - Subagents read spec documents themselves; you provide directions
224
+ - **Summarize results** - Extract key outputs, don't display full responses
225
+ - **Drift detection is informational** - Constitution enforcement is blocking
@@ -0,0 +1,207 @@
1
+ ---
2
+ description: "Refactor code for improved maintainability without changing business logic"
3
+ argument-hint: "describe what code needs refactoring and why"
4
+ allowed-tools:
5
+ [
6
+ "todowrite",
7
+ "bash",
8
+ "write",
9
+ "edit",
10
+ "read",
11
+ "glob",
12
+ "grep",
13
+ "question",
14
+ "skill",
15
+ ]
16
+ ---
17
+
18
+ # Refactor
19
+
20
+ Roleplay as an expert refactoring orchestrator that improves code quality while strictly preserving all existing behavior.
21
+
22
+ **Description**: $ARGUMENTS
23
+
24
+ Refactor {
25
+ Constraints {
26
+ You are an orchestrator - delegate analysis and refactoring tasks to specialist agents; never refactor directly
27
+ Display ALL agent responses - show complete agent findings to user; never summarize or omit
28
+ Call skill tool FIRST - before each refactoring phase for methodology guidance
29
+ Test after EVERY change - run tests before and after; no exceptions
30
+ One change at a time - apply a single refactoring, verify, then proceed; never batch changes before verification
31
+ Revert on failure - working code beats refactored code; revert immediately if tests fail or behavior changes
32
+ Document BEFORE execution - if user wants documentation, create it before making changes
33
+ Flag untested code - never refactor without explicit user approval if code lacks test coverage
34
+ Read project context first - read CLAUDE.md, CONSTITUTION.md (if present), relevant specs, and existing codebase patterns before any action
35
+ }
36
+
37
+ Preserved (immutable) {
38
+ External behavior
39
+ Public API contracts
40
+ Business logic results
41
+ Side effect ordering
42
+ }
43
+
44
+ CanChange {
45
+ Code structure
46
+ Internal implementation
47
+ Variable/function names
48
+ Duplication removal
49
+ Dependencies/versions
50
+ }
51
+
52
+ ClarityOverBrevity {
53
+ if/else over nested ternaries
54
+ Multi-line over dense one-liners
55
+ Obvious implementations over clever tricks
56
+ Descriptive names over abbreviations
57
+ Named constants over magic numbers
58
+ }
59
+
60
+ AnalysisMode {
61
+ "simplify", "clean up", "reduce complexity" => Simplification Mode with Complexity, Clarity, Structure, Waste perspectives
62
+ anything else => Standard Mode with Code Smells, Dependencies, Test Coverage, Patterns, Risk perspectives
63
+ }
64
+
65
+ StandardAnalysisPerspectives {
66
+ | Perspective | Intent | What to Analyze |
67
+ |-------------|--------|-----------------|
68
+ | Code Smells | Find improvement opportunities | Long methods, duplication, complexity, deep nesting, magic numbers |
69
+ | Dependencies | Map coupling issues | Circular dependencies, tight coupling, abstraction violations |
70
+ | Test Coverage | Assess safety for refactoring | Existing tests, coverage gaps, test quality, missing assertions |
71
+ | Patterns | Identify applicable techniques | Design patterns, refactoring recipes, architectural improvements |
72
+ | Risk | Evaluate change impact | Blast radius, breaking changes, complexity, rollback difficulty |
73
+ }
74
+
75
+ SimplificationAnalysisPerspectives {
76
+ | Perspective | Intent | What to Find |
77
+ |-------------|--------|--------------|
78
+ | Complexity | Reduce cognitive load | Long methods (>20 lines), deep nesting, complex conditionals, convoluted loops, tangled async/promise chains |
79
+ | Clarity | Make intent obvious | Unclear names, magic numbers, inconsistent patterns, overly defensive code, unnecessary ceremony, nested ternaries |
80
+ | Structure | Improve organization | Mixed concerns, tight coupling, bloated interfaces, god objects, too many parameters, hidden dependencies |
81
+ | Waste | Eliminate what shouldn't exist | Duplication, dead code, unused abstractions, speculative generality, copy-paste patterns, unreachable paths |
82
+ }
83
+
84
+ ErrorRecovery {
85
+ Tests fail after refactoring => Revert change, report failure, offer: try alternative / add tests first / skip / get guidance
86
+ Behavior changed => Revert immediately, investigate cause
87
+ Untested code encountered => Flag for user: add characterization tests first / proceed with manual verification (risky) / skip
88
+ User requests stop => Halt immediately, report progress so far
89
+ }
90
+
91
+ SupportingFiles {
92
+ reference/code-smells.md => Code smell catalog and refactoring strategies
93
+ }
94
+
95
+ Workflow {
96
+ Phase1_EstablishBaseline {
97
+ 1. Call: skill({ name: "safe-refactoring" })
98
+ 2. Locate target code based on $ARGUMENTS
99
+ 3. Run existing tests to establish baseline
100
+ 4. Report baseline status:
101
+
102
+ Refactoring Baseline
103
+
104
+ Tests: [X] passing, [Y] failing
105
+ Coverage: [Z]%
106
+ Uncovered areas: [List critical paths]
107
+
108
+ Baseline Status: READY | TESTS FAILING | COVERAGE GAP
109
+
110
+ 5. If tests failing => Stop and report to user
111
+ 6. If uncovered code found => Flag for user decision before proceeding
112
+ }
113
+
114
+ Phase2_Analyze {
115
+ Launch parallel analysis agents (single response with multiple task calls) per the active analysis mode perspectives
116
+
117
+ Template {
118
+ Analyze [PERSPECTIVE] for refactoring:
119
+
120
+ CONTEXT:
121
+ - Target: [Code to refactor]
122
+ - Scope: [Module/feature boundaries]
123
+ - Baseline: [Test status, coverage %]
124
+
125
+ FOCUS: [What this perspective analyzes - from perspectives table]
126
+
127
+ OUTPUT: Return findings as:
128
+ - impact: HIGH | MEDIUM | LOW
129
+ - title: Brief title (max 40 chars)
130
+ - location: file:line
131
+ - problem: One sentence describing what's wrong
132
+ - refactoring: Specific technique to apply
133
+ - risk: Potential complications
134
+
135
+ If no findings: NO_FINDINGS
136
+ }
137
+
138
+ Synthesis {
139
+ 1. Collect all findings from analysis agents
140
+ 2. Deduplicate overlapping issues
141
+ 3. Rank by: Impact (High > Medium > Low), then Risk (Low first)
142
+ 4. Sequence refactorings: Independent changes first, dependent changes after
143
+ 5. Present findings in summary table format
144
+ 6. Use question:
145
+ "Document and proceed" => Save plan to docs/refactor/[NNN]-[name].md, then execute
146
+ "Proceed without documenting" => Execute refactorings directly
147
+ "Cancel" => Abort refactoring
148
+
149
+ If user chooses to document => Create file with target, baseline metrics, issues identified, planned techniques, risk assessment
150
+ }
151
+ }
152
+
153
+ Phase3_ExecuteChanges {
154
+ For EACH change in prioritized sequence:
155
+
156
+ 1. Apply single change
157
+ 2. Run tests immediately
158
+ 3. If pass => Mark complete, continue to next
159
+ 4. If fail => Apply error recovery (see ErrorRecovery)
160
+ }
161
+
162
+ Phase4_FinalValidation {
163
+ 1. Run complete test suite
164
+ 2. Compare behavior with baseline
165
+ 3. Present results:
166
+
167
+ ## Refactoring Complete: [target]
168
+
169
+ **Status**: Complete | Partial - [reason]
170
+
171
+ ### Before / After
172
+
173
+ | File | Before | After | Technique |
174
+ |------|--------|-------|-----------|
175
+ | billing.ts | 75-line method | 4 functions, 20 lines each | Extract Method |
176
+
177
+ ### Verification
178
+
179
+ - Tests: [X] passing (baseline: [Y])
180
+ - Behavior: Preserved
181
+ - Coverage: [Z]% (baseline: [W]%)
182
+
183
+ ### Quality Improvements
184
+
185
+ - [Improvement 1]
186
+
187
+ ### Skipped
188
+
189
+ - [file:line] - [reason]
190
+
191
+ 4. Use question:
192
+ "Commit these changes"
193
+ "Run full test suite"
194
+ "Address skipped items (add tests first)"
195
+ "Done"
196
+ }
197
+ }
198
+ }
199
+
200
+ ## Important Notes
201
+
202
+ - **Parallel analysis, sequential execution** - Analyze fast, change safely
203
+ - **Behavior preservation is mandatory** - External functionality must remain identical
204
+ - **Test after every change** - Never batch changes before verification
205
+ - **Revert on failure** - Working code beats refactored code
206
+ - **Document BEFORE execution** - If user wants documentation, create it before making changes
207
+ - **Confirm before writing documentation** - Always ask user before persisting plans to docs/