claude-code-workflow 7.2.29 → 7.3.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 (169) hide show
  1. package/.ccw/workflows/cli-templates/schemas/plan-overview-base-schema.json +2 -2
  2. package/.ccw/workflows/cli-templates/schemas/task-schema.json +14 -7
  3. package/.claude/agents/action-planning-agent.md +7 -4
  4. package/.claude/agents/cli-explore-agent.md +77 -63
  5. package/.claude/agents/cli-lite-planning-agent.md +11 -10
  6. package/.claude/agents/issue-plan-agent.md +421 -426
  7. package/.claude/commands/workflow/spec/setup.md +1 -1
  8. package/.claude/commands/workflow-skill.md +130 -0
  9. package/.claude/skills/ccw-chain/SKILL.md +92 -0
  10. package/.claude/skills/ccw-chain/chains/ccw-cycle.json +31 -0
  11. package/.claude/skills/ccw-chain/chains/ccw-exploration.json +58 -0
  12. package/.claude/skills/ccw-chain/chains/ccw-issue.json +44 -0
  13. package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +71 -0
  14. package/.claude/skills/ccw-chain/chains/ccw-main.json +65 -0
  15. package/.claude/skills/ccw-chain/chains/ccw-standard.json +51 -0
  16. package/.claude/skills/ccw-chain/chains/ccw-team.json +15 -0
  17. package/.claude/skills/ccw-chain/chains/ccw-with-file.json +47 -0
  18. package/.claude/skills/ccw-chain/specs/auto-mode.md +47 -0
  19. package/.claude/skills/chain-loader/SKILL.md +78 -0
  20. package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -0
  21. package/.claude/skills/chain-loader/phases/02-design-graph.md +73 -0
  22. package/.claude/skills/chain-loader/phases/03-generate-validate.md +75 -0
  23. package/.claude/skills/chain-loader/specs/chain-schema.md +126 -0
  24. package/.claude/skills/chain-loader/specs/design-patterns.md +99 -0
  25. package/.claude/skills/chain-loader/templates/chain-json.md +63 -0
  26. package/.claude/skills/review-cycle/phases/review-module.md +764 -764
  27. package/.claude/skills/review-cycle/phases/review-session.md +775 -775
  28. package/.claude/skills/workflow-multi-cli-plan/SKILL.md +2 -2
  29. package/.claude/skills/workflow-plan/SKILL.md +1 -0
  30. package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
  31. package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
  32. package/.claude/skills/workflow-plan/phases/03-conflict-resolution.md +422 -422
  33. package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
  34. package/.claude/skills/workflow-plan/phases/05-plan-verify.md +395 -395
  35. package/.claude/skills/workflow-tdd-plan/phases/02-context-gathering.md +407 -407
  36. package/.claude/skills/workflow-tdd-plan/phases/04-conflict-resolution.md +426 -426
  37. package/.claude/skills/workflow-test-fix/phases/02-test-context-gather.md +493 -493
  38. package/.codex/skills/analyze-with-file/SKILL.md +383 -134
  39. package/.codex/skills/brainstorm/SKILL.md +3 -3
  40. package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
  41. package/.codex/skills/clean/SKILL.md +1 -1
  42. package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
  43. package/.codex/skills/investigate/orchestrator.md +24 -0
  44. package/.codex/skills/issue-discover/SKILL.md +374 -361
  45. package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
  46. package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
  47. package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
  48. package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
  49. package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
  50. package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
  51. package/.codex/skills/review-cycle/SKILL.md +31 -12
  52. package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
  53. package/.codex/skills/security-audit/orchestrator.md +29 -0
  54. package/.codex/skills/session-sync/SKILL.md +1 -1
  55. package/.codex/skills/ship/orchestrator.md +24 -0
  56. package/.codex/skills/spec-add/SKILL.md +5 -5
  57. package/.codex/skills/spec-generator/SKILL.md +33 -2
  58. package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
  59. package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
  60. package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
  61. package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
  62. package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
  63. package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
  64. package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
  65. package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
  66. package/.codex/skills/spec-setup/SKILL.md +669 -669
  67. package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
  68. package/.codex/skills/team-brainstorm/SKILL.md +259 -259
  69. package/.codex/skills/team-coordinate/SKILL.md +359 -359
  70. package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
  71. package/.codex/skills/team-designer/SKILL.md +27 -1
  72. package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
  73. package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
  74. package/.codex/skills/team-designer/phases/04-validation.md +1 -1
  75. package/.codex/skills/team-executor/SKILL.md +218 -218
  76. package/.codex/skills/team-frontend/SKILL.md +227 -227
  77. package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
  78. package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
  79. package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
  80. package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
  81. package/.codex/skills/team-issue/SKILL.md +269 -269
  82. package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
  83. package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
  84. package/.codex/skills/team-motion-design/SKILL.md +222 -222
  85. package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
  86. package/.codex/skills/team-perf-opt/SKILL.md +258 -258
  87. package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
  88. package/.codex/skills/team-planex/SKILL.md +216 -216
  89. package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
  90. package/.codex/skills/team-review/SKILL.md +227 -227
  91. package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
  92. package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
  93. package/.codex/skills/team-tech-debt/SKILL.md +206 -206
  94. package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
  95. package/.codex/skills/team-testing/SKILL.md +237 -237
  96. package/.codex/skills/team-ui-polish/SKILL.md +218 -218
  97. package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
  98. package/.codex/skills/team-uidesign/SKILL.md +219 -219
  99. package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
  100. package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
  101. package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
  102. package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
  103. package/.codex/skills/team-ux-improve/SKILL.md +227 -227
  104. package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
  105. package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
  106. package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
  107. package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
  108. package/.codex/skills/workflow-execute/SKILL.md +5 -5
  109. package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
  110. package/.codex/skills/workflow-plan/SKILL.md +3 -3
  111. package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
  112. package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
  113. package/README.md +14 -0
  114. package/ccw/dist/cli.d.ts.map +1 -1
  115. package/ccw/dist/cli.js +16 -0
  116. package/ccw/dist/cli.js.map +1 -1
  117. package/ccw/dist/commands/chain-loader.d.ts +2 -0
  118. package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
  119. package/ccw/dist/commands/chain-loader.js +11 -0
  120. package/ccw/dist/commands/chain-loader.js.map +1 -0
  121. package/ccw/dist/commands/install.d.ts.map +1 -1
  122. package/ccw/dist/commands/install.js +52 -1
  123. package/ccw/dist/commands/install.js.map +1 -1
  124. package/ccw/dist/commands/launcher.d.ts +2 -0
  125. package/ccw/dist/commands/launcher.d.ts.map +1 -0
  126. package/ccw/dist/commands/launcher.js +434 -0
  127. package/ccw/dist/commands/launcher.js.map +1 -0
  128. package/ccw/dist/core/routes/litellm-api-routes.d.ts.map +1 -1
  129. package/ccw/dist/core/routes/litellm-api-routes.js +0 -23
  130. package/ccw/dist/core/routes/litellm-api-routes.js.map +1 -1
  131. package/ccw/dist/tools/chain-loader.d.ts +10 -0
  132. package/ccw/dist/tools/chain-loader.d.ts.map +1 -0
  133. package/ccw/dist/tools/chain-loader.js +1054 -0
  134. package/ccw/dist/tools/chain-loader.js.map +1 -0
  135. package/ccw/dist/tools/index.d.ts.map +1 -1
  136. package/ccw/dist/tools/index.js +2 -0
  137. package/ccw/dist/tools/index.js.map +1 -1
  138. package/ccw/dist/tools/json-builder.js +20 -0
  139. package/ccw/dist/tools/json-builder.js.map +1 -1
  140. package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
  141. package/ccw/dist/tools/skill-context-loader.js +12 -26
  142. package/ccw/dist/tools/skill-context-loader.js.map +1 -1
  143. package/ccw/dist/types/chain-types.d.ts +112 -0
  144. package/ccw/dist/types/chain-types.d.ts.map +1 -0
  145. package/ccw/dist/types/chain-types.js +5 -0
  146. package/ccw/dist/types/chain-types.js.map +1 -0
  147. package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
  148. package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
  149. package/ccw/dist/utils/chain-visualizer.js +164 -0
  150. package/ccw/dist/utils/chain-visualizer.js.map +1 -0
  151. package/ccw/scripts/prepublish-clean.mjs +0 -1
  152. package/package.json +1 -3
  153. package/.claude/commands/cli/cli-init.md +0 -441
  154. package/.claude/commands/cli/codex-review.md +0 -361
  155. package/.claude/commands/flow-create.md +0 -663
  156. package/.claude/skills/team-edict.zip +0 -0
  157. package/ccw-litellm/README.md +0 -180
  158. package/ccw-litellm/pyproject.toml +0 -35
  159. package/ccw-litellm/src/ccw_litellm/__init__.py +0 -47
  160. package/ccw-litellm/src/ccw_litellm/cli.py +0 -108
  161. package/ccw-litellm/src/ccw_litellm/clients/__init__.py +0 -12
  162. package/ccw-litellm/src/ccw_litellm/clients/litellm_embedder.py +0 -270
  163. package/ccw-litellm/src/ccw_litellm/clients/litellm_llm.py +0 -198
  164. package/ccw-litellm/src/ccw_litellm/config/__init__.py +0 -22
  165. package/ccw-litellm/src/ccw_litellm/config/loader.py +0 -343
  166. package/ccw-litellm/src/ccw_litellm/config/models.py +0 -162
  167. package/ccw-litellm/src/ccw_litellm/interfaces/__init__.py +0 -14
  168. package/ccw-litellm/src/ccw_litellm/interfaces/embedder.py +0 -52
  169. package/ccw-litellm/src/ccw_litellm/interfaces/llm.py +0 -45
@@ -1,305 +1,305 @@
1
- ---
2
- name: team-lifecycle-v4
3
- description: Full lifecycle team skill with clean architecture. SKILL.md is a universal router — all roles read it. Beat model is coordinator-only. Structure is roles/ + specs/ + templates/. Triggers on "team lifecycle v4".
4
- allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*), request_user_input(*)
5
- ---
6
-
7
- # Team Lifecycle v4
8
-
9
- Orchestrate multi-agent software development: specification -> planning -> implementation -> testing -> review.
10
-
11
- ## Architecture
12
-
13
- ```
14
- Skill(skill="team-lifecycle-v4", args="task description")
15
- |
16
- SKILL.md (this file) = Router
17
- |
18
- +--------------+--------------+
19
- | |
20
- no --role flag --role <name>
21
- | |
22
- Coordinator Worker
23
- roles/coordinator/role.md roles/<name>/role.md
24
- |
25
- +-- analyze -> dispatch -> spawn -> wait -> collect
26
- |
27
- +--------+---+--------+
28
- v v v
29
- spawn_agent ... spawn_agent
30
- (team_worker) (team_supervisor)
31
- per-task resident agent
32
- lifecycle assign_task-driven
33
- | |
34
- +-- wait_agent --------+
35
- |
36
- collect results
37
- ```
38
-
39
- ## Role Registry
40
-
41
- | Role | Path | Prefix | Inner Loop |
42
- |------|------|--------|------------|
43
- | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | -- | -- |
44
- | analyst | [roles/analyst/role.md](roles/analyst/role.md) | RESEARCH-* | false |
45
- | writer | [roles/writer/role.md](roles/writer/role.md) | DRAFT-* | true |
46
- | planner | [roles/planner/role.md](roles/planner/role.md) | PLAN-* | true |
47
- | executor | [roles/executor/role.md](roles/executor/role.md) | IMPL-* | true |
48
- | tester | [roles/tester/role.md](roles/tester/role.md) | TEST-* | false |
49
- | reviewer | [roles/reviewer/role.md](roles/reviewer/role.md) | REVIEW-*, QUALITY-*, IMPROVE-* | false |
50
- | supervisor | [roles/supervisor/role.md](roles/supervisor/role.md) | CHECKPOINT-* | false |
51
-
52
- ## Role Router
53
-
54
- Parse `$ARGUMENTS`:
55
- - Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
56
- - No `--role` -> `roles/coordinator/role.md`, execute entry router
57
-
58
- ## Delegation Lock
59
-
60
- **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
61
-
62
- Before calling ANY tool, apply this check:
63
-
64
- | Tool Call | Verdict | Reason |
65
- |-----------|---------|--------|
66
- | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
67
- | `list_agents` | ALLOWED | Agent health check |
68
- | `request_user_input` | ALLOWED | User interaction |
69
- | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
70
- | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
71
- | `Read` on `roles/`, `commands/`, `specs/`, `templates/` | ALLOWED | Loading own instructions |
72
- | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
73
- | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
74
- | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
75
- | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
76
-
77
- **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
78
-
79
- **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
80
-
81
- ---
82
-
83
- ## Shared Constants
84
-
85
- - **Session prefix**: `TLV4`
86
- - **Session path**: `.workflow/.team/TLV4-<slug>-<date>/`
87
- - **State file**: `<session>/tasks.json`
88
- - **Discovery files**: `<session>/discoveries/{task_id}.json`
89
- - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
90
-
91
- ## Worker Spawn Template
92
-
93
- Coordinator spawns workers using this template:
94
-
95
- ```
96
- spawn_agent({
97
- agent_type: "team_worker",
98
- task_name: "<task-id>",
99
- fork_context: false,
100
- items: [
101
- { type: "text", text: `## Role Assignment
102
- role: <role>
103
- role_spec: <skill_root>/roles/<role>/role.md
104
- session: <session-folder>
105
- session_id: <session-id>
106
- requirement: <task-description>
107
- inner_loop: <true|false>
108
-
109
- Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.
110
- Execute built-in Phase 1 (task discovery) -> role Phase 2-4 -> built-in Phase 5 (report).` },
111
-
112
- { type: "text", text: `## Task Context
113
- task_id: <task-id>
114
- title: <task-title>
115
- description: <task-description>
116
- pipeline_phase: <pipeline-phase>` },
117
-
118
- { type: "text", text: `## Upstream Context
119
- <prev_context>` }
120
- ]
121
- })
122
- ```
123
-
124
- ## Supervisor Spawn Template
125
-
126
- Supervisor is a **resident agent** (independent from team_worker). Spawned once during session init, woken via assign_task for each CHECKPOINT task.
127
-
128
- ### Spawn (Phase 2 -- once per session)
129
-
130
- ```
131
- supervisorId = spawn_agent({
132
- agent_type: "team_supervisor",
133
- task_name: "supervisor",
134
- fork_context: false,
135
- items: [
136
- { type: "text", text: `## Role Assignment
137
- role: supervisor
138
- role_spec: <skill_root>/roles/supervisor/role.md
139
- session: <session-folder>
140
- session_id: <session-id>
141
- requirement: <task-description>
142
-
143
- Read role_spec file (<skill_root>/roles/supervisor/role.md) to load checkpoint definitions.
144
- Init: load baseline context, report ready, go idle.
145
- Wake cycle: orchestrator sends checkpoint requests via assign_task.` }
146
- ]
147
- })
148
- ```
149
-
150
- ### Wake (per CHECKPOINT task)
151
-
152
- ```
153
- assign_task({
154
- target: "supervisor",
155
- items: [
156
- { type: "text", text: `## Checkpoint Request
157
- task_id: <CHECKPOINT-NNN>
158
- scope: [<upstream-task-ids>]
159
- pipeline_progress: <done>/<total> tasks completed` }
160
- ]
161
- })
162
- wait_agent({ targets: ["supervisor"], timeout_ms: 300000 })
163
- ```
164
-
165
- ### Shutdown (pipeline complete)
166
-
167
- ```
168
- close_agent({ target: "supervisor" })
169
- ```
170
-
171
-
172
- ### Model Selection Guide
173
-
174
- | Role | model | reasoning_effort | Rationale |
175
- |------|-------|-------------------|-----------|
176
- | Analyst (RESEARCH-*) | (default) | medium | Read-heavy exploration, less reasoning needed |
177
- | Writer (DRAFT-*) | (default) | high | Spec writing requires precision and completeness |
178
- | Planner (PLAN-*) | (default) | high | Architecture decisions need full reasoning |
179
- | Executor (IMPL-*) | (default) | high | Code generation needs precision |
180
- | Tester (TEST-*) | (default) | high | Test generation requires deep code understanding |
181
- | Reviewer (REVIEW-*, QUALITY-*, IMPROVE-*) | (default) | high | Deep analysis for quality assessment |
182
- | Supervisor (CHECKPOINT-*) | (default) | medium | Gate checking, report aggregation |
183
-
184
- Override model/reasoning_effort in spawn_agent when cost optimization is needed:
185
- ```
186
- spawn_agent({
187
- agent_type: "team_worker",
188
- task_name: "<task-id>",
189
- fork_context: false,
190
- model: "<model-override>",
191
- reasoning_effort: "<effort-level>",
192
- items: [...]
193
- })
194
- ```
195
-
196
- ## Wave Execution Engine
197
-
198
- For each wave in the pipeline:
199
-
200
- 1. **Load state** -- Read `<session>/tasks.json`, filter tasks for current wave
201
- 2. **Skip failed deps** -- Mark tasks whose dependencies failed/skipped as `skipped`
202
- 3. **Build upstream context** -- For each task, gather findings from `context_from` tasks via tasks.json and `discoveries/{id}.json`
203
- 4. **Separate task types** -- Split into regular tasks and CHECKPOINT tasks
204
- 5. **Spawn regular tasks** -- For each regular task, call `spawn_agent({ agent_type: "team_worker", items: [...] })`, collect agent IDs
205
- 6. **Wait** -- `wait_agent({ targets: [...], timeout_ms: 900000 })`
206
- 7. **Collect results** -- Read `discoveries/{task_id}.json` for each agent, update tasks.json status/findings/error, then `close_agent({ target })` each worker
207
- 8. **Execute checkpoints** -- For each CHECKPOINT task, `assign_task` to supervisor, `wait_agent`, read checkpoint report from `artifacts/`, parse verdict
208
- 9. **Handle block** -- If verdict is `block`, prompt user via `request_user_input` with options: Override / Revise upstream / Abort
209
- 10. **Persist** -- Write updated state to `<session>/tasks.json`
210
-
211
- ## User Commands
212
-
213
- | Command | Action |
214
- |---------|--------|
215
- | `check` / `status` | View execution status graph |
216
- | `resume` / `continue` | Advance to next step |
217
- | `revise <TASK-ID> [feedback]` | Revise specific task |
218
- | `feedback <text>` | Inject feedback for revision |
219
- | `recheck` | Re-run quality check |
220
- | `improve [dimension]` | Auto-improve weakest dimension |
221
-
222
- ## v4 Agent Coordination
223
-
224
- ### Message Semantics
225
-
226
- | Intent | API | Example |
227
- |--------|-----|---------|
228
- | Queue supplementary info (don't interrupt) | `send_message` | Send planning results to running implementers |
229
- | Wake resident supervisor for checkpoint | `assign_task` | Trigger CHECKPOINT-* evaluation on supervisor |
230
- | Supervisor reports back to coordinator | `send_message` | Supervisor sends checkpoint verdict as supplementary info |
231
- | Check running agents | `list_agents` | Verify agent + supervisor health during resume |
232
-
233
- **CRITICAL**: The supervisor is a **resident agent** woken via `assign_task`, NOT `send_message`. Regular workers complete and are closed; the supervisor persists across checkpoints. See "Supervisor Spawn Template" above.
234
-
235
- ### Agent Health Check
236
-
237
- Use `list_agents({})` in handleResume and handleComplete:
238
-
239
- ```
240
- // Reconcile session state with actual running agents
241
- const running = list_agents({})
242
- // Compare with tasks.json active_agents
243
- // Reset orphaned tasks (in_progress but agent gone) to pending
244
- // ALSO check supervisor: if supervisor missing but CHECKPOINT tasks pending -> respawn
245
- ```
246
-
247
- ### Named Agent Targeting
248
-
249
- Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
250
- - `send_message({ target: "IMPL-001", items: [...] })` -- queue planning context to running implementer
251
- - `assign_task({ target: "supervisor", items: [...] })` -- wake supervisor for checkpoint
252
- - `close_agent({ target: "IMPL-001" })` -- cleanup regular worker by name
253
- - `close_agent({ target: "supervisor" })` -- shutdown supervisor at pipeline end
254
-
255
- ## Completion Action
256
-
257
- When pipeline completes, coordinator presents:
258
-
259
- ```
260
- request_user_input({
261
- questions: [{
262
- question: "Pipeline complete. What would you like to do?",
263
- header: "Completion",
264
- multiSelect: false,
265
- options: [
266
- { label: "Archive & Clean (Recommended)", description: "Archive session, clean up resources" },
267
- { label: "Keep Active", description: "Keep session for follow-up work" },
268
- { label: "Export Results", description: "Export deliverables to target directory" }
269
- ]
270
- }]
271
- })
272
- ```
273
-
274
- ## Specs Reference
275
-
276
- - [specs/pipelines.md](specs/pipelines.md) -- Pipeline definitions and task registry
277
- - [specs/quality-gates.md](specs/quality-gates.md) -- Quality gate criteria and scoring
278
- - [specs/knowledge-transfer.md](specs/knowledge-transfer.md) -- Artifact and state transfer protocols
279
-
280
- ## Session Directory
281
-
282
- ```
283
- .workflow/.team/TLV4-<slug>-<date>/
284
- ├── tasks.json # Task state (JSON)
285
- ├── discoveries/ # Per-task findings ({task_id}.json)
286
- ├── spec/ # Spec phase outputs
287
- ├── plan/ # Implementation plan
288
- ├── artifacts/ # All deliverables
289
- ├── wisdom/ # Cross-task knowledge
290
- ├── explorations/ # Shared explore cache
291
- └── discussions/ # Discuss round records
292
- ```
293
-
294
- ## Error Handling
295
-
296
- | Scenario | Resolution |
297
- |----------|------------|
298
- | Unknown command | Error with available command list |
299
- | Role not found | Error with role registry |
300
- | CLI tool fails | Worker fallback to direct implementation |
301
- | Supervisor crash | Respawn with `recovery: true`, auto-rebuilds from existing reports |
302
- | Supervisor not ready for CHECKPOINT | Spawn/respawn supervisor, wait for ready, then wake |
303
- | Completion action fails | Default to Keep Active |
304
- | Worker timeout | Mark task as failed, continue wave |
305
- | Discovery file missing | Mark task as failed with "No discovery file produced" |
1
+ ---
2
+ name: team-lifecycle-v4
3
+ description: Full lifecycle team skill with clean architecture. SKILL.md is a universal router — all roles read it. Beat model is coordinator-only. Structure is roles/ + specs/ + templates/. Triggers on "team lifecycle v4".
4
+ allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*), request_user_input(*)
5
+ ---
6
+
7
+ # Team Lifecycle v4
8
+
9
+ Orchestrate multi-agent software development: specification -> planning -> implementation -> testing -> review.
10
+
11
+ ## Architecture
12
+
13
+ ```
14
+ Skill(skill="team-lifecycle-v4", args="task description")
15
+ |
16
+ SKILL.md (this file) = Router
17
+ |
18
+ +--------------+--------------+
19
+ | |
20
+ no --role flag --role <name>
21
+ | |
22
+ Coordinator Worker
23
+ roles/coordinator/role.md roles/<name>/role.md
24
+ |
25
+ +-- analyze -> dispatch -> spawn -> wait -> collect
26
+ |
27
+ +--------+---+--------+
28
+ v v v
29
+ spawn_agent ... spawn_agent
30
+ (team_worker) (team_supervisor)
31
+ per-task resident agent
32
+ lifecycle assign_task-driven
33
+ | |
34
+ +-- wait_agent --------+
35
+ |
36
+ collect results
37
+ ```
38
+
39
+ ## Role Registry
40
+
41
+ | Role | Path | Prefix | Inner Loop |
42
+ |------|------|--------|------------|
43
+ | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | -- | -- |
44
+ | analyst | [roles/analyst/role.md](roles/analyst/role.md) | RESEARCH-* | false |
45
+ | writer | [roles/writer/role.md](roles/writer/role.md) | DRAFT-* | true |
46
+ | planner | [roles/planner/role.md](roles/planner/role.md) | PLAN-* | true |
47
+ | executor | [roles/executor/role.md](roles/executor/role.md) | IMPL-* | true |
48
+ | tester | [roles/tester/role.md](roles/tester/role.md) | TEST-* | false |
49
+ | reviewer | [roles/reviewer/role.md](roles/reviewer/role.md) | REVIEW-*, QUALITY-*, IMPROVE-* | false |
50
+ | supervisor | [roles/supervisor/role.md](roles/supervisor/role.md) | CHECKPOINT-* | false |
51
+
52
+ ## Role Router
53
+
54
+ Parse `$ARGUMENTS`:
55
+ - Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
56
+ - No `--role` -> `roles/coordinator/role.md`, execute entry router
57
+
58
+ ## Delegation Lock
59
+
60
+ **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
61
+
62
+ Before calling ANY tool, apply this check:
63
+
64
+ | Tool Call | Verdict | Reason |
65
+ |-----------|---------|--------|
66
+ | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
67
+ | `list_agents` | ALLOWED | Agent health check |
68
+ | `request_user_input` | ALLOWED | User interaction |
69
+ | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
70
+ | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
71
+ | `Read` on `roles/`, `commands/`, `specs/`, `templates/` | ALLOWED | Loading own instructions |
72
+ | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
73
+ | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
74
+ | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
75
+ | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
76
+
77
+ **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
78
+
79
+ **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
80
+
81
+ ---
82
+
83
+ ## Shared Constants
84
+
85
+ - **Session prefix**: `TLV4`
86
+ - **Session path**: `.workflow/.team/TLV4-<slug>-<date>/`
87
+ - **State file**: `<session>/tasks.json`
88
+ - **Discovery files**: `<session>/discoveries/{task_id}.json`
89
+ - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
90
+
91
+ ## Worker Spawn Template
92
+
93
+ Coordinator spawns workers using this template:
94
+
95
+ ```
96
+ spawn_agent({
97
+ agent_type: "team_worker",
98
+ task_name: "<task-id>",
99
+ fork_context: false,
100
+ items: [
101
+ { type: "text", text: `## Role Assignment
102
+ role: <role>
103
+ role_spec: <skill_root>/roles/<role>/role.md
104
+ session: <session-folder>
105
+ session_id: <session-id>
106
+ requirement: <task-description>
107
+ inner_loop: <true|false>
108
+
109
+ Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.
110
+ Execute built-in Phase 1 (task discovery) -> role Phase 2-4 -> built-in Phase 5 (report).` },
111
+
112
+ { type: "text", text: `## Task Context
113
+ task_id: <task-id>
114
+ title: <task-title>
115
+ description: <task-description>
116
+ pipeline_phase: <pipeline-phase>` },
117
+
118
+ { type: "text", text: `## Upstream Context
119
+ <prev_context>` }
120
+ ]
121
+ })
122
+ ```
123
+
124
+ ## Supervisor Spawn Template
125
+
126
+ Supervisor is a **resident agent** (independent from team_worker). Spawned once during session init, woken via assign_task for each CHECKPOINT task.
127
+
128
+ ### Spawn (Phase 2 -- once per session)
129
+
130
+ ```
131
+ supervisorId = spawn_agent({
132
+ agent_type: "team_supervisor",
133
+ task_name: "supervisor",
134
+ fork_context: false,
135
+ items: [
136
+ { type: "text", text: `## Role Assignment
137
+ role: supervisor
138
+ role_spec: <skill_root>/roles/supervisor/role.md
139
+ session: <session-folder>
140
+ session_id: <session-id>
141
+ requirement: <task-description>
142
+
143
+ Read role_spec file (<skill_root>/roles/supervisor/role.md) to load checkpoint definitions.
144
+ Init: load baseline context, report ready, go idle.
145
+ Wake cycle: orchestrator sends checkpoint requests via assign_task.` }
146
+ ]
147
+ })
148
+ ```
149
+
150
+ ### Wake (per CHECKPOINT task)
151
+
152
+ ```
153
+ assign_task({
154
+ target: "supervisor",
155
+ items: [
156
+ { type: "text", text: `## Checkpoint Request
157
+ task_id: <CHECKPOINT-NNN>
158
+ scope: [<upstream-task-ids>]
159
+ pipeline_progress: <done>/<total> tasks completed` }
160
+ ]
161
+ })
162
+ wait_agent({ targets: ["supervisor"], timeout_ms: 300000 })
163
+ ```
164
+
165
+ ### Shutdown (pipeline complete)
166
+
167
+ ```
168
+ close_agent({ target: "supervisor" })
169
+ ```
170
+
171
+
172
+ ### Model Selection Guide
173
+
174
+ | Role | model | reasoning_effort | Rationale |
175
+ |------|-------|-------------------|-----------|
176
+ | Analyst (RESEARCH-*) | (default) | medium | Read-heavy exploration, less reasoning needed |
177
+ | Writer (DRAFT-*) | (default) | high | Spec writing requires precision and completeness |
178
+ | Planner (PLAN-*) | (default) | high | Architecture decisions need full reasoning |
179
+ | Executor (IMPL-*) | (default) | high | Code generation needs precision |
180
+ | Tester (TEST-*) | (default) | high | Test generation requires deep code understanding |
181
+ | Reviewer (REVIEW-*, QUALITY-*, IMPROVE-*) | (default) | high | Deep analysis for quality assessment |
182
+ | Supervisor (CHECKPOINT-*) | (default) | medium | Gate checking, report aggregation |
183
+
184
+ Override model/reasoning_effort in spawn_agent when cost optimization is needed:
185
+ ```
186
+ spawn_agent({
187
+ agent_type: "team_worker",
188
+ task_name: "<task-id>",
189
+ fork_context: false,
190
+ model: "<model-override>",
191
+ reasoning_effort: "<effort-level>",
192
+ items: [...]
193
+ })
194
+ ```
195
+
196
+ ## Wave Execution Engine
197
+
198
+ For each wave in the pipeline:
199
+
200
+ 1. **Load state** -- Read `<session>/tasks.json`, filter tasks for current wave
201
+ 2. **Skip failed deps** -- Mark tasks whose dependencies failed/skipped as `skipped`
202
+ 3. **Build upstream context** -- For each task, gather findings from `context_from` tasks via tasks.json and `discoveries/{id}.json`
203
+ 4. **Separate task types** -- Split into regular tasks and CHECKPOINT tasks
204
+ 5. **Spawn regular tasks** -- For each regular task, call `spawn_agent({ agent_type: "team_worker", items: [...] })`, collect agent IDs
205
+ 6. **Wait** -- `wait_agent({ targets: [...], timeout_ms: 900000 })`
206
+ 7. **Collect results** -- Read `discoveries/{task_id}.json` for each agent, update tasks.json status/findings/error, then `close_agent({ target })` each worker
207
+ 8. **Execute checkpoints** -- For each CHECKPOINT task, `assign_task` to supervisor, `wait_agent`, read checkpoint report from `artifacts/`, parse verdict
208
+ 9. **Handle block** -- If verdict is `block`, prompt user via `request_user_input` with options: Override / Revise upstream / Abort
209
+ 10. **Persist** -- Write updated state to `<session>/tasks.json`
210
+
211
+ ## User Commands
212
+
213
+ | Command | Action |
214
+ |---------|--------|
215
+ | `check` / `status` | View execution status graph |
216
+ | `resume` / `continue` | Advance to next step |
217
+ | `revise <TASK-ID> [feedback]` | Revise specific task |
218
+ | `feedback <text>` | Inject feedback for revision |
219
+ | `recheck` | Re-run quality check |
220
+ | `improve [dimension]` | Auto-improve weakest dimension |
221
+
222
+ ## v4 Agent Coordination
223
+
224
+ ### Message Semantics
225
+
226
+ | Intent | API | Example |
227
+ |--------|-----|---------|
228
+ | Queue supplementary info (don't interrupt) | `send_message` | Send planning results to running implementers |
229
+ | Wake resident supervisor for checkpoint | `assign_task` | Trigger CHECKPOINT-* evaluation on supervisor |
230
+ | Supervisor reports back to coordinator | `send_message` | Supervisor sends checkpoint verdict as supplementary info |
231
+ | Check running agents | `list_agents` | Verify agent + supervisor health during resume |
232
+
233
+ **CRITICAL**: The supervisor is a **resident agent** woken via `assign_task`, NOT `send_message`. Regular workers complete and are closed; the supervisor persists across checkpoints. See "Supervisor Spawn Template" above.
234
+
235
+ ### Agent Health Check
236
+
237
+ Use `list_agents({})` in handleResume and handleComplete:
238
+
239
+ ```
240
+ // Reconcile session state with actual running agents
241
+ const running = list_agents({})
242
+ // Compare with tasks.json active_agents
243
+ // Reset orphaned tasks (in_progress but agent gone) to pending
244
+ // ALSO check supervisor: if supervisor missing but CHECKPOINT tasks pending -> respawn
245
+ ```
246
+
247
+ ### Named Agent Targeting
248
+
249
+ Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
250
+ - `send_message({ target: "IMPL-001", items: [...] })` -- queue planning context to running implementer
251
+ - `assign_task({ target: "supervisor", items: [...] })` -- wake supervisor for checkpoint
252
+ - `close_agent({ target: "IMPL-001" })` -- cleanup regular worker by name
253
+ - `close_agent({ target: "supervisor" })` -- shutdown supervisor at pipeline end
254
+
255
+ ## Completion Action
256
+
257
+ When pipeline completes, coordinator presents:
258
+
259
+ ```
260
+ functions.request_user_input({
261
+ questions: [{
262
+ question: "Pipeline complete. What would you like to do?",
263
+ header: "Completion",
264
+ multiSelect: false,
265
+ options: [
266
+ { label: "Archive & Clean (Recommended)", description: "Archive session, clean up resources" },
267
+ { label: "Keep Active", description: "Keep session for follow-up work" },
268
+ { label: "Export Results", description: "Export deliverables to target directory" }
269
+ ]
270
+ }]
271
+ })
272
+ ```
273
+
274
+ ## Specs Reference
275
+
276
+ - [specs/pipelines.md](specs/pipelines.md) -- Pipeline definitions and task registry
277
+ - [specs/quality-gates.md](specs/quality-gates.md) -- Quality gate criteria and scoring
278
+ - [specs/knowledge-transfer.md](specs/knowledge-transfer.md) -- Artifact and state transfer protocols
279
+
280
+ ## Session Directory
281
+
282
+ ```
283
+ .workflow/.team/TLV4-<slug>-<date>/
284
+ ├── tasks.json # Task state (JSON)
285
+ ├── discoveries/ # Per-task findings ({task_id}.json)
286
+ ├── spec/ # Spec phase outputs
287
+ ├── plan/ # Implementation plan
288
+ ├── artifacts/ # All deliverables
289
+ ├── wisdom/ # Cross-task knowledge
290
+ ├── explorations/ # Shared explore cache
291
+ └── discussions/ # Discuss round records
292
+ ```
293
+
294
+ ## Error Handling
295
+
296
+ | Scenario | Resolution |
297
+ |----------|------------|
298
+ | Unknown command | Error with available command list |
299
+ | Role not found | Error with role registry |
300
+ | CLI tool fails | Worker fallback to direct implementation |
301
+ | Supervisor crash | Respawn with `recovery: true`, auto-rebuilds from existing reports |
302
+ | Supervisor not ready for CHECKPOINT | Spawn/respawn supervisor, wait for ready, then wake |
303
+ | Completion action fails | Default to Keep Active |
304
+ | Worker timeout | Mark task as failed, continue wave |
305
+ | Discovery file missing | Mark task as failed with "No discovery file produced" |