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,216 +1,216 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-planex
|
|
3
|
-
description: Unified team skill for plan-and-execute pipeline. Pure router — coordinator always. Beat model is coordinator-only in monitor.md. Triggers on "team planex".
|
|
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(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Team PlanEx
|
|
8
|
-
|
|
9
|
-
Unified team skill: plan-and-execute pipeline for issue-based development. Built on **team-worker agent architecture** — coordinator orchestrates, workers are team-worker agents loading role-specific instructions from `roles/<role>/role.md`.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-planex", args="task description")
|
|
15
|
-
|
|
|
16
|
-
SKILL.md (this file) = Router
|
|
17
|
-
|
|
|
18
|
-
+--------------+--------------+
|
|
19
|
-
| |
|
|
20
|
-
no --role flag --role <name>
|
|
21
|
-
| |
|
|
22
|
-
Coordinator Worker
|
|
23
|
-
roles/coordinator/role.md roles/<name>/role.md
|
|
24
|
-
|
|
|
25
|
-
+-- analyze -> dispatch -> spawn workers -> STOP
|
|
26
|
-
|
|
|
27
|
-
+---------------+---------------+
|
|
28
|
-
v v
|
|
29
|
-
[planner] [executor]
|
|
30
|
-
(team-worker agent, (team-worker agent,
|
|
31
|
-
loads roles/planner/role.md) loads roles/executor/role.md)
|
|
32
|
-
```
|
|
33
|
-
|
|
34
|
-
## Role Registry
|
|
35
|
-
|
|
36
|
-
| Role | Path | Prefix | Inner Loop |
|
|
37
|
-
|------|------|--------|------------|
|
|
38
|
-
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
39
|
-
| planner | [roles/planner/role.md](roles/planner/role.md) | PLAN-* | true |
|
|
40
|
-
| executor | [roles/executor/role.md](roles/executor/role.md) | EXEC-* | true |
|
|
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**: `PEX`
|
|
76
|
-
- **Session path**: `.workflow/.team/PEX-<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: <task-description>
|
|
96
|
-
inner_loop: <true|false>
|
|
97
|
-
execution_method: <codex|gemini>
|
|
98
|
-
|
|
99
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
100
|
-
|
|
101
|
-
{ type: "text", text: `## Task Context
|
|
102
|
-
task_id: <task-id>
|
|
103
|
-
title: <task-title>
|
|
104
|
-
description: <task-description>
|
|
105
|
-
pipeline_phase: <pipeline-phase>` },
|
|
106
|
-
|
|
107
|
-
{ type: "text", text: `## Upstream Context
|
|
108
|
-
<prev_context>` }
|
|
109
|
-
]
|
|
110
|
-
})
|
|
111
|
-
```
|
|
112
|
-
|
|
113
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
### Model Selection Guide
|
|
117
|
-
|
|
118
|
-
| Role | model | reasoning_effort | Rationale |
|
|
119
|
-
|------|-------|-------------------|-----------|
|
|
120
|
-
| Planner (PLAN-*) | (default) | high | Solution planning requires deep code analysis |
|
|
121
|
-
| Executor (EXEC-*) | (default) | high | Code implementation needs precision |
|
|
122
|
-
|
|
123
|
-
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
124
|
-
```
|
|
125
|
-
spawn_agent({
|
|
126
|
-
agent_type: "team_worker",
|
|
127
|
-
task_name: "<task-id>",
|
|
128
|
-
fork_context: false,
|
|
129
|
-
model: "<model-override>",
|
|
130
|
-
reasoning_effort: "<effort-level>",
|
|
131
|
-
items: [...]
|
|
132
|
-
})
|
|
133
|
-
```
|
|
134
|
-
|
|
135
|
-
## User Commands
|
|
136
|
-
|
|
137
|
-
| Command | Action |
|
|
138
|
-
|---------|--------|
|
|
139
|
-
| `check` / `status` | View execution status graph |
|
|
140
|
-
| `resume` / `continue` | Advance to next step |
|
|
141
|
-
| `add <issue-ids or --text '...' or --plan path>` | Append new tasks to planner queue |
|
|
142
|
-
|
|
143
|
-
## Session Directory
|
|
144
|
-
|
|
145
|
-
```
|
|
146
|
-
.workflow/.team/PEX-<slug>-<YYYY-MM-DD>/
|
|
147
|
-
├── .msg/
|
|
148
|
-
│ ├── messages.jsonl # Message bus log
|
|
149
|
-
│ └── meta.json # Session state
|
|
150
|
-
├── task-analysis.json # Coordinator analyze output
|
|
151
|
-
├── artifacts/
|
|
152
|
-
│ └── solutions/ # Planner solution output per issue
|
|
153
|
-
│ ├── <issueId-1>.json
|
|
154
|
-
│ └── <issueId-N>.json
|
|
155
|
-
└── wisdom/ # Cross-task knowledge
|
|
156
|
-
├── learnings.md
|
|
157
|
-
├── decisions.md
|
|
158
|
-
├── conventions.md
|
|
159
|
-
└── issues.md
|
|
160
|
-
```
|
|
161
|
-
|
|
162
|
-
## Specs Reference
|
|
163
|
-
|
|
164
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions, task metadata registry, execution method selection
|
|
165
|
-
|
|
166
|
-
## v4 Agent Coordination
|
|
167
|
-
|
|
168
|
-
### Message Semantics
|
|
169
|
-
|
|
170
|
-
| Intent | API | Example |
|
|
171
|
-
|--------|-----|---------|
|
|
172
|
-
| Send plan updates to running executor | `send_message` | Queue planner solution details to EXEC-* workers |
|
|
173
|
-
| Not used in this skill | `assign_task` | No resident agents -- planner and executor are one-shot |
|
|
174
|
-
| Check running agents | `list_agents` | Verify planner/executor health during resume |
|
|
175
|
-
|
|
176
|
-
### Two-Phase Pipeline Pattern
|
|
177
|
-
|
|
178
|
-
Plan-and-execute is a **Two-Phase pattern**: planner creates solution plans (PLAN-*), then coordinator spawns executors (EXEC-*) for each planned issue. The planner may dynamically create EXEC-* task entries in tasks.json.
|
|
179
|
-
|
|
180
|
-
```
|
|
181
|
-
// Phase 1: Planner runs, creates EXEC-* tasks in tasks.json
|
|
182
|
-
spawn_agent({ agent_type: "team_worker", task_name: "PLAN-001", ... })
|
|
183
|
-
wait_agent({ targets: ["PLAN-001"], timeout_ms: 900000 })
|
|
184
|
-
// Phase 2: Executors run per-issue, may run in sequence or parallel
|
|
185
|
-
// Inner loop: planner/executor handle multiple tasks internally
|
|
186
|
-
```
|
|
187
|
-
|
|
188
|
-
### Agent Health Check
|
|
189
|
-
|
|
190
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
191
|
-
|
|
192
|
-
```
|
|
193
|
-
// Reconcile session state with actual running agents
|
|
194
|
-
const running = list_agents({})
|
|
195
|
-
// Compare with tasks.json active_agents
|
|
196
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
197
|
-
```
|
|
198
|
-
|
|
199
|
-
### Named Agent Targeting
|
|
200
|
-
|
|
201
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
202
|
-
- `send_message({ target: "EXEC-001", items: [...] })` -- queue plan solution to running executor
|
|
203
|
-
- `close_agent({ target: "PLAN-001" })` -- cleanup by name after completion
|
|
204
|
-
|
|
205
|
-
## Error Handling
|
|
206
|
-
|
|
207
|
-
| Scenario | Resolution |
|
|
208
|
-
|----------|------------|
|
|
209
|
-
| Unknown command | Error with available command list |
|
|
210
|
-
| Role not found | Error with role registry |
|
|
211
|
-
| Role spec file not found | Error with expected path (roles/<name>/role.md) |
|
|
212
|
-
| team-worker agent unavailable | Error: requires .claude/agents/team-worker.md |
|
|
213
|
-
| Planner issue planning failure | Retry once, then skip to next issue |
|
|
214
|
-
| Executor impl failure | Report to coordinator, continue with next EXEC-* task |
|
|
215
|
-
| Pipeline stall | Coordinator monitors, escalate to user |
|
|
216
|
-
| Worker no response | Report waiting task, suggest user `resume` |
|
|
1
|
+
---
|
|
2
|
+
name: team-planex
|
|
3
|
+
description: Unified team skill for plan-and-execute pipeline. Pure router — coordinator always. Beat model is coordinator-only in monitor.md. Triggers on "team planex".
|
|
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(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Team PlanEx
|
|
8
|
+
|
|
9
|
+
Unified team skill: plan-and-execute pipeline for issue-based development. Built on **team-worker agent architecture** — coordinator orchestrates, workers are team-worker agents loading role-specific instructions from `roles/<role>/role.md`.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-planex", args="task description")
|
|
15
|
+
|
|
|
16
|
+
SKILL.md (this file) = Router
|
|
17
|
+
|
|
|
18
|
+
+--------------+--------------+
|
|
19
|
+
| |
|
|
20
|
+
no --role flag --role <name>
|
|
21
|
+
| |
|
|
22
|
+
Coordinator Worker
|
|
23
|
+
roles/coordinator/role.md roles/<name>/role.md
|
|
24
|
+
|
|
|
25
|
+
+-- analyze -> dispatch -> spawn workers -> STOP
|
|
26
|
+
|
|
|
27
|
+
+---------------+---------------+
|
|
28
|
+
v v
|
|
29
|
+
[planner] [executor]
|
|
30
|
+
(team-worker agent, (team-worker agent,
|
|
31
|
+
loads roles/planner/role.md) loads roles/executor/role.md)
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
## Role Registry
|
|
35
|
+
|
|
36
|
+
| Role | Path | Prefix | Inner Loop |
|
|
37
|
+
|------|------|--------|------------|
|
|
38
|
+
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
39
|
+
| planner | [roles/planner/role.md](roles/planner/role.md) | PLAN-* | true |
|
|
40
|
+
| executor | [roles/executor/role.md](roles/executor/role.md) | EXEC-* | true |
|
|
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**: `PEX`
|
|
76
|
+
- **Session path**: `.workflow/.team/PEX-<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: <task-description>
|
|
96
|
+
inner_loop: <true|false>
|
|
97
|
+
execution_method: <codex|gemini>
|
|
98
|
+
|
|
99
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
100
|
+
|
|
101
|
+
{ type: "text", text: `## Task Context
|
|
102
|
+
task_id: <task-id>
|
|
103
|
+
title: <task-title>
|
|
104
|
+
description: <task-description>
|
|
105
|
+
pipeline_phase: <pipeline-phase>` },
|
|
106
|
+
|
|
107
|
+
{ type: "text", text: `## Upstream Context
|
|
108
|
+
<prev_context>` }
|
|
109
|
+
]
|
|
110
|
+
})
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
114
|
+
|
|
115
|
+
|
|
116
|
+
### Model Selection Guide
|
|
117
|
+
|
|
118
|
+
| Role | model | reasoning_effort | Rationale |
|
|
119
|
+
|------|-------|-------------------|-----------|
|
|
120
|
+
| Planner (PLAN-*) | (default) | high | Solution planning requires deep code analysis |
|
|
121
|
+
| Executor (EXEC-*) | (default) | high | Code implementation needs precision |
|
|
122
|
+
|
|
123
|
+
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
124
|
+
```
|
|
125
|
+
spawn_agent({
|
|
126
|
+
agent_type: "team_worker",
|
|
127
|
+
task_name: "<task-id>",
|
|
128
|
+
fork_context: false,
|
|
129
|
+
model: "<model-override>",
|
|
130
|
+
reasoning_effort: "<effort-level>",
|
|
131
|
+
items: [...]
|
|
132
|
+
})
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
## User Commands
|
|
136
|
+
|
|
137
|
+
| Command | Action |
|
|
138
|
+
|---------|--------|
|
|
139
|
+
| `check` / `status` | View execution status graph |
|
|
140
|
+
| `resume` / `continue` | Advance to next step |
|
|
141
|
+
| `add <issue-ids or --text '...' or --plan path>` | Append new tasks to planner queue |
|
|
142
|
+
|
|
143
|
+
## Session Directory
|
|
144
|
+
|
|
145
|
+
```
|
|
146
|
+
.workflow/.team/PEX-<slug>-<YYYY-MM-DD>/
|
|
147
|
+
├── .msg/
|
|
148
|
+
│ ├── messages.jsonl # Message bus log
|
|
149
|
+
│ └── meta.json # Session state
|
|
150
|
+
├── task-analysis.json # Coordinator analyze output
|
|
151
|
+
├── artifacts/
|
|
152
|
+
│ └── solutions/ # Planner solution output per issue
|
|
153
|
+
│ ├── <issueId-1>.json
|
|
154
|
+
│ └── <issueId-N>.json
|
|
155
|
+
└── wisdom/ # Cross-task knowledge
|
|
156
|
+
├── learnings.md
|
|
157
|
+
├── decisions.md
|
|
158
|
+
├── conventions.md
|
|
159
|
+
└── issues.md
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
## Specs Reference
|
|
163
|
+
|
|
164
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions, task metadata registry, execution method selection
|
|
165
|
+
|
|
166
|
+
## v4 Agent Coordination
|
|
167
|
+
|
|
168
|
+
### Message Semantics
|
|
169
|
+
|
|
170
|
+
| Intent | API | Example |
|
|
171
|
+
|--------|-----|---------|
|
|
172
|
+
| Send plan updates to running executor | `send_message` | Queue planner solution details to EXEC-* workers |
|
|
173
|
+
| Not used in this skill | `assign_task` | No resident agents -- planner and executor are one-shot |
|
|
174
|
+
| Check running agents | `list_agents` | Verify planner/executor health during resume |
|
|
175
|
+
|
|
176
|
+
### Two-Phase Pipeline Pattern
|
|
177
|
+
|
|
178
|
+
Plan-and-execute is a **Two-Phase pattern**: planner creates solution plans (PLAN-*), then coordinator spawns executors (EXEC-*) for each planned issue. The planner may dynamically create EXEC-* task entries in tasks.json.
|
|
179
|
+
|
|
180
|
+
```
|
|
181
|
+
// Phase 1: Planner runs, creates EXEC-* tasks in tasks.json
|
|
182
|
+
spawn_agent({ agent_type: "team_worker", task_name: "PLAN-001", ... })
|
|
183
|
+
wait_agent({ targets: ["PLAN-001"], timeout_ms: 900000 })
|
|
184
|
+
// Phase 2: Executors run per-issue, may run in sequence or parallel
|
|
185
|
+
// Inner loop: planner/executor handle multiple tasks internally
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
### Agent Health Check
|
|
189
|
+
|
|
190
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
191
|
+
|
|
192
|
+
```
|
|
193
|
+
// Reconcile session state with actual running agents
|
|
194
|
+
const running = list_agents({})
|
|
195
|
+
// Compare with tasks.json active_agents
|
|
196
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
### Named Agent Targeting
|
|
200
|
+
|
|
201
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
202
|
+
- `send_message({ target: "EXEC-001", items: [...] })` -- queue plan solution to running executor
|
|
203
|
+
- `close_agent({ target: "PLAN-001" })` -- cleanup by name after completion
|
|
204
|
+
|
|
205
|
+
## Error Handling
|
|
206
|
+
|
|
207
|
+
| Scenario | Resolution |
|
|
208
|
+
|----------|------------|
|
|
209
|
+
| Unknown command | Error with available command list |
|
|
210
|
+
| Role not found | Error with role registry |
|
|
211
|
+
| Role spec file not found | Error with expected path (roles/<name>/role.md) |
|
|
212
|
+
| team-worker agent unavailable | Error: requires .claude/agents/team-worker.md |
|
|
213
|
+
| Planner issue planning failure | Retry once, then skip to next issue |
|
|
214
|
+
| Executor impl failure | Report to coordinator, continue with next EXEC-* task |
|
|
215
|
+
| Pipeline stall | Coordinator monitors, escalate to user |
|
|
216
|
+
| Worker no response | Report waiting task, suggest user `resume` |
|