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.
- package/.ccw/workflows/cli-templates/schemas/plan-overview-base-schema.json +2 -2
- package/.ccw/workflows/cli-templates/schemas/task-schema.json +14 -7
- package/.claude/agents/action-planning-agent.md +7 -4
- package/.claude/agents/cli-explore-agent.md +77 -63
- package/.claude/agents/cli-lite-planning-agent.md +11 -10
- package/.claude/agents/issue-plan-agent.md +421 -426
- package/.claude/commands/workflow/spec/setup.md +1 -1
- package/.claude/commands/workflow-skill.md +130 -0
- package/.claude/skills/ccw-chain/SKILL.md +92 -0
- package/.claude/skills/ccw-chain/chains/ccw-cycle.json +31 -0
- package/.claude/skills/ccw-chain/chains/ccw-exploration.json +58 -0
- package/.claude/skills/ccw-chain/chains/ccw-issue.json +44 -0
- package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +71 -0
- package/.claude/skills/ccw-chain/chains/ccw-main.json +65 -0
- package/.claude/skills/ccw-chain/chains/ccw-standard.json +51 -0
- package/.claude/skills/ccw-chain/chains/ccw-team.json +15 -0
- package/.claude/skills/ccw-chain/chains/ccw-with-file.json +47 -0
- package/.claude/skills/ccw-chain/specs/auto-mode.md +47 -0
- package/.claude/skills/chain-loader/SKILL.md +78 -0
- package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -0
- package/.claude/skills/chain-loader/phases/02-design-graph.md +73 -0
- package/.claude/skills/chain-loader/phases/03-generate-validate.md +75 -0
- package/.claude/skills/chain-loader/specs/chain-schema.md +126 -0
- package/.claude/skills/chain-loader/specs/design-patterns.md +99 -0
- package/.claude/skills/chain-loader/templates/chain-json.md +63 -0
- package/.claude/skills/review-cycle/phases/review-module.md +764 -764
- package/.claude/skills/review-cycle/phases/review-session.md +775 -775
- package/.claude/skills/workflow-multi-cli-plan/SKILL.md +2 -2
- package/.claude/skills/workflow-plan/SKILL.md +1 -0
- package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
- package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
- package/.claude/skills/workflow-plan/phases/03-conflict-resolution.md +422 -422
- package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
- package/.claude/skills/workflow-plan/phases/05-plan-verify.md +395 -395
- package/.claude/skills/workflow-tdd-plan/phases/02-context-gathering.md +407 -407
- package/.claude/skills/workflow-tdd-plan/phases/04-conflict-resolution.md +426 -426
- package/.claude/skills/workflow-test-fix/phases/02-test-context-gather.md +493 -493
- package/.codex/skills/analyze-with-file/SKILL.md +383 -134
- package/.codex/skills/brainstorm/SKILL.md +3 -3
- package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
- package/.codex/skills/clean/SKILL.md +1 -1
- package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
- package/.codex/skills/investigate/orchestrator.md +24 -0
- package/.codex/skills/issue-discover/SKILL.md +374 -361
- package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
- package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
- package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
- package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
- package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
- package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
- package/.codex/skills/review-cycle/SKILL.md +31 -12
- package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
- package/.codex/skills/security-audit/orchestrator.md +29 -0
- package/.codex/skills/session-sync/SKILL.md +1 -1
- package/.codex/skills/ship/orchestrator.md +24 -0
- package/.codex/skills/spec-add/SKILL.md +5 -5
- package/.codex/skills/spec-generator/SKILL.md +33 -2
- package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
- package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
- package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
- package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
- package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
- package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
- package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
- package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
- package/.codex/skills/spec-setup/SKILL.md +669 -669
- package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-brainstorm/SKILL.md +259 -259
- package/.codex/skills/team-coordinate/SKILL.md +359 -359
- package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-designer/SKILL.md +27 -1
- package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
- package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
- package/.codex/skills/team-designer/phases/04-validation.md +1 -1
- package/.codex/skills/team-executor/SKILL.md +218 -218
- package/.codex/skills/team-frontend/SKILL.md +227 -227
- package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
- package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
- package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
- package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
- package/.codex/skills/team-issue/SKILL.md +269 -269
- package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
- package/.codex/skills/team-motion-design/SKILL.md +222 -222
- package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
- package/.codex/skills/team-perf-opt/SKILL.md +258 -258
- package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-planex/SKILL.md +216 -216
- package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
- package/.codex/skills/team-review/SKILL.md +227 -227
- package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
- package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
- package/.codex/skills/team-tech-debt/SKILL.md +206 -206
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-testing/SKILL.md +237 -237
- package/.codex/skills/team-ui-polish/SKILL.md +218 -218
- package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
- package/.codex/skills/team-uidesign/SKILL.md +219 -219
- package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
- package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
- package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/SKILL.md +227 -227
- package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
- package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
- package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
- package/.codex/skills/workflow-execute/SKILL.md +5 -5
- package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
- package/.codex/skills/workflow-plan/SKILL.md +3 -3
- package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
- package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
- package/README.md +14 -0
- package/ccw/dist/cli.d.ts.map +1 -1
- package/ccw/dist/cli.js +16 -0
- package/ccw/dist/cli.js.map +1 -1
- package/ccw/dist/commands/chain-loader.d.ts +2 -0
- package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
- package/ccw/dist/commands/chain-loader.js +11 -0
- package/ccw/dist/commands/chain-loader.js.map +1 -0
- package/ccw/dist/commands/install.d.ts.map +1 -1
- package/ccw/dist/commands/install.js +52 -1
- package/ccw/dist/commands/install.js.map +1 -1
- package/ccw/dist/commands/launcher.d.ts +2 -0
- package/ccw/dist/commands/launcher.d.ts.map +1 -0
- package/ccw/dist/commands/launcher.js +434 -0
- package/ccw/dist/commands/launcher.js.map +1 -0
- package/ccw/dist/core/routes/litellm-api-routes.d.ts.map +1 -1
- package/ccw/dist/core/routes/litellm-api-routes.js +0 -23
- package/ccw/dist/core/routes/litellm-api-routes.js.map +1 -1
- package/ccw/dist/tools/chain-loader.d.ts +10 -0
- package/ccw/dist/tools/chain-loader.d.ts.map +1 -0
- package/ccw/dist/tools/chain-loader.js +1054 -0
- package/ccw/dist/tools/chain-loader.js.map +1 -0
- package/ccw/dist/tools/index.d.ts.map +1 -1
- package/ccw/dist/tools/index.js +2 -0
- package/ccw/dist/tools/index.js.map +1 -1
- package/ccw/dist/tools/json-builder.js +20 -0
- package/ccw/dist/tools/json-builder.js.map +1 -1
- package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
- package/ccw/dist/tools/skill-context-loader.js +12 -26
- package/ccw/dist/tools/skill-context-loader.js.map +1 -1
- package/ccw/dist/types/chain-types.d.ts +112 -0
- package/ccw/dist/types/chain-types.d.ts.map +1 -0
- package/ccw/dist/types/chain-types.js +5 -0
- package/ccw/dist/types/chain-types.js.map +1 -0
- package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
- package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
- package/ccw/dist/utils/chain-visualizer.js +164 -0
- package/ccw/dist/utils/chain-visualizer.js.map +1 -0
- package/ccw/scripts/prepublish-clean.mjs +0 -1
- package/package.json +1 -3
- package/.claude/commands/cli/cli-init.md +0 -441
- package/.claude/commands/cli/codex-review.md +0 -361
- package/.claude/commands/flow-create.md +0 -663
- package/.claude/skills/team-edict.zip +0 -0
- package/ccw-litellm/README.md +0 -180
- package/ccw-litellm/pyproject.toml +0 -35
- package/ccw-litellm/src/ccw_litellm/__init__.py +0 -47
- package/ccw-litellm/src/ccw_litellm/cli.py +0 -108
- package/ccw-litellm/src/ccw_litellm/clients/__init__.py +0 -12
- package/ccw-litellm/src/ccw_litellm/clients/litellm_embedder.py +0 -270
- package/ccw-litellm/src/ccw_litellm/clients/litellm_llm.py +0 -198
- package/ccw-litellm/src/ccw_litellm/config/__init__.py +0 -22
- package/ccw-litellm/src/ccw_litellm/config/loader.py +0 -343
- package/ccw-litellm/src/ccw_litellm/config/models.py +0 -162
- package/ccw-litellm/src/ccw_litellm/interfaces/__init__.py +0 -14
- package/ccw-litellm/src/ccw_litellm/interfaces/embedder.py +0 -52
- 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 |
|
|
@@ -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",
|