aiwcli 0.12.3 → 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 (125) 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 -64
  11. package/dist/templates/_shared/.claude/commands/handoff.md +12 -198
  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 -0
  16. package/dist/templates/_shared/{lib-ts/handoff → handoff-system/lib}/document-generator.ts +215 -216
  17. package/dist/templates/_shared/{lib-ts/handoff → handoff-system/lib}/handoff-reader.ts +157 -158
  18. package/dist/templates/_shared/{scripts → handoff-system/scripts}/resume_handoff.ts +373 -373
  19. package/dist/templates/_shared/{scripts → handoff-system/scripts}/save_handoff.ts +469 -358
  20. package/dist/templates/_shared/handoff-system/workflows/handoff-resume.md +66 -0
  21. package/dist/templates/_shared/{workflows → 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 -183
  28. package/dist/templates/_shared/hooks-ts/session_start.ts +163 -151
  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 -130
  40. package/dist/templates/_shared/lib-ts/base/stop-words.ts +184 -184
  41. package/dist/templates/_shared/lib-ts/base/subprocess-utils.ts +56 -0
  42. package/dist/templates/_shared/lib-ts/base/utils.ts +184 -184
  43. package/dist/templates/_shared/lib-ts/context/context-formatter.ts +566 -560
  44. package/dist/templates/_shared/lib-ts/context/context-selector.ts +524 -515
  45. package/dist/templates/_shared/lib-ts/context/context-store.ts +712 -668
  46. package/dist/templates/_shared/lib-ts/context/plan-manager.ts +312 -312
  47. package/dist/templates/_shared/lib-ts/context/task-tracker.ts +185 -185
  48. package/dist/templates/_shared/lib-ts/package.json +20 -20
  49. package/dist/templates/_shared/lib-ts/templates/formatters.ts +102 -102
  50. package/dist/templates/_shared/lib-ts/templates/plan-context.ts +58 -58
  51. package/dist/templates/_shared/lib-ts/tsconfig.json +13 -13
  52. package/dist/templates/_shared/lib-ts/types.ts +186 -180
  53. package/dist/templates/_shared/scripts/resolve_context.ts +33 -33
  54. package/dist/templates/_shared/scripts/status_line.ts +690 -690
  55. package/dist/templates/cc-native/.claude/commands/{rlm → cc-native/rlm}/ask.md +136 -136
  56. package/dist/templates/cc-native/.claude/commands/{rlm → cc-native/rlm}/index.md +21 -21
  57. package/dist/templates/cc-native/.claude/commands/{rlm → cc-native/rlm}/overview.md +56 -56
  58. package/dist/templates/cc-native/.claude/commands/cc-native/specdev.md +10 -10
  59. package/dist/templates/cc-native/.windsurf/workflows/cc-native/fix.md +8 -8
  60. package/dist/templates/cc-native/.windsurf/workflows/cc-native/implement.md +8 -8
  61. package/dist/templates/cc-native/.windsurf/workflows/cc-native/research.md +8 -8
  62. package/dist/templates/cc-native/CC-NATIVE-README.md +189 -189
  63. package/dist/templates/cc-native/TEMPLATE-SCHEMA.md +304 -304
  64. package/dist/templates/cc-native/_cc-native/agents/CLAUDE.md +143 -143
  65. package/dist/templates/cc-native/_cc-native/agents/PLAN-ORCHESTRATOR.md +213 -213
  66. package/dist/templates/cc-native/_cc-native/agents/plan-questions/PLAN-QUESTIONER.md +70 -70
  67. package/dist/templates/cc-native/_cc-native/cc-native.config.json +96 -96
  68. package/dist/templates/cc-native/_cc-native/hooks/CLAUDE.md +247 -247
  69. package/dist/templates/cc-native/_cc-native/hooks/cc-native-plan-review.ts +76 -76
  70. package/dist/templates/cc-native/_cc-native/hooks/enhance_plan_post_subagent.ts +54 -54
  71. package/dist/templates/cc-native/_cc-native/hooks/enhance_plan_post_write.ts +51 -51
  72. package/dist/templates/cc-native/_cc-native/hooks/mark_questions_asked.ts +53 -53
  73. package/dist/templates/cc-native/_cc-native/hooks/plan_questions_early.ts +61 -61
  74. package/dist/templates/cc-native/_cc-native/lib-ts/agent-selection.ts +163 -163
  75. package/dist/templates/cc-native/_cc-native/lib-ts/aggregate-agents.ts +156 -156
  76. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/format.ts +597 -597
  77. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/index.ts +26 -26
  78. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/tracker.ts +107 -107
  79. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts/write.ts +119 -119
  80. package/dist/templates/cc-native/_cc-native/lib-ts/artifacts.ts +21 -21
  81. package/dist/templates/cc-native/_cc-native/lib-ts/cc-native-state.ts +319 -319
  82. package/dist/templates/cc-native/_cc-native/lib-ts/cli-output-parser.ts +144 -144
  83. package/dist/templates/cc-native/_cc-native/lib-ts/config.ts +57 -57
  84. package/dist/templates/cc-native/_cc-native/lib-ts/constants.ts +83 -83
  85. package/dist/templates/cc-native/_cc-native/lib-ts/corroboration.ts +119 -119
  86. package/dist/templates/cc-native/_cc-native/lib-ts/debug.ts +79 -79
  87. package/dist/templates/cc-native/_cc-native/lib-ts/graduation.ts +132 -132
  88. package/dist/templates/cc-native/_cc-native/lib-ts/index.ts +116 -116
  89. package/dist/templates/cc-native/_cc-native/lib-ts/json-parser.ts +168 -168
  90. package/dist/templates/cc-native/_cc-native/lib-ts/orchestrator.ts +70 -70
  91. package/dist/templates/cc-native/_cc-native/lib-ts/output-builder.ts +130 -130
  92. package/dist/templates/cc-native/_cc-native/lib-ts/plan-discovery.ts +80 -80
  93. package/dist/templates/cc-native/_cc-native/lib-ts/plan-enhancement.ts +41 -41
  94. package/dist/templates/cc-native/_cc-native/lib-ts/plan-questions.ts +101 -101
  95. package/dist/templates/cc-native/_cc-native/lib-ts/review-pipeline.ts +511 -511
  96. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/agent.ts +71 -71
  97. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/base/base-agent.ts +217 -217
  98. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/index.ts +12 -12
  99. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/claude-agent.ts +66 -65
  100. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/codex-agent.ts +184 -184
  101. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/gemini-agent.ts +39 -39
  102. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/providers/orchestrator-claude-agent.ts +196 -195
  103. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/schemas.ts +201 -201
  104. package/dist/templates/cc-native/_cc-native/lib-ts/reviewers/types.ts +21 -21
  105. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/CLAUDE.md +480 -480
  106. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/embedding-indexer.ts +287 -287
  107. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/hyde.ts +148 -148
  108. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/index.ts +54 -54
  109. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/logger.ts +58 -58
  110. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/ollama-client.ts +208 -208
  111. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/retrieval-pipeline.ts +460 -460
  112. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-indexer.ts +446 -447
  113. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-loader.ts +280 -280
  114. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/transcript-searcher.ts +274 -274
  115. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/types.ts +201 -201
  116. package/dist/templates/cc-native/_cc-native/lib-ts/rlm/vector-store.ts +278 -278
  117. package/dist/templates/cc-native/_cc-native/lib-ts/settings.ts +184 -184
  118. package/dist/templates/cc-native/_cc-native/lib-ts/state.ts +275 -275
  119. package/dist/templates/cc-native/_cc-native/lib-ts/tsconfig.json +18 -18
  120. package/dist/templates/cc-native/_cc-native/lib-ts/types.ts +329 -329
  121. package/dist/templates/cc-native/_cc-native/lib-ts/verdict.ts +72 -72
  122. package/dist/templates/cc-native/_cc-native/workflows/specdev.md +9 -9
  123. package/oclif.manifest.json +1 -1
  124. package/package.json +108 -108
  125. 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
+ }