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,269 +1,269 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-issue
|
|
3
|
-
description: Unified team skill for issue resolution. Uses team-worker agent architecture with role directories for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team issue".
|
|
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__ace-tool__search_context(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Team Issue Resolution
|
|
8
|
-
|
|
9
|
-
Orchestrate issue resolution pipeline: explore context -> plan solution -> review (optional) -> marshal queue -> implement. Supports Quick, Full, and Batch pipelines with review-fix cycle.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-issue", args="<issue-ids> [--mode=<mode>]")
|
|
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
|
-
+-- clarify -> dispatch -> spawn workers -> STOP
|
|
26
|
-
|
|
|
27
|
-
+-------+-------+-------+-------+
|
|
28
|
-
v v v v v
|
|
29
|
-
[explor] [plann] [review] [integ] [imple]
|
|
30
|
-
```
|
|
31
|
-
|
|
32
|
-
## Role Registry
|
|
33
|
-
|
|
34
|
-
| Role | Path | Prefix | Inner Loop |
|
|
35
|
-
|------|------|--------|------------|
|
|
36
|
-
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
37
|
-
| explorer | [roles/explorer/role.md](roles/explorer/role.md) | EXPLORE-* | false |
|
|
38
|
-
| planner | [roles/planner/role.md](roles/planner/role.md) | SOLVE-* | false |
|
|
39
|
-
| reviewer | [roles/reviewer/role.md](roles/reviewer/role.md) | AUDIT-* | false |
|
|
40
|
-
| integrator | [roles/integrator/role.md](roles/integrator/role.md) | MARSHAL-* | false |
|
|
41
|
-
| implementer | [roles/implementer/role.md](roles/implementer/role.md) | BUILD-* | false |
|
|
42
|
-
|
|
43
|
-
## Role Router
|
|
44
|
-
|
|
45
|
-
Parse `$ARGUMENTS`:
|
|
46
|
-
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
47
|
-
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
48
|
-
|
|
49
|
-
## Delegation Lock
|
|
50
|
-
|
|
51
|
-
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
52
|
-
|
|
53
|
-
Before calling ANY tool, apply this check:
|
|
54
|
-
|
|
55
|
-
| Tool Call | Verdict | Reason |
|
|
56
|
-
|-----------|---------|--------|
|
|
57
|
-
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
58
|
-
| `list_agents` | ALLOWED | Agent health check |
|
|
59
|
-
| `request_user_input` | ALLOWED | User interaction |
|
|
60
|
-
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
61
|
-
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
62
|
-
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
63
|
-
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
64
|
-
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
65
|
-
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
66
|
-
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
67
|
-
|
|
68
|
-
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
69
|
-
|
|
70
|
-
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
71
|
-
|
|
72
|
-
---
|
|
73
|
-
|
|
74
|
-
## Shared Constants
|
|
75
|
-
|
|
76
|
-
- **Session prefix**: `TISL`
|
|
77
|
-
- **Session path**: `.workflow/.team/TISL-<slug>-<date>/`
|
|
78
|
-
- **Team name**: `issue`
|
|
79
|
-
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
80
|
-
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
81
|
-
|
|
82
|
-
## Worker Spawn Template
|
|
83
|
-
|
|
84
|
-
Coordinator spawns workers using this template:
|
|
85
|
-
|
|
86
|
-
```
|
|
87
|
-
spawn_agent({
|
|
88
|
-
agent_type: "team_worker",
|
|
89
|
-
task_name: "<task-id>",
|
|
90
|
-
fork_context: false,
|
|
91
|
-
items: [
|
|
92
|
-
{ type: "text", text: `## Role Assignment
|
|
93
|
-
role: <role>
|
|
94
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
95
|
-
session: <session-folder>
|
|
96
|
-
session_id: <session-id>
|
|
97
|
-
requirement: <task-description>
|
|
98
|
-
inner_loop: false
|
|
99
|
-
|
|
100
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
101
|
-
|
|
102
|
-
{ type: "text", text: `## Task Context
|
|
103
|
-
task_id: <task-id>
|
|
104
|
-
title: <task-title>
|
|
105
|
-
description: <task-description>
|
|
106
|
-
pipeline_phase: <pipeline-phase>` },
|
|
107
|
-
|
|
108
|
-
{ type: "text", text: `## Upstream Context
|
|
109
|
-
<prev_context>` }
|
|
110
|
-
]
|
|
111
|
-
})
|
|
112
|
-
```
|
|
113
|
-
|
|
114
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
115
|
-
|
|
116
|
-
**Parallel spawn** (Batch mode, N explorer or M implementer instances):
|
|
117
|
-
|
|
118
|
-
```
|
|
119
|
-
spawn_agent({
|
|
120
|
-
agent_type: "team_worker",
|
|
121
|
-
task_name: "<task-id>",
|
|
122
|
-
fork_context: false,
|
|
123
|
-
items: [
|
|
124
|
-
{ type: "text", text: `## Role Assignment
|
|
125
|
-
role: <role>
|
|
126
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
127
|
-
session: <session-folder>
|
|
128
|
-
session_id: <session-id>
|
|
129
|
-
requirement: <task-description>
|
|
130
|
-
agent_name: <role>-<N>
|
|
131
|
-
inner_loop: false
|
|
132
|
-
|
|
133
|
-
Read role_spec file (<skill_root>/roles/<role>/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: <task-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 })` each worker.
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
### Model Selection Guide
|
|
151
|
-
|
|
152
|
-
| Role | model | reasoning_effort | Rationale |
|
|
153
|
-
|------|-------|-------------------|-----------|
|
|
154
|
-
| Explorer (EXPLORE-*) | (default) | medium | Context gathering, file reading, less reasoning |
|
|
155
|
-
| Planner (SOLVE-*) | (default) | high | Solution design requires deep analysis |
|
|
156
|
-
| Reviewer (AUDIT-*) | (default) | high | Code review and plan validation need full reasoning |
|
|
157
|
-
| Integrator (MARSHAL-*) | (default) | medium | Queue ordering and dependency resolution |
|
|
158
|
-
| Implementer (BUILD-*) | (default) | high | Code generation needs precision |
|
|
159
|
-
|
|
160
|
-
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
161
|
-
```
|
|
162
|
-
spawn_agent({
|
|
163
|
-
agent_type: "team_worker",
|
|
164
|
-
task_name: "<task-id>",
|
|
165
|
-
fork_context: false,
|
|
166
|
-
model: "<model-override>",
|
|
167
|
-
reasoning_effort: "<effort-level>",
|
|
168
|
-
items: [...]
|
|
169
|
-
})
|
|
170
|
-
```
|
|
171
|
-
|
|
172
|
-
## User Commands
|
|
173
|
-
|
|
174
|
-
| Command | Action |
|
|
175
|
-
|---------|--------|
|
|
176
|
-
| `check` / `status` | View execution status graph, no advancement |
|
|
177
|
-
| `resume` / `continue` | Check worker states, advance next step |
|
|
178
|
-
|
|
179
|
-
## Session Directory
|
|
180
|
-
|
|
181
|
-
```
|
|
182
|
-
.workflow/.team/TISL-<slug>-<date>/
|
|
183
|
-
├── session.json # Session metadata + pipeline + fix_cycles
|
|
184
|
-
├── task-analysis.json # Coordinator analyze output
|
|
185
|
-
├── .msg/
|
|
186
|
-
│ ├── messages.jsonl # Message bus log
|
|
187
|
-
│ └── meta.json # Session state + cross-role state
|
|
188
|
-
├── wisdom/ # Cross-task knowledge
|
|
189
|
-
│ ├── learnings.md
|
|
190
|
-
│ ├── decisions.md
|
|
191
|
-
│ ├── conventions.md
|
|
192
|
-
│ └── issues.md
|
|
193
|
-
├── explorations/ # Explorer output
|
|
194
|
-
│ └── context-<issueId>.json
|
|
195
|
-
├── solutions/ # Planner output
|
|
196
|
-
│ └── solution-<issueId>.json
|
|
197
|
-
├── audits/ # Reviewer output
|
|
198
|
-
│ └── audit-report.json
|
|
199
|
-
├── queue/ # Integrator output (also .workflow/issues/queue/)
|
|
200
|
-
└── builds/ # Implementer output
|
|
201
|
-
```
|
|
202
|
-
|
|
203
|
-
## Specs Reference
|
|
204
|
-
|
|
205
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
206
|
-
|
|
207
|
-
## v4 Agent Coordination
|
|
208
|
-
|
|
209
|
-
### Message Semantics
|
|
210
|
-
|
|
211
|
-
| Intent | API | Example |
|
|
212
|
-
|--------|-----|---------|
|
|
213
|
-
| Send exploration context to running planner | `send_message` | Queue EXPLORE-* findings to SOLVE-* worker |
|
|
214
|
-
| Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
|
|
215
|
-
| Check running agents | `list_agents` | Verify parallel explorer/implementer health |
|
|
216
|
-
|
|
217
|
-
### Pipeline Pattern
|
|
218
|
-
|
|
219
|
-
Pipeline with context passing: explore -> plan -> review (optional) -> marshal -> implement. In **Batch mode**, N explorers and M implementers run in parallel:
|
|
220
|
-
|
|
221
|
-
```
|
|
222
|
-
// Batch mode: spawn N explorers in parallel (max 5)
|
|
223
|
-
const explorerNames = ["EXPLORE-001", "EXPLORE-002", ..., "EXPLORE-00N"]
|
|
224
|
-
for (const name of explorerNames) {
|
|
225
|
-
spawn_agent({ agent_type: "team_worker", task_name: name, ... })
|
|
226
|
-
}
|
|
227
|
-
wait_agent({ targets: explorerNames, timeout_ms: 900000 })
|
|
228
|
-
|
|
229
|
-
// After MARSHAL completes: spawn M implementers in parallel (max 3)
|
|
230
|
-
const buildNames = ["BUILD-001", "BUILD-002", ..., "BUILD-00M"]
|
|
231
|
-
for (const name of buildNames) {
|
|
232
|
-
spawn_agent({ agent_type: "team_worker", task_name: name, ... })
|
|
233
|
-
}
|
|
234
|
-
wait_agent({ targets: buildNames, timeout_ms: 900000 })
|
|
235
|
-
```
|
|
236
|
-
|
|
237
|
-
### Review-Fix Cycle
|
|
238
|
-
|
|
239
|
-
Reviewer (AUDIT-*) may reject plans, triggering fix cycles (max 2). Dynamic SOLVE-fix and AUDIT re-review tasks are created in tasks.json.
|
|
240
|
-
|
|
241
|
-
### Agent Health Check
|
|
242
|
-
|
|
243
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
244
|
-
|
|
245
|
-
```
|
|
246
|
-
// Reconcile session state with actual running agents
|
|
247
|
-
const running = list_agents({})
|
|
248
|
-
// Compare with tasks.json active_agents
|
|
249
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
250
|
-
```
|
|
251
|
-
|
|
252
|
-
### Named Agent Targeting
|
|
253
|
-
|
|
254
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
255
|
-
- `send_message({ target: "SOLVE-001", items: [...] })` -- queue exploration context to running planner
|
|
256
|
-
- `close_agent({ target: "BUILD-001" })` -- cleanup by name after completion
|
|
257
|
-
|
|
258
|
-
## Error Handling
|
|
259
|
-
|
|
260
|
-
| Scenario | Resolution |
|
|
261
|
-
|----------|------------|
|
|
262
|
-
| Unknown command | Error with available command list |
|
|
263
|
-
| Role not found | Error with role registry |
|
|
264
|
-
| CLI tool fails | Worker fallback to direct implementation |
|
|
265
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
266
|
-
| Completion action fails | Default to Keep Active |
|
|
267
|
-
| Review rejection exceeds 2 rounds | Force convergence to integrator |
|
|
268
|
-
| No issues found for given IDs | Coordinator reports error to user |
|
|
269
|
-
| Deferred BUILD count unknown | Defer to MARSHAL callback |
|
|
1
|
+
---
|
|
2
|
+
name: team-issue
|
|
3
|
+
description: Unified team skill for issue resolution. Uses team-worker agent architecture with role directories for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team issue".
|
|
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__ace-tool__search_context(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Team Issue Resolution
|
|
8
|
+
|
|
9
|
+
Orchestrate issue resolution pipeline: explore context -> plan solution -> review (optional) -> marshal queue -> implement. Supports Quick, Full, and Batch pipelines with review-fix cycle.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-issue", args="<issue-ids> [--mode=<mode>]")
|
|
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
|
+
+-- clarify -> dispatch -> spawn workers -> STOP
|
|
26
|
+
|
|
|
27
|
+
+-------+-------+-------+-------+
|
|
28
|
+
v v v v v
|
|
29
|
+
[explor] [plann] [review] [integ] [imple]
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
## Role Registry
|
|
33
|
+
|
|
34
|
+
| Role | Path | Prefix | Inner Loop |
|
|
35
|
+
|------|------|--------|------------|
|
|
36
|
+
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
37
|
+
| explorer | [roles/explorer/role.md](roles/explorer/role.md) | EXPLORE-* | false |
|
|
38
|
+
| planner | [roles/planner/role.md](roles/planner/role.md) | SOLVE-* | false |
|
|
39
|
+
| reviewer | [roles/reviewer/role.md](roles/reviewer/role.md) | AUDIT-* | false |
|
|
40
|
+
| integrator | [roles/integrator/role.md](roles/integrator/role.md) | MARSHAL-* | false |
|
|
41
|
+
| implementer | [roles/implementer/role.md](roles/implementer/role.md) | BUILD-* | false |
|
|
42
|
+
|
|
43
|
+
## Role Router
|
|
44
|
+
|
|
45
|
+
Parse `$ARGUMENTS`:
|
|
46
|
+
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
47
|
+
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
48
|
+
|
|
49
|
+
## Delegation Lock
|
|
50
|
+
|
|
51
|
+
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
52
|
+
|
|
53
|
+
Before calling ANY tool, apply this check:
|
|
54
|
+
|
|
55
|
+
| Tool Call | Verdict | Reason |
|
|
56
|
+
|-----------|---------|--------|
|
|
57
|
+
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
58
|
+
| `list_agents` | ALLOWED | Agent health check |
|
|
59
|
+
| `request_user_input` | ALLOWED | User interaction |
|
|
60
|
+
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
61
|
+
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
62
|
+
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
63
|
+
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
64
|
+
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
65
|
+
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
66
|
+
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
67
|
+
|
|
68
|
+
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
69
|
+
|
|
70
|
+
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
71
|
+
|
|
72
|
+
---
|
|
73
|
+
|
|
74
|
+
## Shared Constants
|
|
75
|
+
|
|
76
|
+
- **Session prefix**: `TISL`
|
|
77
|
+
- **Session path**: `.workflow/.team/TISL-<slug>-<date>/`
|
|
78
|
+
- **Team name**: `issue`
|
|
79
|
+
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
80
|
+
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
81
|
+
|
|
82
|
+
## Worker Spawn Template
|
|
83
|
+
|
|
84
|
+
Coordinator spawns workers using this template:
|
|
85
|
+
|
|
86
|
+
```
|
|
87
|
+
spawn_agent({
|
|
88
|
+
agent_type: "team_worker",
|
|
89
|
+
task_name: "<task-id>",
|
|
90
|
+
fork_context: false,
|
|
91
|
+
items: [
|
|
92
|
+
{ type: "text", text: `## Role Assignment
|
|
93
|
+
role: <role>
|
|
94
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
95
|
+
session: <session-folder>
|
|
96
|
+
session_id: <session-id>
|
|
97
|
+
requirement: <task-description>
|
|
98
|
+
inner_loop: false
|
|
99
|
+
|
|
100
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
101
|
+
|
|
102
|
+
{ type: "text", text: `## Task Context
|
|
103
|
+
task_id: <task-id>
|
|
104
|
+
title: <task-title>
|
|
105
|
+
description: <task-description>
|
|
106
|
+
pipeline_phase: <pipeline-phase>` },
|
|
107
|
+
|
|
108
|
+
{ type: "text", text: `## Upstream Context
|
|
109
|
+
<prev_context>` }
|
|
110
|
+
]
|
|
111
|
+
})
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
115
|
+
|
|
116
|
+
**Parallel spawn** (Batch mode, N explorer or M implementer instances):
|
|
117
|
+
|
|
118
|
+
```
|
|
119
|
+
spawn_agent({
|
|
120
|
+
agent_type: "team_worker",
|
|
121
|
+
task_name: "<task-id>",
|
|
122
|
+
fork_context: false,
|
|
123
|
+
items: [
|
|
124
|
+
{ type: "text", text: `## Role Assignment
|
|
125
|
+
role: <role>
|
|
126
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
127
|
+
session: <session-folder>
|
|
128
|
+
session_id: <session-id>
|
|
129
|
+
requirement: <task-description>
|
|
130
|
+
agent_name: <role>-<N>
|
|
131
|
+
inner_loop: false
|
|
132
|
+
|
|
133
|
+
Read role_spec file (<skill_root>/roles/<role>/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: <task-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 })` each worker.
|
|
148
|
+
|
|
149
|
+
|
|
150
|
+
### Model Selection Guide
|
|
151
|
+
|
|
152
|
+
| Role | model | reasoning_effort | Rationale |
|
|
153
|
+
|------|-------|-------------------|-----------|
|
|
154
|
+
| Explorer (EXPLORE-*) | (default) | medium | Context gathering, file reading, less reasoning |
|
|
155
|
+
| Planner (SOLVE-*) | (default) | high | Solution design requires deep analysis |
|
|
156
|
+
| Reviewer (AUDIT-*) | (default) | high | Code review and plan validation need full reasoning |
|
|
157
|
+
| Integrator (MARSHAL-*) | (default) | medium | Queue ordering and dependency resolution |
|
|
158
|
+
| Implementer (BUILD-*) | (default) | high | Code generation needs precision |
|
|
159
|
+
|
|
160
|
+
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
161
|
+
```
|
|
162
|
+
spawn_agent({
|
|
163
|
+
agent_type: "team_worker",
|
|
164
|
+
task_name: "<task-id>",
|
|
165
|
+
fork_context: false,
|
|
166
|
+
model: "<model-override>",
|
|
167
|
+
reasoning_effort: "<effort-level>",
|
|
168
|
+
items: [...]
|
|
169
|
+
})
|
|
170
|
+
```
|
|
171
|
+
|
|
172
|
+
## User Commands
|
|
173
|
+
|
|
174
|
+
| Command | Action |
|
|
175
|
+
|---------|--------|
|
|
176
|
+
| `check` / `status` | View execution status graph, no advancement |
|
|
177
|
+
| `resume` / `continue` | Check worker states, advance next step |
|
|
178
|
+
|
|
179
|
+
## Session Directory
|
|
180
|
+
|
|
181
|
+
```
|
|
182
|
+
.workflow/.team/TISL-<slug>-<date>/
|
|
183
|
+
├── session.json # Session metadata + pipeline + fix_cycles
|
|
184
|
+
├── task-analysis.json # Coordinator analyze output
|
|
185
|
+
├── .msg/
|
|
186
|
+
│ ├── messages.jsonl # Message bus log
|
|
187
|
+
│ └── meta.json # Session state + cross-role state
|
|
188
|
+
├── wisdom/ # Cross-task knowledge
|
|
189
|
+
│ ├── learnings.md
|
|
190
|
+
│ ├── decisions.md
|
|
191
|
+
│ ├── conventions.md
|
|
192
|
+
│ └── issues.md
|
|
193
|
+
├── explorations/ # Explorer output
|
|
194
|
+
│ └── context-<issueId>.json
|
|
195
|
+
├── solutions/ # Planner output
|
|
196
|
+
│ └── solution-<issueId>.json
|
|
197
|
+
├── audits/ # Reviewer output
|
|
198
|
+
│ └── audit-report.json
|
|
199
|
+
├── queue/ # Integrator output (also .workflow/issues/queue/)
|
|
200
|
+
└── builds/ # Implementer output
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
## Specs Reference
|
|
204
|
+
|
|
205
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
206
|
+
|
|
207
|
+
## v4 Agent Coordination
|
|
208
|
+
|
|
209
|
+
### Message Semantics
|
|
210
|
+
|
|
211
|
+
| Intent | API | Example |
|
|
212
|
+
|--------|-----|---------|
|
|
213
|
+
| Send exploration context to running planner | `send_message` | Queue EXPLORE-* findings to SOLVE-* worker |
|
|
214
|
+
| Not used in this skill | `assign_task` | No resident agents -- all workers are one-shot |
|
|
215
|
+
| Check running agents | `list_agents` | Verify parallel explorer/implementer health |
|
|
216
|
+
|
|
217
|
+
### Pipeline Pattern
|
|
218
|
+
|
|
219
|
+
Pipeline with context passing: explore -> plan -> review (optional) -> marshal -> implement. In **Batch mode**, N explorers and M implementers run in parallel:
|
|
220
|
+
|
|
221
|
+
```
|
|
222
|
+
// Batch mode: spawn N explorers in parallel (max 5)
|
|
223
|
+
const explorerNames = ["EXPLORE-001", "EXPLORE-002", ..., "EXPLORE-00N"]
|
|
224
|
+
for (const name of explorerNames) {
|
|
225
|
+
spawn_agent({ agent_type: "team_worker", task_name: name, ... })
|
|
226
|
+
}
|
|
227
|
+
wait_agent({ targets: explorerNames, timeout_ms: 900000 })
|
|
228
|
+
|
|
229
|
+
// After MARSHAL completes: spawn M implementers in parallel (max 3)
|
|
230
|
+
const buildNames = ["BUILD-001", "BUILD-002", ..., "BUILD-00M"]
|
|
231
|
+
for (const name of buildNames) {
|
|
232
|
+
spawn_agent({ agent_type: "team_worker", task_name: name, ... })
|
|
233
|
+
}
|
|
234
|
+
wait_agent({ targets: buildNames, timeout_ms: 900000 })
|
|
235
|
+
```
|
|
236
|
+
|
|
237
|
+
### Review-Fix Cycle
|
|
238
|
+
|
|
239
|
+
Reviewer (AUDIT-*) may reject plans, triggering fix cycles (max 2). Dynamic SOLVE-fix and AUDIT re-review tasks are created in tasks.json.
|
|
240
|
+
|
|
241
|
+
### Agent Health Check
|
|
242
|
+
|
|
243
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
244
|
+
|
|
245
|
+
```
|
|
246
|
+
// Reconcile session state with actual running agents
|
|
247
|
+
const running = list_agents({})
|
|
248
|
+
// Compare with tasks.json active_agents
|
|
249
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
250
|
+
```
|
|
251
|
+
|
|
252
|
+
### Named Agent Targeting
|
|
253
|
+
|
|
254
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
255
|
+
- `send_message({ target: "SOLVE-001", items: [...] })` -- queue exploration context to running planner
|
|
256
|
+
- `close_agent({ target: "BUILD-001" })` -- cleanup by name after completion
|
|
257
|
+
|
|
258
|
+
## Error Handling
|
|
259
|
+
|
|
260
|
+
| Scenario | Resolution |
|
|
261
|
+
|----------|------------|
|
|
262
|
+
| Unknown command | Error with available command list |
|
|
263
|
+
| Role not found | Error with role registry |
|
|
264
|
+
| CLI tool fails | Worker fallback to direct implementation |
|
|
265
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
266
|
+
| Completion action fails | Default to Keep Active |
|
|
267
|
+
| Review rejection exceeds 2 rounds | Force convergence to integrator |
|
|
268
|
+
| No issues found for given IDs | Coordinator reports error to user |
|
|
269
|
+
| Deferred BUILD count unknown | Defer to MARSHAL callback |
|
|
@@ -168,7 +168,7 @@ Delegate to @commands/monitor.md#handleSpawnNext:
|
|
|
168
168
|
|
|
169
169
|
4. Execute completion action (interactive):
|
|
170
170
|
```
|
|
171
|
-
request_user_input({
|
|
171
|
+
functions.request_user_input({
|
|
172
172
|
questions: [{ question: "Issue pipeline complete. What would you like to do?",
|
|
173
173
|
options: [
|
|
174
174
|
{ label: "Archive & Clean (Recommended)", description: "Archive session, clean up tasks and team" },
|