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,260 +1,260 @@
1
- ---
2
- name: team-ultra-analyze
3
- description: Deep collaborative analysis team skill. All roles route via this SKILL.md. Beat model is coordinator-only (monitor.md). Structure is roles/ + specs/. Triggers on "team ultra-analyze", "team analyze".
4
- allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*)
5
- ---
6
-
7
- # Team Ultra Analyze
8
-
9
- Deep collaborative analysis: explore -> analyze -> discuss -> synthesize. Supports Quick/Standard/Deep pipeline modes with configurable depth (N parallel agents). Discussion loops enable user-guided progressive understanding.
10
-
11
- ## Architecture
12
-
13
- ```
14
- Skill(skill="team-ultra-analyze", args="<topic>")
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 workers -> STOP
26
- |
27
- +-------+-------+-------+-------+
28
- v v v v
29
- [team-worker agents, each loads roles/<role>/role.md]
30
-
31
- Pipeline (Standard mode):
32
- [EXPLORE-1..N](parallel) -> [ANALYZE-1..N](parallel) -> DISCUSS-001 -> SYNTH-001
33
-
34
- Pipeline (Deep mode):
35
- [EXPLORE-1..N] -> [ANALYZE-1..N] -> DISCUSS-001 -> ANALYZE-fix -> DISCUSS-002 -> ... -> SYNTH-001
36
-
37
- Pipeline (Quick mode):
38
- EXPLORE-001 -> ANALYZE-001 -> SYNTH-001
39
- ```
40
-
41
- ## Role Registry
42
-
43
- | Role | Path | Prefix | Inner Loop |
44
- |------|------|--------|------------|
45
- | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
46
- | explorer | [roles/explorer/role.md](roles/explorer/role.md) | EXPLORE-* | false |
47
- | analyst | [roles/analyst/role.md](roles/analyst/role.md) | ANALYZE-* | false |
48
- | discussant | [roles/discussant/role.md](roles/discussant/role.md) | DISCUSS-* | false |
49
- | synthesizer | [roles/synthesizer/role.md](roles/synthesizer/role.md) | SYNTH-* | false |
50
-
51
- ## Role Router
52
-
53
- Parse `$ARGUMENTS`:
54
- - Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
55
- - No `--role` → `roles/coordinator/role.md`, execute entry router
56
-
57
- ## Delegation Lock
58
-
59
- **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
60
-
61
- Before calling ANY tool, apply this check:
62
-
63
- | Tool Call | Verdict | Reason |
64
- |-----------|---------|--------|
65
- | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
66
- | `list_agents` | ALLOWED | Agent health check |
67
- | `request_user_input` | ALLOWED | User interaction |
68
- | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
69
- | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
70
- | `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
71
- | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
72
- | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
73
- | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
74
- | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
75
-
76
- **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
77
-
78
- **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
79
-
80
- ---
81
-
82
- ## Shared Constants
83
-
84
- - **Session prefix**: `UAN`
85
- - **Session path**: `.workflow/.team/UAN-<slug>-<date>/`
86
- - **Team name**: `ultra-analyze`
87
- - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
88
- - **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
89
-
90
- ## Worker Spawn Template
91
-
92
- Coordinator spawns workers using this template:
93
-
94
- ```
95
- spawn_agent({
96
- agent_type: "team_worker",
97
- task_name: "<task-id>",
98
- fork_context: false,
99
- items: [
100
- { type: "text", text: `## Role Assignment
101
- role: <role>
102
- role_spec: <skill_root>/roles/<role>/role.md
103
- session: <session-folder>
104
- session_id: <session-id>
105
- requirement: <topic-description>
106
- inner_loop: false
107
-
108
- Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
109
-
110
- { type: "text", text: `## Task Context
111
- task_id: <task-id>
112
- title: <task-title>
113
- description: <task-description>
114
- pipeline_phase: <pipeline-phase>` },
115
-
116
- { type: "text", text: `## Upstream Context
117
- <prev_context>` }
118
- ]
119
- })
120
- ```
121
-
122
- After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
123
-
124
-
125
- ### Model Selection Guide
126
-
127
- | Role | model | reasoning_effort | Rationale |
128
- |------|-------|-------------------|-----------|
129
- | Explorer (EXPLORE-*) | (default) | medium | File reading and pattern scanning, less reasoning needed |
130
- | Analyst (ANALYZE-*) | (default) | high | Deep analysis requires full reasoning |
131
- | Discussant (DISCUSS-*) | (default) | high | Synthesis of multiple viewpoints, dialectic reasoning |
132
- | Synthesizer (SYNTH-*) | (default) | medium | Aggregation and summary over generation |
133
-
134
- Override model/reasoning_effort in spawn_agent when cost optimization is needed:
135
- ```
136
- spawn_agent({
137
- agent_type: "team_worker",
138
- task_name: "<task-id>",
139
- fork_context: false,
140
- model: "<model-override>",
141
- reasoning_effort: "<effort-level>",
142
- items: [...]
143
- })
144
- ```
145
-
146
- ## User Commands
147
-
148
- | Command | Action |
149
- |---------|--------|
150
- | `check` / `status` | Output execution status diagram, do not advance pipeline |
151
- | `resume` / `continue` | Check worker status, advance to next pipeline step |
152
-
153
- ## Session Directory
154
-
155
- ```
156
- .workflow/.team/UAN-{slug}-{YYYY-MM-DD}/
157
- +-- .msg/messages.jsonl # Message bus log
158
- +-- .msg/meta.json # Session metadata + cross-role state
159
- +-- discussion.md # Understanding evolution and discussion timeline
160
- +-- explorations/ # Explorer output
161
- | +-- exploration-001.json
162
- | +-- exploration-002.json
163
- +-- analyses/ # Analyst output
164
- | +-- analysis-001.json
165
- | +-- analysis-002.json
166
- +-- discussions/ # Discussant output
167
- | +-- discussion-round-001.json
168
- +-- conclusions.json # Synthesizer output
169
- +-- wisdom/ # Cross-task knowledge
170
- | +-- learnings.md
171
- | +-- decisions.md
172
- | +-- conventions.md
173
- | +-- issues.md
174
- ```
175
-
176
- ## v4 Agent Coordination
177
-
178
- ### Message Semantics
179
-
180
- | Intent | API | Example |
181
- |--------|-----|---------|
182
- | Send exploration findings to running analysts | `send_message` | Queue upstream context without interrupting ANALYZE-* workers |
183
- | Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
184
- | Check running agents | `list_agents` | Verify parallel explorer/analyst health during resume |
185
-
186
- ### Parallel Phase Coordination
187
-
188
- Standard/Deep modes spawn N parallel agents in EXPLORE and ANALYZE phases. Use batch spawn + wait:
189
-
190
- ```
191
- // EXPLORE phase: spawn N explorers in parallel
192
- const explorerNames = ["EXPLORE-001", "EXPLORE-002", ..., "EXPLORE-00N"]
193
- for (const name of explorerNames) {
194
- spawn_agent({ agent_type: "team_worker", task_name: name, ... })
195
- }
196
- wait_agent({ targets: explorerNames, timeout_ms: 900000 })
197
- // Collect all results, then spawn ANALYZE phase
198
-
199
- // ANALYZE phase: send exploration context to analysts via items (not send_message)
200
- // since analysts are spawned AFTER explorers complete
201
- ```
202
-
203
- ### Agent Health Check
204
-
205
- Use `list_agents({})` in handleResume and handleComplete:
206
-
207
- ```
208
- // Reconcile session state with actual running agents
209
- const running = list_agents({})
210
- // Compare with tasks.json active_agents
211
- // Reset orphaned tasks (in_progress but agent gone) to pending
212
- // Critical for parallel phases -- multiple agents may crash independently
213
- ```
214
-
215
- ### Named Agent Targeting
216
-
217
- Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
218
- - `send_message({ target: "ANALYZE-001", items: [...] })` -- queue supplementary exploration findings
219
- - `close_agent({ target: "EXPLORE-001" })` -- cleanup by name after wait_agent returns
220
-
221
- ## Completion Action
222
-
223
- When pipeline completes, coordinator presents:
224
-
225
- ```
226
- request_user_input({
227
- questions: [{
228
- question: "Ultra-Analyze pipeline complete. What would you like to do?",
229
- header: "Completion",
230
- multiSelect: false,
231
- options: [
232
- { label: "Archive & Clean (Recommended)", description: "Archive session, clean up tasks and team resources" },
233
- { label: "Keep Active", description: "Keep session active for follow-up work or inspection" },
234
- { label: "Export Results", description: "Export deliverables to a specified location, then clean" }
235
- ]
236
- }]
237
- })
238
- ```
239
-
240
- | Choice | Action |
241
- |--------|--------|
242
- | Archive & Clean | Update session status="completed" -> output final summary |
243
- | Keep Active | Update session status="paused" -> output resume instructions |
244
- | Export Results | request_user_input for target path -> copy deliverables -> Archive & Clean |
245
-
246
- ## Specs Reference
247
-
248
- - [specs/team-config.json](specs/team-config.json) — Team configuration and pipeline settings
249
-
250
- ## Error Handling
251
-
252
- | Scenario | Resolution |
253
- |----------|------------|
254
- | Unknown --role value | Error with role registry list |
255
- | Role file not found | Error with expected path (roles/{name}/role.md) |
256
- | Discussion loop stuck >5 rounds | Force synthesis, offer continuation |
257
- | CLI tool unavailable | Fallback chain: gemini -> codex -> manual analysis |
258
- | Explorer agent fails | Continue with available context, note limitation |
259
- | Fast-advance conflict | Coordinator reconciles on next callback |
260
- | Completion action fails | Default to Keep Active |
1
+ ---
2
+ name: team-ultra-analyze
3
+ description: Deep collaborative analysis team skill. All roles route via this SKILL.md. Beat model is coordinator-only (monitor.md). Structure is roles/ + specs/. Triggers on "team ultra-analyze", "team analyze".
4
+ allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*)
5
+ ---
6
+
7
+ # Team Ultra Analyze
8
+
9
+ Deep collaborative analysis: explore -> analyze -> discuss -> synthesize. Supports Quick/Standard/Deep pipeline modes with configurable depth (N parallel agents). Discussion loops enable user-guided progressive understanding.
10
+
11
+ ## Architecture
12
+
13
+ ```
14
+ Skill(skill="team-ultra-analyze", args="<topic>")
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 workers -> STOP
26
+ |
27
+ +-------+-------+-------+-------+
28
+ v v v v
29
+ [team-worker agents, each loads roles/<role>/role.md]
30
+
31
+ Pipeline (Standard mode):
32
+ [EXPLORE-1..N](parallel) -> [ANALYZE-1..N](parallel) -> DISCUSS-001 -> SYNTH-001
33
+
34
+ Pipeline (Deep mode):
35
+ [EXPLORE-1..N] -> [ANALYZE-1..N] -> DISCUSS-001 -> ANALYZE-fix -> DISCUSS-002 -> ... -> SYNTH-001
36
+
37
+ Pipeline (Quick mode):
38
+ EXPLORE-001 -> ANALYZE-001 -> SYNTH-001
39
+ ```
40
+
41
+ ## Role Registry
42
+
43
+ | Role | Path | Prefix | Inner Loop |
44
+ |------|------|--------|------------|
45
+ | coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
46
+ | explorer | [roles/explorer/role.md](roles/explorer/role.md) | EXPLORE-* | false |
47
+ | analyst | [roles/analyst/role.md](roles/analyst/role.md) | ANALYZE-* | false |
48
+ | discussant | [roles/discussant/role.md](roles/discussant/role.md) | DISCUSS-* | false |
49
+ | synthesizer | [roles/synthesizer/role.md](roles/synthesizer/role.md) | SYNTH-* | false |
50
+
51
+ ## Role Router
52
+
53
+ Parse `$ARGUMENTS`:
54
+ - Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
55
+ - No `--role` → `roles/coordinator/role.md`, execute entry router
56
+
57
+ ## Delegation Lock
58
+
59
+ **Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
60
+
61
+ Before calling ANY tool, apply this check:
62
+
63
+ | Tool Call | Verdict | Reason |
64
+ |-----------|---------|--------|
65
+ | `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
66
+ | `list_agents` | ALLOWED | Agent health check |
67
+ | `request_user_input` | ALLOWED | User interaction |
68
+ | `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
69
+ | `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
70
+ | `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
71
+ | `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
72
+ | `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
73
+ | `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
74
+ | `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
75
+
76
+ **If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
77
+
78
+ **No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
79
+
80
+ ---
81
+
82
+ ## Shared Constants
83
+
84
+ - **Session prefix**: `UAN`
85
+ - **Session path**: `.workflow/.team/UAN-<slug>-<date>/`
86
+ - **Team name**: `ultra-analyze`
87
+ - **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
88
+ - **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
89
+
90
+ ## Worker Spawn Template
91
+
92
+ Coordinator spawns workers using this template:
93
+
94
+ ```
95
+ spawn_agent({
96
+ agent_type: "team_worker",
97
+ task_name: "<task-id>",
98
+ fork_context: false,
99
+ items: [
100
+ { type: "text", text: `## Role Assignment
101
+ role: <role>
102
+ role_spec: <skill_root>/roles/<role>/role.md
103
+ session: <session-folder>
104
+ session_id: <session-id>
105
+ requirement: <topic-description>
106
+ inner_loop: false
107
+
108
+ Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
109
+
110
+ { type: "text", text: `## Task Context
111
+ task_id: <task-id>
112
+ title: <task-title>
113
+ description: <task-description>
114
+ pipeline_phase: <pipeline-phase>` },
115
+
116
+ { type: "text", text: `## Upstream Context
117
+ <prev_context>` }
118
+ ]
119
+ })
120
+ ```
121
+
122
+ After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
123
+
124
+
125
+ ### Model Selection Guide
126
+
127
+ | Role | model | reasoning_effort | Rationale |
128
+ |------|-------|-------------------|-----------|
129
+ | Explorer (EXPLORE-*) | (default) | medium | File reading and pattern scanning, less reasoning needed |
130
+ | Analyst (ANALYZE-*) | (default) | high | Deep analysis requires full reasoning |
131
+ | Discussant (DISCUSS-*) | (default) | high | Synthesis of multiple viewpoints, dialectic reasoning |
132
+ | Synthesizer (SYNTH-*) | (default) | medium | Aggregation and summary over generation |
133
+
134
+ Override model/reasoning_effort in spawn_agent when cost optimization is needed:
135
+ ```
136
+ spawn_agent({
137
+ agent_type: "team_worker",
138
+ task_name: "<task-id>",
139
+ fork_context: false,
140
+ model: "<model-override>",
141
+ reasoning_effort: "<effort-level>",
142
+ items: [...]
143
+ })
144
+ ```
145
+
146
+ ## User Commands
147
+
148
+ | Command | Action |
149
+ |---------|--------|
150
+ | `check` / `status` | Output execution status diagram, do not advance pipeline |
151
+ | `resume` / `continue` | Check worker status, advance to next pipeline step |
152
+
153
+ ## Session Directory
154
+
155
+ ```
156
+ .workflow/.team/UAN-{slug}-{YYYY-MM-DD}/
157
+ +-- .msg/messages.jsonl # Message bus log
158
+ +-- .msg/meta.json # Session metadata + cross-role state
159
+ +-- discussion.md # Understanding evolution and discussion timeline
160
+ +-- explorations/ # Explorer output
161
+ | +-- exploration-001.json
162
+ | +-- exploration-002.json
163
+ +-- analyses/ # Analyst output
164
+ | +-- analysis-001.json
165
+ | +-- analysis-002.json
166
+ +-- discussions/ # Discussant output
167
+ | +-- discussion-round-001.json
168
+ +-- conclusions.json # Synthesizer output
169
+ +-- wisdom/ # Cross-task knowledge
170
+ | +-- learnings.md
171
+ | +-- decisions.md
172
+ | +-- conventions.md
173
+ | +-- issues.md
174
+ ```
175
+
176
+ ## v4 Agent Coordination
177
+
178
+ ### Message Semantics
179
+
180
+ | Intent | API | Example |
181
+ |--------|-----|---------|
182
+ | Send exploration findings to running analysts | `send_message` | Queue upstream context without interrupting ANALYZE-* workers |
183
+ | Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
184
+ | Check running agents | `list_agents` | Verify parallel explorer/analyst health during resume |
185
+
186
+ ### Parallel Phase Coordination
187
+
188
+ Standard/Deep modes spawn N parallel agents in EXPLORE and ANALYZE phases. Use batch spawn + wait:
189
+
190
+ ```
191
+ // EXPLORE phase: spawn N explorers in parallel
192
+ const explorerNames = ["EXPLORE-001", "EXPLORE-002", ..., "EXPLORE-00N"]
193
+ for (const name of explorerNames) {
194
+ spawn_agent({ agent_type: "team_worker", task_name: name, ... })
195
+ }
196
+ wait_agent({ targets: explorerNames, timeout_ms: 900000 })
197
+ // Collect all results, then spawn ANALYZE phase
198
+
199
+ // ANALYZE phase: send exploration context to analysts via items (not send_message)
200
+ // since analysts are spawned AFTER explorers complete
201
+ ```
202
+
203
+ ### Agent Health Check
204
+
205
+ Use `list_agents({})` in handleResume and handleComplete:
206
+
207
+ ```
208
+ // Reconcile session state with actual running agents
209
+ const running = list_agents({})
210
+ // Compare with tasks.json active_agents
211
+ // Reset orphaned tasks (in_progress but agent gone) to pending
212
+ // Critical for parallel phases -- multiple agents may crash independently
213
+ ```
214
+
215
+ ### Named Agent Targeting
216
+
217
+ Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
218
+ - `send_message({ target: "ANALYZE-001", items: [...] })` -- queue supplementary exploration findings
219
+ - `close_agent({ target: "EXPLORE-001" })` -- cleanup by name after wait_agent returns
220
+
221
+ ## Completion Action
222
+
223
+ When pipeline completes, coordinator presents:
224
+
225
+ ```
226
+ functions.request_user_input({
227
+ questions: [{
228
+ question: "Ultra-Analyze pipeline complete. What would you like to do?",
229
+ header: "Completion",
230
+ multiSelect: false,
231
+ options: [
232
+ { label: "Archive & Clean (Recommended)", description: "Archive session, clean up tasks and team resources" },
233
+ { label: "Keep Active", description: "Keep session active for follow-up work or inspection" },
234
+ { label: "Export Results", description: "Export deliverables to a specified location, then clean" }
235
+ ]
236
+ }]
237
+ })
238
+ ```
239
+
240
+ | Choice | Action |
241
+ |--------|--------|
242
+ | Archive & Clean | Update session status="completed" -> output final summary |
243
+ | Keep Active | Update session status="paused" -> output resume instructions |
244
+ | Export Results | request_user_input for target path -> copy deliverables -> Archive & Clean |
245
+
246
+ ## Specs Reference
247
+
248
+ - [specs/team-config.json](specs/team-config.json) — Team configuration and pipeline settings
249
+
250
+ ## Error Handling
251
+
252
+ | Scenario | Resolution |
253
+ |----------|------------|
254
+ | Unknown --role value | Error with role registry list |
255
+ | Role file not found | Error with expected path (roles/{name}/role.md) |
256
+ | Discussion loop stuck >5 rounds | Force synthesis, offer continuation |
257
+ | CLI tool unavailable | Fallback chain: gemini -> codex -> manual analysis |
258
+ | Explorer agent fails | Continue with available context, note limitation |
259
+ | Fast-advance conflict | Coordinator reconciles on next callback |
260
+ | Completion action fails | Default to Keep Active |
@@ -91,7 +91,7 @@ ELSE IF discussion_round >= MAX_ROUNDS:
91
91
 
92
92
  ELSE:
93
93
  // Collect user feedback
94
- request_user_input({
94
+ functions.request_user_input({
95
95
  questions: [{
96
96
  question: "Discussion round <N> complete. What next?",
97
97
  header: "Discussion Feedback",
@@ -216,7 +216,7 @@ All subsequent coordination is handled by `commands/monitor.md` handlers trigger
216
216
  5. **Completion Action** (interactive):
217
217
 
218
218
  ```
219
- request_user_input({
219
+ functions.request_user_input({
220
220
  questions: [{
221
221
  question: "Ultra-Analyze pipeline complete. What would you like to do?",
222
222
  header: "Completion",