claude-code-workflow 7.2.30 → 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/.claude/commands/workflow-skill.md +130 -0
- package/.claude/skills/ccw-chain/SKILL.md +44 -71
- package/.claude/skills/ccw-chain/chains/ccw-cycle.json +13 -3
- package/.claude/skills/ccw-chain/chains/ccw-exploration.json +33 -22
- package/.claude/skills/ccw-chain/chains/ccw-issue.json +23 -12
- package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +23 -9
- package/.claude/skills/ccw-chain/chains/ccw-main.json +15 -2
- package/.claude/skills/ccw-chain/chains/ccw-standard.json +28 -16
- package/.claude/skills/ccw-chain/chains/ccw-team.json +7 -2
- package/.claude/skills/ccw-chain/chains/ccw-with-file.json +25 -9
- package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -53
- package/.claude/skills/chain-loader/specs/chain-schema.md +30 -3
- package/.claude/skills/chain-loader/templates/chain-json.md +63 -63
- 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/04-task-generation.md +9 -1
- 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/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/tools/chain-loader.d.ts.map +1 -1
- package/ccw/dist/tools/chain-loader.js +457 -45
- package/ccw/dist/tools/chain-loader.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 +41 -1
- package/ccw/dist/types/chain-types.d.ts.map +1 -1
- 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/package.json +1 -1
- 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/ccw-chain/phases/analyze-with-file.md +0 -788
- package/.claude/skills/ccw-chain/phases/brainstorm/SKILL.md +0 -408
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/01-mode-routing.md +0 -207
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/02-artifacts.md +0 -567
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/03-role-analysis.md +0 -748
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/04-synthesis.md +0 -827
- package/.claude/skills/ccw-chain/phases/brainstorm-with-file.md +0 -482
- package/.claude/skills/ccw-chain/phases/collaborative-plan-with-file.md +0 -639
- package/.claude/skills/ccw-chain/phases/debug-with-file.md +0 -656
- package/.claude/skills/ccw-chain/phases/integration-test-cycle.md +0 -936
- package/.claude/skills/ccw-chain/phases/issue-convert-to-plan.md +0 -720
- package/.claude/skills/ccw-chain/phases/issue-discover.md +0 -483
- package/.claude/skills/ccw-chain/phases/issue-execute.md +0 -629
- package/.claude/skills/ccw-chain/phases/issue-from-brainstorm.md +0 -382
- package/.claude/skills/ccw-chain/phases/issue-plan.md +0 -343
- package/.claude/skills/ccw-chain/phases/issue-queue.md +0 -464
- package/.claude/skills/ccw-chain/phases/refactor-cycle.md +0 -852
- package/.claude/skills/ccw-chain/phases/review-cycle/SKILL.md +0 -132
- package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-fix.md +0 -760
- package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-module.md +0 -764
- package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-session.md +0 -775
- package/.claude/skills/ccw-chain/phases/roadmap-with-file.md +0 -544
- package/.claude/skills/ccw-chain/phases/spec-generator/SKILL.md +0 -338
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/01-5-requirement-clarification.md +0 -404
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/01-discovery.md +0 -257
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/02-product-brief.md +0 -274
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/03-requirements.md +0 -184
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/04-architecture.md +0 -248
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/05-epics-stories.md +0 -178
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/06-5-auto-fix.md +0 -144
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/06-readiness-check.md +0 -480
- package/.claude/skills/ccw-chain/phases/team-planex.md +0 -123
- package/.claude/skills/ccw-chain/phases/ui-design-explore-auto.md +0 -678
- package/.claude/skills/ccw-chain/phases/unified-execute-with-file.md +0 -870
- package/.claude/skills/ccw-chain/phases/workflow-execute/SKILL.md +0 -625
- package/.claude/skills/ccw-chain/phases/workflow-execute/phases/06-review.md +0 -215
- package/.claude/skills/ccw-chain/phases/workflow-lite-plan.md +0 -616
- package/.claude/skills/ccw-chain/phases/workflow-multi-cli-plan.md +0 -424
- package/.claude/skills/ccw-chain/phases/workflow-plan/SKILL.md +0 -466
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/01-session-discovery.md +0 -99
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/02-context-gathering.md +0 -338
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/03-conflict-resolution.md +0 -422
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/04-task-generation.md +0 -440
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/05-plan-verify.md +0 -395
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/06-replan.md +0 -594
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/SKILL.md +0 -527
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/01-session-discovery.md +0 -57
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/02-context-gathering.md +0 -407
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/03-test-coverage-analysis.md +0 -172
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/04-conflict-resolution.md +0 -426
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/05-tdd-task-generation.md +0 -473
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/06-tdd-structure-validation.md +0 -189
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/07-tdd-verify.md +0 -635
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/SKILL.md +0 -482
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/01-session-start.md +0 -60
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/02-test-context-gather.md +0 -493
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/03-test-concept-enhanced.md +0 -150
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/04-test-task-generate.md +0 -346
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/05-test-cycle-execute.md +0 -538
- package/.claude/skills/ccw-chain/specs/intent-patterns.md +0 -60
- package/.claude/skills/team-edict.zip +0 -0
|
@@ -17,7 +17,7 @@
|
|
|
17
17
|
"type": "orchestrator",
|
|
18
18
|
"description": "Orchestrates architecture optimization pipeline, manages task chains, handles review-fix cycles",
|
|
19
19
|
"spec_path": "roles/coordinator/role.md",
|
|
20
|
-
"tools": ["Task", "TaskCreate", "TaskList", "TaskGet", "TaskUpdate", "TeamCreate", "TeamDelete", "SendMessage", "
|
|
20
|
+
"tools": ["Task", "TaskCreate", "TaskList", "TaskGet", "TaskUpdate", "TeamCreate", "TeamDelete", "SendMessage", "request_user_input", "Read", "Write", "Bash", "Glob", "Grep"]
|
|
21
21
|
},
|
|
22
22
|
{
|
|
23
23
|
"name": "analyzer",
|
|
@@ -1,259 +1,259 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-brainstorm
|
|
3
|
-
description: Unified team skill for brainstorming team. Uses team-worker agent architecture with role directories for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team brainstorm".
|
|
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 Brainstorm
|
|
8
|
-
|
|
9
|
-
Orchestrate multi-agent brainstorming: generate ideas -> challenge assumptions -> synthesize -> evaluate. Supports Quick, Deep, and Full pipelines with Generator-Critic loop.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-brainstorm", args="topic 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 workers -> STOP
|
|
26
|
-
|
|
|
27
|
-
+-------+-------+-------+
|
|
28
|
-
v v v v
|
|
29
|
-
[ideator][challenger][synthesizer][evaluator]
|
|
30
|
-
```
|
|
31
|
-
|
|
32
|
-
## Role Registry
|
|
33
|
-
|
|
34
|
-
| Role | Path | Prefix | Inner Loop |
|
|
35
|
-
|------|------|--------|------------|
|
|
36
|
-
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
37
|
-
| ideator | [roles/ideator/role.md](roles/ideator/role.md) | IDEA-* | false |
|
|
38
|
-
| challenger | [roles/challenger/role.md](roles/challenger/role.md) | CHALLENGE-* | false |
|
|
39
|
-
| synthesizer | [roles/synthesizer/role.md](roles/synthesizer/role.md) | SYNTH-* | false |
|
|
40
|
-
| evaluator | [roles/evaluator/role.md](roles/evaluator/role.md) | EVAL-* | false |
|
|
41
|
-
|
|
42
|
-
## Role Router
|
|
43
|
-
|
|
44
|
-
Parse `$ARGUMENTS`:
|
|
45
|
-
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
46
|
-
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
47
|
-
|
|
48
|
-
## Delegation Lock
|
|
49
|
-
|
|
50
|
-
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
51
|
-
|
|
52
|
-
Before calling ANY tool, apply this check:
|
|
53
|
-
|
|
54
|
-
| Tool Call | Verdict | Reason |
|
|
55
|
-
|-----------|---------|--------|
|
|
56
|
-
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
57
|
-
| `list_agents` | ALLOWED | Agent health check |
|
|
58
|
-
| `request_user_input` | ALLOWED | User interaction |
|
|
59
|
-
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
60
|
-
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
61
|
-
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
62
|
-
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
63
|
-
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
64
|
-
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
65
|
-
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
66
|
-
|
|
67
|
-
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
68
|
-
|
|
69
|
-
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
70
|
-
|
|
71
|
-
---
|
|
72
|
-
|
|
73
|
-
## Shared Constants
|
|
74
|
-
|
|
75
|
-
- **Session prefix**: `BRS`
|
|
76
|
-
- **Session path**: `.workflow/.team/BRS-<slug>-<date>/`
|
|
77
|
-
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
78
|
-
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
79
|
-
|
|
80
|
-
## Worker Spawn Template
|
|
81
|
-
|
|
82
|
-
Coordinator spawns workers using this template:
|
|
83
|
-
|
|
84
|
-
```
|
|
85
|
-
spawn_agent({
|
|
86
|
-
agent_type: "team_worker",
|
|
87
|
-
task_name: "<task-id>",
|
|
88
|
-
fork_context: false,
|
|
89
|
-
items: [
|
|
90
|
-
{ type: "text", text: `## Role Assignment
|
|
91
|
-
role: <role>
|
|
92
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
93
|
-
session: <session-folder>
|
|
94
|
-
session_id: <session-id>
|
|
95
|
-
requirement: <topic-description>
|
|
96
|
-
inner_loop: false
|
|
97
|
-
|
|
98
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
99
|
-
|
|
100
|
-
{ type: "text", text: `## Task Context
|
|
101
|
-
task_id: <task-id>
|
|
102
|
-
title: <task-title>
|
|
103
|
-
description: <topic-description>
|
|
104
|
-
pipeline_phase: <pipeline-phase>` },
|
|
105
|
-
|
|
106
|
-
{ type: "text", text: `## Upstream Context
|
|
107
|
-
<prev_context>` }
|
|
108
|
-
]
|
|
109
|
-
})
|
|
110
|
-
```
|
|
111
|
-
|
|
112
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target: <name> })` each worker.
|
|
113
|
-
|
|
114
|
-
**Parallel ideator spawn** (Full pipeline with N angles):
|
|
115
|
-
|
|
116
|
-
When Full pipeline has N parallel IDEA tasks, spawn N distinct team-worker agents named `ideator-1`, `ideator-2`, etc.
|
|
117
|
-
|
|
118
|
-
```
|
|
119
|
-
spawn_agent({
|
|
120
|
-
agent_type: "team_worker",
|
|
121
|
-
task_name: "ideator-<N>",
|
|
122
|
-
fork_context: false,
|
|
123
|
-
items: [
|
|
124
|
-
{ type: "text", text: `## Role Assignment
|
|
125
|
-
role: ideator
|
|
126
|
-
role_spec: <skill_root>/roles/ideator/role.md
|
|
127
|
-
session: <session-folder>
|
|
128
|
-
session_id: <session-id>
|
|
129
|
-
requirement: <topic-description>
|
|
130
|
-
agent_name: ideator-<N>
|
|
131
|
-
inner_loop: false
|
|
132
|
-
|
|
133
|
-
Read role_spec file (<skill_root>/roles/ideator/role.md) to load Phase 2-4 domain instructions.` },
|
|
134
|
-
|
|
135
|
-
{ type: "text", text: `## Task Context
|
|
136
|
-
task_id: <task-id>
|
|
137
|
-
title: <task-title>
|
|
138
|
-
description: <topic-description>
|
|
139
|
-
pipeline_phase: <pipeline-phase>` },
|
|
140
|
-
|
|
141
|
-
{ type: "text", text: `## Upstream Context
|
|
142
|
-
<prev_context>` }
|
|
143
|
-
]
|
|
144
|
-
})
|
|
145
|
-
```
|
|
146
|
-
|
|
147
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target: <name> })` each worker.
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
### Model Selection Guide
|
|
151
|
-
|
|
152
|
-
| Role | model | reasoning_effort | Rationale |
|
|
153
|
-
|------|-------|-------------------|-----------|
|
|
154
|
-
| Ideator (IDEA-*) | (default) | high | Creative divergent thinking requires full reasoning |
|
|
155
|
-
| Challenger (CHALLENGE-*) | (default) | high | Critical analysis of ideas needs deep reasoning |
|
|
156
|
-
| Synthesizer (SYNTH-*) | (default) | medium | Aggregation and convergence over generation |
|
|
157
|
-
| Evaluator (EVAL-*) | (default) | medium | Scoring and ranking against criteria |
|
|
158
|
-
|
|
159
|
-
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
160
|
-
```
|
|
161
|
-
spawn_agent({
|
|
162
|
-
agent_type: "team_worker",
|
|
163
|
-
task_name: "<task-id>",
|
|
164
|
-
fork_context: false,
|
|
165
|
-
model: "<model-override>",
|
|
166
|
-
reasoning_effort: "<effort-level>",
|
|
167
|
-
items: [...]
|
|
168
|
-
})
|
|
169
|
-
```
|
|
170
|
-
|
|
171
|
-
## User Commands
|
|
172
|
-
|
|
173
|
-
| Command | Action |
|
|
174
|
-
|---------|--------|
|
|
175
|
-
| `check` / `status` | View execution status graph, no advancement |
|
|
176
|
-
| `resume` / `continue` | Check worker states, advance next step |
|
|
177
|
-
|
|
178
|
-
## Session Directory
|
|
179
|
-
|
|
180
|
-
```
|
|
181
|
-
.workflow/.team/BRS-<slug>-<date>/
|
|
182
|
-
├── session.json # Session metadata + pipeline + gc_round
|
|
183
|
-
├── task-analysis.json # Coordinator analyze output
|
|
184
|
-
├── .msg/
|
|
185
|
-
│ ├── messages.jsonl # Message bus log
|
|
186
|
-
│ └── meta.json # Session state + cross-role state
|
|
187
|
-
├── wisdom/ # Cross-task knowledge
|
|
188
|
-
│ ├── learnings.md
|
|
189
|
-
│ ├── decisions.md
|
|
190
|
-
│ ├── conventions.md
|
|
191
|
-
│ └── issues.md
|
|
192
|
-
├── ideas/ # Ideator output
|
|
193
|
-
│ ├── idea-001.md
|
|
194
|
-
│ └── idea-002.md
|
|
195
|
-
├── critiques/ # Challenger output
|
|
196
|
-
│ ├── critique-001.md
|
|
197
|
-
│ └── critique-002.md
|
|
198
|
-
├── synthesis/ # Synthesizer output
|
|
199
|
-
│ └── synthesis-001.md
|
|
200
|
-
└── evaluation/ # Evaluator output
|
|
201
|
-
└── evaluation-001.md
|
|
202
|
-
```
|
|
203
|
-
|
|
204
|
-
## Specs Reference
|
|
205
|
-
|
|
206
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
207
|
-
|
|
208
|
-
## v4 Agent Coordination
|
|
209
|
-
|
|
210
|
-
### Message Semantics
|
|
211
|
-
|
|
212
|
-
| Intent | API | Example |
|
|
213
|
-
|--------|-----|---------|
|
|
214
|
-
| Share idea context across ideators | `send_message` | Send seed ideas to running ideator for cross-pollination |
|
|
215
|
-
| Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
|
|
216
|
-
| Check running agents | `list_agents` | Verify parallel ideator health during Full pipeline |
|
|
217
|
-
|
|
218
|
-
### Parallel Ideator Coordination (Full Pipeline)
|
|
219
|
-
|
|
220
|
-
Full pipeline spawns N parallel ideators for different brainstorming angles. Use batch spawn + wait:
|
|
221
|
-
|
|
222
|
-
```
|
|
223
|
-
// Spawn N ideators in parallel, each with a different angle
|
|
224
|
-
const ideatorNames = ["IDEA-001", "IDEA-002", "IDEA-003"]
|
|
225
|
-
for (const name of ideatorNames) {
|
|
226
|
-
spawn_agent({ agent_type: "team_worker", task_name: name, fork_context: false, ... })
|
|
227
|
-
}
|
|
228
|
-
wait_agent({ targets: ideatorNames, timeout_ms: 900000 })
|
|
229
|
-
// Collect all idea outputs, feed to challenger as upstream context
|
|
230
|
-
```
|
|
231
|
-
|
|
232
|
-
### Agent Health Check
|
|
233
|
-
|
|
234
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
235
|
-
|
|
236
|
-
```
|
|
237
|
-
// Reconcile session state with actual running agents
|
|
238
|
-
const running = list_agents({})
|
|
239
|
-
// Compare with tasks.json active_agents
|
|
240
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
241
|
-
```
|
|
242
|
-
|
|
243
|
-
### Named Agent Targeting
|
|
244
|
-
|
|
245
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
246
|
-
- `send_message({ target: "IDEA-002", items: [...] })` -- share context from another ideator
|
|
247
|
-
- `close_agent({ target: "IDEA-001" })` -- cleanup by name after wait_agent returns
|
|
248
|
-
|
|
249
|
-
## Error Handling
|
|
250
|
-
|
|
251
|
-
| Scenario | Resolution |
|
|
252
|
-
|----------|------------|
|
|
253
|
-
| Unknown command | Error with available command list |
|
|
254
|
-
| Role not found | Error with role registry |
|
|
255
|
-
| CLI tool fails | Worker fallback to direct implementation |
|
|
256
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
257
|
-
| Completion action fails | Default to Keep Active |
|
|
258
|
-
| Generator-Critic loop exceeds 2 rounds | Force convergence to synthesizer |
|
|
259
|
-
| No ideas generated | Coordinator prompts with seed questions |
|
|
1
|
+
---
|
|
2
|
+
name: team-brainstorm
|
|
3
|
+
description: Unified team skill for brainstorming team. Uses team-worker agent architecture with role directories for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team brainstorm".
|
|
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 Brainstorm
|
|
8
|
+
|
|
9
|
+
Orchestrate multi-agent brainstorming: generate ideas -> challenge assumptions -> synthesize -> evaluate. Supports Quick, Deep, and Full pipelines with Generator-Critic loop.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-brainstorm", args="topic 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 workers -> STOP
|
|
26
|
+
|
|
|
27
|
+
+-------+-------+-------+
|
|
28
|
+
v v v v
|
|
29
|
+
[ideator][challenger][synthesizer][evaluator]
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
## Role Registry
|
|
33
|
+
|
|
34
|
+
| Role | Path | Prefix | Inner Loop |
|
|
35
|
+
|------|------|--------|------------|
|
|
36
|
+
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
37
|
+
| ideator | [roles/ideator/role.md](roles/ideator/role.md) | IDEA-* | false |
|
|
38
|
+
| challenger | [roles/challenger/role.md](roles/challenger/role.md) | CHALLENGE-* | false |
|
|
39
|
+
| synthesizer | [roles/synthesizer/role.md](roles/synthesizer/role.md) | SYNTH-* | false |
|
|
40
|
+
| evaluator | [roles/evaluator/role.md](roles/evaluator/role.md) | EVAL-* | false |
|
|
41
|
+
|
|
42
|
+
## Role Router
|
|
43
|
+
|
|
44
|
+
Parse `$ARGUMENTS`:
|
|
45
|
+
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
46
|
+
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
47
|
+
|
|
48
|
+
## Delegation Lock
|
|
49
|
+
|
|
50
|
+
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
51
|
+
|
|
52
|
+
Before calling ANY tool, apply this check:
|
|
53
|
+
|
|
54
|
+
| Tool Call | Verdict | Reason |
|
|
55
|
+
|-----------|---------|--------|
|
|
56
|
+
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
57
|
+
| `list_agents` | ALLOWED | Agent health check |
|
|
58
|
+
| `request_user_input` | ALLOWED | User interaction |
|
|
59
|
+
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
60
|
+
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
61
|
+
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
62
|
+
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
63
|
+
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
64
|
+
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
65
|
+
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
66
|
+
|
|
67
|
+
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
68
|
+
|
|
69
|
+
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
70
|
+
|
|
71
|
+
---
|
|
72
|
+
|
|
73
|
+
## Shared Constants
|
|
74
|
+
|
|
75
|
+
- **Session prefix**: `BRS`
|
|
76
|
+
- **Session path**: `.workflow/.team/BRS-<slug>-<date>/`
|
|
77
|
+
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
78
|
+
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
79
|
+
|
|
80
|
+
## Worker Spawn Template
|
|
81
|
+
|
|
82
|
+
Coordinator spawns workers using this template:
|
|
83
|
+
|
|
84
|
+
```
|
|
85
|
+
spawn_agent({
|
|
86
|
+
agent_type: "team_worker",
|
|
87
|
+
task_name: "<task-id>",
|
|
88
|
+
fork_context: false,
|
|
89
|
+
items: [
|
|
90
|
+
{ type: "text", text: `## Role Assignment
|
|
91
|
+
role: <role>
|
|
92
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
93
|
+
session: <session-folder>
|
|
94
|
+
session_id: <session-id>
|
|
95
|
+
requirement: <topic-description>
|
|
96
|
+
inner_loop: false
|
|
97
|
+
|
|
98
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
99
|
+
|
|
100
|
+
{ type: "text", text: `## Task Context
|
|
101
|
+
task_id: <task-id>
|
|
102
|
+
title: <task-title>
|
|
103
|
+
description: <topic-description>
|
|
104
|
+
pipeline_phase: <pipeline-phase>` },
|
|
105
|
+
|
|
106
|
+
{ type: "text", text: `## Upstream Context
|
|
107
|
+
<prev_context>` }
|
|
108
|
+
]
|
|
109
|
+
})
|
|
110
|
+
```
|
|
111
|
+
|
|
112
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target: <name> })` each worker.
|
|
113
|
+
|
|
114
|
+
**Parallel ideator spawn** (Full pipeline with N angles):
|
|
115
|
+
|
|
116
|
+
When Full pipeline has N parallel IDEA tasks, spawn N distinct team-worker agents named `ideator-1`, `ideator-2`, etc.
|
|
117
|
+
|
|
118
|
+
```
|
|
119
|
+
spawn_agent({
|
|
120
|
+
agent_type: "team_worker",
|
|
121
|
+
task_name: "ideator-<N>",
|
|
122
|
+
fork_context: false,
|
|
123
|
+
items: [
|
|
124
|
+
{ type: "text", text: `## Role Assignment
|
|
125
|
+
role: ideator
|
|
126
|
+
role_spec: <skill_root>/roles/ideator/role.md
|
|
127
|
+
session: <session-folder>
|
|
128
|
+
session_id: <session-id>
|
|
129
|
+
requirement: <topic-description>
|
|
130
|
+
agent_name: ideator-<N>
|
|
131
|
+
inner_loop: false
|
|
132
|
+
|
|
133
|
+
Read role_spec file (<skill_root>/roles/ideator/role.md) to load Phase 2-4 domain instructions.` },
|
|
134
|
+
|
|
135
|
+
{ type: "text", text: `## Task Context
|
|
136
|
+
task_id: <task-id>
|
|
137
|
+
title: <task-title>
|
|
138
|
+
description: <topic-description>
|
|
139
|
+
pipeline_phase: <pipeline-phase>` },
|
|
140
|
+
|
|
141
|
+
{ type: "text", text: `## Upstream Context
|
|
142
|
+
<prev_context>` }
|
|
143
|
+
]
|
|
144
|
+
})
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target: <name> })` each worker.
|
|
148
|
+
|
|
149
|
+
|
|
150
|
+
### Model Selection Guide
|
|
151
|
+
|
|
152
|
+
| Role | model | reasoning_effort | Rationale |
|
|
153
|
+
|------|-------|-------------------|-----------|
|
|
154
|
+
| Ideator (IDEA-*) | (default) | high | Creative divergent thinking requires full reasoning |
|
|
155
|
+
| Challenger (CHALLENGE-*) | (default) | high | Critical analysis of ideas needs deep reasoning |
|
|
156
|
+
| Synthesizer (SYNTH-*) | (default) | medium | Aggregation and convergence over generation |
|
|
157
|
+
| Evaluator (EVAL-*) | (default) | medium | Scoring and ranking against criteria |
|
|
158
|
+
|
|
159
|
+
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
160
|
+
```
|
|
161
|
+
spawn_agent({
|
|
162
|
+
agent_type: "team_worker",
|
|
163
|
+
task_name: "<task-id>",
|
|
164
|
+
fork_context: false,
|
|
165
|
+
model: "<model-override>",
|
|
166
|
+
reasoning_effort: "<effort-level>",
|
|
167
|
+
items: [...]
|
|
168
|
+
})
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
## User Commands
|
|
172
|
+
|
|
173
|
+
| Command | Action |
|
|
174
|
+
|---------|--------|
|
|
175
|
+
| `check` / `status` | View execution status graph, no advancement |
|
|
176
|
+
| `resume` / `continue` | Check worker states, advance next step |
|
|
177
|
+
|
|
178
|
+
## Session Directory
|
|
179
|
+
|
|
180
|
+
```
|
|
181
|
+
.workflow/.team/BRS-<slug>-<date>/
|
|
182
|
+
├── session.json # Session metadata + pipeline + gc_round
|
|
183
|
+
├── task-analysis.json # Coordinator analyze output
|
|
184
|
+
├── .msg/
|
|
185
|
+
│ ├── messages.jsonl # Message bus log
|
|
186
|
+
│ └── meta.json # Session state + cross-role state
|
|
187
|
+
├── wisdom/ # Cross-task knowledge
|
|
188
|
+
│ ├── learnings.md
|
|
189
|
+
│ ├── decisions.md
|
|
190
|
+
│ ├── conventions.md
|
|
191
|
+
│ └── issues.md
|
|
192
|
+
├── ideas/ # Ideator output
|
|
193
|
+
│ ├── idea-001.md
|
|
194
|
+
│ └── idea-002.md
|
|
195
|
+
├── critiques/ # Challenger output
|
|
196
|
+
│ ├── critique-001.md
|
|
197
|
+
│ └── critique-002.md
|
|
198
|
+
├── synthesis/ # Synthesizer output
|
|
199
|
+
│ └── synthesis-001.md
|
|
200
|
+
└── evaluation/ # Evaluator output
|
|
201
|
+
└── evaluation-001.md
|
|
202
|
+
```
|
|
203
|
+
|
|
204
|
+
## Specs Reference
|
|
205
|
+
|
|
206
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
207
|
+
|
|
208
|
+
## v4 Agent Coordination
|
|
209
|
+
|
|
210
|
+
### Message Semantics
|
|
211
|
+
|
|
212
|
+
| Intent | API | Example |
|
|
213
|
+
|--------|-----|---------|
|
|
214
|
+
| Share idea context across ideators | `send_message` | Send seed ideas to running ideator for cross-pollination |
|
|
215
|
+
| Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
|
|
216
|
+
| Check running agents | `list_agents` | Verify parallel ideator health during Full pipeline |
|
|
217
|
+
|
|
218
|
+
### Parallel Ideator Coordination (Full Pipeline)
|
|
219
|
+
|
|
220
|
+
Full pipeline spawns N parallel ideators for different brainstorming angles. Use batch spawn + wait:
|
|
221
|
+
|
|
222
|
+
```
|
|
223
|
+
// Spawn N ideators in parallel, each with a different angle
|
|
224
|
+
const ideatorNames = ["IDEA-001", "IDEA-002", "IDEA-003"]
|
|
225
|
+
for (const name of ideatorNames) {
|
|
226
|
+
spawn_agent({ agent_type: "team_worker", task_name: name, fork_context: false, ... })
|
|
227
|
+
}
|
|
228
|
+
wait_agent({ targets: ideatorNames, timeout_ms: 900000 })
|
|
229
|
+
// Collect all idea outputs, feed to challenger as upstream context
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
### Agent Health Check
|
|
233
|
+
|
|
234
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
235
|
+
|
|
236
|
+
```
|
|
237
|
+
// Reconcile session state with actual running agents
|
|
238
|
+
const running = list_agents({})
|
|
239
|
+
// Compare with tasks.json active_agents
|
|
240
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
241
|
+
```
|
|
242
|
+
|
|
243
|
+
### Named Agent Targeting
|
|
244
|
+
|
|
245
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
246
|
+
- `send_message({ target: "IDEA-002", items: [...] })` -- share context from another ideator
|
|
247
|
+
- `close_agent({ target: "IDEA-001" })` -- cleanup by name after wait_agent returns
|
|
248
|
+
|
|
249
|
+
## Error Handling
|
|
250
|
+
|
|
251
|
+
| Scenario | Resolution |
|
|
252
|
+
|----------|------------|
|
|
253
|
+
| Unknown command | Error with available command list |
|
|
254
|
+
| Role not found | Error with role registry |
|
|
255
|
+
| CLI tool fails | Worker fallback to direct implementation |
|
|
256
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
257
|
+
| Completion action fails | Default to Keep Active |
|
|
258
|
+
| Generator-Critic loop exceeds 2 rounds | Force convergence to synthesizer |
|
|
259
|
+
| No ideas generated | Coordinator prompts with seed questions |
|