aiwcli 0.12.6 → 0.12.7

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.
Files changed (124) hide show
  1. package/bin/dev.cmd +3 -3
  2. package/bin/dev.js +16 -16
  3. package/bin/run.cmd +3 -3
  4. package/bin/run.js +21 -21
  5. package/dist/commands/branch.js +7 -2
  6. package/dist/lib/bmad-installer.js +37 -37
  7. package/dist/lib/terminal.d.ts +2 -0
  8. package/dist/lib/terminal.js +57 -7
  9. package/dist/templates/CLAUDE.md +205 -205
  10. package/dist/templates/_shared/.claude/commands/handoff-resume.md +12 -12
  11. package/dist/templates/_shared/.claude/commands/handoff.md +12 -12
  12. package/dist/templates/_shared/.claude/settings.json +65 -65
  13. package/dist/templates/_shared/.codex/workflows/handoff.md +226 -226
  14. package/dist/templates/_shared/.windsurf/workflows/handoff.md +226 -226
  15. package/dist/templates/_shared/handoff-system/CLAUDE.md +421 -421
  16. package/dist/templates/_shared/handoff-system/lib/document-generator.ts +215 -215
  17. package/dist/templates/_shared/handoff-system/lib/handoff-reader.ts +158 -158
  18. package/dist/templates/_shared/handoff-system/scripts/resume_handoff.ts +373 -373
  19. package/dist/templates/_shared/handoff-system/scripts/save_handoff.ts +469 -469
  20. package/dist/templates/_shared/handoff-system/workflows/handoff-resume.md +66 -66
  21. package/dist/templates/_shared/handoff-system/workflows/handoff.md +254 -254
  22. package/dist/templates/_shared/hooks-ts/_utils/git-state.ts +2 -2
  23. package/dist/templates/_shared/hooks-ts/archive_plan.ts +159 -159
  24. package/dist/templates/_shared/hooks-ts/context_monitor.ts +147 -147
  25. package/dist/templates/_shared/hooks-ts/file-suggestion.ts +128 -128
  26. package/dist/templates/_shared/hooks-ts/pre_compact.ts +49 -49
  27. package/dist/templates/_shared/hooks-ts/session_end.ts +196 -196
  28. package/dist/templates/_shared/hooks-ts/session_start.ts +163 -163
  29. package/dist/templates/_shared/hooks-ts/task_create_capture.ts +48 -48
  30. package/dist/templates/_shared/hooks-ts/task_update_capture.ts +74 -74
  31. package/dist/templates/_shared/hooks-ts/user_prompt_submit.ts +93 -93
  32. package/dist/templates/_shared/lib-ts/CLAUDE.md +367 -367
  33. package/dist/templates/_shared/lib-ts/base/atomic-write.ts +138 -138
  34. package/dist/templates/_shared/lib-ts/base/constants.ts +303 -303
  35. package/dist/templates/_shared/lib-ts/base/git-state.ts +58 -58
  36. package/dist/templates/_shared/lib-ts/base/hook-utils.ts +582 -582
  37. package/dist/templates/_shared/lib-ts/base/inference.ts +301 -301
  38. package/dist/templates/_shared/lib-ts/base/logger.ts +247 -247
  39. package/dist/templates/_shared/lib-ts/base/state-io.ts +202 -202
  40. package/dist/templates/_shared/lib-ts/base/stop-words.ts +184 -184
  41. package/dist/templates/_shared/lib-ts/base/utils.ts +184 -184
  42. package/dist/templates/_shared/lib-ts/context/context-formatter.ts +566 -566
  43. package/dist/templates/_shared/lib-ts/context/context-selector.ts +524 -524
  44. package/dist/templates/_shared/lib-ts/context/context-store.ts +712 -712
  45. package/dist/templates/_shared/lib-ts/context/plan-manager.ts +312 -312
  46. package/dist/templates/_shared/lib-ts/context/task-tracker.ts +185 -185
  47. package/dist/templates/_shared/lib-ts/package.json +20 -20
  48. package/dist/templates/_shared/lib-ts/templates/formatters.ts +102 -102
  49. package/dist/templates/_shared/lib-ts/templates/plan-context.ts +58 -58
  50. package/dist/templates/_shared/lib-ts/tsconfig.json +13 -13
  51. package/dist/templates/_shared/lib-ts/types.ts +186 -186
  52. package/dist/templates/_shared/scripts/resolve_context.ts +33 -33
  53. package/dist/templates/_shared/scripts/status_line.ts +690 -690
  54. package/dist/templates/cc-native/.claude/commands/cc-native/rlm/ask.md +136 -136
  55. package/dist/templates/cc-native/.claude/commands/cc-native/rlm/index.md +21 -21
  56. package/dist/templates/cc-native/.claude/commands/cc-native/rlm/overview.md +56 -56
  57. package/dist/templates/cc-native/.claude/commands/cc-native/specdev.md +10 -10
  58. package/dist/templates/cc-native/.windsurf/workflows/cc-native/fix.md +8 -8
  59. package/dist/templates/cc-native/.windsurf/workflows/cc-native/implement.md +8 -8
  60. package/dist/templates/cc-native/.windsurf/workflows/cc-native/research.md +8 -8
  61. package/dist/templates/cc-native/CC-NATIVE-README.md +189 -189
  62. package/dist/templates/cc-native/TEMPLATE-SCHEMA.md +304 -304
  63. package/dist/templates/cc-native/_cc-native/agents/CLAUDE.md +143 -143
  64. package/dist/templates/cc-native/_cc-native/agents/PLAN-ORCHESTRATOR.md +213 -213
  65. package/dist/templates/cc-native/_cc-native/agents/plan-questions/PLAN-QUESTIONER.md +70 -70
  66. package/dist/templates/cc-native/_cc-native/cc-native.config.json +96 -96
  67. package/dist/templates/cc-native/_cc-native/hooks/CLAUDE.md +247 -247
  68. package/dist/templates/cc-native/_cc-native/hooks/cc-native-plan-review.ts +76 -76
  69. package/dist/templates/cc-native/_cc-native/hooks/enhance_plan_post_subagent.ts +54 -54
  70. package/dist/templates/cc-native/_cc-native/hooks/enhance_plan_post_write.ts +51 -51
  71. package/dist/templates/cc-native/_cc-native/hooks/mark_questions_asked.ts +53 -53
  72. package/dist/templates/cc-native/_cc-native/hooks/plan_questions_early.ts +61 -61
  73. package/dist/templates/cc-native/_cc-native/lib-ts/agent-selection.ts +163 -163
  74. package/dist/templates/cc-native/_cc-native/lib-ts/aggregate-agents.ts +156 -156
  75. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/format.ts +597 -597
  76. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/index.ts +26 -26
  77. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/tracker.ts +107 -107
  78. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/write.ts +119 -119
  79. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts.ts +21 -21
  80. package/dist/templates/cc-native/_cc-native/lib-ts/cc-native-state.ts +319 -319
  81. package/dist/templates/cc-native/_cc-native/lib-ts/cli-output-parser.ts +144 -144
  82. package/dist/templates/cc-native/_cc-native/lib-ts/config.ts +57 -57
  83. package/dist/templates/cc-native/_cc-native/lib-ts/constants.ts +83 -83
  84. package/dist/templates/cc-native/_cc-native/lib-ts/corroboration.ts +119 -119
  85. package/dist/templates/cc-native/_cc-native/lib-ts/debug.ts +79 -79
  86. package/dist/templates/cc-native/_cc-native/lib-ts/graduation.ts +132 -132
  87. package/dist/templates/cc-native/_cc-native/lib-ts/index.ts +116 -116
  88. package/dist/templates/cc-native/_cc-native/lib-ts/json-parser.ts +168 -168
  89. package/dist/templates/cc-native/_cc-native/lib-ts/orchestrator.ts +70 -70
  90. package/dist/templates/cc-native/_cc-native/lib-ts/output-builder.ts +130 -130
  91. package/dist/templates/cc-native/_cc-native/lib-ts/plan-discovery.ts +80 -80
  92. package/dist/templates/cc-native/_cc-native/lib-ts/plan-enhancement.ts +41 -41
  93. package/dist/templates/cc-native/_cc-native/lib-ts/plan-questions.ts +101 -101
  94. package/dist/templates/cc-native/_cc-native/lib-ts/review-pipeline.ts +511 -511
  95. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/agent.ts +71 -71
  96. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/base/base-agent.ts +217 -217
  97. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/index.ts +12 -12
  98. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/claude-agent.ts +66 -66
  99. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/codex-agent.ts +184 -184
  100. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/gemini-agent.ts +39 -39
  101. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/orchestrator-claude-agent.ts +196 -196
  102. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/schemas.ts +201 -201
  103. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/types.ts +21 -21
  104. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/CLAUDE.md +480 -480
  105. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/embedding-indexer.ts +287 -287
  106. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/hyde.ts +148 -148
  107. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/index.ts +54 -54
  108. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/logger.ts +58 -58
  109. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/ollama-client.ts +208 -208
  110. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/retrieval-pipeline.ts +460 -460
  111. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-indexer.ts +446 -446
  112. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-loader.ts +280 -280
  113. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-searcher.ts +274 -274
  114. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/types.ts +201 -201
  115. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/vector-store.ts +278 -278
  116. package/dist/templates/cc-native/_cc-native/lib-ts/settings.ts +184 -184
  117. package/dist/templates/cc-native/_cc-native/lib-ts/state.ts +275 -275
  118. package/dist/templates/cc-native/_cc-native/lib-ts/tsconfig.json +18 -18
  119. package/dist/templates/cc-native/_cc-native/lib-ts/types.ts +329 -329
  120. package/dist/templates/cc-native/_cc-native/lib-ts/verdict.ts +72 -72
  121. package/dist/templates/cc-native/_cc-native/workflows/specdev.md +9 -9
  122. package/oclif.manifest.json +1 -1
  123. package/package.json +108 -108
  124. package/dist/templates/cc-native/_cc-native/lib-ts/nul +0 -3
@@ -1,329 +1,329 @@
1
- /**
2
- * CC-Native plan review type definitions.
3
- * All interfaces, schemas, and prompt constants for the plan review engine.
4
- * See cc-native-plan-review-spec.md §3
5
- */
6
-
7
- // Re-export shared types used by cc-native consumers
8
- export type { ContextState, HookInput, HookOutput } from "../../_shared/lib-ts/types.js";
9
-
10
- // ---------------------------------------------------------------------------
11
- // Verdict & Decision Types
12
- // ---------------------------------------------------------------------------
13
-
14
- /** Verdict from a single reviewer */
15
- export type Verdict = "pass" | "warn" | "fail" | "error" | "skip";
16
-
17
- /** Decision after aggregating all verdicts */
18
- export type ReviewDecision = "allow" | "deny";
19
-
20
- /** Complexity level assigned by orchestrator */
21
- export type ComplexityCategory = "simple" | "medium" | "high";
22
-
23
- // ---------------------------------------------------------------------------
24
- // Review Data Structures
25
- // ---------------------------------------------------------------------------
26
-
27
- /** Dimension classification for corroboration-based verdict */
28
- export type IssueDimension =
29
- | "completeness"
30
- | "simplicity"
31
- | "security"
32
- | "performance"
33
- | "reliability"
34
- | "maintainability"
35
- | "testability"
36
- | "scope"
37
- | "feasibility"
38
- | "clarity";
39
-
40
- /** A single issue found during review */
41
- export interface ReviewIssue {
42
- severity: "high" | "medium" | "low";
43
- category: string;
44
- issue: string;
45
- suggested_fix: string;
46
- dimension?: IssueDimension;
47
- }
48
-
49
- /** A group of issues in one dimension, classified as blocking or solo */
50
- export interface DimensionGroup {
51
- dimension: IssueDimension;
52
- issues: Array<{ agent: string; issue: ReviewIssue }>;
53
- agentCount: number;
54
- threshold: number; // 2 × agentCount
55
- }
56
-
57
- /** Corroborated (blocking) group — threshold exceeded */
58
- export type CorroboratedGroup = DimensionGroup;
59
-
60
- /** Solo finding — below threshold, informational only */
61
- export type SoloFinding = DimensionGroup;
62
-
63
- /** Result of corroboration-based verdict computation */
64
- export interface CorroborationResult {
65
- blocking: CorroboratedGroup[];
66
- solo: SoloFinding[];
67
- unclassified: Array<{ agent: string; issue: ReviewIssue }>;
68
- verdict: "pass" | "warn" | "fail";
69
- }
70
-
71
- /** Normalized review data from any reviewer */
72
- export interface ReviewData {
73
- verdict: Verdict;
74
- summary: string;
75
- summary_source: "reviewer" | "default";
76
- issues: ReviewIssue[];
77
- missing_sections: string[];
78
- questions: string[];
79
- }
80
-
81
- /** Result from a single plan reviewer (Codex, Gemini, or Claude agent) */
82
- export interface ReviewerResult {
83
- name: string;
84
- ok: boolean;
85
- verdict: Verdict;
86
- data: Record<string, unknown>;
87
- raw: string;
88
- err: string;
89
- }
90
-
91
- /** Result from the plan orchestrator */
92
- export interface OrchestratorResult {
93
- complexity: ComplexityCategory;
94
- category: string;
95
- selected_agents: string[];
96
- reasoning: string;
97
- skip_reason?: string;
98
- error?: string;
99
- }
100
-
101
- /** Combined result from all review phases */
102
- export interface CombinedReviewResult {
103
- plan_hash: string;
104
- overall_verdict: Verdict;
105
- orchestration: OrchestratorResult | null;
106
- agents: Record<string, ReviewerResult>;
107
- timestamp: string;
108
- }
109
-
110
- /** Result from verdict aggregation */
111
- export interface ReviewDecisionResult {
112
- should_deny: boolean;
113
- reason: string; // "fail_veto" | "acceptable" | "no_signal"
114
- score: number;
115
- }
116
-
117
- // ---------------------------------------------------------------------------
118
- // Agent & Orchestrator Configuration
119
- // ---------------------------------------------------------------------------
120
-
121
- /** Configuration for a Claude Code review agent */
122
- export interface AgentConfig {
123
- name: string;
124
- model: string;
125
- provider: string; // e.g. "claude" | "codex" — assigned at runtime by assignModelsToAgents()
126
- focus: string;
127
- categories: string[];
128
- description: string;
129
- system_prompt: string; // Markdown body content for --system-prompt
130
- }
131
-
132
- /** Configuration for the plan orchestrator */
133
- export interface OrchestratorConfig {
134
- enabled: boolean;
135
- model: string;
136
- timeout: number;
137
- }
138
-
139
- /** Configuration for a model provider (Claude, Codex, etc.) */
140
- export interface ProviderConfig {
141
- enabled: boolean;
142
- models: string[];
143
- }
144
-
145
- /** Model provider pool configuration */
146
- export interface ModelsConfig {
147
- providers: Record<string, ProviderConfig>;
148
- }
149
-
150
- // ---------------------------------------------------------------------------
151
- // State Interfaces
152
- // ---------------------------------------------------------------------------
153
-
154
- /** A single iteration history entry */
155
- export interface IterationEntry {
156
- hash: string;
157
- verdict: string;
158
- timestamp: string;
159
- }
160
-
161
- /** Iteration tracking state (stored adjacent to plan file) */
162
- export interface IterationState {
163
- current: number;
164
- max: number;
165
- complexity: string;
166
- history: IterationEntry[];
167
- graduated: string[];
168
- passStreaks: Record<string, number>;
169
- lastPlanHash: string;
170
- lastPlanPath: string;
171
- sessionId: string;
172
- }
173
-
174
- /** CC-native state stored in context state.json under cc_native key */
175
- export interface CcNativeState {
176
- plan_review?: PlanReviewState;
177
- questions_asked?: QuestionsAskedState;
178
- stuck_detection?: StuckDetectionState;
179
- [key: string]: unknown;
180
- }
181
-
182
- /** Plan review state within cc_native */
183
- export interface PlanReviewState {
184
- plan_hash: string;
185
- reviewed_at: string;
186
- decision: string;
187
- iteration?: {
188
- current: number;
189
- max: number;
190
- complexity: string;
191
- latest_verdict?: string;
192
- };
193
- }
194
-
195
- /** Questions-asked tracking state */
196
- export interface QuestionsAskedState {
197
- asked: boolean; // Backward-compatible: true if either phase asked
198
- asked_at: string;
199
- early_questions_asked?: {
200
- asked: boolean;
201
- asked_at: string;
202
- };
203
- plan_questions_agent_asked?: {
204
- asked: boolean;
205
- asked_at: string;
206
- };
207
- }
208
-
209
- /** Stuck detection state — tracks repeated errors, file edits, and test failures */
210
- export interface StuckDetectionState {
211
- error_hashes: Record<string, number>;
212
- file_edits: Record<string, number>;
213
- test_failures: number;
214
- tool_calls_since_suggestion: number;
215
- suggestion_count: number;
216
- }
217
-
218
- // ---------------------------------------------------------------------------
219
- // Configuration
220
- // ---------------------------------------------------------------------------
221
-
222
- /** Display settings for review output formatting */
223
- export interface DisplaySettings {
224
- maxIssues: number;
225
- maxMissingSections: number;
226
- maxQuestions: number;
227
- }
228
-
229
- /** Full plan review configuration (from cc-native.config.json) */
230
- export interface PlanReviewConfig {
231
- planReview?: {
232
- enabled?: boolean;
233
- reviewers?: {
234
- codex?: { enabled?: boolean; timeout?: number; model?: string };
235
- gemini?: { enabled?: boolean; timeout?: number; model?: string };
236
- };
237
- agentReview?: {
238
- enabled?: boolean;
239
- timeout?: number;
240
- orchestrator?: { enabled?: boolean; model?: string; timeout?: number };
241
- agentSelection?: Record<string, unknown>;
242
- complexityCategories?: string[];
243
- };
244
- display?: Partial<DisplaySettings>;
245
- reviewIterations?: Record<string, number>;
246
- earlyExitOnAllPass?: boolean;
247
- };
248
- display?: Partial<DisplaySettings>;
249
- [key: string]: unknown;
250
- }
251
-
252
- // ---------------------------------------------------------------------------
253
- // Reviewer Interface
254
- // ---------------------------------------------------------------------------
255
-
256
- /** Options passed to reviewer implementations */
257
- export interface ReviewOptions {
258
- timeout: number;
259
- context_path?: string;
260
- session_name?: string;
261
- }
262
-
263
- /** Interface all reviewers must implement */
264
- export interface Reviewer {
265
- review(
266
- plan: string,
267
- schema: Record<string, unknown>,
268
- options: ReviewOptions,
269
- ): Promise<ReviewerResult>;
270
- }
271
-
272
- // ---------------------------------------------------------------------------
273
- // JSON Schemas (moved to reviewers/schemas.ts)
274
- // ---------------------------------------------------------------------------
275
- // Re-export for backwards compatibility
276
- export { REVIEW_SCHEMA, ORCHESTRATOR_SCHEMA, REVIEW_PROMPT_PREFIX, AGENT_REVIEW_PROMPT_PREFIX } from "./reviewers/schemas.js";
277
-
278
- // ---------------------------------------------------------------------------
279
- // Display Defaults
280
- // ---------------------------------------------------------------------------
281
-
282
- export const DEFAULT_DISPLAY: DisplaySettings = {
283
- maxIssues: 12,
284
- maxMissingSections: 12,
285
- maxQuestions: 12,
286
- };
287
-
288
- export const DEFAULT_SANITIZATION = {
289
- maxSessionIdLength: 32,
290
- maxTitleLength: 50,
291
- };
292
-
293
- // ---------------------------------------------------------------------------
294
- // Pipeline Types (review-pipeline.ts)
295
- // ---------------------------------------------------------------------------
296
-
297
- /** Discovered plan file with content and hash */
298
- export interface DiscoveredPlan {
299
- path: string;
300
- content: string;
301
- hash: string;
302
- }
303
-
304
- /** Input to the review pipeline */
305
- export interface PipelineInput {
306
- sessionId: string;
307
- base: string;
308
- aiwcliDir: string;
309
- transcriptPath?: string;
310
- payload: Record<string, unknown>;
311
- }
312
-
313
- /** Result from the review pipeline */
314
- export type PipelineResult =
315
- | { action: "skip"; reason: string }
316
- | { action: "block"; contextText: string; blockReason: string };
317
-
318
- /** Result of agent selection phase */
319
- export interface AgentSelectionResult {
320
- selectedAgents: AgentConfig[];
321
- mandatoryNames: Set<string>;
322
- detectedComplexity: string;
323
- }
324
-
325
- /** Result of iteration advancement after review */
326
- export interface IterationAdvancement {
327
- updatedState: IterationState;
328
- newGraduates: string[];
329
- }
1
+ /**
2
+ * CC-Native plan review type definitions.
3
+ * All interfaces, schemas, and prompt constants for the plan review engine.
4
+ * See cc-native-plan-review-spec.md §3
5
+ */
6
+
7
+ // Re-export shared types used by cc-native consumers
8
+ export type { ContextState, HookInput, HookOutput } from "../../_shared/lib-ts/types.js";
9
+
10
+ // ---------------------------------------------------------------------------
11
+ // Verdict & Decision Types
12
+ // ---------------------------------------------------------------------------
13
+
14
+ /** Verdict from a single reviewer */
15
+ export type Verdict = "pass" | "warn" | "fail" | "error" | "skip";
16
+
17
+ /** Decision after aggregating all verdicts */
18
+ export type ReviewDecision = "allow" | "deny";
19
+
20
+ /** Complexity level assigned by orchestrator */
21
+ export type ComplexityCategory = "simple" | "medium" | "high";
22
+
23
+ // ---------------------------------------------------------------------------
24
+ // Review Data Structures
25
+ // ---------------------------------------------------------------------------
26
+
27
+ /** Dimension classification for corroboration-based verdict */
28
+ export type IssueDimension =
29
+ | "completeness"
30
+ | "simplicity"
31
+ | "security"
32
+ | "performance"
33
+ | "reliability"
34
+ | "maintainability"
35
+ | "testability"
36
+ | "scope"
37
+ | "feasibility"
38
+ | "clarity";
39
+
40
+ /** A single issue found during review */
41
+ export interface ReviewIssue {
42
+ severity: "high" | "medium" | "low";
43
+ category: string;
44
+ issue: string;
45
+ suggested_fix: string;
46
+ dimension?: IssueDimension;
47
+ }
48
+
49
+ /** A group of issues in one dimension, classified as blocking or solo */
50
+ export interface DimensionGroup {
51
+ dimension: IssueDimension;
52
+ issues: Array<{ agent: string; issue: ReviewIssue }>;
53
+ agentCount: number;
54
+ threshold: number; // 2 × agentCount
55
+ }
56
+
57
+ /** Corroborated (blocking) group — threshold exceeded */
58
+ export type CorroboratedGroup = DimensionGroup;
59
+
60
+ /** Solo finding — below threshold, informational only */
61
+ export type SoloFinding = DimensionGroup;
62
+
63
+ /** Result of corroboration-based verdict computation */
64
+ export interface CorroborationResult {
65
+ blocking: CorroboratedGroup[];
66
+ solo: SoloFinding[];
67
+ unclassified: Array<{ agent: string; issue: ReviewIssue }>;
68
+ verdict: "pass" | "warn" | "fail";
69
+ }
70
+
71
+ /** Normalized review data from any reviewer */
72
+ export interface ReviewData {
73
+ verdict: Verdict;
74
+ summary: string;
75
+ summary_source: "reviewer" | "default";
76
+ issues: ReviewIssue[];
77
+ missing_sections: string[];
78
+ questions: string[];
79
+ }
80
+
81
+ /** Result from a single plan reviewer (Codex, Gemini, or Claude agent) */
82
+ export interface ReviewerResult {
83
+ name: string;
84
+ ok: boolean;
85
+ verdict: Verdict;
86
+ data: Record<string, unknown>;
87
+ raw: string;
88
+ err: string;
89
+ }
90
+
91
+ /** Result from the plan orchestrator */
92
+ export interface OrchestratorResult {
93
+ complexity: ComplexityCategory;
94
+ category: string;
95
+ selected_agents: string[];
96
+ reasoning: string;
97
+ skip_reason?: string;
98
+ error?: string;
99
+ }
100
+
101
+ /** Combined result from all review phases */
102
+ export interface CombinedReviewResult {
103
+ plan_hash: string;
104
+ overall_verdict: Verdict;
105
+ orchestration: OrchestratorResult | null;
106
+ agents: Record<string, ReviewerResult>;
107
+ timestamp: string;
108
+ }
109
+
110
+ /** Result from verdict aggregation */
111
+ export interface ReviewDecisionResult {
112
+ should_deny: boolean;
113
+ reason: string; // "fail_veto" | "acceptable" | "no_signal"
114
+ score: number;
115
+ }
116
+
117
+ // ---------------------------------------------------------------------------
118
+ // Agent & Orchestrator Configuration
119
+ // ---------------------------------------------------------------------------
120
+
121
+ /** Configuration for a Claude Code review agent */
122
+ export interface AgentConfig {
123
+ name: string;
124
+ model: string;
125
+ provider: string; // e.g. "claude" | "codex" — assigned at runtime by assignModelsToAgents()
126
+ focus: string;
127
+ categories: string[];
128
+ description: string;
129
+ system_prompt: string; // Markdown body content for --system-prompt
130
+ }
131
+
132
+ /** Configuration for the plan orchestrator */
133
+ export interface OrchestratorConfig {
134
+ enabled: boolean;
135
+ model: string;
136
+ timeout: number;
137
+ }
138
+
139
+ /** Configuration for a model provider (Claude, Codex, etc.) */
140
+ export interface ProviderConfig {
141
+ enabled: boolean;
142
+ models: string[];
143
+ }
144
+
145
+ /** Model provider pool configuration */
146
+ export interface ModelsConfig {
147
+ providers: Record<string, ProviderConfig>;
148
+ }
149
+
150
+ // ---------------------------------------------------------------------------
151
+ // State Interfaces
152
+ // ---------------------------------------------------------------------------
153
+
154
+ /** A single iteration history entry */
155
+ export interface IterationEntry {
156
+ hash: string;
157
+ verdict: string;
158
+ timestamp: string;
159
+ }
160
+
161
+ /** Iteration tracking state (stored adjacent to plan file) */
162
+ export interface IterationState {
163
+ current: number;
164
+ max: number;
165
+ complexity: string;
166
+ history: IterationEntry[];
167
+ graduated: string[];
168
+ passStreaks: Record<string, number>;
169
+ lastPlanHash: string;
170
+ lastPlanPath: string;
171
+ sessionId: string;
172
+ }
173
+
174
+ /** CC-native state stored in context state.json under cc_native key */
175
+ export interface CcNativeState {
176
+ plan_review?: PlanReviewState;
177
+ questions_asked?: QuestionsAskedState;
178
+ stuck_detection?: StuckDetectionState;
179
+ [key: string]: unknown;
180
+ }
181
+
182
+ /** Plan review state within cc_native */
183
+ export interface PlanReviewState {
184
+ plan_hash: string;
185
+ reviewed_at: string;
186
+ decision: string;
187
+ iteration?: {
188
+ current: number;
189
+ max: number;
190
+ complexity: string;
191
+ latest_verdict?: string;
192
+ };
193
+ }
194
+
195
+ /** Questions-asked tracking state */
196
+ export interface QuestionsAskedState {
197
+ asked: boolean; // Backward-compatible: true if either phase asked
198
+ asked_at: string;
199
+ early_questions_asked?: {
200
+ asked: boolean;
201
+ asked_at: string;
202
+ };
203
+ plan_questions_agent_asked?: {
204
+ asked: boolean;
205
+ asked_at: string;
206
+ };
207
+ }
208
+
209
+ /** Stuck detection state — tracks repeated errors, file edits, and test failures */
210
+ export interface StuckDetectionState {
211
+ error_hashes: Record<string, number>;
212
+ file_edits: Record<string, number>;
213
+ test_failures: number;
214
+ tool_calls_since_suggestion: number;
215
+ suggestion_count: number;
216
+ }
217
+
218
+ // ---------------------------------------------------------------------------
219
+ // Configuration
220
+ // ---------------------------------------------------------------------------
221
+
222
+ /** Display settings for review output formatting */
223
+ export interface DisplaySettings {
224
+ maxIssues: number;
225
+ maxMissingSections: number;
226
+ maxQuestions: number;
227
+ }
228
+
229
+ /** Full plan review configuration (from cc-native.config.json) */
230
+ export interface PlanReviewConfig {
231
+ planReview?: {
232
+ enabled?: boolean;
233
+ reviewers?: {
234
+ codex?: { enabled?: boolean; timeout?: number; model?: string };
235
+ gemini?: { enabled?: boolean; timeout?: number; model?: string };
236
+ };
237
+ agentReview?: {
238
+ enabled?: boolean;
239
+ timeout?: number;
240
+ orchestrator?: { enabled?: boolean; model?: string; timeout?: number };
241
+ agentSelection?: Record<string, unknown>;
242
+ complexityCategories?: string[];
243
+ };
244
+ display?: Partial<DisplaySettings>;
245
+ reviewIterations?: Record<string, number>;
246
+ earlyExitOnAllPass?: boolean;
247
+ };
248
+ display?: Partial<DisplaySettings>;
249
+ [key: string]: unknown;
250
+ }
251
+
252
+ // ---------------------------------------------------------------------------
253
+ // Reviewer Interface
254
+ // ---------------------------------------------------------------------------
255
+
256
+ /** Options passed to reviewer implementations */
257
+ export interface ReviewOptions {
258
+ timeout: number;
259
+ context_path?: string;
260
+ session_name?: string;
261
+ }
262
+
263
+ /** Interface all reviewers must implement */
264
+ export interface Reviewer {
265
+ review(
266
+ plan: string,
267
+ schema: Record<string, unknown>,
268
+ options: ReviewOptions,
269
+ ): Promise<ReviewerResult>;
270
+ }
271
+
272
+ // ---------------------------------------------------------------------------
273
+ // JSON Schemas (moved to reviewers/schemas.ts)
274
+ // ---------------------------------------------------------------------------
275
+ // Re-export for backwards compatibility
276
+ export { REVIEW_SCHEMA, ORCHESTRATOR_SCHEMA, REVIEW_PROMPT_PREFIX, AGENT_REVIEW_PROMPT_PREFIX } from "./reviewers/schemas.js";
277
+
278
+ // ---------------------------------------------------------------------------
279
+ // Display Defaults
280
+ // ---------------------------------------------------------------------------
281
+
282
+ export const DEFAULT_DISPLAY: DisplaySettings = {
283
+ maxIssues: 12,
284
+ maxMissingSections: 12,
285
+ maxQuestions: 12,
286
+ };
287
+
288
+ export const DEFAULT_SANITIZATION = {
289
+ maxSessionIdLength: 32,
290
+ maxTitleLength: 50,
291
+ };
292
+
293
+ // ---------------------------------------------------------------------------
294
+ // Pipeline Types (review-pipeline.ts)
295
+ // ---------------------------------------------------------------------------
296
+
297
+ /** Discovered plan file with content and hash */
298
+ export interface DiscoveredPlan {
299
+ path: string;
300
+ content: string;
301
+ hash: string;
302
+ }
303
+
304
+ /** Input to the review pipeline */
305
+ export interface PipelineInput {
306
+ sessionId: string;
307
+ base: string;
308
+ aiwcliDir: string;
309
+ transcriptPath?: string;
310
+ payload: Record<string, unknown>;
311
+ }
312
+
313
+ /** Result from the review pipeline */
314
+ export type PipelineResult =
315
+ | { action: "skip"; reason: string }
316
+ | { action: "block"; contextText: string; blockReason: string };
317
+
318
+ /** Result of agent selection phase */
319
+ export interface AgentSelectionResult {
320
+ selectedAgents: AgentConfig[];
321
+ mandatoryNames: Set<string>;
322
+ detectedComplexity: string;
323
+ }
324
+
325
+ /** Result of iteration advancement after review */
326
+ export interface IterationAdvancement {
327
+ updatedState: IterationState;
328
+ newGraduates: string[];
329
+ }