@sienklogic/plan-build-run 2.34.0 → 2.38.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/CHANGELOG.md +683 -0
- package/dashboard/public/css/command-center.css +152 -65
- package/dashboard/public/css/explorer.css +22 -41
- package/dashboard/public/css/layout.css +119 -1
- package/dashboard/public/css/tokens.css +13 -0
- package/dashboard/src/components/Layout.tsx +32 -6
- package/dashboard/src/components/explorer/tabs/PhasesTab.tsx +11 -1
- package/dashboard/src/components/explorer/tabs/TodosTab.tsx +18 -2
- package/dashboard/src/components/partials/AttentionPanel.tsx +7 -1
- package/dashboard/src/components/partials/CurrentPhaseCard.tsx +26 -24
- package/dashboard/src/components/partials/QuickActions.tsx +21 -11
- package/dashboard/src/components/partials/StatCardGrid.tsx +67 -0
- package/dashboard/src/components/partials/StatusHeader.tsx +1 -0
- package/dashboard/src/routes/command-center.routes.tsx +8 -7
- package/dashboard/src/routes/index.routes.tsx +32 -29
- package/package.json +2 -2
- package/plugins/copilot-pbr/agents/audit.agent.md +129 -16
- package/plugins/copilot-pbr/agents/codebase-mapper.agent.md +49 -1
- package/plugins/copilot-pbr/agents/debugger.agent.md +50 -1
- package/plugins/copilot-pbr/agents/dev-sync.agent.md +23 -0
- package/plugins/copilot-pbr/agents/executor.agent.md +153 -8
- package/plugins/copilot-pbr/agents/general.agent.md +46 -1
- package/plugins/copilot-pbr/agents/integration-checker.agent.md +55 -2
- package/plugins/copilot-pbr/agents/plan-checker.agent.md +50 -2
- package/plugins/copilot-pbr/agents/planner.agent.md +80 -1
- package/plugins/copilot-pbr/agents/researcher.agent.md +50 -2
- package/plugins/copilot-pbr/agents/synthesizer.agent.md +49 -1
- package/plugins/copilot-pbr/agents/verifier.agent.md +114 -13
- package/plugins/copilot-pbr/commands/test.md +5 -0
- package/plugins/copilot-pbr/hooks/hooks.json +11 -0
- package/plugins/copilot-pbr/plugin.json +1 -1
- package/plugins/copilot-pbr/references/agent-contracts.md +27 -0
- package/plugins/copilot-pbr/references/checkpoints.md +32 -1
- package/plugins/copilot-pbr/references/context-quality-tiers.md +45 -0
- package/plugins/copilot-pbr/references/pbr-tools-cli.md +115 -0
- package/plugins/copilot-pbr/references/questioning.md +21 -1
- package/plugins/copilot-pbr/references/verification-patterns.md +96 -18
- package/plugins/copilot-pbr/skills/audit/SKILL.md +19 -3
- package/plugins/copilot-pbr/skills/begin/SKILL.md +57 -4
- package/plugins/copilot-pbr/skills/build/SKILL.md +39 -2
- package/plugins/copilot-pbr/skills/config/SKILL.md +12 -2
- package/plugins/copilot-pbr/skills/debug/SKILL.md +12 -1
- package/plugins/copilot-pbr/skills/explore/SKILL.md +13 -2
- package/plugins/copilot-pbr/skills/health/SKILL.md +13 -5
- package/plugins/copilot-pbr/skills/import/SKILL.md +26 -1
- package/plugins/copilot-pbr/skills/milestone/SKILL.md +15 -3
- package/plugins/copilot-pbr/skills/plan/SKILL.md +50 -0
- package/plugins/copilot-pbr/skills/quick/SKILL.md +21 -0
- package/plugins/copilot-pbr/skills/review/SKILL.md +45 -0
- package/plugins/copilot-pbr/skills/scan/SKILL.md +20 -0
- package/plugins/copilot-pbr/skills/setup/SKILL.md +9 -1
- package/plugins/copilot-pbr/skills/shared/context-budget.md +10 -0
- package/plugins/copilot-pbr/skills/shared/universal-anti-patterns.md +6 -0
- package/plugins/copilot-pbr/skills/test/SKILL.md +210 -0
- package/plugins/copilot-pbr/templates/SUMMARY-complex.md.tmpl +95 -0
- package/plugins/copilot-pbr/templates/SUMMARY-minimal.md.tmpl +48 -0
- package/plugins/cursor-pbr/.cursor-plugin/plugin.json +1 -1
- package/plugins/cursor-pbr/agents/audit.md +52 -5
- package/plugins/cursor-pbr/agents/codebase-mapper.md +49 -1
- package/plugins/cursor-pbr/agents/debugger.md +50 -1
- package/plugins/cursor-pbr/agents/dev-sync.md +23 -0
- package/plugins/cursor-pbr/agents/executor.md +153 -8
- package/plugins/cursor-pbr/agents/general.md +46 -1
- package/plugins/cursor-pbr/agents/integration-checker.md +54 -1
- package/plugins/cursor-pbr/agents/plan-checker.md +49 -1
- package/plugins/cursor-pbr/agents/planner.md +80 -1
- package/plugins/cursor-pbr/agents/researcher.md +49 -1
- package/plugins/cursor-pbr/agents/synthesizer.md +49 -1
- package/plugins/cursor-pbr/agents/verifier.md +113 -12
- package/plugins/cursor-pbr/commands/test.md +5 -0
- package/plugins/cursor-pbr/hooks/hooks.json +9 -0
- package/plugins/cursor-pbr/references/agent-contracts.md +27 -0
- package/plugins/cursor-pbr/references/checkpoints.md +32 -1
- package/plugins/cursor-pbr/references/context-quality-tiers.md +45 -0
- package/plugins/cursor-pbr/references/pbr-tools-cli.md +115 -0
- package/plugins/cursor-pbr/references/questioning.md +21 -1
- package/plugins/cursor-pbr/references/verification-patterns.md +96 -18
- package/plugins/cursor-pbr/skills/audit/SKILL.md +19 -3
- package/plugins/cursor-pbr/skills/begin/SKILL.md +57 -4
- package/plugins/cursor-pbr/skills/build/SKILL.md +37 -2
- package/plugins/cursor-pbr/skills/config/SKILL.md +12 -2
- package/plugins/cursor-pbr/skills/debug/SKILL.md +12 -1
- package/plugins/cursor-pbr/skills/explore/SKILL.md +13 -2
- package/plugins/cursor-pbr/skills/health/SKILL.md +14 -5
- package/plugins/cursor-pbr/skills/import/SKILL.md +26 -1
- package/plugins/cursor-pbr/skills/milestone/SKILL.md +15 -3
- package/plugins/cursor-pbr/skills/plan/SKILL.md +50 -0
- package/plugins/cursor-pbr/skills/quick/SKILL.md +21 -0
- package/plugins/cursor-pbr/skills/review/SKILL.md +45 -0
- package/plugins/cursor-pbr/skills/scan/SKILL.md +20 -0
- package/plugins/cursor-pbr/skills/setup/SKILL.md +9 -1
- package/plugins/cursor-pbr/skills/shared/context-budget.md +10 -0
- package/plugins/cursor-pbr/skills/shared/universal-anti-patterns.md +6 -0
- package/plugins/cursor-pbr/skills/test/SKILL.md +211 -0
- package/plugins/cursor-pbr/templates/SUMMARY-complex.md.tmpl +95 -0
- package/plugins/cursor-pbr/templates/SUMMARY-minimal.md.tmpl +48 -0
- package/plugins/pbr/.claude-plugin/plugin.json +1 -1
- package/plugins/pbr/agents/audit.md +45 -0
- package/plugins/pbr/agents/codebase-mapper.md +48 -0
- package/plugins/pbr/agents/debugger.md +49 -0
- package/plugins/pbr/agents/dev-sync.md +23 -0
- package/plugins/pbr/agents/executor.md +151 -6
- package/plugins/pbr/agents/general.md +45 -0
- package/plugins/pbr/agents/integration-checker.md +53 -0
- package/plugins/pbr/agents/plan-checker.md +48 -0
- package/plugins/pbr/agents/planner.md +78 -1
- package/plugins/pbr/agents/researcher.md +48 -0
- package/plugins/pbr/agents/synthesizer.md +48 -0
- package/plugins/pbr/agents/verifier.md +112 -11
- package/plugins/pbr/commands/test.md +5 -0
- package/plugins/pbr/hooks/hooks.json +9 -0
- package/plugins/pbr/references/agent-contracts.md +27 -0
- package/plugins/pbr/references/checkpoints.md +32 -0
- package/plugins/pbr/references/context-quality-tiers.md +45 -0
- package/plugins/pbr/references/pbr-tools-cli.md +115 -0
- package/plugins/pbr/references/questioning.md +21 -0
- package/plugins/pbr/references/verification-patterns.md +96 -17
- package/plugins/pbr/scripts/check-plan-format.js +13 -1
- package/plugins/pbr/scripts/check-state-sync.js +26 -7
- package/plugins/pbr/scripts/check-subagent-output.js +30 -2
- package/plugins/pbr/scripts/config-schema.json +11 -1
- package/plugins/pbr/scripts/context-bridge.js +265 -0
- package/plugins/pbr/scripts/lib/config.js +271 -0
- package/plugins/pbr/scripts/lib/core.js +587 -0
- package/plugins/pbr/scripts/lib/history.js +73 -0
- package/plugins/pbr/scripts/lib/init.js +166 -0
- package/plugins/pbr/scripts/lib/migrate.js +169 -0
- package/plugins/pbr/scripts/lib/phase.js +364 -0
- package/plugins/pbr/scripts/lib/roadmap.js +175 -0
- package/plugins/pbr/scripts/lib/state.js +397 -0
- package/plugins/pbr/scripts/lib/todo.js +300 -0
- package/plugins/pbr/scripts/pbr-tools.js +425 -1310
- package/plugins/pbr/scripts/post-write-dispatch.js +5 -4
- package/plugins/pbr/scripts/pre-write-dispatch.js +1 -1
- package/plugins/pbr/scripts/progress-tracker.js +1 -1
- package/plugins/pbr/scripts/suggest-compact.js +1 -1
- package/plugins/pbr/scripts/track-context-budget.js +53 -2
- package/plugins/pbr/scripts/validate-task.js +20 -28
- package/plugins/pbr/skills/audit/SKILL.md +19 -3
- package/plugins/pbr/skills/begin/SKILL.md +48 -2
- package/plugins/pbr/skills/build/SKILL.md +39 -2
- package/plugins/pbr/skills/config/SKILL.md +12 -2
- package/plugins/pbr/skills/debug/SKILL.md +12 -1
- package/plugins/pbr/skills/debug/templates/continuation-prompt.md.tmpl +12 -1
- package/plugins/pbr/skills/debug/templates/initial-investigation-prompt.md.tmpl +12 -5
- package/plugins/pbr/skills/explore/SKILL.md +13 -2
- package/plugins/pbr/skills/health/SKILL.md +14 -3
- package/plugins/pbr/skills/help/SKILL.md +2 -0
- package/plugins/pbr/skills/import/SKILL.md +26 -1
- package/plugins/pbr/skills/milestone/SKILL.md +15 -3
- package/plugins/pbr/skills/plan/SKILL.md +52 -2
- package/plugins/pbr/skills/quick/SKILL.md +21 -0
- package/plugins/pbr/skills/review/SKILL.md +46 -0
- package/plugins/pbr/skills/scan/SKILL.md +20 -0
- package/plugins/pbr/skills/setup/SKILL.md +9 -1
- package/plugins/pbr/skills/shared/context-budget.md +10 -0
- package/plugins/pbr/skills/shared/universal-anti-patterns.md +6 -0
- package/plugins/pbr/skills/test/SKILL.md +212 -0
- package/plugins/pbr/templates/SUMMARY-complex.md.tmpl +95 -0
- package/plugins/pbr/templates/SUMMARY-minimal.md.tmpl +48 -0
|
@@ -14,6 +14,14 @@ tools:
|
|
|
14
14
|
- Bash
|
|
15
15
|
---
|
|
16
16
|
|
|
17
|
+
<files_to_read>
|
|
18
|
+
CRITICAL: If your spawn prompt contains a files_to_read block,
|
|
19
|
+
you MUST Read every listed file BEFORE any other action.
|
|
20
|
+
Skipping this causes hallucinated context and broken output.
|
|
21
|
+
</files_to_read>
|
|
22
|
+
|
|
23
|
+
> Default files: ROADMAP.md (phase goal), existing research in .planning/research/
|
|
24
|
+
|
|
17
25
|
# Plan-Build-Run Researcher
|
|
18
26
|
|
|
19
27
|
You are **researcher**, the unified research agent for the Plan-Build-Run development system. You investigate technologies, architectures, implementation approaches, and synthesize findings into actionable intelligence for planning agents.
|
|
@@ -190,6 +198,19 @@ coverage: "complete|partial|minimal"
|
|
|
190
198
|
|
|
191
199
|
---
|
|
192
200
|
|
|
201
|
+
### Context Quality Tiers
|
|
202
|
+
|
|
203
|
+
| Budget Used | Tier | Behavior |
|
|
204
|
+
|------------|------|----------|
|
|
205
|
+
| 0-30% | PEAK | Explore freely, read broadly |
|
|
206
|
+
| 30-50% | GOOD | Be selective with reads |
|
|
207
|
+
| 50-70% | DEGRADING | Write incrementally, skip non-essential |
|
|
208
|
+
| 70%+ | POOR | Finish current task and return immediately |
|
|
209
|
+
|
|
210
|
+
---
|
|
211
|
+
|
|
212
|
+
<anti_patterns>
|
|
213
|
+
|
|
193
214
|
## Universal Anti-Patterns
|
|
194
215
|
|
|
195
216
|
1. DO NOT guess or assume — read actual files for evidence
|
|
@@ -214,3 +235,30 @@ Additionally for this agent:
|
|
|
214
235
|
5. **DO NOT** present a single blog post as definitive guidance
|
|
215
236
|
6. **DO NOT** ignore version numbers — "React" is not the same as "React 18"
|
|
216
237
|
7. **DO NOT** research alternatives when CONTEXT.md has locked the choice
|
|
238
|
+
|
|
239
|
+
---
|
|
240
|
+
|
|
241
|
+
</anti_patterns>
|
|
242
|
+
|
|
243
|
+
<success_criteria>
|
|
244
|
+
- [ ] Research scope defined from phase goal or prompt
|
|
245
|
+
- [ ] Source hierarchy followed (S1-S6 ordering)
|
|
246
|
+
- [ ] All findings tagged with source level and confidence
|
|
247
|
+
- [ ] Version-sensitive info sourced from S1-S3 only
|
|
248
|
+
- [ ] Negative claims verified (absence of feature confirmed, not just unmentioned)
|
|
249
|
+
- [ ] Multiple sources cross-referenced for key decisions
|
|
250
|
+
- [ ] Publication dates checked — no stale guidance presented as current
|
|
251
|
+
- [ ] Gaps documented with reasons and "What might I have missed?" reflection
|
|
252
|
+
- [ ] Research output file written with required sections
|
|
253
|
+
- [ ] Completion marker returned
|
|
254
|
+
</success_criteria>
|
|
255
|
+
|
|
256
|
+
---
|
|
257
|
+
|
|
258
|
+
## Completion Protocol
|
|
259
|
+
|
|
260
|
+
CRITICAL: Your final output MUST end with exactly one completion marker.
|
|
261
|
+
Orchestrators pattern-match on these markers to route results. Omitting causes silent failures.
|
|
262
|
+
|
|
263
|
+
- `## RESEARCH COMPLETE` - findings written to output file(s)
|
|
264
|
+
- `## RESEARCH BLOCKED` - cannot proceed without human input or access
|
|
@@ -8,6 +8,14 @@ tools:
|
|
|
8
8
|
- Write
|
|
9
9
|
---
|
|
10
10
|
|
|
11
|
+
<files_to_read>
|
|
12
|
+
CRITICAL: If your spawn prompt contains a files_to_read block,
|
|
13
|
+
you MUST Read every listed file BEFORE any other action.
|
|
14
|
+
Skipping this causes hallucinated context and broken output.
|
|
15
|
+
</files_to_read>
|
|
16
|
+
|
|
17
|
+
> Default files: 2-4 research document paths provided in spawn prompt
|
|
18
|
+
|
|
11
19
|
# Plan-Build-Run Synthesizer
|
|
12
20
|
|
|
13
21
|
You are **synthesizer**, the fast synthesis agent for the Plan-Build-Run development system. You combine multiple research outputs into a single, coherent summary that the planner can consume efficiently. You use the sonnet model for quality — synthesis must resolve contradictions accurately.
|
|
@@ -112,6 +120,21 @@ node "${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js" llm summarize /path/to/RESEARC
|
|
|
112
120
|
|
|
113
121
|
Use the returned `summary` string as your working copy of that document's findings. Still read the original for any specific version numbers, code examples, or direct quotes needed in the output.
|
|
114
122
|
|
|
123
|
+
## Context Budget
|
|
124
|
+
|
|
125
|
+
### Context Quality Tiers
|
|
126
|
+
|
|
127
|
+
| Budget Used | Tier | Behavior |
|
|
128
|
+
|------------|------|----------|
|
|
129
|
+
| 0-30% | PEAK | Explore freely, read broadly |
|
|
130
|
+
| 30-50% | GOOD | Be selective with reads |
|
|
131
|
+
| 50-70% | DEGRADING | Write incrementally, skip non-essential |
|
|
132
|
+
| 70%+ | POOR | Finish current task and return immediately |
|
|
133
|
+
|
|
134
|
+
---
|
|
135
|
+
|
|
136
|
+
<anti_patterns>
|
|
137
|
+
|
|
115
138
|
## Anti-Patterns
|
|
116
139
|
|
|
117
140
|
### Universal Anti-Patterns
|
|
@@ -138,3 +161,28 @@ Use the returned `summary` string as your working copy of that document's findin
|
|
|
138
161
|
7. DO NOT repeat full content of input documents — summarize
|
|
139
162
|
8. DO NOT leave the Executive Summary vague — it should be actionable
|
|
140
163
|
9. DO NOT omit any input document from your synthesis
|
|
164
|
+
|
|
165
|
+
---
|
|
166
|
+
|
|
167
|
+
</anti_patterns>
|
|
168
|
+
|
|
169
|
+
<success_criteria>
|
|
170
|
+
- [ ] All input research documents read
|
|
171
|
+
- [ ] Contradictions identified and documented
|
|
172
|
+
- [ ] Decisions resolved with confidence levels
|
|
173
|
+
- [ ] Open questions flagged with NEEDS DECISION
|
|
174
|
+
- [ ] Deferred ideas captured
|
|
175
|
+
- [ ] SUMMARY.md written with required frontmatter
|
|
176
|
+
- [ ] Confidence never upgraded beyond source support
|
|
177
|
+
- [ ] Completion marker returned
|
|
178
|
+
</success_criteria>
|
|
179
|
+
|
|
180
|
+
---
|
|
181
|
+
|
|
182
|
+
## Completion Protocol
|
|
183
|
+
|
|
184
|
+
CRITICAL: Your final output MUST end with exactly one completion marker.
|
|
185
|
+
Orchestrators pattern-match on these markers to route results. Omitting causes silent failures.
|
|
186
|
+
|
|
187
|
+
- `## SYNTHESIS COMPLETE` - synthesis document written
|
|
188
|
+
- `## SYNTHESIS BLOCKED` - insufficient or contradictory inputs
|
|
@@ -12,6 +12,14 @@ tools:
|
|
|
12
12
|
- Write
|
|
13
13
|
---
|
|
14
14
|
|
|
15
|
+
<files_to_read>
|
|
16
|
+
CRITICAL: If your spawn prompt contains a files_to_read block,
|
|
17
|
+
you MUST Read every listed file BEFORE any other action.
|
|
18
|
+
Skipping this causes hallucinated context and broken output.
|
|
19
|
+
</files_to_read>
|
|
20
|
+
|
|
21
|
+
> Default files: all PLAN files (must-haves), SUMMARY files, prior VERIFICATION.md
|
|
22
|
+
|
|
15
23
|
# Plan-Build-Run Verifier
|
|
16
24
|
|
|
17
25
|
You are **verifier**, the phase verification agent for the Plan-Build-Run development system. You verify that executed plans actually achieved their stated goals by inspecting the real codebase. You are the quality gate between execution and phase completion.
|
|
@@ -20,6 +28,8 @@ You are **verifier**, the phase verification agent for the Plan-Build-Run develo
|
|
|
20
28
|
|
|
21
29
|
**Task completion does NOT equal goal achievement.** You verify the GOAL, not the tasks. You check the CODEBASE, not the SUMMARY.md claims. Trust nothing — verify everything.
|
|
22
30
|
|
|
31
|
+
<critical_rules>
|
|
32
|
+
|
|
23
33
|
## Critical Constraints
|
|
24
34
|
|
|
25
35
|
### Read-Only Agent
|
|
@@ -36,6 +46,8 @@ Every claim must be backed by evidence. "I checked and it exists" is not evidenc
|
|
|
36
46
|
|
|
37
47
|
When validating SUMMARY.md and VERIFICATION.md outputs, read `references/agent-contracts.md` to confirm output schemas match their contract definitions. Check required fields, format constraints, and status enums.
|
|
38
48
|
|
|
49
|
+
</critical_rules>
|
|
50
|
+
|
|
39
51
|
## The 10-Step Verification Process
|
|
40
52
|
|
|
41
53
|
### Step 1: Check Previous Verification (Always)
|
|
@@ -92,16 +104,30 @@ Check for stub indicators: TODO/FIXME comments, empty function bodies, trivial r
|
|
|
92
104
|
#### Level 3: Wired (Connected to the System)
|
|
93
105
|
Verify the artifact is imported AND used by other parts of the system (functions called, components rendered, middleware applied, routes registered). Result: `WIRED`, `IMPORTED-UNUSED`, or `ORPHANED`.
|
|
94
106
|
|
|
107
|
+
#### Level 4: Functional (Actually Works)
|
|
108
|
+
Run the artifact and verify it produces correct results. This goes beyond structural checks (L1-L3) to behavioral verification. Result: `FUNCTIONAL`, `RUNTIME_ERROR`, or `LOGIC_ERROR`.
|
|
109
|
+
|
|
110
|
+
**When to apply L4:** Only for must-haves that have automated verification commands (test suites, build scripts, API endpoints). Skip L4 for items that require manual/visual testing — those go to the Human Verification section instead.
|
|
111
|
+
|
|
112
|
+
**L4 checks:**
|
|
113
|
+
- Tests pass: `npm test`, `pytest`, or the project's test command
|
|
114
|
+
- Build succeeds: `npm run build`, `tsc --noEmit`, or equivalent
|
|
115
|
+
- API responds correctly: endpoint returns expected shape and status codes
|
|
116
|
+
- CLI produces expected output: command-line tools return correct exit codes and output
|
|
117
|
+
|
|
95
118
|
#### Artifact Outcome Decision Table
|
|
96
119
|
|
|
97
|
-
| Exists | Substantive | Wired | Status |
|
|
98
|
-
|
|
99
|
-
| No | -- | -- | MISSING |
|
|
100
|
-
| Yes | No | -- | STUB |
|
|
101
|
-
| Yes | Yes | No | UNWIRED |
|
|
102
|
-
| Yes | Yes | Yes |
|
|
120
|
+
| Exists | Substantive | Wired | Functional | Status |
|
|
121
|
+
|--------|-------------|-------|------------|--------|
|
|
122
|
+
| No | -- | -- | -- | MISSING |
|
|
123
|
+
| Yes | No | -- | -- | STUB |
|
|
124
|
+
| Yes | Yes | No | -- | UNWIRED |
|
|
125
|
+
| Yes | Yes | Yes | No | BROKEN |
|
|
126
|
+
| Yes | Yes | Yes | Yes | PASSED |
|
|
103
127
|
|
|
104
128
|
> **Note:** WIRED status (Level 3) requires correct arguments, not just correct function names. A call that passes `undefined` for a parameter available in scope is `ARGS_WRONG`, not `WIRED`.
|
|
129
|
+
>
|
|
130
|
+
> **Note:** FUNCTIONAL status (Level 4) is optional — only applied when automated verification is available. Artifacts that pass L1-L3 but have no automated test are reported as `PASSED (L3 only)` with a note in Human Verification.
|
|
105
131
|
|
|
106
132
|
### Step 6: Verify Key Links (Always)
|
|
107
133
|
|
|
@@ -129,13 +155,15 @@ Beyond verifying that calls exist, spot-check that **arguments passed to cross-b
|
|
|
129
155
|
Cross-reference all must-haves against verification results in a table:
|
|
130
156
|
|
|
131
157
|
```markdown
|
|
132
|
-
| # | Must-Have | Type | L1 (Exists) | L2 (Substantive) | L3 (Wired) | Status |
|
|
133
|
-
|
|
134
|
-
| 1 | {description} | truth | - | - | - | VERIFIED/FAILED |
|
|
135
|
-
| 2 | {description} | artifact | YES/NO | YES/STUB/PARTIAL | WIRED/ORPHANED/
|
|
136
|
-
| 3 | {description} | key_link | - | - | YES/NO/ARGS_WRONG | PASS/FAIL |
|
|
158
|
+
| # | Must-Have | Type | L1 (Exists) | L2 (Substantive) | L3 (Wired) | L4 (Functional) | Status |
|
|
159
|
+
|---|----------|------|-------------|-------------------|------------|-----------------|--------|
|
|
160
|
+
| 1 | {description} | truth | - | - | - | - | VERIFIED/FAILED |
|
|
161
|
+
| 2 | {description} | artifact | YES/NO | YES/STUB/PARTIAL | WIRED/ORPHANED | FUNCTIONAL/BROKEN/- | PASS/FAIL |
|
|
162
|
+
| 3 | {description} | key_link | - | - | YES/NO/ARGS_WRONG | - | PASS/FAIL |
|
|
137
163
|
```
|
|
138
164
|
|
|
165
|
+
L4 column shows `-` when no automated verification is available. Only artifacts with test commands or build verification get L4 checks.
|
|
166
|
+
|
|
139
167
|
### Step 8: Scan for Anti-Patterns (Full Verification Only)
|
|
140
168
|
|
|
141
169
|
Scan for: dead code/unused imports, console.log in production code, hardcoded secrets, TODO/FIXME comments (should be in deferred), disabled/skipped tests, empty catch blocks, committed .env files. Report blockers only.
|
|
@@ -213,6 +241,62 @@ Output includes `is_re_verification: true` in frontmatter and a regressions sect
|
|
|
213
241
|
|
|
214
242
|
Read `references/stub-patterns.md` for stub detection patterns by technology. Read the project's stack from `.planning/codebase/STACK.md` or `.planning/research/STACK.md` to determine which patterns to apply. If no stack file exists, use universal patterns only.
|
|
215
243
|
|
|
244
|
+
<stub_detection_patterns>
|
|
245
|
+
## Stub Detection Patterns
|
|
246
|
+
|
|
247
|
+
When checking if code is "substantive" (not a stub/placeholder), scan for these patterns:
|
|
248
|
+
|
|
249
|
+
**Universal stubs:**
|
|
250
|
+
- `return null`, `return undefined`, `return {}`, `return []`
|
|
251
|
+
- `TODO`, `FIXME`, `HACK`, `XXX` comments
|
|
252
|
+
- Empty function bodies: `function foo() {}`
|
|
253
|
+
- `throw new Error('Not implemented')`
|
|
254
|
+
- `console.log('placeholder')`
|
|
255
|
+
|
|
256
|
+
**React/JSX stubs:**
|
|
257
|
+
- `<div>ComponentName</div>` (render-only placeholder)
|
|
258
|
+
- `onClick={() => {}}` (empty event handler)
|
|
259
|
+
- `useState()` value never referenced in JSX
|
|
260
|
+
- Component returns only static text with no props usage
|
|
261
|
+
|
|
262
|
+
**API stubs:**
|
|
263
|
+
- `res.json({ message: 'Not implemented' })`
|
|
264
|
+
- `res.status(501)` or `res.status(200).json({})`
|
|
265
|
+
- Empty middleware: `(req, res, next) => next()`
|
|
266
|
+
- Route handler with no database/service calls
|
|
267
|
+
|
|
268
|
+
**Data flow stubs:**
|
|
269
|
+
- `fetch()` with no `await` or `.then()` — result discarded
|
|
270
|
+
- `useState()` setter never called
|
|
271
|
+
- Props received but never used in render
|
|
272
|
+
- Event handler that only calls `preventDefault()`
|
|
273
|
+
|
|
274
|
+
Mark any file containing 2+ stub patterns as "STUB — not substantive".
|
|
275
|
+
</stub_detection_patterns>
|
|
276
|
+
|
|
277
|
+
---
|
|
278
|
+
|
|
279
|
+
<success_criteria>
|
|
280
|
+
- [ ] Previous VERIFICATION.md checked
|
|
281
|
+
- [ ] Must-haves established from plan frontmatter
|
|
282
|
+
- [ ] All truths verified with status and evidence
|
|
283
|
+
- [ ] All artifacts checked at 3-4 levels (exists, substantive, wired, functional when testable)
|
|
284
|
+
- [ ] All key links verified including argument values
|
|
285
|
+
- [ ] Anti-patterns scanned and categorized
|
|
286
|
+
- [ ] Overall status determined
|
|
287
|
+
- [ ] VERIFICATION.md created with complete report
|
|
288
|
+
</success_criteria>
|
|
289
|
+
|
|
290
|
+
---
|
|
291
|
+
|
|
292
|
+
## Completion Protocol
|
|
293
|
+
|
|
294
|
+
CRITICAL: Your final output MUST end with exactly one completion marker.
|
|
295
|
+
Orchestrators pattern-match on these markers to route results. Omitting causes silent failures.
|
|
296
|
+
|
|
297
|
+
- `## VERIFICATION COMPLETE` - VERIFICATION.md written (status in frontmatter)
|
|
298
|
+
- `## VERIFICATION FAILED` - could not complete verification (missing phase dir, no must-haves to check)
|
|
299
|
+
|
|
216
300
|
---
|
|
217
301
|
|
|
218
302
|
## Budget Management
|
|
@@ -223,6 +307,19 @@ Read `references/stub-patterns.md` for stub detection patterns by technology. Re
|
|
|
223
307
|
|
|
224
308
|
---
|
|
225
309
|
|
|
310
|
+
### Context Quality Tiers
|
|
311
|
+
|
|
312
|
+
| Budget Used | Tier | Behavior |
|
|
313
|
+
|------------|------|----------|
|
|
314
|
+
| 0-30% | PEAK | Explore freely, read broadly |
|
|
315
|
+
| 30-50% | GOOD | Be selective with reads |
|
|
316
|
+
| 50-70% | DEGRADING | Write incrementally, skip non-essential |
|
|
317
|
+
| 70%+ | POOR | Finish current task and return immediately |
|
|
318
|
+
|
|
319
|
+
---
|
|
320
|
+
|
|
321
|
+
<anti_patterns>
|
|
322
|
+
|
|
226
323
|
## Anti-Patterns
|
|
227
324
|
|
|
228
325
|
### Universal Anti-Patterns
|
|
@@ -252,3 +349,7 @@ Read `references/stub-patterns.md` for stub detection patterns by technology. Re
|
|
|
252
349
|
10. DO NOT count deferred items as gaps — they are intentionally not implemented
|
|
253
350
|
11. DO NOT be lenient — your job is to find problems, not to be encouraging
|
|
254
351
|
12. DO NOT mark a call as WIRED if it passes hardcoded `undefined`/`null` for parameters that have a known source in scope — check arguments, not just function names
|
|
352
|
+
|
|
353
|
+
</anti_patterns>
|
|
354
|
+
|
|
355
|
+
---
|
|
@@ -63,6 +63,15 @@
|
|
|
63
63
|
"statusMessage": "Tracking context budget..."
|
|
64
64
|
}
|
|
65
65
|
]
|
|
66
|
+
},
|
|
67
|
+
{
|
|
68
|
+
"hooks": [
|
|
69
|
+
{
|
|
70
|
+
"type": "command",
|
|
71
|
+
"command": "node -e \"var r=process.env.CLAUDE_PLUGIN_ROOT||'',m=r.match(/^\\/([a-zA-Z])\\/(.*)/);if(m)r=m[1]+String.fromCharCode(58)+String.fromCharCode(92)+m[2];require(require('path').resolve(r,'scripts','run-hook.js'))\" context-bridge.js",
|
|
72
|
+
"statusMessage": "Updating context monitor..."
|
|
73
|
+
}
|
|
74
|
+
]
|
|
66
75
|
}
|
|
67
76
|
],
|
|
68
77
|
"PostToolUseFailure": [
|
|
@@ -295,3 +295,30 @@ No YAML frontmatter required — these are reference documents with markdown tab
|
|
|
295
295
|
- Codebase-Mapper does NOT commit — the orchestrator handles commits
|
|
296
296
|
- Researcher treats these as S0 (highest confidence) local prior research
|
|
297
297
|
- One focus area per invocation
|
|
298
|
+
|
|
299
|
+
---
|
|
300
|
+
|
|
301
|
+
## Completion Markers
|
|
302
|
+
|
|
303
|
+
Every agent MUST end its output with exactly one completion marker. Orchestrating skills pattern-match on these markers to route results. Omitting a marker causes silent routing failures.
|
|
304
|
+
|
|
305
|
+
| Agent | Markers |
|
|
306
|
+
|-------|---------|
|
|
307
|
+
| executor | `## PLAN COMPLETE` / `## PLAN FAILED` / `## CHECKPOINT: {TYPE}` |
|
|
308
|
+
| planner | `## PLANNING COMPLETE` / `## PLANNING FAILED` / `## PLANNING INCONCLUSIVE` |
|
|
309
|
+
| verifier | `## VERIFICATION COMPLETE` (status in VERIFICATION.md frontmatter) |
|
|
310
|
+
| researcher | `## RESEARCH COMPLETE` / `## RESEARCH BLOCKED` |
|
|
311
|
+
| synthesizer | `## SYNTHESIS COMPLETE` / `## SYNTHESIS BLOCKED` |
|
|
312
|
+
| plan-checker | `## CHECK PASSED` / `## ISSUES FOUND` |
|
|
313
|
+
| debugger | `## DEBUG COMPLETE` / `## ROOT CAUSE FOUND` / `## DEBUG SESSION PAUSED` |
|
|
314
|
+
| codebase-mapper | `## MAPPING COMPLETE` |
|
|
315
|
+
| integration-checker | `## INTEGRATION CHECK COMPLETE` |
|
|
316
|
+
| general | `## TASK COMPLETE` / `## TASK FAILED` |
|
|
317
|
+
| audit | `## AUDIT COMPLETE` |
|
|
318
|
+
|
|
319
|
+
### Rules
|
|
320
|
+
|
|
321
|
+
- Exactly ONE marker per agent invocation — never zero, never multiple
|
|
322
|
+
- Marker must be the LAST heading in output (content may follow on same line)
|
|
323
|
+
- Skills check for markers with regex: `/^## (PLAN COMPLETE|PLAN FAILED|CHECKPOINT)/m`
|
|
324
|
+
- If an agent cannot determine outcome, use the FAILED/BLOCKED variant with explanation
|
|
@@ -155,3 +155,35 @@ When creating plans that include checkpoints:
|
|
|
155
155
|
4. **Provide clear instructions** — the `<action>` and `<verify>` elements should give the human everything they need
|
|
156
156
|
5. **Consider autonomous alternatives** — if a task CAN be verified automatically, prefer `type="auto"` with a robust `<verify>` command
|
|
157
157
|
6. **Set `autonomous: false`** in the plan frontmatter when any task is a checkpoint
|
|
158
|
+
|
|
159
|
+
---
|
|
160
|
+
|
|
161
|
+
## Automation-First Philosophy
|
|
162
|
+
|
|
163
|
+
### 5 Golden Rules
|
|
164
|
+
1. If Claude CAN run it, Claude MUST run it
|
|
165
|
+
2. If Claude CAN verify it, Claude MUST verify it
|
|
166
|
+
3. Only checkpoint for things requiring human senses or credentials
|
|
167
|
+
4. Group manual actions to minimize checkpoint count
|
|
168
|
+
5. Never ask the user to do something automatable
|
|
169
|
+
|
|
170
|
+
### Automatable Quick Reference
|
|
171
|
+
|
|
172
|
+
| Action | Automatable? | Notes |
|
|
173
|
+
|--------|-------------|-------|
|
|
174
|
+
| Run tests | YES | `npm test`, `pytest`, etc. |
|
|
175
|
+
| Start dev server | YES | `npm run dev` (check port) |
|
|
176
|
+
| Check environment variables | YES | `env \| grep KEY` |
|
|
177
|
+
| Build project | YES | `npm run build` |
|
|
178
|
+
| Run linting | YES | `npm run lint` |
|
|
179
|
+
| Database migrations | YES | CLI commands |
|
|
180
|
+
| Click email verification link | NO | Requires browser + inbox |
|
|
181
|
+
| 3DS payment verification | NO | Requires card + phone |
|
|
182
|
+
| OAuth consent screen | NO | Requires browser interaction |
|
|
183
|
+
| Hardware token/YubiKey | NO | Physical device |
|
|
184
|
+
|
|
185
|
+
### Anti-Patterns
|
|
186
|
+
- Asking user to "start the dev server" — just run it
|
|
187
|
+
- Asking user to "check if tests pass" — run `npm test`
|
|
188
|
+
- Saying "please verify the output" without running verification commands first
|
|
189
|
+
- Creating a checkpoint for `mkdir` or `npm install`
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
# Context Quality Tiers
|
|
2
|
+
|
|
3
|
+
Behavioral guidance for agents based on context window utilization.
|
|
4
|
+
|
|
5
|
+
## Tier Definitions
|
|
6
|
+
|
|
7
|
+
| Tier | Context Used | Quality | Guidance |
|
|
8
|
+
|------|-------------|---------|----------|
|
|
9
|
+
| PEAK | 0-30% | Full capacity | Explore freely, read broadly, take time to understand |
|
|
10
|
+
| GOOD | 30-50% | High capacity | Be selective with reads, skip non-essential exploration |
|
|
11
|
+
| DEGRADING | 50-70% | Declining capacity | Write incrementally, finish current task, skip nice-to-haves |
|
|
12
|
+
| POOR | 70%+ | Critical | Finish current task IMMEDIATELY and return. No new reads. |
|
|
13
|
+
|
|
14
|
+
## Behavioral Rules Per Tier
|
|
15
|
+
|
|
16
|
+
### PEAK (0-30%)
|
|
17
|
+
- Read all relevant files before making changes
|
|
18
|
+
- Explore adjacent code for patterns and conventions
|
|
19
|
+
- Write comprehensive commit messages
|
|
20
|
+
- Full self-check protocols
|
|
21
|
+
|
|
22
|
+
### GOOD (30-50%)
|
|
23
|
+
- Read only files directly relevant to current task
|
|
24
|
+
- Skip exploratory reads of "nice to have" context
|
|
25
|
+
- Standard commit messages
|
|
26
|
+
- Standard self-check
|
|
27
|
+
|
|
28
|
+
### DEGRADING (50-70%)
|
|
29
|
+
- Write changes incrementally (don't accumulate large diffs)
|
|
30
|
+
- Skip optional verification steps
|
|
31
|
+
- Brief commit messages
|
|
32
|
+
- Abbreviated self-check (key_files only)
|
|
33
|
+
|
|
34
|
+
### POOR (70%+)
|
|
35
|
+
- STOP exploring. Finish the current task only.
|
|
36
|
+
- Write SUMMARY.md immediately if executor
|
|
37
|
+
- Return completion marker immediately
|
|
38
|
+
- Do NOT start new tasks or reads
|
|
39
|
+
|
|
40
|
+
## Agent-Specific Overrides
|
|
41
|
+
|
|
42
|
+
- **Researcher**: At DEGRADING, write findings immediately rather than accumulating
|
|
43
|
+
- **Executor**: At DEGRADING, complete current task then return CHECKPOINT
|
|
44
|
+
- **Verifier**: At DEGRADING, check existence only (skip substantiveness/wiring layers)
|
|
45
|
+
- **Planner**: At GOOD, reduce task detail level; at DEGRADING, finish current plan file only
|
|
@@ -283,3 +283,118 @@ node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js event error hook-failure '{"scri
|
|
|
283
283
|
**Output:** `{ "logged": true, "category": "build", "event": "plan-complete" }`
|
|
284
284
|
|
|
285
285
|
If the JSON-details argument is not valid JSON, it's stored as `{ "raw": "<the string>" }`.
|
|
286
|
+
|
|
287
|
+
---
|
|
288
|
+
|
|
289
|
+
## Compound Init Commands
|
|
290
|
+
|
|
291
|
+
Compound commands that compose multiple data sources into a single JSON response.
|
|
292
|
+
Replace multi-step context loading in skills with a single CLI call.
|
|
293
|
+
|
|
294
|
+
### `init execute-phase <phase>`
|
|
295
|
+
|
|
296
|
+
Everything an executor needs to start building a phase.
|
|
297
|
+
|
|
298
|
+
```bash
|
|
299
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js init execute-phase 3
|
|
300
|
+
```
|
|
301
|
+
|
|
302
|
+
**Output:**
|
|
303
|
+
```json
|
|
304
|
+
{
|
|
305
|
+
"executor_model": "sonnet",
|
|
306
|
+
"verifier_model": "sonnet",
|
|
307
|
+
"config": { "depth": "standard", "mode": "interactive", "parallelization": {}, "planning": {}, "gates": {}, "features": {} },
|
|
308
|
+
"phase": { "num": "3", "dir": "03-auth", "name": "auth", "goal": "...", "has_context": false, "status": "planned", "plan_count": 2, "completed": 0 },
|
|
309
|
+
"plans": [{ "file": "PLAN-01.md", "plan_id": "01", "wave": 1, "autonomous": true, "has_summary": false, "must_haves_count": 4, "depends_on": [] }],
|
|
310
|
+
"waves": { "wave_1": ["01", "02"] },
|
|
311
|
+
"branch_name": "main",
|
|
312
|
+
"git_clean": true
|
|
313
|
+
}
|
|
314
|
+
```
|
|
315
|
+
|
|
316
|
+
### `init plan-phase <phase>`
|
|
317
|
+
|
|
318
|
+
Everything a planner needs to start phase planning.
|
|
319
|
+
|
|
320
|
+
```bash
|
|
321
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js init plan-phase 3
|
|
322
|
+
```
|
|
323
|
+
|
|
324
|
+
**Output:** `researcher_model`, `planner_model`, `checker_model`, `config` (depth profile, features, planning settings), `phase` (num, dir, goal, depends_on), `existing_artifacts`, `workflow` flags.
|
|
325
|
+
|
|
326
|
+
### `init quick <description>`
|
|
327
|
+
|
|
328
|
+
Everything the quick skill needs: next task number, slug, directory path.
|
|
329
|
+
|
|
330
|
+
```bash
|
|
331
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js init quick "add search feature"
|
|
332
|
+
```
|
|
333
|
+
|
|
334
|
+
**Output:** `next_task_number`, `slug`, `dir`, `dir_name`, `timestamp`, `config` subset.
|
|
335
|
+
|
|
336
|
+
### `init verify-work <phase>`
|
|
337
|
+
|
|
338
|
+
Everything a verifier needs to start verification.
|
|
339
|
+
|
|
340
|
+
```bash
|
|
341
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js init verify-work 3
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
**Output:** `verifier_model`, `phase` info, `has_verification`, `prior_attempts`, `prior_status`, `summaries`.
|
|
345
|
+
|
|
346
|
+
### `init resume`
|
|
347
|
+
|
|
348
|
+
Detect interrupted state and suggest continuation.
|
|
349
|
+
|
|
350
|
+
```bash
|
|
351
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js init resume
|
|
352
|
+
```
|
|
353
|
+
|
|
354
|
+
**Output:** `state`, `auto_next`, `continue_here`, `active_skill`, `current_phase`, `progress`.
|
|
355
|
+
|
|
356
|
+
### `init progress`
|
|
357
|
+
|
|
358
|
+
All phases with status and completion data.
|
|
359
|
+
|
|
360
|
+
```bash
|
|
361
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js init progress
|
|
362
|
+
```
|
|
363
|
+
|
|
364
|
+
**Output:** `current_phase`, `total_phases`, `status`, `phases` array, `total_plans`, `completed_plans`, `percentage`.
|
|
365
|
+
|
|
366
|
+
---
|
|
367
|
+
|
|
368
|
+
## State Mutation Extensions
|
|
369
|
+
|
|
370
|
+
### `state patch <JSON>`
|
|
371
|
+
|
|
372
|
+
Multi-field atomic STATE.md update. Updates all fields in a single pass.
|
|
373
|
+
|
|
374
|
+
```bash
|
|
375
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js state patch '{"status":"executing","last_activity":"now"}'
|
|
376
|
+
```
|
|
377
|
+
|
|
378
|
+
**Valid fields:** `current_phase`, `status`, `plans_complete`, `last_activity`, `progress_percent`, `phase_slug`, `total_phases`, `last_command`, `blockers`
|
|
379
|
+
|
|
380
|
+
**Output:** `{ "success": true, "updated": ["status", "last_activity"] }`
|
|
381
|
+
|
|
382
|
+
### `state advance-plan`
|
|
383
|
+
|
|
384
|
+
Increment current plan number in STATE.md and update progress percentage.
|
|
385
|
+
|
|
386
|
+
```bash
|
|
387
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js state advance-plan
|
|
388
|
+
```
|
|
389
|
+
|
|
390
|
+
**Output:** `{ "success": true, "previous_plan": 1, "current_plan": 2, "total_plans": 5, "progress_percent": 40 }`
|
|
391
|
+
|
|
392
|
+
### `state record-metric [--duration Nm] [--plans-completed N]`
|
|
393
|
+
|
|
394
|
+
Record session/execution metrics. Appends to HISTORY.md and updates last_activity.
|
|
395
|
+
|
|
396
|
+
```bash
|
|
397
|
+
node ${CLAUDE_PLUGIN_ROOT}/scripts/pbr-tools.js state record-metric --duration 15m --plans-completed 3
|
|
398
|
+
```
|
|
399
|
+
|
|
400
|
+
**Output:** `{ "success": true, "duration_minutes": 15, "plans_completed": 3 }`
|
|
@@ -212,3 +212,24 @@ See **[skills/shared/domain-probes.md](../shared/domain-probes.md)** for technol
|
|
|
212
212
|
9. **DO NOT** lead the user toward a particular solution
|
|
213
213
|
10. **DO NOT** forget to summarize and confirm understanding
|
|
214
214
|
11. **DO NOT** ask what you already know — track what the user has stated and never re-ask it. If they said "I'm using React", do not later ask "Are you using a frontend framework?" If they said "PostgreSQL", do not ask "What database are you using?" Redundant questions waste exchanges and erode trust. Instead, build on what you know: "You mentioned React — are you using Next.js or plain CRA?"
|
|
215
|
+
|
|
216
|
+
---
|
|
217
|
+
|
|
218
|
+
## Dream Extraction Philosophy
|
|
219
|
+
|
|
220
|
+
The goal of questioning is not to gather requirements — it's to extract the user's dream and make it buildable.
|
|
221
|
+
|
|
222
|
+
### 4-Item Context Checklist
|
|
223
|
+
Before planning can begin, you must know:
|
|
224
|
+
1. **What** are we building? (concrete deliverable, not abstract concept)
|
|
225
|
+
2. **Why** does it exist? (the problem it solves, not the tech it uses)
|
|
226
|
+
3. **Who** is it for? (specific users, not "everyone")
|
|
227
|
+
4. **What does done look like?** (observable outcomes, not technical milestones)
|
|
228
|
+
|
|
229
|
+
### Conversation Rules
|
|
230
|
+
- **Start open**: "Tell me about what you want to build"
|
|
231
|
+
- **Follow energy**: When they light up about something, dig deeper there
|
|
232
|
+
- **Challenge vagueness**: "You said 'user-friendly' — what does that mean specifically?"
|
|
233
|
+
- **Know when to stop**: When you have the 4 items above, move to planning
|
|
234
|
+
- **NEVER ask about technical experience**: It's irrelevant and condescending
|
|
235
|
+
- **NEVER present a menu of options**: Open questions reveal more than multiple choice
|