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,206 +1,206 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-tech-debt
|
|
3
|
-
description: Unified team skill for tech debt identification and remediation. Scans codebase for tech debt, assesses severity, plans and executes fixes with validation. Uses team-worker agent architecture with roles/ for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team tech debt".
|
|
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__read_file(*), mcp__ccw-tools__write_file(*), mcp__ccw-tools__edit_file(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Team Tech Debt
|
|
8
|
-
|
|
9
|
-
Systematic tech debt governance: scan -> assess -> plan -> fix -> validate. Built on **team-worker agent architecture** — all worker roles share a single agent definition with role-specific Phase 2-4 loaded from `roles/<role>/role.md`.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-tech-debt", 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 v v v
|
|
29
|
-
[team-worker agents, each loads roles/<role>/role.md]
|
|
30
|
-
scanner assessor planner executor validator
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
## Role Registry
|
|
34
|
-
|
|
35
|
-
| Role | Path | Prefix | Inner Loop |
|
|
36
|
-
|------|------|--------|------------|
|
|
37
|
-
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
38
|
-
| scanner | [roles/scanner/role.md](roles/scanner/role.md) | TDSCAN-* | false |
|
|
39
|
-
| assessor | [roles/assessor/role.md](roles/assessor/role.md) | TDEVAL-* | false |
|
|
40
|
-
| planner | [roles/planner/role.md](roles/planner/role.md) | TDPLAN-* | false |
|
|
41
|
-
| executor | [roles/executor/role.md](roles/executor/role.md) | TDFIX-* | true |
|
|
42
|
-
| validator | [roles/validator/role.md](roles/validator/role.md) | TDVAL-* | false |
|
|
43
|
-
|
|
44
|
-
## Role Router
|
|
45
|
-
|
|
46
|
-
Parse `$ARGUMENTS`:
|
|
47
|
-
- Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
|
|
48
|
-
- No `--role` → `roles/coordinator/role.md`, execute entry router
|
|
49
|
-
|
|
50
|
-
## Delegation Lock
|
|
51
|
-
|
|
52
|
-
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
53
|
-
|
|
54
|
-
Before calling ANY tool, apply this check:
|
|
55
|
-
|
|
56
|
-
| Tool Call | Verdict | Reason |
|
|
57
|
-
|-----------|---------|--------|
|
|
58
|
-
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
59
|
-
| `list_agents` | ALLOWED | Agent health check |
|
|
60
|
-
| `request_user_input` | ALLOWED | User interaction |
|
|
61
|
-
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
62
|
-
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
63
|
-
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
64
|
-
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
65
|
-
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
66
|
-
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
67
|
-
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
68
|
-
|
|
69
|
-
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
70
|
-
|
|
71
|
-
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
72
|
-
|
|
73
|
-
---
|
|
74
|
-
|
|
75
|
-
## Shared Constants
|
|
76
|
-
|
|
77
|
-
- **Session prefix**: `TD`
|
|
78
|
-
- **Session path**: `.workflow/.team/TD-<slug>-<date>/`
|
|
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
|
-
- **Max GC rounds**: 3
|
|
82
|
-
|
|
83
|
-
## Worker Spawn Template
|
|
84
|
-
|
|
85
|
-
Coordinator spawns workers using this template:
|
|
86
|
-
|
|
87
|
-
```
|
|
88
|
-
spawn_agent({
|
|
89
|
-
agent_type: "team_worker",
|
|
90
|
-
task_name: "<task-id>",
|
|
91
|
-
fork_context: false,
|
|
92
|
-
items: [
|
|
93
|
-
{ type: "text", text: `## Role Assignment
|
|
94
|
-
role: <role>
|
|
95
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
96
|
-
session: <session-folder>
|
|
97
|
-
session_id: <session-id>
|
|
98
|
-
requirement: <task-description>
|
|
99
|
-
inner_loop: <true|false>
|
|
100
|
-
|
|
101
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
102
|
-
|
|
103
|
-
{ type: "text", text: `## Task Context
|
|
104
|
-
task_id: <task-id>
|
|
105
|
-
title: <task-title>
|
|
106
|
-
description: <task-description>
|
|
107
|
-
pipeline_phase: <pipeline-phase>` },
|
|
108
|
-
|
|
109
|
-
{ type: "text", text: `## Upstream Context
|
|
110
|
-
<prev_context>` }
|
|
111
|
-
]
|
|
112
|
-
})
|
|
113
|
-
```
|
|
114
|
-
|
|
115
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
### Model Selection Guide
|
|
119
|
-
|
|
120
|
-
Tech debt follows a discovery-to-fix pipeline. Scanner is broad/fast, later stages need deeper reasoning.
|
|
121
|
-
|
|
122
|
-
| Role | reasoning_effort | Rationale |
|
|
123
|
-
|------|-------------------|-----------|
|
|
124
|
-
| scanner | medium | Broad codebase scan, pattern matching over deep analysis |
|
|
125
|
-
| assessor | high | Severity assessment requires understanding impact and risk |
|
|
126
|
-
| planner | high | Remediation planning must prioritize and sequence fixes |
|
|
127
|
-
| executor | high | Code fixes must preserve behavior while removing debt |
|
|
128
|
-
| validator | medium | Validation follows defined acceptance criteria |
|
|
129
|
-
|
|
130
|
-
### Pipeline Pattern: Scanner Results Inform Downstream
|
|
131
|
-
|
|
132
|
-
Scanner discoveries flow through the pipeline — each stage narrows and refines:
|
|
133
|
-
1. TDSCAN produces broad debt inventory
|
|
134
|
-
2. TDEVAL assesses and prioritizes (filters low-impact items)
|
|
135
|
-
3. TDPLAN creates sequenced fix plan from assessed items
|
|
136
|
-
4. TDFIX implements fixes per plan
|
|
137
|
-
5. TDVAL validates fixes against original debt findings
|
|
138
|
-
|
|
139
|
-
## User Commands
|
|
140
|
-
|
|
141
|
-
| Command | Action |
|
|
142
|
-
|---------|--------|
|
|
143
|
-
| `check` / `status` | View execution status graph |
|
|
144
|
-
| `resume` / `continue` | Advance to next step |
|
|
145
|
-
| `--mode=scan` | Run scan-only pipeline (TDSCAN + TDEVAL) |
|
|
146
|
-
| `--mode=targeted` | Run targeted pipeline (TDPLAN + TDFIX + TDVAL) |
|
|
147
|
-
| `--mode=remediate` | Run full pipeline (default) |
|
|
148
|
-
| `-y` / `--yes` | Skip confirmations |
|
|
149
|
-
|
|
150
|
-
## Specs Reference
|
|
151
|
-
|
|
152
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
153
|
-
|
|
154
|
-
## Session Directory
|
|
155
|
-
|
|
156
|
-
```
|
|
157
|
-
.workflow/.team/TD-<slug>-<date>/
|
|
158
|
-
├── .msg/
|
|
159
|
-
│ ├── messages.jsonl # Team message bus
|
|
160
|
-
│ └── meta.json # Pipeline config + role state snapshot
|
|
161
|
-
├── scan/ # Scanner output
|
|
162
|
-
├── assessment/ # Assessor output
|
|
163
|
-
├── plan/ # Planner output
|
|
164
|
-
├── fixes/ # Executor output
|
|
165
|
-
├── validation/ # Validator output
|
|
166
|
-
└── wisdom/ # Cross-task knowledge
|
|
167
|
-
```
|
|
168
|
-
|
|
169
|
-
## v4 Agent Coordination
|
|
170
|
-
|
|
171
|
-
### Message Semantics
|
|
172
|
-
|
|
173
|
-
| Intent | API | Example |
|
|
174
|
-
|--------|-----|---------|
|
|
175
|
-
| Queue supplementary info (don't interrupt) | `send_message` | Send scan findings to running assessor |
|
|
176
|
-
| Assign fix from remediation plan | `assign_task` | Assign TDFIX task from planner output |
|
|
177
|
-
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
178
|
-
|
|
179
|
-
### Agent Health Check
|
|
180
|
-
|
|
181
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
182
|
-
|
|
183
|
-
```
|
|
184
|
-
// Reconcile session state with actual running agents
|
|
185
|
-
const running = list_agents({})
|
|
186
|
-
// Compare with meta.json active tasks
|
|
187
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
188
|
-
```
|
|
189
|
-
|
|
190
|
-
### Named Agent Targeting
|
|
191
|
-
|
|
192
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
193
|
-
- `send_message({ target: "TDSCAN-001", items: [...] })` -- send additional scan scope to scanner
|
|
194
|
-
- `assign_task({ target: "TDFIX-001", items: [...] })` -- assign fix task from planner output
|
|
195
|
-
- `close_agent({ target: "TDVAL-001" })` -- cleanup after validation
|
|
196
|
-
|
|
197
|
-
## Error Handling
|
|
198
|
-
|
|
199
|
-
| Scenario | Resolution |
|
|
200
|
-
|----------|------------|
|
|
201
|
-
| Unknown command | Error with available command list |
|
|
202
|
-
| Role not found | Error with role registry |
|
|
203
|
-
| Session corruption | Attempt recovery, fallback to manual |
|
|
204
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
205
|
-
| Completion action fails | Default to Keep Active |
|
|
206
|
-
| Scanner finds no debt | Report clean codebase, skip to summary |
|
|
1
|
+
---
|
|
2
|
+
name: team-tech-debt
|
|
3
|
+
description: Unified team skill for tech debt identification and remediation. Scans codebase for tech debt, assesses severity, plans and executes fixes with validation. Uses team-worker agent architecture with roles/ for domain logic. Coordinator orchestrates pipeline, workers are team-worker agents. Triggers on "team tech debt".
|
|
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__read_file(*), mcp__ccw-tools__write_file(*), mcp__ccw-tools__edit_file(*), mcp__ccw-tools__team_msg(*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Team Tech Debt
|
|
8
|
+
|
|
9
|
+
Systematic tech debt governance: scan -> assess -> plan -> fix -> validate. Built on **team-worker agent architecture** — all worker roles share a single agent definition with role-specific Phase 2-4 loaded from `roles/<role>/role.md`.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-tech-debt", 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 v v v
|
|
29
|
+
[team-worker agents, each loads roles/<role>/role.md]
|
|
30
|
+
scanner assessor planner executor validator
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Role Registry
|
|
34
|
+
|
|
35
|
+
| Role | Path | Prefix | Inner Loop |
|
|
36
|
+
|------|------|--------|------------|
|
|
37
|
+
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
38
|
+
| scanner | [roles/scanner/role.md](roles/scanner/role.md) | TDSCAN-* | false |
|
|
39
|
+
| assessor | [roles/assessor/role.md](roles/assessor/role.md) | TDEVAL-* | false |
|
|
40
|
+
| planner | [roles/planner/role.md](roles/planner/role.md) | TDPLAN-* | false |
|
|
41
|
+
| executor | [roles/executor/role.md](roles/executor/role.md) | TDFIX-* | true |
|
|
42
|
+
| validator | [roles/validator/role.md](roles/validator/role.md) | TDVAL-* | false |
|
|
43
|
+
|
|
44
|
+
## Role Router
|
|
45
|
+
|
|
46
|
+
Parse `$ARGUMENTS`:
|
|
47
|
+
- Has `--role <name>` → Read `roles/<name>/role.md`, execute Phase 2-4
|
|
48
|
+
- No `--role` → `roles/coordinator/role.md`, execute entry router
|
|
49
|
+
|
|
50
|
+
## Delegation Lock
|
|
51
|
+
|
|
52
|
+
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
53
|
+
|
|
54
|
+
Before calling ANY tool, apply this check:
|
|
55
|
+
|
|
56
|
+
| Tool Call | Verdict | Reason |
|
|
57
|
+
|-----------|---------|--------|
|
|
58
|
+
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
59
|
+
| `list_agents` | ALLOWED | Agent health check |
|
|
60
|
+
| `request_user_input` | ALLOWED | User interaction |
|
|
61
|
+
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
62
|
+
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
63
|
+
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
64
|
+
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
65
|
+
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
66
|
+
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
67
|
+
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
68
|
+
|
|
69
|
+
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
70
|
+
|
|
71
|
+
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
72
|
+
|
|
73
|
+
---
|
|
74
|
+
|
|
75
|
+
## Shared Constants
|
|
76
|
+
|
|
77
|
+
- **Session prefix**: `TD`
|
|
78
|
+
- **Session path**: `.workflow/.team/TD-<slug>-<date>/`
|
|
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
|
+
- **Max GC rounds**: 3
|
|
82
|
+
|
|
83
|
+
## Worker Spawn Template
|
|
84
|
+
|
|
85
|
+
Coordinator spawns workers using this template:
|
|
86
|
+
|
|
87
|
+
```
|
|
88
|
+
spawn_agent({
|
|
89
|
+
agent_type: "team_worker",
|
|
90
|
+
task_name: "<task-id>",
|
|
91
|
+
fork_context: false,
|
|
92
|
+
items: [
|
|
93
|
+
{ type: "text", text: `## Role Assignment
|
|
94
|
+
role: <role>
|
|
95
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
96
|
+
session: <session-folder>
|
|
97
|
+
session_id: <session-id>
|
|
98
|
+
requirement: <task-description>
|
|
99
|
+
inner_loop: <true|false>
|
|
100
|
+
|
|
101
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
102
|
+
|
|
103
|
+
{ type: "text", text: `## Task Context
|
|
104
|
+
task_id: <task-id>
|
|
105
|
+
title: <task-title>
|
|
106
|
+
description: <task-description>
|
|
107
|
+
pipeline_phase: <pipeline-phase>` },
|
|
108
|
+
|
|
109
|
+
{ type: "text", text: `## Upstream Context
|
|
110
|
+
<prev_context>` }
|
|
111
|
+
]
|
|
112
|
+
})
|
|
113
|
+
```
|
|
114
|
+
|
|
115
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
### Model Selection Guide
|
|
119
|
+
|
|
120
|
+
Tech debt follows a discovery-to-fix pipeline. Scanner is broad/fast, later stages need deeper reasoning.
|
|
121
|
+
|
|
122
|
+
| Role | reasoning_effort | Rationale |
|
|
123
|
+
|------|-------------------|-----------|
|
|
124
|
+
| scanner | medium | Broad codebase scan, pattern matching over deep analysis |
|
|
125
|
+
| assessor | high | Severity assessment requires understanding impact and risk |
|
|
126
|
+
| planner | high | Remediation planning must prioritize and sequence fixes |
|
|
127
|
+
| executor | high | Code fixes must preserve behavior while removing debt |
|
|
128
|
+
| validator | medium | Validation follows defined acceptance criteria |
|
|
129
|
+
|
|
130
|
+
### Pipeline Pattern: Scanner Results Inform Downstream
|
|
131
|
+
|
|
132
|
+
Scanner discoveries flow through the pipeline — each stage narrows and refines:
|
|
133
|
+
1. TDSCAN produces broad debt inventory
|
|
134
|
+
2. TDEVAL assesses and prioritizes (filters low-impact items)
|
|
135
|
+
3. TDPLAN creates sequenced fix plan from assessed items
|
|
136
|
+
4. TDFIX implements fixes per plan
|
|
137
|
+
5. TDVAL validates fixes against original debt findings
|
|
138
|
+
|
|
139
|
+
## User Commands
|
|
140
|
+
|
|
141
|
+
| Command | Action |
|
|
142
|
+
|---------|--------|
|
|
143
|
+
| `check` / `status` | View execution status graph |
|
|
144
|
+
| `resume` / `continue` | Advance to next step |
|
|
145
|
+
| `--mode=scan` | Run scan-only pipeline (TDSCAN + TDEVAL) |
|
|
146
|
+
| `--mode=targeted` | Run targeted pipeline (TDPLAN + TDFIX + TDVAL) |
|
|
147
|
+
| `--mode=remediate` | Run full pipeline (default) |
|
|
148
|
+
| `-y` / `--yes` | Skip confirmations |
|
|
149
|
+
|
|
150
|
+
## Specs Reference
|
|
151
|
+
|
|
152
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
153
|
+
|
|
154
|
+
## Session Directory
|
|
155
|
+
|
|
156
|
+
```
|
|
157
|
+
.workflow/.team/TD-<slug>-<date>/
|
|
158
|
+
├── .msg/
|
|
159
|
+
│ ├── messages.jsonl # Team message bus
|
|
160
|
+
│ └── meta.json # Pipeline config + role state snapshot
|
|
161
|
+
├── scan/ # Scanner output
|
|
162
|
+
├── assessment/ # Assessor output
|
|
163
|
+
├── plan/ # Planner output
|
|
164
|
+
├── fixes/ # Executor output
|
|
165
|
+
├── validation/ # Validator output
|
|
166
|
+
└── wisdom/ # Cross-task knowledge
|
|
167
|
+
```
|
|
168
|
+
|
|
169
|
+
## v4 Agent Coordination
|
|
170
|
+
|
|
171
|
+
### Message Semantics
|
|
172
|
+
|
|
173
|
+
| Intent | API | Example |
|
|
174
|
+
|--------|-----|---------|
|
|
175
|
+
| Queue supplementary info (don't interrupt) | `send_message` | Send scan findings to running assessor |
|
|
176
|
+
| Assign fix from remediation plan | `assign_task` | Assign TDFIX task from planner output |
|
|
177
|
+
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
178
|
+
|
|
179
|
+
### Agent Health Check
|
|
180
|
+
|
|
181
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
182
|
+
|
|
183
|
+
```
|
|
184
|
+
// Reconcile session state with actual running agents
|
|
185
|
+
const running = list_agents({})
|
|
186
|
+
// Compare with meta.json active tasks
|
|
187
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
188
|
+
```
|
|
189
|
+
|
|
190
|
+
### Named Agent Targeting
|
|
191
|
+
|
|
192
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
193
|
+
- `send_message({ target: "TDSCAN-001", items: [...] })` -- send additional scan scope to scanner
|
|
194
|
+
- `assign_task({ target: "TDFIX-001", items: [...] })` -- assign fix task from planner output
|
|
195
|
+
- `close_agent({ target: "TDVAL-001" })` -- cleanup after validation
|
|
196
|
+
|
|
197
|
+
## Error Handling
|
|
198
|
+
|
|
199
|
+
| Scenario | Resolution |
|
|
200
|
+
|----------|------------|
|
|
201
|
+
| Unknown command | Error with available command list |
|
|
202
|
+
| Role not found | Error with role registry |
|
|
203
|
+
| Session corruption | Attempt recovery, fallback to manual |
|
|
204
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
205
|
+
| Completion action fails | Default to Keep Active |
|
|
206
|
+
| Scanner finds no debt | Report clean codebase, skip to summary |
|
|
@@ -148,7 +148,7 @@ After task completion, check for checkpoints:
|
|
|
148
148
|
|
|
149
149
|
- **TDPLAN-001 completes** -> Plan Approval Gate:
|
|
150
150
|
```javascript
|
|
151
|
-
request_user_input({
|
|
151
|
+
functions.request_user_input({
|
|
152
152
|
questions: [{
|
|
153
153
|
question: "Remediation plan generated. Review and decide:",
|
|
154
154
|
header: "Plan Review",
|