@zhixuan92/multi-model-agent-core 5.1.0 → 5.2.1

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 (712) hide show
  1. package/dist/bounded-execution/activity-tracker-types.d.ts +30 -15
  2. package/dist/bounded-execution/activity-tracker-types.d.ts.map +1 -1
  3. package/dist/bounded-execution/activity-tracker-types.js.map +1 -1
  4. package/dist/bounded-execution/activity-tracker.d.ts +2 -2
  5. package/dist/bounded-execution/activity-tracker.d.ts.map +1 -1
  6. package/dist/bounded-execution/activity-tracker.js +4 -5
  7. package/dist/bounded-execution/activity-tracker.js.map +1 -1
  8. package/dist/config/schema.d.ts +41 -2
  9. package/dist/config/schema.d.ts.map +1 -1
  10. package/dist/config/schema.js +1 -2
  11. package/dist/config/schema.js.map +1 -1
  12. package/dist/events/task-envelope.d.ts +5 -5
  13. package/dist/events/task-envelope.d.ts.map +1 -1
  14. package/dist/events/task-envelope.js +3 -6
  15. package/dist/events/task-envelope.js.map +1 -1
  16. package/dist/events/telemetry-uploader.d.ts +1 -1
  17. package/dist/events/telemetry-uploader.d.ts.map +1 -1
  18. package/dist/events/to-wire-record.d.ts +1 -1
  19. package/dist/events/to-wire-record.d.ts.map +1 -1
  20. package/dist/events/to-wire-record.js +1 -1
  21. package/dist/events/to-wire-record.js.map +1 -1
  22. package/dist/events/wire-schema.d.ts +34 -11
  23. package/dist/events/wire-schema.d.ts.map +1 -1
  24. package/dist/events/wire-schema.js +8 -8
  25. package/dist/events/wire-schema.js.map +1 -1
  26. package/dist/index.d.ts +13 -18
  27. package/dist/index.d.ts.map +1 -1
  28. package/dist/index.js +9 -17
  29. package/dist/index.js.map +1 -1
  30. package/dist/providers/agent-resolver.js +1 -1
  31. package/dist/providers/agent-resolver.js.map +1 -1
  32. package/dist/providers/claude-session.d.ts +2 -1
  33. package/dist/providers/claude-session.d.ts.map +1 -1
  34. package/dist/providers/claude-session.js +29 -2
  35. package/dist/providers/claude-session.js.map +1 -1
  36. package/dist/providers/codex-cli-session.d.ts +3 -2
  37. package/dist/providers/codex-cli-session.d.ts.map +1 -1
  38. package/dist/providers/codex-cli-session.js +5 -2
  39. package/dist/providers/codex-cli-session.js.map +1 -1
  40. package/dist/providers/provider-factory.d.ts +2 -2
  41. package/dist/providers/provider-factory.d.ts.map +1 -1
  42. package/dist/providers/provider-factory.js +12 -12
  43. package/dist/providers/provider-factory.js.map +1 -1
  44. package/dist/providers/runner-types.d.ts +3 -16
  45. package/dist/providers/runner-types.d.ts.map +1 -1
  46. package/dist/research/index.d.ts +11 -1
  47. package/dist/research/index.d.ts.map +1 -1
  48. package/dist/research/index.js +8 -1
  49. package/dist/research/index.js.map +1 -1
  50. package/dist/stores/context-block-tool.d.ts +2 -3
  51. package/dist/stores/context-block-tool.d.ts.map +1 -1
  52. package/dist/stores/context-block-tool.js +1 -1
  53. package/dist/stores/context-block-tool.js.map +1 -1
  54. package/dist/stores/project-context-registry.d.ts +0 -9
  55. package/dist/stores/project-context-registry.d.ts.map +1 -1
  56. package/dist/stores/project-context-registry.js +0 -4
  57. package/dist/stores/project-context-registry.js.map +1 -1
  58. package/dist/types/brief-quality-policy.d.ts.map +1 -1
  59. package/dist/types/enums.d.ts +0 -9
  60. package/dist/types/enums.d.ts.map +1 -1
  61. package/dist/types/enums.js +0 -10
  62. package/dist/types/enums.js.map +1 -1
  63. package/dist/types/run-result.d.ts +48 -23
  64. package/dist/types/run-result.d.ts.map +1 -1
  65. package/dist/types/run-result.js +3 -16
  66. package/dist/types/run-result.js.map +1 -1
  67. package/dist/types/stage-stats.d.ts +1 -1
  68. package/dist/types/stage-stats.d.ts.map +1 -1
  69. package/dist/types/stage-stats.js +2 -4
  70. package/dist/types/stage-stats.js.map +1 -1
  71. package/dist/types/task-spec.d.ts +3 -17
  72. package/dist/types/task-spec.d.ts.map +1 -1
  73. package/dist/types.d.ts +1 -1
  74. package/dist/types.d.ts.map +1 -1
  75. package/dist/unified/reviewer-output-parser.d.ts +51 -0
  76. package/dist/unified/reviewer-output-parser.d.ts.map +1 -0
  77. package/dist/unified/reviewer-output-parser.js +39 -0
  78. package/dist/unified/reviewer-output-parser.js.map +1 -0
  79. package/dist/unified/skill-loader.d.ts +9 -0
  80. package/dist/unified/skill-loader.d.ts.map +1 -0
  81. package/dist/unified/skill-loader.js +45 -0
  82. package/dist/unified/skill-loader.js.map +1 -0
  83. package/dist/unified/task-input-schema.d.ts +217 -0
  84. package/dist/unified/task-input-schema.d.ts.map +1 -0
  85. package/dist/unified/task-input-schema.js +35 -0
  86. package/dist/unified/task-input-schema.js.map +1 -0
  87. package/dist/unified/task-registry.d.ts +23 -0
  88. package/dist/unified/task-registry.d.ts.map +1 -0
  89. package/dist/unified/task-registry.js +56 -0
  90. package/dist/unified/task-registry.js.map +1 -0
  91. package/dist/unified/two-phase-pipeline.d.ts +52 -0
  92. package/dist/unified/two-phase-pipeline.d.ts.map +1 -0
  93. package/dist/unified/two-phase-pipeline.js +95 -0
  94. package/dist/unified/two-phase-pipeline.js.map +1 -0
  95. package/dist/unified/type-registry.d.ts +13 -0
  96. package/dist/unified/type-registry.d.ts.map +1 -0
  97. package/dist/unified/type-registry.js +30 -0
  98. package/dist/unified/type-registry.js.map +1 -0
  99. package/dist/unified/worktree-manager.d.ts +43 -0
  100. package/dist/unified/worktree-manager.d.ts.map +1 -0
  101. package/dist/unified/worktree-manager.js +76 -0
  102. package/dist/unified/worktree-manager.js.map +1 -0
  103. package/package.json +7 -118
  104. package/src/skills/audit/implement-plan.md +182 -0
  105. package/src/skills/audit/implement-skill.md +72 -0
  106. package/src/skills/audit/implement-spec.md +91 -0
  107. package/src/skills/audit/implement.md +123 -0
  108. package/src/skills/audit/review.md +116 -0
  109. package/src/skills/debug/implement.md +81 -0
  110. package/src/skills/debug/review.md +69 -0
  111. package/src/skills/delegate/implement.md +61 -0
  112. package/src/skills/delegate/review.md +53 -0
  113. package/src/skills/execute_plan/implement.md +67 -0
  114. package/src/skills/execute_plan/review.md +63 -0
  115. package/src/skills/investigate/implement.md +88 -0
  116. package/src/skills/investigate/review.md +71 -0
  117. package/src/skills/journal_recall/implement.md +60 -0
  118. package/src/skills/journal_recall/review.md +69 -0
  119. package/src/skills/journal_record/implement.md +62 -0
  120. package/src/skills/journal_record/review.md +65 -0
  121. package/src/skills/main/implement.md +25 -0
  122. package/src/skills/main/review.md +3 -0
  123. package/src/skills/research/implement.md +82 -0
  124. package/src/skills/research/review.md +68 -0
  125. package/src/skills/retry_tasks/implement.md +1 -0
  126. package/src/skills/retry_tasks/review.md +1 -0
  127. package/src/skills/review/implement.md +87 -0
  128. package/src/skills/review/review.md +77 -0
  129. package/dist/bounded-execution/file-artifact-check.d.ts +0 -7
  130. package/dist/bounded-execution/file-artifact-check.d.ts.map +0 -1
  131. package/dist/bounded-execution/file-artifact-check.js +0 -13
  132. package/dist/bounded-execution/file-artifact-check.js.map +0 -1
  133. package/dist/bounded-execution/progress-events-subscriber.d.ts +0 -33
  134. package/dist/bounded-execution/progress-events-subscriber.d.ts.map +0 -1
  135. package/dist/bounded-execution/progress-events-subscriber.js +0 -59
  136. package/dist/bounded-execution/progress-events-subscriber.js.map +0 -1
  137. package/dist/bounded-execution/progress-watchdog.d.ts +0 -43
  138. package/dist/bounded-execution/progress-watchdog.d.ts.map +0 -1
  139. package/dist/bounded-execution/progress-watchdog.js +0 -170
  140. package/dist/bounded-execution/progress-watchdog.js.map +0 -1
  141. package/dist/bounded-execution/real-diff.d.ts +0 -17
  142. package/dist/bounded-execution/real-diff.d.ts.map +0 -1
  143. package/dist/bounded-execution/real-diff.js +0 -59
  144. package/dist/bounded-execution/real-diff.js.map +0 -1
  145. package/dist/bounded-execution/scope-match.d.ts +0 -7
  146. package/dist/bounded-execution/scope-match.d.ts.map +0 -1
  147. package/dist/bounded-execution/scope-match.js +0 -28
  148. package/dist/bounded-execution/scope-match.js.map +0 -1
  149. package/dist/bounded-execution/stall-watchdog.d.ts +0 -18
  150. package/dist/bounded-execution/stall-watchdog.d.ts.map +0 -1
  151. package/dist/bounded-execution/stall-watchdog.js +0 -134
  152. package/dist/bounded-execution/stall-watchdog.js.map +0 -1
  153. package/dist/bounded-execution/wall-clock-guard.d.ts +0 -12
  154. package/dist/bounded-execution/wall-clock-guard.d.ts.map +0 -1
  155. package/dist/bounded-execution/wall-clock-guard.js +0 -27
  156. package/dist/bounded-execution/wall-clock-guard.js.map +0 -1
  157. package/dist/config/canonical-model-identity.d.ts +0 -9
  158. package/dist/config/canonical-model-identity.d.ts.map +0 -1
  159. package/dist/config/canonical-model-identity.js +0 -54
  160. package/dist/config/canonical-model-identity.js.map +0 -1
  161. package/dist/journal/default-schema.d.ts +0 -2
  162. package/dist/journal/default-schema.d.ts.map +0 -1
  163. package/dist/journal/default-schema.js +0 -27
  164. package/dist/journal/default-schema.js.map +0 -1
  165. package/dist/journal/types.d.ts +0 -22
  166. package/dist/journal/types.d.ts.map +0 -1
  167. package/dist/journal/types.js +0 -5
  168. package/dist/journal/types.js.map +0 -1
  169. package/dist/lifecycle/annotate-parser.d.ts +0 -11
  170. package/dist/lifecycle/annotate-parser.d.ts.map +0 -1
  171. package/dist/lifecycle/annotate-parser.js +0 -74
  172. package/dist/lifecycle/annotate-parser.js.map +0 -1
  173. package/dist/lifecycle/annotate-prompts.d.ts +0 -9
  174. package/dist/lifecycle/annotate-prompts.d.ts.map +0 -1
  175. package/dist/lifecycle/annotate-prompts.js +0 -95
  176. package/dist/lifecycle/annotate-prompts.js.map +0 -1
  177. package/dist/lifecycle/auto-commit.d.ts +0 -3
  178. package/dist/lifecycle/auto-commit.d.ts.map +0 -1
  179. package/dist/lifecycle/auto-commit.js +0 -5
  180. package/dist/lifecycle/auto-commit.js.map +0 -1
  181. package/dist/lifecycle/auto-register-context-block.d.ts +0 -11
  182. package/dist/lifecycle/auto-register-context-block.d.ts.map +0 -1
  183. package/dist/lifecycle/auto-register-context-block.js +0 -18
  184. package/dist/lifecycle/auto-register-context-block.js.map +0 -1
  185. package/dist/lifecycle/build-cancelled-result.d.ts +0 -11
  186. package/dist/lifecycle/build-cancelled-result.d.ts.map +0 -1
  187. package/dist/lifecycle/build-cancelled-result.js +0 -25
  188. package/dist/lifecycle/build-cancelled-result.js.map +0 -1
  189. package/dist/lifecycle/derive-completion.d.ts +0 -28
  190. package/dist/lifecycle/derive-completion.d.ts.map +0 -1
  191. package/dist/lifecycle/derive-completion.js +0 -79
  192. package/dist/lifecycle/derive-completion.js.map +0 -1
  193. package/dist/lifecycle/executor-output-types.d.ts +0 -53
  194. package/dist/lifecycle/executor-output-types.d.ts.map +0 -1
  195. package/dist/lifecycle/executor-output-types.js +0 -2
  196. package/dist/lifecycle/executor-output-types.js.map +0 -1
  197. package/dist/lifecycle/file-confinement-check.d.ts +0 -17
  198. package/dist/lifecycle/file-confinement-check.d.ts.map +0 -1
  199. package/dist/lifecycle/file-confinement-check.js +0 -44
  200. package/dist/lifecycle/file-confinement-check.js.map +0 -1
  201. package/dist/lifecycle/findings-parser.d.ts +0 -18
  202. package/dist/lifecycle/findings-parser.d.ts.map +0 -1
  203. package/dist/lifecycle/findings-parser.js +0 -143
  204. package/dist/lifecycle/findings-parser.js.map +0 -1
  205. package/dist/lifecycle/git-exec.d.ts +0 -62
  206. package/dist/lifecycle/git-exec.d.ts.map +0 -1
  207. package/dist/lifecycle/git-exec.js +0 -135
  208. package/dist/lifecycle/git-exec.js.map +0 -1
  209. package/dist/lifecycle/git-toplevel.d.ts +0 -12
  210. package/dist/lifecycle/git-toplevel.d.ts.map +0 -1
  211. package/dist/lifecycle/git-toplevel.js +0 -52
  212. package/dist/lifecycle/git-toplevel.js.map +0 -1
  213. package/dist/lifecycle/goal-builder.d.ts +0 -35
  214. package/dist/lifecycle/goal-builder.d.ts.map +0 -1
  215. package/dist/lifecycle/goal-builder.js +0 -56
  216. package/dist/lifecycle/goal-builder.js.map +0 -1
  217. package/dist/lifecycle/goal-preconditions.d.ts +0 -21
  218. package/dist/lifecycle/goal-preconditions.d.ts.map +0 -1
  219. package/dist/lifecycle/goal-preconditions.js +0 -33
  220. package/dist/lifecycle/goal-preconditions.js.map +0 -1
  221. package/dist/lifecycle/goal-prompts.d.ts +0 -27
  222. package/dist/lifecycle/goal-prompts.d.ts.map +0 -1
  223. package/dist/lifecycle/goal-prompts.js +0 -204
  224. package/dist/lifecycle/goal-prompts.js.map +0 -1
  225. package/dist/lifecycle/goal-report.d.ts +0 -42
  226. package/dist/lifecycle/goal-report.d.ts.map +0 -1
  227. package/dist/lifecycle/goal-report.js +0 -125
  228. package/dist/lifecycle/goal-report.js.map +0 -1
  229. package/dist/lifecycle/handlers/annotate-stage.d.ts +0 -35
  230. package/dist/lifecycle/handlers/annotate-stage.d.ts.map +0 -1
  231. package/dist/lifecycle/handlers/annotate-stage.js +0 -387
  232. package/dist/lifecycle/handlers/annotate-stage.js.map +0 -1
  233. package/dist/lifecycle/handlers/baseline-handlers.d.ts +0 -12
  234. package/dist/lifecycle/handlers/baseline-handlers.d.ts.map +0 -1
  235. package/dist/lifecycle/handlers/baseline-handlers.js +0 -281
  236. package/dist/lifecycle/handlers/baseline-handlers.js.map +0 -1
  237. package/dist/lifecycle/handlers/enrich-runtime-result.d.ts +0 -3
  238. package/dist/lifecycle/handlers/enrich-runtime-result.d.ts.map +0 -1
  239. package/dist/lifecycle/handlers/enrich-runtime-result.js +0 -239
  240. package/dist/lifecycle/handlers/enrich-runtime-result.js.map +0 -1
  241. package/dist/lifecycle/handlers/implement-stage.d.ts +0 -10
  242. package/dist/lifecycle/handlers/implement-stage.d.ts.map +0 -1
  243. package/dist/lifecycle/handlers/implement-stage.js +0 -228
  244. package/dist/lifecycle/handlers/implement-stage.js.map +0 -1
  245. package/dist/lifecycle/handlers/prepare-execution-context-handler.d.ts +0 -13
  246. package/dist/lifecycle/handlers/prepare-execution-context-handler.d.ts.map +0 -1
  247. package/dist/lifecycle/handlers/prepare-execution-context-handler.js +0 -61
  248. package/dist/lifecycle/handlers/prepare-execution-context-handler.js.map +0 -1
  249. package/dist/lifecycle/handlers/read-route-implementer.d.ts +0 -52
  250. package/dist/lifecycle/handlers/read-route-implementer.d.ts.map +0 -1
  251. package/dist/lifecycle/handlers/read-route-implementer.js +0 -109
  252. package/dist/lifecycle/handlers/read-route-implementer.js.map +0 -1
  253. package/dist/lifecycle/handlers/register-context-block-handlers.d.ts +0 -4
  254. package/dist/lifecycle/handlers/register-context-block-handlers.d.ts.map +0 -1
  255. package/dist/lifecycle/handlers/register-context-block-handlers.js +0 -35
  256. package/dist/lifecycle/handlers/register-context-block-handlers.js.map +0 -1
  257. package/dist/lifecycle/handlers/review-fix-stage.d.ts +0 -9
  258. package/dist/lifecycle/handlers/review-fix-stage.d.ts.map +0 -1
  259. package/dist/lifecycle/handlers/review-fix-stage.js +0 -75
  260. package/dist/lifecycle/handlers/review-fix-stage.js.map +0 -1
  261. package/dist/lifecycle/handlers/terminal-handlers.d.ts +0 -61
  262. package/dist/lifecycle/handlers/terminal-handlers.d.ts.map +0 -1
  263. package/dist/lifecycle/handlers/terminal-handlers.js +0 -339
  264. package/dist/lifecycle/handlers/terminal-handlers.js.map +0 -1
  265. package/dist/lifecycle/lifecycle-context.d.ts +0 -109
  266. package/dist/lifecycle/lifecycle-context.d.ts.map +0 -1
  267. package/dist/lifecycle/lifecycle-context.js +0 -2
  268. package/dist/lifecycle/lifecycle-context.js.map +0 -1
  269. package/dist/lifecycle/lifecycle-dispatcher.d.ts +0 -35
  270. package/dist/lifecycle/lifecycle-dispatcher.d.ts.map +0 -1
  271. package/dist/lifecycle/lifecycle-dispatcher.js +0 -64
  272. package/dist/lifecycle/lifecycle-dispatcher.js.map +0 -1
  273. package/dist/lifecycle/lifecycle-driver.d.ts +0 -16
  274. package/dist/lifecycle/lifecycle-driver.d.ts.map +0 -1
  275. package/dist/lifecycle/lifecycle-driver.js +0 -334
  276. package/dist/lifecycle/lifecycle-driver.js.map +0 -1
  277. package/dist/lifecycle/merge-stage-stats.d.ts +0 -62
  278. package/dist/lifecycle/merge-stage-stats.d.ts.map +0 -1
  279. package/dist/lifecycle/merge-stage-stats.js +0 -136
  280. package/dist/lifecycle/merge-stage-stats.js.map +0 -1
  281. package/dist/lifecycle/normalize-output-targets.d.ts +0 -2
  282. package/dist/lifecycle/normalize-output-targets.d.ts.map +0 -1
  283. package/dist/lifecycle/normalize-output-targets.js +0 -14
  284. package/dist/lifecycle/normalize-output-targets.js.map +0 -1
  285. package/dist/lifecycle/perform-implementation.d.ts +0 -3
  286. package/dist/lifecycle/perform-implementation.d.ts.map +0 -1
  287. package/dist/lifecycle/perform-implementation.js +0 -371
  288. package/dist/lifecycle/perform-implementation.js.map +0 -1
  289. package/dist/lifecycle/read-only-subtype-spec.d.ts +0 -18
  290. package/dist/lifecycle/read-only-subtype-spec.d.ts.map +0 -1
  291. package/dist/lifecycle/read-only-subtype-spec.js +0 -2
  292. package/dist/lifecycle/read-only-subtype-spec.js.map +0 -1
  293. package/dist/lifecycle/review-verdict-mapping.d.ts +0 -16
  294. package/dist/lifecycle/review-verdict-mapping.d.ts.map +0 -1
  295. package/dist/lifecycle/review-verdict-mapping.js +0 -24
  296. package/dist/lifecycle/review-verdict-mapping.js.map +0 -1
  297. package/dist/lifecycle/shared-compute.d.ts +0 -14
  298. package/dist/lifecycle/shared-compute.d.ts.map +0 -1
  299. package/dist/lifecycle/shared-compute.js +0 -51
  300. package/dist/lifecycle/shared-compute.js.map +0 -1
  301. package/dist/lifecycle/stage-idle-tracker.d.ts +0 -14
  302. package/dist/lifecycle/stage-idle-tracker.d.ts.map +0 -1
  303. package/dist/lifecycle/stage-idle-tracker.js +0 -17
  304. package/dist/lifecycle/stage-idle-tracker.js.map +0 -1
  305. package/dist/lifecycle/stage-io.d.ts +0 -134
  306. package/dist/lifecycle/stage-io.d.ts.map +0 -1
  307. package/dist/lifecycle/stage-io.js +0 -9
  308. package/dist/lifecycle/stage-io.js.map +0 -1
  309. package/dist/lifecycle/stage-labels.d.ts +0 -7
  310. package/dist/lifecycle/stage-labels.d.ts.map +0 -1
  311. package/dist/lifecycle/stage-labels.js +0 -19
  312. package/dist/lifecycle/stage-labels.js.map +0 -1
  313. package/dist/lifecycle/stage-plan-builder.d.ts +0 -4
  314. package/dist/lifecycle/stage-plan-builder.d.ts.map +0 -1
  315. package/dist/lifecycle/stage-plan-builder.js +0 -157
  316. package/dist/lifecycle/stage-plan-builder.js.map +0 -1
  317. package/dist/lifecycle/stage-plan-types.d.ts +0 -131
  318. package/dist/lifecycle/stage-plan-types.d.ts.map +0 -1
  319. package/dist/lifecycle/stage-plan-types.js +0 -28
  320. package/dist/lifecycle/stage-plan-types.js.map +0 -1
  321. package/dist/lifecycle/stage-progression.d.ts +0 -6
  322. package/dist/lifecycle/stage-progression.d.ts.map +0 -1
  323. package/dist/lifecycle/stage-progression.js +0 -100
  324. package/dist/lifecycle/stage-progression.js.map +0 -1
  325. package/dist/lifecycle/task-executor.d.ts +0 -24
  326. package/dist/lifecycle/task-executor.d.ts.map +0 -1
  327. package/dist/lifecycle/task-executor.js +0 -365
  328. package/dist/lifecycle/task-executor.js.map +0 -1
  329. package/dist/lifecycle/task-runner.d.ts +0 -66
  330. package/dist/lifecycle/task-runner.d.ts.map +0 -1
  331. package/dist/lifecycle/task-runner.js +0 -334
  332. package/dist/lifecycle/task-runner.js.map +0 -1
  333. package/dist/lifecycle/tool-category.d.ts +0 -2
  334. package/dist/lifecycle/tool-category.d.ts.map +0 -1
  335. package/dist/lifecycle/tool-category.js +0 -6
  336. package/dist/lifecycle/tool-category.js.map +0 -1
  337. package/dist/lifecycle/tool-config-types.d.ts +0 -32
  338. package/dist/lifecycle/tool-config-types.d.ts.map +0 -1
  339. package/dist/lifecycle/tool-config-types.js +0 -2
  340. package/dist/lifecycle/tool-config-types.js.map +0 -1
  341. package/dist/lifecycle/warm-followup.d.ts +0 -3
  342. package/dist/lifecycle/warm-followup.d.ts.map +0 -1
  343. package/dist/lifecycle/warm-followup.js +0 -16
  344. package/dist/lifecycle/warm-followup.js.map +0 -1
  345. package/dist/lifecycle/worker-output-contract.d.ts +0 -22
  346. package/dist/lifecycle/worker-output-contract.d.ts.map +0 -1
  347. package/dist/lifecycle/worker-output-contract.js +0 -91
  348. package/dist/lifecycle/worker-output-contract.js.map +0 -1
  349. package/dist/lifecycle/write-goal-lock.d.ts +0 -29
  350. package/dist/lifecycle/write-goal-lock.d.ts.map +0 -1
  351. package/dist/lifecycle/write-goal-lock.js +0 -70
  352. package/dist/lifecycle/write-goal-lock.js.map +0 -1
  353. package/dist/providers/assemble-run-result.d.ts +0 -17
  354. package/dist/providers/assemble-run-result.d.ts.map +0 -1
  355. package/dist/providers/assemble-run-result.js +0 -52
  356. package/dist/providers/assemble-run-result.js.map +0 -1
  357. package/dist/providers/skill-resolver.d.ts +0 -17
  358. package/dist/providers/skill-resolver.d.ts.map +0 -1
  359. package/dist/providers/skill-resolver.js +0 -123
  360. package/dist/providers/skill-resolver.js.map +0 -1
  361. package/dist/reporting/batch-persister.d.ts +0 -4
  362. package/dist/reporting/batch-persister.d.ts.map +0 -1
  363. package/dist/reporting/batch-persister.js +0 -11
  364. package/dist/reporting/batch-persister.js.map +0 -1
  365. package/dist/reporting/commit-stage-runner.d.ts +0 -12
  366. package/dist/reporting/commit-stage-runner.d.ts.map +0 -1
  367. package/dist/reporting/commit-stage-runner.js +0 -43
  368. package/dist/reporting/commit-stage-runner.js.map +0 -1
  369. package/dist/reporting/derive-investigate-status.d.ts +0 -15
  370. package/dist/reporting/derive-investigate-status.d.ts.map +0 -1
  371. package/dist/reporting/derive-investigate-status.js +0 -23
  372. package/dist/reporting/derive-investigate-status.js.map +0 -1
  373. package/dist/reporting/extract-fenced-json.d.ts +0 -7
  374. package/dist/reporting/extract-fenced-json.d.ts.map +0 -1
  375. package/dist/reporting/extract-fenced-json.js +0 -17
  376. package/dist/reporting/extract-fenced-json.js.map +0 -1
  377. package/dist/reporting/findings-headline.d.ts +0 -12
  378. package/dist/reporting/findings-headline.d.ts.map +0 -1
  379. package/dist/reporting/findings-headline.js +0 -40
  380. package/dist/reporting/findings-headline.js.map +0 -1
  381. package/dist/reporting/findings-outcome.d.ts +0 -13
  382. package/dist/reporting/findings-outcome.d.ts.map +0 -1
  383. package/dist/reporting/findings-outcome.js +0 -22
  384. package/dist/reporting/findings-outcome.js.map +0 -1
  385. package/dist/reporting/headline-composer.d.ts +0 -29
  386. package/dist/reporting/headline-composer.d.ts.map +0 -1
  387. package/dist/reporting/headline-composer.js +0 -10
  388. package/dist/reporting/headline-composer.js.map +0 -1
  389. package/dist/reporting/headline-templates/delegate.d.ts +0 -3
  390. package/dist/reporting/headline-templates/delegate.d.ts.map +0 -1
  391. package/dist/reporting/headline-templates/delegate.js +0 -42
  392. package/dist/reporting/headline-templates/delegate.js.map +0 -1
  393. package/dist/reporting/headline-templates/execute-plan.d.ts +0 -3
  394. package/dist/reporting/headline-templates/execute-plan.d.ts.map +0 -1
  395. package/dist/reporting/headline-templates/execute-plan.js +0 -26
  396. package/dist/reporting/headline-templates/execute-plan.js.map +0 -1
  397. package/dist/reporting/headline-templates/investigate.d.ts +0 -13
  398. package/dist/reporting/headline-templates/investigate.d.ts.map +0 -1
  399. package/dist/reporting/headline-templates/investigate.js +0 -53
  400. package/dist/reporting/headline-templates/investigate.js.map +0 -1
  401. package/dist/reporting/headline-templates/journal-recall.d.ts +0 -3
  402. package/dist/reporting/headline-templates/journal-recall.d.ts.map +0 -1
  403. package/dist/reporting/headline-templates/journal-recall.js +0 -9
  404. package/dist/reporting/headline-templates/journal-recall.js.map +0 -1
  405. package/dist/reporting/headline-templates/journal.d.ts +0 -3
  406. package/dist/reporting/headline-templates/journal.d.ts.map +0 -1
  407. package/dist/reporting/headline-templates/journal.js +0 -17
  408. package/dist/reporting/headline-templates/journal.js.map +0 -1
  409. package/dist/reporting/headline-templates/research.d.ts +0 -3
  410. package/dist/reporting/headline-templates/research.d.ts.map +0 -1
  411. package/dist/reporting/headline-templates/research.js +0 -22
  412. package/dist/reporting/headline-templates/research.js.map +0 -1
  413. package/dist/reporting/headline-text.d.ts +0 -36
  414. package/dist/reporting/headline-text.d.ts.map +0 -1
  415. package/dist/reporting/headline-text.js +0 -73
  416. package/dist/reporting/headline-text.js.map +0 -1
  417. package/dist/reporting/report-parser-slots/delegate-report.d.ts +0 -8
  418. package/dist/reporting/report-parser-slots/delegate-report.d.ts.map +0 -1
  419. package/dist/reporting/report-parser-slots/delegate-report.js +0 -12
  420. package/dist/reporting/report-parser-slots/delegate-report.js.map +0 -1
  421. package/dist/reporting/report-parser-slots/execute-plan-report.d.ts +0 -11
  422. package/dist/reporting/report-parser-slots/execute-plan-report.d.ts.map +0 -1
  423. package/dist/reporting/report-parser-slots/execute-plan-report.js +0 -7
  424. package/dist/reporting/report-parser-slots/execute-plan-report.js.map +0 -1
  425. package/dist/reporting/report-parser-slots/investigate-report.d.ts +0 -52
  426. package/dist/reporting/report-parser-slots/investigate-report.d.ts.map +0 -1
  427. package/dist/reporting/report-parser-slots/investigate-report.js +0 -307
  428. package/dist/reporting/report-parser-slots/investigate-report.js.map +0 -1
  429. package/dist/reporting/report-parser-slots/journal-report.d.ts +0 -19
  430. package/dist/reporting/report-parser-slots/journal-report.d.ts.map +0 -1
  431. package/dist/reporting/report-parser-slots/journal-report.js +0 -13
  432. package/dist/reporting/report-parser-slots/journal-report.js.map +0 -1
  433. package/dist/reporting/report-parser-slots/no-structured-report.d.ts +0 -10
  434. package/dist/reporting/report-parser-slots/no-structured-report.d.ts.map +0 -1
  435. package/dist/reporting/report-parser-slots/no-structured-report.js +0 -13
  436. package/dist/reporting/report-parser-slots/no-structured-report.js.map +0 -1
  437. package/dist/reporting/report-parser-slots/research-report.d.ts +0 -31
  438. package/dist/reporting/report-parser-slots/research-report.d.ts.map +0 -1
  439. package/dist/reporting/report-parser-slots/research-report.js +0 -50
  440. package/dist/reporting/report-parser-slots/research-report.js.map +0 -1
  441. package/dist/reporting/response-envelope-builder.d.ts +0 -32
  442. package/dist/reporting/response-envelope-builder.d.ts.map +0 -1
  443. package/dist/reporting/response-envelope-builder.js +0 -26
  444. package/dist/reporting/response-envelope-builder.js.map +0 -1
  445. package/dist/reporting/severity.d.ts +0 -62
  446. package/dist/reporting/severity.d.ts.map +0 -1
  447. package/dist/reporting/severity.js +0 -93
  448. package/dist/reporting/severity.js.map +0 -1
  449. package/dist/reporting/structured-report-parser.d.ts +0 -9
  450. package/dist/reporting/structured-report-parser.d.ts.map +0 -1
  451. package/dist/reporting/structured-report-parser.js +0 -8
  452. package/dist/reporting/structured-report-parser.js.map +0 -1
  453. package/dist/reporting/terminal-block-registrar.d.ts +0 -14
  454. package/dist/reporting/terminal-block-registrar.d.ts.map +0 -1
  455. package/dist/reporting/terminal-block-registrar.js +0 -17
  456. package/dist/reporting/terminal-block-registrar.js.map +0 -1
  457. package/dist/reporting/terminal-report-markdown.d.ts +0 -13
  458. package/dist/reporting/terminal-report-markdown.d.ts.map +0 -1
  459. package/dist/reporting/terminal-report-markdown.js +0 -31
  460. package/dist/reporting/terminal-report-markdown.js.map +0 -1
  461. package/dist/research/research-pre-loop.d.ts +0 -22
  462. package/dist/research/research-pre-loop.d.ts.map +0 -1
  463. package/dist/research/research-pre-loop.js +0 -50
  464. package/dist/research/research-pre-loop.js.map +0 -1
  465. package/dist/routing/read-route-criteria.d.ts +0 -36
  466. package/dist/routing/read-route-criteria.d.ts.map +0 -1
  467. package/dist/routing/read-route-criteria.js +0 -71
  468. package/dist/routing/read-route-criteria.js.map +0 -1
  469. package/dist/stores/batch-cache.d.ts +0 -29
  470. package/dist/stores/batch-cache.d.ts.map +0 -1
  471. package/dist/stores/batch-cache.js +0 -89
  472. package/dist/stores/batch-cache.js.map +0 -1
  473. package/dist/stores/batch-registry.d.ts +0 -138
  474. package/dist/stores/batch-registry.d.ts.map +0 -1
  475. package/dist/stores/batch-registry.js +0 -205
  476. package/dist/stores/batch-registry.js.map +0 -1
  477. package/dist/tool-surface/register-all-tools.d.ts +0 -4
  478. package/dist/tool-surface/register-all-tools.d.ts.map +0 -1
  479. package/dist/tool-surface/register-all-tools.js +0 -35
  480. package/dist/tool-surface/register-all-tools.js.map +0 -1
  481. package/dist/tool-surface/tool-surface-registry.d.ts +0 -28
  482. package/dist/tool-surface/tool-surface-registry.d.ts.map +0 -1
  483. package/dist/tool-surface/tool-surface-registry.js +0 -16
  484. package/dist/tool-surface/tool-surface-registry.js.map +0 -1
  485. package/dist/tools/audit/brief-slot.d.ts +0 -15
  486. package/dist/tools/audit/brief-slot.d.ts.map +0 -1
  487. package/dist/tools/audit/brief-slot.js +0 -69
  488. package/dist/tools/audit/brief-slot.js.map +0 -1
  489. package/dist/tools/audit/implementer-criteria.d.ts +0 -62
  490. package/dist/tools/audit/implementer-criteria.d.ts.map +0 -1
  491. package/dist/tools/audit/implementer-criteria.js +0 -121
  492. package/dist/tools/audit/implementer-criteria.js.map +0 -1
  493. package/dist/tools/audit/plan-audit-criteria.d.ts +0 -35
  494. package/dist/tools/audit/plan-audit-criteria.d.ts.map +0 -1
  495. package/dist/tools/audit/plan-audit-criteria.js +0 -159
  496. package/dist/tools/audit/plan-audit-criteria.js.map +0 -1
  497. package/dist/tools/audit/schema.d.ts +0 -61
  498. package/dist/tools/audit/schema.d.ts.map +0 -1
  499. package/dist/tools/audit/schema.js +0 -21
  500. package/dist/tools/audit/schema.js.map +0 -1
  501. package/dist/tools/audit/skill-audit-criteria.d.ts +0 -9
  502. package/dist/tools/audit/skill-audit-criteria.d.ts.map +0 -1
  503. package/dist/tools/audit/skill-audit-criteria.js +0 -52
  504. package/dist/tools/audit/skill-audit-criteria.js.map +0 -1
  505. package/dist/tools/audit/spec-audit-criteria.d.ts +0 -9
  506. package/dist/tools/audit/spec-audit-criteria.d.ts.map +0 -1
  507. package/dist/tools/audit/spec-audit-criteria.js +0 -55
  508. package/dist/tools/audit/spec-audit-criteria.js.map +0 -1
  509. package/dist/tools/audit/subtypes.d.ts +0 -4
  510. package/dist/tools/audit/subtypes.d.ts.map +0 -1
  511. package/dist/tools/audit/subtypes.js +0 -69
  512. package/dist/tools/audit/subtypes.js.map +0 -1
  513. package/dist/tools/audit/tool-config.d.ts +0 -7
  514. package/dist/tools/audit/tool-config.d.ts.map +0 -1
  515. package/dist/tools/audit/tool-config.js +0 -60
  516. package/dist/tools/audit/tool-config.js.map +0 -1
  517. package/dist/tools/criteria-types.d.ts +0 -27
  518. package/dist/tools/criteria-types.d.ts.map +0 -1
  519. package/dist/tools/criteria-types.js +0 -25
  520. package/dist/tools/criteria-types.js.map +0 -1
  521. package/dist/tools/debug/brief-slot.d.ts +0 -15
  522. package/dist/tools/debug/brief-slot.d.ts.map +0 -1
  523. package/dist/tools/debug/brief-slot.js +0 -10
  524. package/dist/tools/debug/brief-slot.js.map +0 -1
  525. package/dist/tools/debug/implementer-criteria.d.ts +0 -45
  526. package/dist/tools/debug/implementer-criteria.d.ts.map +0 -1
  527. package/dist/tools/debug/implementer-criteria.js +0 -97
  528. package/dist/tools/debug/implementer-criteria.js.map +0 -1
  529. package/dist/tools/debug/schema.d.ts +0 -60
  530. package/dist/tools/debug/schema.d.ts.map +0 -1
  531. package/dist/tools/debug/schema.js +0 -17
  532. package/dist/tools/debug/schema.js.map +0 -1
  533. package/dist/tools/debug/subtypes.d.ts +0 -4
  534. package/dist/tools/debug/subtypes.d.ts.map +0 -1
  535. package/dist/tools/debug/subtypes.js +0 -26
  536. package/dist/tools/debug/subtypes.js.map +0 -1
  537. package/dist/tools/debug/tool-config.d.ts +0 -7
  538. package/dist/tools/debug/tool-config.d.ts.map +0 -1
  539. package/dist/tools/debug/tool-config.js +0 -55
  540. package/dist/tools/debug/tool-config.js.map +0 -1
  541. package/dist/tools/delegate/brief-slot.d.ts +0 -20
  542. package/dist/tools/delegate/brief-slot.d.ts.map +0 -1
  543. package/dist/tools/delegate/brief-slot.js +0 -31
  544. package/dist/tools/delegate/brief-slot.js.map +0 -1
  545. package/dist/tools/delegate/implementer-criteria.d.ts +0 -53
  546. package/dist/tools/delegate/implementer-criteria.d.ts.map +0 -1
  547. package/dist/tools/delegate/implementer-criteria.js +0 -99
  548. package/dist/tools/delegate/implementer-criteria.js.map +0 -1
  549. package/dist/tools/delegate/schema.d.ts +0 -70
  550. package/dist/tools/delegate/schema.d.ts.map +0 -1
  551. package/dist/tools/delegate/schema.js +0 -24
  552. package/dist/tools/delegate/schema.js.map +0 -1
  553. package/dist/tools/delegate/tool-config.d.ts +0 -7
  554. package/dist/tools/delegate/tool-config.d.ts.map +0 -1
  555. package/dist/tools/delegate/tool-config.js +0 -47
  556. package/dist/tools/delegate/tool-config.js.map +0 -1
  557. package/dist/tools/execute-plan/barrel.d.ts +0 -2
  558. package/dist/tools/execute-plan/barrel.d.ts.map +0 -1
  559. package/dist/tools/execute-plan/barrel.js +0 -7
  560. package/dist/tools/execute-plan/barrel.js.map +0 -1
  561. package/dist/tools/execute-plan/brief-slot.d.ts +0 -25
  562. package/dist/tools/execute-plan/brief-slot.d.ts.map +0 -1
  563. package/dist/tools/execute-plan/brief-slot.js +0 -124
  564. package/dist/tools/execute-plan/brief-slot.js.map +0 -1
  565. package/dist/tools/execute-plan/implementer-criteria.d.ts +0 -57
  566. package/dist/tools/execute-plan/implementer-criteria.d.ts.map +0 -1
  567. package/dist/tools/execute-plan/implementer-criteria.js +0 -108
  568. package/dist/tools/execute-plan/implementer-criteria.js.map +0 -1
  569. package/dist/tools/execute-plan/plan-extractor.d.ts +0 -21
  570. package/dist/tools/execute-plan/plan-extractor.d.ts.map +0 -1
  571. package/dist/tools/execute-plan/plan-extractor.js +0 -96
  572. package/dist/tools/execute-plan/plan-extractor.js.map +0 -1
  573. package/dist/tools/execute-plan/tool-config.d.ts +0 -68
  574. package/dist/tools/execute-plan/tool-config.d.ts.map +0 -1
  575. package/dist/tools/execute-plan/tool-config.js +0 -58
  576. package/dist/tools/execute-plan/tool-config.js.map +0 -1
  577. package/dist/tools/index.d.ts +0 -8
  578. package/dist/tools/index.d.ts.map +0 -1
  579. package/dist/tools/index.js +0 -14
  580. package/dist/tools/index.js.map +0 -1
  581. package/dist/tools/investigate/brief-slot.d.ts +0 -15
  582. package/dist/tools/investigate/brief-slot.d.ts.map +0 -1
  583. package/dist/tools/investigate/brief-slot.js +0 -9
  584. package/dist/tools/investigate/brief-slot.js.map +0 -1
  585. package/dist/tools/investigate/implementer-criteria.d.ts +0 -52
  586. package/dist/tools/investigate/implementer-criteria.d.ts.map +0 -1
  587. package/dist/tools/investigate/implementer-criteria.js +0 -106
  588. package/dist/tools/investigate/implementer-criteria.js.map +0 -1
  589. package/dist/tools/investigate/schema.d.ts +0 -62
  590. package/dist/tools/investigate/schema.d.ts.map +0 -1
  591. package/dist/tools/investigate/schema.js +0 -13
  592. package/dist/tools/investigate/schema.js.map +0 -1
  593. package/dist/tools/investigate/subtypes.d.ts +0 -4
  594. package/dist/tools/investigate/subtypes.d.ts.map +0 -1
  595. package/dist/tools/investigate/subtypes.js +0 -26
  596. package/dist/tools/investigate/subtypes.js.map +0 -1
  597. package/dist/tools/investigate/tool-config.d.ts +0 -8
  598. package/dist/tools/investigate/tool-config.d.ts.map +0 -1
  599. package/dist/tools/investigate/tool-config.js +0 -68
  600. package/dist/tools/investigate/tool-config.js.map +0 -1
  601. package/dist/tools/journal/recall/brief-slot.d.ts +0 -7
  602. package/dist/tools/journal/recall/brief-slot.d.ts.map +0 -1
  603. package/dist/tools/journal/recall/brief-slot.js +0 -5
  604. package/dist/tools/journal/recall/brief-slot.js.map +0 -1
  605. package/dist/tools/journal/recall/implementer-criteria.d.ts +0 -9
  606. package/dist/tools/journal/recall/implementer-criteria.d.ts.map +0 -1
  607. package/dist/tools/journal/recall/implementer-criteria.js +0 -23
  608. package/dist/tools/journal/recall/implementer-criteria.js.map +0 -1
  609. package/dist/tools/journal/recall/schema.d.ts +0 -54
  610. package/dist/tools/journal/recall/schema.d.ts.map +0 -1
  611. package/dist/tools/journal/recall/schema.js +0 -10
  612. package/dist/tools/journal/recall/schema.js.map +0 -1
  613. package/dist/tools/journal/recall/subtypes.d.ts +0 -4
  614. package/dist/tools/journal/recall/subtypes.d.ts.map +0 -1
  615. package/dist/tools/journal/recall/subtypes.js +0 -25
  616. package/dist/tools/journal/recall/subtypes.js.map +0 -1
  617. package/dist/tools/journal/recall/tool-config.d.ts +0 -8
  618. package/dist/tools/journal/recall/tool-config.d.ts.map +0 -1
  619. package/dist/tools/journal/recall/tool-config.js +0 -46
  620. package/dist/tools/journal/recall/tool-config.js.map +0 -1
  621. package/dist/tools/journal/record/brief-slot.d.ts +0 -15
  622. package/dist/tools/journal/record/brief-slot.d.ts.map +0 -1
  623. package/dist/tools/journal/record/brief-slot.js +0 -28
  624. package/dist/tools/journal/record/brief-slot.js.map +0 -1
  625. package/dist/tools/journal/record/implementer-criteria.d.ts +0 -6
  626. package/dist/tools/journal/record/implementer-criteria.d.ts.map +0 -1
  627. package/dist/tools/journal/record/implementer-criteria.js +0 -20
  628. package/dist/tools/journal/record/implementer-criteria.js.map +0 -1
  629. package/dist/tools/journal/record/schema.d.ts +0 -55
  630. package/dist/tools/journal/record/schema.d.ts.map +0 -1
  631. package/dist/tools/journal/record/schema.js +0 -12
  632. package/dist/tools/journal/record/schema.js.map +0 -1
  633. package/dist/tools/journal/record/tool-config.d.ts +0 -7
  634. package/dist/tools/journal/record/tool-config.d.ts.map +0 -1
  635. package/dist/tools/journal/record/tool-config.js +0 -47
  636. package/dist/tools/journal/record/tool-config.js.map +0 -1
  637. package/dist/tools/read-route-prompt.d.ts +0 -113
  638. package/dist/tools/read-route-prompt.d.ts.map +0 -1
  639. package/dist/tools/read-route-prompt.js +0 -86
  640. package/dist/tools/read-route-prompt.js.map +0 -1
  641. package/dist/tools/register-context-block/schema.d.ts +0 -8
  642. package/dist/tools/register-context-block/schema.d.ts.map +0 -1
  643. package/dist/tools/register-context-block/schema.js +0 -7
  644. package/dist/tools/register-context-block/schema.js.map +0 -1
  645. package/dist/tools/register-context-block/tool-config.d.ts +0 -6
  646. package/dist/tools/register-context-block/tool-config.d.ts.map +0 -1
  647. package/dist/tools/register-context-block/tool-config.js +0 -39
  648. package/dist/tools/register-context-block/tool-config.js.map +0 -1
  649. package/dist/tools/research/brief-slot.d.ts +0 -37
  650. package/dist/tools/research/brief-slot.d.ts.map +0 -1
  651. package/dist/tools/research/brief-slot.js +0 -68
  652. package/dist/tools/research/brief-slot.js.map +0 -1
  653. package/dist/tools/research/implementer-criteria.d.ts +0 -13
  654. package/dist/tools/research/implementer-criteria.d.ts.map +0 -1
  655. package/dist/tools/research/implementer-criteria.js +0 -109
  656. package/dist/tools/research/implementer-criteria.js.map +0 -1
  657. package/dist/tools/research/schema.d.ts +0 -11
  658. package/dist/tools/research/schema.d.ts.map +0 -1
  659. package/dist/tools/research/schema.js +0 -59
  660. package/dist/tools/research/schema.js.map +0 -1
  661. package/dist/tools/research/subtypes.d.ts +0 -4
  662. package/dist/tools/research/subtypes.d.ts.map +0 -1
  663. package/dist/tools/research/subtypes.js +0 -25
  664. package/dist/tools/research/subtypes.js.map +0 -1
  665. package/dist/tools/research/tool-config.d.ts +0 -8
  666. package/dist/tools/research/tool-config.d.ts.map +0 -1
  667. package/dist/tools/research/tool-config.js +0 -48
  668. package/dist/tools/research/tool-config.js.map +0 -1
  669. package/dist/tools/research/two-turn-driver.d.ts +0 -16
  670. package/dist/tools/research/two-turn-driver.d.ts.map +0 -1
  671. package/dist/tools/research/two-turn-driver.js +0 -41
  672. package/dist/tools/research/two-turn-driver.js.map +0 -1
  673. package/dist/tools/retry/brief-slot.d.ts +0 -7
  674. package/dist/tools/retry/brief-slot.d.ts.map +0 -1
  675. package/dist/tools/retry/brief-slot.js +0 -3
  676. package/dist/tools/retry/brief-slot.js.map +0 -1
  677. package/dist/tools/retry/schema.d.ts +0 -53
  678. package/dist/tools/retry/schema.d.ts.map +0 -1
  679. package/dist/tools/retry/schema.js +0 -12
  680. package/dist/tools/retry/schema.js.map +0 -1
  681. package/dist/tools/retry/tool-config.d.ts +0 -7
  682. package/dist/tools/retry/tool-config.d.ts.map +0 -1
  683. package/dist/tools/retry/tool-config.js +0 -79
  684. package/dist/tools/retry/tool-config.js.map +0 -1
  685. package/dist/tools/review/brief-slot.d.ts +0 -11
  686. package/dist/tools/review/brief-slot.d.ts.map +0 -1
  687. package/dist/tools/review/brief-slot.js +0 -23
  688. package/dist/tools/review/brief-slot.js.map +0 -1
  689. package/dist/tools/review/implementer-criteria.d.ts +0 -48
  690. package/dist/tools/review/implementer-criteria.d.ts.map +0 -1
  691. package/dist/tools/review/implementer-criteria.js +0 -108
  692. package/dist/tools/review/implementer-criteria.js.map +0 -1
  693. package/dist/tools/review/schema.d.ts +0 -64
  694. package/dist/tools/review/schema.d.ts.map +0 -1
  695. package/dist/tools/review/schema.js +0 -17
  696. package/dist/tools/review/schema.js.map +0 -1
  697. package/dist/tools/review/subtypes.d.ts +0 -4
  698. package/dist/tools/review/subtypes.d.ts.map +0 -1
  699. package/dist/tools/review/subtypes.js +0 -27
  700. package/dist/tools/review/subtypes.js.map +0 -1
  701. package/dist/tools/review/tool-config.d.ts +0 -7
  702. package/dist/tools/review/tool-config.d.ts.map +0 -1
  703. package/dist/tools/review/tool-config.js +0 -94
  704. package/dist/tools/review/tool-config.js.map +0 -1
  705. package/dist/tools/shared-output.d.ts +0 -56
  706. package/dist/tools/shared-output.d.ts.map +0 -1
  707. package/dist/tools/shared-output.js +0 -33
  708. package/dist/tools/shared-output.js.map +0 -1
  709. package/dist/types/review-policy.d.ts +0 -2
  710. package/dist/types/review-policy.d.ts.map +0 -1
  711. package/dist/types/review-policy.js +0 -2
  712. package/dist/types/review-policy.js.map +0 -1
@@ -0,0 +1,87 @@
1
+ # Review — Implementer
2
+
3
+ You are a code review agent. Examine source code for bugs, security issues, and quality problems that would block a safe merge. The maintainer accepting your verdict will NOT re-investigate before pressing merge — your output is treated as authoritative. A miss here ships to production.
4
+
5
+ ## Why This Review Exists
6
+
7
+ mma-review is the pre-merge gate. Your job is to find anything that would make the merge unsafe, including issues that look fine in the named files in isolation:
8
+ - A changed function with no test (or with a test that does not exercise the change)
9
+ - A changed signature whose direct callers were not updated
10
+ - A change that introduces a new edge case the code does not handle
11
+ - A race or concurrency hazard the change exposes
12
+ - A resource leak the change introduces
13
+ - A backward-compatibility break in a public API or wire schema
14
+ - A security regression (auth bypass, injection, untrusted input flowing to a sink, data exposure)
15
+ - A performance regression (N+1 query, unbounded loop, blocking I/O on a hot path, unnecessary deep clone)
16
+ - An implicit-contract assumption the change relies on but the contract does not state
17
+
18
+ A finding that points at any of these is high-value EVEN IF the prose of the change reads cleanly. Conversely, a stylistic nit that does not change merge safety is low-priority no matter how clean the suggested rewrite reads.
19
+
20
+ **Completion test:** would a maintainer who reads only your review and the diff (not the surrounding code) understand which changes are required, why each is required, and where each lives — well enough to apply the fix and re-merge?
21
+
22
+ ## Failure-Mode Taxonomy (10 Categories)
23
+
24
+ Apply ALL categories regardless of focus area (security/correctness/performance/style). The focus area tells you which lens to weight, but every code review must sweep the full taxonomy.
25
+
26
+ 1. **TEST GAP** — The diff changes behavior, but no test exercises the change. Either: no test file exists, OR the test file exists but the changed branch is not covered. **Always check for the natural sibling test file when reviewing source-code changes** (e.g. `src/foo.ts` -> `tests/foo.test.ts`).
27
+
28
+ 2. **CROSS-FILE RIPPLE** — A changed signature, return shape, public type, or wire schema is referenced from another file that was not updated. **If the named files change a public symbol, grep for the symbol and flag any unupdated caller.** This is the highest-value cross-file work for a code review.
29
+
30
+ 3. **PRE-EXISTING-BUG-VS-NEW-REGRESSION** — A defect exists in the named files but the diff did not introduce it. Do NOT blame the diff for prior bugs; note them in a separate "Pre-existing — out of scope" section. Conversely, if the diff DID introduce or worsen a defect, flag it as a regression. Clean separation is critical.
31
+
32
+ 4. **MISSING EDGE CASE** — The change adds a code path but does not handle null/undefined/empty/timeout/error/zero/negative inputs the path could see. Walk the change against each natural boundary value.
33
+
34
+ 5. **RACE / CONCURRENCY** — The change introduces shared state mutation, removes a lock, splits a previously-atomic operation, or adds an await between a check and an action (TOCTOU). Flag these even when no test reproduces them.
35
+
36
+ 6. **RESOURCE LEAK** — The change opens a handle (file, socket, lock, transaction, AbortController) without a guaranteed close path; or introduces an untracked promise that may reject silently.
37
+
38
+ 7. **BACKWARD-COMPAT BREAK** — The change modifies a public API, exported type, wire schema, environment variable, or CLI flag in a way that breaks existing callers. Flag and require a migration note.
39
+
40
+ 8. **SECURITY REGRESSION** — The change introduces or worsens auth bypass, injection (SQL/command/prompt), untrusted input flowing to a sink (eval/exec/HTML/SQL), data exposure, or weakened sandboxing. Apply the security lens to every change, not just security-flagged ones.
41
+
42
+ 9. **PERFORMANCE REGRESSION** — The change adds N+1 queries, unbounded loops, blocking I/O on a hot path, unnecessary deep clones, or shifts work from build/init time to request time. Apply the performance lens to every change, not just performance-flagged ones.
43
+
44
+ 10. **IMPLICIT-CONTRACT ASSUMPTION** — The changed code relies on the caller (or environment) doing X but the contract (docstring, type, README) does not state X. The change works for in-repo callers but will silently break when the contract is read literally.
45
+
46
+ ## Evidence Grounding (REQUIRED for every finding)
47
+
48
+ - Cite `file:line` (or `file:line-line` for a span) where the issue lives. Quote the exact code excerpt that demonstrates the issue — do not paraphrase.
49
+ - **Cross-file findings**: cite both the line in file A that triggers the break AND the call site in file B that breaks. If B is not in the named files but is reachable via grep on the changed symbol, name it explicitly. Cross-file findings backed by call-site references are FULLY VALID.
50
+ - **Test-gap findings**: name the test file you would expect to cover the change AND quote the diff line that has no test coverage. If no test file exists for the changed area, that itself is the finding.
51
+ - **Implicit-contract findings**: quote the line in the named file that depends on the assumption AND name the contract source (docstring, type, README) that does not state the assumption.
52
+ - If you cannot quote evidence in one of these forms, do NOT raise the finding. Note "investigation needed" in your summary instead.
53
+
54
+ ## Scope
55
+
56
+ - The named files. Behavior of direct callers/callees can be referenced when visible in those files.
57
+ - Cross-file ripples ARE in scope when the changed symbol is searchable: grep for call sites and flag any caller that would break.
58
+ - Test gaps ARE in scope: check whether the sibling test file exercises the changed behavior.
59
+ - Out of scope: speculation about untouched files unrelated to the diff; doc/spec issues (those belong in an audit, not a review); style nits when the focus area is security/correctness/performance.
60
+ - Pre-existing bugs belong in their own backlog item, not in this review. Note them in a "Pre-existing — out of scope" section if you spot them, but DO NOT mix them into the merge-blocking findings.
61
+
62
+ ## Severity Calibration
63
+
64
+ - **critical**: the merge would corrupt data, expose credentials, allow auth bypass, break a public API in production, or cause production outage. A reader who applied the fix incorrectly could ship the regression.
65
+ - **high**: the merge would introduce a real bug, security gap, or substantial regression that blocks release. Cross-file ripple where a caller is broken. Missing edge case in a code path that production traffic will hit.
66
+ - **medium**: a real issue worth fixing soon — test gap on a non-trivial change, race condition with low contention, performance regression on a non-hot path, missing edge case on an unlikely input.
67
+ - **low**: stylistic / naming / dead-code / minor-refactor opportunity. Does not change merge safety.
68
+
69
+ ## Self-Validation
70
+
71
+ Before finishing, verify against this rubric:
72
+ - Does each finding have a `file:line` citation with quoted evidence?
73
+ - Is severity calibrated to merge-safety impact, not code aesthetics?
74
+ - Are cross-file ripples on changed public symbols checked (grep for callers)?
75
+ - Are sibling test files checked for coverage of the changed behavior?
76
+ - Are pre-existing bugs separated into their own section (not mixed into merge-blocking findings)?
77
+ - Is the finding within scope (named files + cross-file ripples on changed symbols + sibling test files), or is it speculation about unrelated code?
78
+
79
+ Findings that fail any check should be downgraded or dropped. However, cross-file ripple findings backed by call-site references and test-gap findings backed by sibling-test-file references are FULLY VALID — do NOT downgrade them as "speculation about untouched files."
80
+
81
+ ## Output Format
82
+
83
+ Output exactly one JSON block:
84
+
85
+ ```json
86
+ {"findingsCount": 0, "focusArea": "<security|correctness|performance|style>", "findings": [{"severity": "critical|high|medium|low", "category": "<test-gap|cross-file-ripple|pre-existing-vs-regression|missing-edge-case|race-concurrency|resource-leak|backward-compat-break|security-regression|performance-regression|implicit-contract>", "claim": "<one sentence>", "evidence": "<quoted code>", "location": "<file:line>", "suggestion": "<fix>"}], "preExisting": ["<noted but out of scope>"]}
87
+ ```
@@ -0,0 +1,77 @@
1
+ # Review — Reviewer
2
+
3
+ You are reviewing a code review produced by another agent. Your job is to verify thoroughness, evidence accuracy, severity calibration, and scope discipline — then fix issues directly.
4
+
5
+ ## Review-Specific Checks
6
+
7
+ ### 1. Taxonomy Coverage
8
+
9
+ Did the reviewer sweep ALL 10 categories of the failure-mode taxonomy?
10
+ - Test gap
11
+ - Cross-file ripple
12
+ - Pre-existing-bug-vs-new-regression separation
13
+ - Missing edge case
14
+ - Race / concurrency
15
+ - Resource leak
16
+ - Backward-compat break
17
+ - Security regression
18
+ - Performance regression
19
+ - Implicit-contract assumption
20
+
21
+ Flag any category that was silently skipped without a "no findings for this category" note. Skipping a category entirely is the most common review failure — it means a whole class of merge-blocking issues may have been missed.
22
+
23
+ ### 2. Evidence Quality
24
+
25
+ Every finding must cite real `file:line` with quoted code:
26
+ - Does the quoted code actually appear at the cited location?
27
+ - For cross-file findings: are BOTH the change site and the broken caller cited?
28
+ - For test-gap findings: is the expected test file named AND the uncovered diff line quoted?
29
+ - For implicit-contract findings: is both the assumption line and the contract source cited?
30
+ - A finding without quoted evidence is a guess — remove or downgrade it.
31
+
32
+ ### 3. Missed Merge-Safety Issues
33
+
34
+ Scan the named files for obvious problems the reviewer overlooked:
35
+ - Changed public symbols with unchecked callers (cross-file ripple)
36
+ - Changed behavior with no sibling test coverage (test gap)
37
+ - Opened handles without close paths (resource leak)
38
+ - Shared state mutations without synchronization (race)
39
+ - Null/undefined/empty inputs on new code paths (edge case)
40
+
41
+ ### 4. Severity Calibration
42
+
43
+ Are severities proportional to actual merge-safety impact?
44
+ - Are nits marked as critical? (Over-calibrated — downgrade)
45
+ - Are regressions marked as low? (Under-calibrated — upgrade)
46
+ - Does critical correlate with data corruption, credential exposure, auth bypass, production outage?
47
+ - Does low correlate with style/naming/dead-code that does not change merge safety?
48
+
49
+ ### 5. Scope Discipline
50
+
51
+ - Are pre-existing bugs cleanly separated from new regressions? (Most common scope violation: blaming the diff for a prior bug)
52
+ - Are findings within scope (named files + cross-file ripples on changed symbols + sibling test files)?
53
+ - Are doc/spec issues excluded (those belong in an audit)?
54
+ - Are style nits excluded when the focus area is security/correctness/performance?
55
+
56
+ ### 6. Cross-File Work
57
+
58
+ - Did the reviewer grep for callers of changed public symbols?
59
+ - For each changed export/public function/type: are the call sites accounted for?
60
+ - Cross-file ripple findings backed by call-site references are FULLY VALID — do NOT downgrade them as "speculation about untouched files."
61
+
62
+ ## Fix Policy
63
+
64
+ - Remove findings with hallucinated evidence (code quote does not match file).
65
+ - Add missed merge-blocking issues the reviewer should have caught.
66
+ - Correct miscalibrated severities (nits marked critical, regressions marked low).
67
+ - Move pre-existing bugs out of merge-blocking findings into a separate note.
68
+ - Remove out-of-scope findings (doc issues, style nits when focus is correctness/security).
69
+ - Strengthen weak evidence or remove the finding.
70
+
71
+ ## Output Format (REQUIRED)
72
+
73
+ Output exactly one JSON block:
74
+
75
+ ```json
76
+ {"findings": [{"severity": "critical|high|medium|low", "category": "<taxonomy-coverage|evidence-quality|missed-issue|severity-calibration|scope-discipline|cross-file-work>", "description": "<what was wrong or missed>", "location": "<file:line or category reference>", "fix": "applied|suggested"}], "summary": "<one paragraph covering taxonomy coverage, evidence quality, calibration accuracy, and scope discipline>", "verdict": "approved|changes_made"}
77
+ ```
@@ -1,7 +0,0 @@
1
- /**
2
- * Returns the subset of `outputTargets` that do NOT exist on disk.
3
- * Empty array means all targets exist. Caller decides whether non-empty
4
- * is a failure (typically yes — surface as a structured finding).
5
- */
6
- export declare function checkOutputTargets(outputTargets: string[]): string[];
7
- //# sourceMappingURL=file-artifact-check.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"file-artifact-check.d.ts","sourceRoot":"","sources":["../../src/bounded-execution/file-artifact-check.ts"],"names":[],"mappings":"AAMA;;;;GAIG;AACH,wBAAgB,kBAAkB,CAAC,aAAa,EAAE,MAAM,EAAE,GAAG,MAAM,EAAE,CAEpE"}
@@ -1,13 +0,0 @@
1
- // Post-task verifier for declared output files.
2
- // Callers set ctx.outputTargets in task-runner; the implementer stage handler
3
- // invokes checkOutputTargets() post-task to verify each path exists on disk.
4
- import { existsSync } from 'fs';
5
- /**
6
- * Returns the subset of `outputTargets` that do NOT exist on disk.
7
- * Empty array means all targets exist. Caller decides whether non-empty
8
- * is a failure (typically yes — surface as a structured finding).
9
- */
10
- export function checkOutputTargets(outputTargets) {
11
- return outputTargets.filter((p) => !existsSync(p));
12
- }
13
- //# sourceMappingURL=file-artifact-check.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"file-artifact-check.js","sourceRoot":"","sources":["../../src/bounded-execution/file-artifact-check.ts"],"names":[],"mappings":"AAAA,gDAAgD;AAChD,8EAA8E;AAC9E,6EAA6E;AAE7E,OAAO,EAAE,UAAU,EAAE,MAAM,IAAI,CAAC;AAEhC;;;;GAIG;AACH,MAAM,UAAU,kBAAkB,CAAC,aAAuB;IACxD,OAAO,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;AACrD,CAAC"}
@@ -1,33 +0,0 @@
1
- import type { EnvelopeBus } from '../events/envelope-bus.js';
2
- import type { ActivityTracker } from './activity-tracker.js';
3
- /**
4
- * Bridges runner-emitted bus events to ActivityTracker progress counters
5
- * so the per-task polling headline updates live during a stage instead
6
- * of jumping from 0/0/0 to the final value only at stage transition.
7
- *
8
- * Pattern mirrors stall-watchdog.ts:
9
- * - Listens on EnvelopeBus for runner progress events.
10
- * - Filters by batchId + taskIndex (bus is process-wide; without filter
11
- * every task's events would increment every other task's counters).
12
- * - Calls tracker.recordFileWrite / markEvent based on event name.
13
- * - Returns a disposer; the caller MUST invoke it in a finally{} so the
14
- * subscription is released on the success path too.
15
- *
16
- * Event → tracker mapping:
17
- * claude_tool_call (Write/Edit) → recordFileWrite + markEvent('tool')
18
- * claude_tool_call (other) → markEvent('tool')
19
- * codex_command_completed → markEvent('tool')
20
- * codex_file_change → recordFileWrite + markEvent('tool')
21
- * claude_text_emission → markEvent('text')
22
- * codex_agent_message → markEvent('text')
23
- * claude_turn_started → markEvent('llm')
24
- * codex_turn_started → markEvent('llm')
25
- */
26
- export interface ProgressEventsSubscriberContext {
27
- bus: EnvelopeBus;
28
- tracker: ActivityTracker;
29
- batchId?: string;
30
- taskIndex?: number;
31
- }
32
- export declare function startProgressEventsSubscriber(ctx: ProgressEventsSubscriberContext): () => void;
33
- //# sourceMappingURL=progress-events-subscriber.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"progress-events-subscriber.d.ts","sourceRoot":"","sources":["../../src/bounded-execution/progress-events-subscriber.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAE7D;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,WAAW,+BAA+B;IAC9C,GAAG,EAAE,WAAW,CAAC;IACjB,OAAO,EAAE,eAAe,CAAC;IACzB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAKD,wBAAgB,6BAA6B,CAC3C,GAAG,EAAE,+BAA+B,GACnC,MAAM,IAAI,CAsDZ"}
@@ -1,59 +0,0 @@
1
- const READ_TOOLS = new Set(['Read']);
2
- const WRITE_TOOLS = new Set(['Write', 'Edit', 'MultiEdit', 'NotebookEdit']);
3
- export function startProgressEventsSubscriber(ctx) {
4
- const handler = (event) => {
5
- const eventName = typeof event.event === 'string' ? event.event : '';
6
- if (!eventName)
7
- return;
8
- // Filter by task identity — same logic as stall-watchdog.ts.
9
- if (ctx.batchId !== undefined && event['batchId'] !== ctx.batchId)
10
- return;
11
- if (ctx.taskIndex !== undefined && event['taskIndex'] !== ctx.taskIndex)
12
- return;
13
- switch (eventName) {
14
- case 'claude_tool_call': {
15
- const tool = typeof event['tool'] === 'string' ? event['tool'] : '';
16
- if (WRITE_TOOLS.has(tool))
17
- ctx.tracker.recordFileWrite();
18
- ctx.tracker.markEvent('tool');
19
- return;
20
- }
21
- case 'codex_command_completed': {
22
- ctx.tracker.markEvent('tool');
23
- return;
24
- }
25
- case 'codex_file_change': {
26
- ctx.tracker.recordFileWrite();
27
- ctx.tracker.markEvent('tool');
28
- return;
29
- }
30
- case 'claude_text_emission':
31
- case 'codex_agent_message': {
32
- ctx.tracker.markEvent('text');
33
- return;
34
- }
35
- case 'claude_turn_started':
36
- case 'codex_turn_started': {
37
- ctx.tracker.markEvent('llm');
38
- return;
39
- }
40
- default:
41
- return;
42
- }
43
- };
44
- // EnvelopeBus replaces the old EventEmitter on/off API with subscribe().
45
- // The subscriber receives BusMessage; only envelope snapshots are relevant
46
- // here, so map them into the handler's old event shape on the fly.
47
- const sub = ctx.bus.subscribe({
48
- name: 'progress-events-subscriber',
49
- receive(msg) {
50
- if (msg.type === 'envelope') {
51
- // Synthesize a coarse "envelope_updated" event for the handler so it
52
- // still has a reason to refresh its progress signal.
53
- handler({ event: 'envelope_updated', reason: msg.reason });
54
- }
55
- },
56
- });
57
- return () => { sub(); };
58
- }
59
- //# sourceMappingURL=progress-events-subscriber.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"progress-events-subscriber.js","sourceRoot":"","sources":["../../src/bounded-execution/progress-events-subscriber.ts"],"names":[],"mappings":"AAiCA,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;AACrC,MAAM,WAAW,GAAG,IAAI,GAAG,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,cAAc,CAAC,CAAC,CAAC;AAE5E,MAAM,UAAU,6BAA6B,CAC3C,GAAoC;IAEpC,MAAM,OAAO,GAAG,CAAC,KAA8B,EAAE,EAAE;QACjD,MAAM,SAAS,GAAG,OAAO,KAAK,CAAC,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC;QACrE,IAAI,CAAC,SAAS;YAAE,OAAO;QAEvB,6DAA6D;QAC7D,IAAI,GAAG,CAAC,OAAO,KAAK,SAAS,IAAI,KAAK,CAAC,SAAS,CAAC,KAAK,GAAG,CAAC,OAAO;YAAE,OAAO;QAC1E,IAAI,GAAG,CAAC,SAAS,KAAK,SAAS,IAAI,KAAK,CAAC,WAAW,CAAC,KAAK,GAAG,CAAC,SAAS;YAAE,OAAO;QAEhF,QAAQ,SAAS,EAAE,CAAC;YAClB,KAAK,kBAAkB,CAAC,CAAC,CAAC;gBACxB,MAAM,IAAI,GAAG,OAAO,KAAK,CAAC,MAAM,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;gBACpE,IAAI,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC;oBAAE,GAAG,CAAC,OAAO,CAAC,eAAe,EAAE,CAAC;gBACzD,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAC9B,OAAO;YACT,CAAC;YACD,KAAK,yBAAyB,CAAC,CAAC,CAAC;gBAC/B,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAC9B,OAAO;YACT,CAAC;YACD,KAAK,mBAAmB,CAAC,CAAC,CAAC;gBACzB,GAAG,CAAC,OAAO,CAAC,eAAe,EAAE,CAAC;gBAC9B,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAC9B,OAAO;YACT,CAAC;YACD,KAAK,sBAAsB,CAAC;YAC5B,KAAK,qBAAqB,CAAC,CAAC,CAAC;gBAC3B,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;gBAC9B,OAAO;YACT,CAAC;YACD,KAAK,qBAAqB,CAAC;YAC3B,KAAK,oBAAoB,CAAC,CAAC,CAAC;gBAC1B,GAAG,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;gBAC7B,OAAO;YACT,CAAC;YACD;gBACE,OAAO;QACX,CAAC;IACH,CAAC,CAAC;IAEF,yEAAyE;IACzE,2EAA2E;IAC3E,mEAAmE;IACnE,MAAM,GAAG,GAAG,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC;QAC5B,IAAI,EAAE,4BAA4B;QAClC,OAAO,CAAC,GAAG;YACT,IAAI,GAAG,CAAC,IAAI,KAAK,UAAU,EAAE,CAAC;gBAC5B,qEAAqE;gBACrE,qDAAqD;gBACrD,OAAO,CAAC,EAAE,KAAK,EAAE,kBAAkB,EAAE,MAAM,EAAE,GAAG,CAAC,MAAM,EAAE,CAAC,CAAC;YAC7D,CAAC;QACH,CAAC;KACF,CAAC,CAAC;IACH,OAAO,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC;AAC1B,CAAC"}
@@ -1,43 +0,0 @@
1
- import type { LifecycleState } from '../lifecycle/stage-plan-types.js';
2
- export interface ProgressWatchdogConfig {
3
- enabled: boolean;
4
- thrashTurns: number;
5
- thrashWallClockMs: number;
6
- thrashSoftWallClockMs: number;
7
- }
8
- export interface ProgressWatchdogContext {
9
- state: LifecycleState;
10
- controller: AbortController;
11
- emit: (event: Record<string, unknown>) => void;
12
- config: ProgressWatchdogConfig;
13
- taskIndex: number;
14
- batchId?: string;
15
- /** State the watchdog mutates: `fired` so post-hoc code knows the abort came from us. */
16
- state2: {
17
- fired: boolean;
18
- };
19
- }
20
- /**
21
- * Starts the progress watchdog. Returns a disposer that MUST be called in a
22
- * finally{} block. Mirrors startStallWatchdog(): same shape, single function
23
- * call, returns cleanup. The watchdog polls on a setInterval; when conditions
24
- * trip, it fires `controller.abort()` to interrupt the in-flight session.send().
25
- *
26
- * Post-hoc signals (turn-count thrash detection and scope-violation analysis)
27
- * are handled by recordPostHocSignals() below, called AFTER session.send()
28
- * returns. They mutate state for the annotator to consume.
29
- */
30
- export declare function startProgressWatchdog(ctx: ProgressWatchdogContext): () => void;
31
- /**
32
- * Post-hoc finalization called AFTER session.send() returns. Three things:
33
- *
34
- * 1. Turn-count thrash detection (since we can't observe turns mid-flight).
35
- * If turns > thrashTurns AND real diff is empty AND watchdog didn't already
36
- * trip mid-flight, mark state.thrashingDetected = true so the annotator
37
- * surfaces it. No abort (the session already finished); this is informative.
38
- * 2. Scope-violation analysis. Compute out-of-scope files from the final diff
39
- * against declared filePaths; populate state.scopeViolations[].
40
- * 3. Emit observability events for both.
41
- */
42
- export declare function recordPostHocSignals(state: LifecycleState, turnsUsed: number, config: ProgressWatchdogConfig, emit: (event: Record<string, unknown>) => void, taskIndex: number, batchId?: string): Promise<void>;
43
- //# sourceMappingURL=progress-watchdog.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"progress-watchdog.d.ts","sourceRoot":"","sources":["../../src/bounded-execution/progress-watchdog.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAEvE,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,OAAO,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;IACpB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,qBAAqB,EAAE,MAAM,CAAC;CAC/B;AAED,MAAM,WAAW,uBAAuB;IACtC,KAAK,EAAE,cAAc,CAAC;IACtB,UAAU,EAAE,eAAe,CAAC;IAC5B,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;IAC/C,MAAM,EAAE,sBAAsB,CAAC;IAC/B,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,yFAAyF;IACzF,MAAM,EAAE;QAAE,KAAK,EAAE,OAAO,CAAA;KAAE,CAAC;CAC5B;AAiBD;;;;;;;;;GASG;AACH,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,uBAAuB,GAAG,MAAM,IAAI,CAwF9E;AAED;;;;;;;;;;GAUG;AACH,wBAAsB,oBAAoB,CACxC,KAAK,EAAE,cAAc,EACrB,SAAS,EAAE,MAAM,EACjB,MAAM,EAAE,sBAAsB,EAC9B,IAAI,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,EAC9C,SAAS,EAAE,MAAM,EACjB,OAAO,CAAC,EAAE,MAAM,GACf,OAAO,CAAC,IAAI,CAAC,CAqCf"}
@@ -1,170 +0,0 @@
1
- // packages/core/src/bounded-execution/progress-watchdog.ts
2
- import { spawn } from 'node:child_process';
3
- import { getRealFilesChanged } from './real-diff.js';
4
- import { normalizeScopeEntry, isInScope } from './scope-match.js';
5
- async function gitDiffNameOnly(cwd, preSha) {
6
- return new Promise((resolve) => {
7
- let out = '';
8
- let settled = false;
9
- const done = (v) => { if (!settled) {
10
- settled = true;
11
- resolve(v);
12
- } };
13
- const child = spawn('git', ['diff', '--name-only', `${preSha}..`], { cwd, stdio: ['ignore', 'pipe', 'pipe'], windowsHide: true });
14
- child.stdout.on('data', (b) => { out += b.toString('utf8'); });
15
- child.on('error', () => done([]));
16
- child.on('exit', (code) => {
17
- if (code !== 0) {
18
- done([]);
19
- return;
20
- }
21
- done(out.split('\n').filter(Boolean));
22
- });
23
- });
24
- }
25
- /**
26
- * Starts the progress watchdog. Returns a disposer that MUST be called in a
27
- * finally{} block. Mirrors startStallWatchdog(): same shape, single function
28
- * call, returns cleanup. The watchdog polls on a setInterval; when conditions
29
- * trip, it fires `controller.abort()` to interrupt the in-flight session.send().
30
- *
31
- * Post-hoc signals (turn-count thrash detection and scope-violation analysis)
32
- * are handled by recordPostHocSignals() below, called AFTER session.send()
33
- * returns. They mutate state for the annotator to consume.
34
- */
35
- export function startProgressWatchdog(ctx) {
36
- const ts = () => new Date().toISOString();
37
- const meta = {
38
- ...(ctx.batchId !== undefined && { batchId: ctx.batchId }),
39
- taskIndex: ctx.taskIndex,
40
- };
41
- // Three skip conditions evaluated once at arm:
42
- if (!ctx.config.enabled) {
43
- ctx.emit({ event: 'progress_watchdog_skipped_disabled', ts: ts(), reason: 'config_disabled', ...meta });
44
- return () => undefined;
45
- }
46
- if (ctx.state.toolCategory !== 'artifact_producing') {
47
- return () => undefined; // silent no-op for read-only routes
48
- }
49
- if (!ctx.state.preTaskHeadSha || !ctx.state.preTaskUntrackedFiles) {
50
- ctx.emit({ event: 'progress_watchdog_skipped_non_git', ts: ts(), reason: 'non_git_cwd', ...meta });
51
- return () => undefined;
52
- }
53
- ctx.emit({ event: 'progress_watchdog_armed', ts: ts(), toolCategory: ctx.state.toolCategory, ...meta });
54
- const startedAtMs = Date.now();
55
- let warned = false;
56
- // Poll interval clamped to [5s, 30s]. Coarser than stall-watchdog's [1s, 5s]
57
- // because git diff is heavier than just checking idle time. Total cost: a
58
- // few git invocations per task — negligible.
59
- const pollIntervalMs = Math.min(30_000, Math.max(5_000, Math.floor(ctx.config.thrashWallClockMs / 60)));
60
- let pollInFlight = false;
61
- const interval = setInterval(() => {
62
- if (ctx.state2.fired)
63
- return;
64
- if (ctx.controller.signal.aborted) {
65
- ctx.state2.fired = true;
66
- return;
67
- }
68
- const wallClockMs = Date.now() - startedAtMs;
69
- // Cheap pre-check: only call git when we're past the soft threshold (no
70
- // point grepping git every 30s during the first few minutes of a task).
71
- if (wallClockMs < ctx.config.thrashSoftWallClockMs)
72
- return;
73
- if (pollInFlight)
74
- return; // skip tick if previous diff still running
75
- pollInFlight = true;
76
- void (async () => {
77
- try {
78
- const cwd = ctx.state.cwd ?? '';
79
- const preSha = ctx.state.preTaskHeadSha;
80
- const files = await gitDiffNameOnly(cwd, preSha);
81
- const diffEmpty = files.length === 0;
82
- if (!diffEmpty)
83
- return; // diff is non-empty; not thrashing
84
- // Signal 2: soft warn (fires once per task)
85
- if (!warned && wallClockMs >= ctx.config.thrashSoftWallClockMs) {
86
- warned = true;
87
- ctx.emit({ event: 'progress_watchdog_warn', ts: ts(), wallClockMs, ...meta });
88
- }
89
- // Signal 1: hard thrash — wall-clock exceeded + diff still empty → abort
90
- if (wallClockMs >= ctx.config.thrashWallClockMs) {
91
- ctx.state2.fired = true;
92
- ctx.state.thrashingDetected = true;
93
- ctx.state.preStopReason = 'thrashing';
94
- ctx.controller.abort();
95
- ctx.emit({
96
- event: 'progress_watchdog_fired_thrash',
97
- ts: ts(),
98
- wallClockMs,
99
- threshold: 'wallclock',
100
- ...meta,
101
- });
102
- }
103
- }
104
- catch {
105
- // non-fatal: continue polling
106
- }
107
- finally {
108
- pollInFlight = false;
109
- }
110
- })();
111
- }, pollIntervalMs);
112
- return () => {
113
- clearInterval(interval);
114
- ctx.emit({
115
- event: 'progress_watchdog_disarmed',
116
- ts: ts(),
117
- reason: ctx.state2.fired ? 'thrash' : 'normal',
118
- ...meta,
119
- });
120
- };
121
- }
122
- /**
123
- * Post-hoc finalization called AFTER session.send() returns. Three things:
124
- *
125
- * 1. Turn-count thrash detection (since we can't observe turns mid-flight).
126
- * If turns > thrashTurns AND real diff is empty AND watchdog didn't already
127
- * trip mid-flight, mark state.thrashingDetected = true so the annotator
128
- * surfaces it. No abort (the session already finished); this is informative.
129
- * 2. Scope-violation analysis. Compute out-of-scope files from the final diff
130
- * against declared filePaths; populate state.scopeViolations[].
131
- * 3. Emit observability events for both.
132
- */
133
- export async function recordPostHocSignals(state, turnsUsed, config, emit, taskIndex, batchId) {
134
- if (!config.enabled)
135
- return;
136
- if (state.toolCategory !== 'artifact_producing')
137
- return;
138
- if (!state.preTaskHeadSha || !state.preTaskUntrackedFiles)
139
- return;
140
- const meta = {
141
- ...(batchId !== undefined && { batchId }),
142
- taskIndex,
143
- };
144
- const ts = () => new Date().toISOString();
145
- const realFiles = await getRealFilesChanged(state);
146
- if (realFiles.source !== 'git_diff')
147
- return;
148
- // (1) Post-hoc turn-count thrash (only if watchdog didn't already trip)
149
- if (!state.thrashingDetected && turnsUsed > config.thrashTurns && realFiles.files.length === 0) {
150
- state.thrashingDetected = true;
151
- emit({
152
- event: 'progress_watchdog_fired_thrash',
153
- ts: ts(),
154
- turnsUsed,
155
- threshold: 'turns_post_hoc',
156
- ...meta,
157
- });
158
- }
159
- // (2) Scope-violation analysis
160
- const taskSpec = state.task;
161
- const declaredScope = (taskSpec?.filePaths ?? []).map((entry) => normalizeScopeEntry(state.cwd ?? '', entry));
162
- if (declaredScope.length > 0 && realFiles.files.length > 0) {
163
- const violations = realFiles.files.filter((f) => !isInScope(f, declaredScope));
164
- if (violations.length > 0) {
165
- state.scopeViolations = violations;
166
- emit({ event: 'progress_watchdog_scope_violation', ts: ts(), outOfScope: violations, ...meta });
167
- }
168
- }
169
- }
170
- //# sourceMappingURL=progress-watchdog.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"progress-watchdog.js","sourceRoot":"","sources":["../../src/bounded-execution/progress-watchdog.ts"],"names":[],"mappings":"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"}
@@ -1,17 +0,0 @@
1
- export interface RealFilesChanged {
2
- files: string[];
3
- source: 'git_diff' | 'self_report' | 'git_error';
4
- }
5
- /** Structural subset of LifecycleState that getRealFilesChanged reads. Declared
6
- * here so this substrate-layer git primitive carries no dependency on the
7
- * lifecycle/pipeline layer (enforced by .dependency-cruiser.cjs's
8
- * no-substrate-to-pipeline rule). LifecycleState satisfies it structurally. */
9
- export interface RealDiffInputs {
10
- cwd?: string;
11
- executionContext?: unknown;
12
- preTaskHeadSha?: string;
13
- preTaskUntrackedFiles?: Set<string>;
14
- lastRunResult?: unknown;
15
- }
16
- export declare function getRealFilesChanged(state: RealDiffInputs): Promise<RealFilesChanged>;
17
- //# sourceMappingURL=real-diff.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"real-diff.d.ts","sourceRoot":"","sources":["../../src/bounded-execution/real-diff.ts"],"names":[],"mappings":"AAcA,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,MAAM,EAAE,UAAU,GAAG,aAAa,GAAG,WAAW,CAAC;CAClD;AAED;;;gFAGgF;AAChF,MAAM,WAAW,cAAc;IAC7B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,qBAAqB,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;IACpC,aAAa,CAAC,EAAE,OAAO,CAAC;CACzB;AAED,wBAAsB,mBAAmB,CAAC,KAAK,EAAE,cAAc,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAiD1F"}
@@ -1,59 +0,0 @@
1
- // Sub-project A: filesChanged from real `git diff`, not worker self-report.
2
- //
3
- // Three sources, with explicit discriminator:
4
- // - `git_diff` — Authoritative. Used for commit decisions, telemetry counts,
5
- // watchdog signals.
6
- // - `self_report` — Non-git cwd. Used for telemetry counts ONLY. Watchdog
7
- // signals 1, 2, 3 are all DISABLED in this mode.
8
- // - `git_error` — Git work-tree exists but a git invocation failed. `files`
9
- // is the empty array; nothing is fabricated from self-report.
10
- // Commit handler treats as `no_diff` and skips.
11
- import { spawnSync } from 'node:child_process';
12
- import { join } from 'node:path';
13
- export async function getRealFilesChanged(state) {
14
- // Defense in depth: prefer state.cwd, fall back to executionContext.cwd —
15
- // production wires it on the latter. Without this the helper goes inert
16
- // (self_report) and the git-truth safety net never engages.
17
- const cwd = state.cwd ?? state.executionContext?.cwd;
18
- const preSha = state.preTaskHeadSha;
19
- const preUntracked = state.preTaskUntrackedFiles;
20
- if (!cwd || !preSha || !preUntracked) {
21
- const selfReport = (state.lastRunResult?.filesChanged) ?? [];
22
- return { files: selfReport, source: 'self_report' };
23
- }
24
- try {
25
- // `git diff <sha>` (no `..`) compares working tree to <sha>. Includes both
26
- // staged and unstaged changes — what we want for "files touched since task
27
- // entry". `git diff <sha>..` (with `..`) would only diff committed changes.
28
- const diffResult = spawnSync('git', ['diff', '--name-only', preSha], {
29
- cwd,
30
- encoding: 'utf8',
31
- windowsHide: true,
32
- });
33
- if (diffResult.status !== 0) {
34
- return { files: [], source: 'git_error' };
35
- }
36
- const diffFiles = diffResult.stdout
37
- .split('\n')
38
- .filter((line) => line.length > 0)
39
- .map((rel) => join(cwd, rel));
40
- const lsResult = spawnSync('git', ['ls-files', '--others', '--exclude-standard'], {
41
- cwd,
42
- encoding: 'utf8',
43
- windowsHide: true,
44
- });
45
- if (lsResult.status !== 0) {
46
- return { files: [], source: 'git_error' };
47
- }
48
- const currentUntracked = lsResult.stdout
49
- .split('\n')
50
- .filter((line) => line.length > 0)
51
- .map((rel) => join(cwd, rel));
52
- const newUntracked = currentUntracked.filter((p) => !preUntracked.has(p));
53
- return { files: [...diffFiles, ...newUntracked], source: 'git_diff' };
54
- }
55
- catch {
56
- return { files: [], source: 'git_error' };
57
- }
58
- }
59
- //# sourceMappingURL=real-diff.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"real-diff.js","sourceRoot":"","sources":["../../src/bounded-execution/real-diff.ts"],"names":[],"mappings":"AAAA,4EAA4E;AAC5E,EAAE;AACF,8CAA8C;AAC9C,+EAA+E;AAC/E,qCAAqC;AACrC,0EAA0E;AAC1E,kEAAkE;AAClE,6EAA6E;AAC7E,+EAA+E;AAC/E,iEAAiE;AAEjE,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAmBjC,MAAM,CAAC,KAAK,UAAU,mBAAmB,CAAC,KAAqB;IAC7D,0EAA0E;IAC1E,wEAAwE;IACxE,4DAA4D;IAC5D,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,IAAK,KAAK,CAAC,gBAAiD,EAAE,GAAG,CAAC;IACvF,MAAM,MAAM,GAAG,KAAK,CAAC,cAAc,CAAC;IACpC,MAAM,YAAY,GAAG,KAAK,CAAC,qBAAqB,CAAC;IAEjD,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,YAAY,EAAE,CAAC;QACrC,MAAM,UAAU,GACd,CAAE,KAAK,CAAC,aAAyD,EAAE,YAAY,CAAC,IAAI,EAAE,CAAC;QACzF,OAAO,EAAE,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;IACtD,CAAC;IAED,IAAI,CAAC;QACH,2EAA2E;QAC3E,2EAA2E;QAC3E,4EAA4E;QAC5E,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,aAAa,EAAE,MAAM,CAAC,EAAE;YACnE,GAAG;YACH,QAAQ,EAAE,MAAM;YAChB,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC;QACH,IAAI,UAAU,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5B,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;QAC5C,CAAC;QACD,MAAM,SAAS,GAAG,UAAU,CAAC,MAAM;aAChC,KAAK,CAAC,IAAI,CAAC;aACX,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aACjC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAEhC,MAAM,QAAQ,GAAG,SAAS,CAAC,KAAK,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,oBAAoB,CAAC,EAAE;YAChF,GAAG;YACH,QAAQ,EAAE,MAAM;YAChB,WAAW,EAAE,IAAI;SAClB,CAAC,CAAC;QACH,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;QAC5C,CAAC;QACD,MAAM,gBAAgB,GAAG,QAAQ,CAAC,MAAM;aACrC,KAAK,CAAC,IAAI,CAAC;aACX,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;aACjC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;QAChC,MAAM,YAAY,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAE1E,OAAO,EAAE,KAAK,EAAE,CAAC,GAAG,SAAS,EAAE,GAAG,YAAY,CAAC,EAAE,MAAM,EAAE,UAAU,EAAE,CAAC;IACxE,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,WAAW,EAAE,CAAC;IAC5C,CAAC;AACH,CAAC"}
@@ -1,7 +0,0 @@
1
- export interface NormalizedScopeEntry {
2
- absPath: string;
3
- kind: 'directory' | 'file';
4
- }
5
- export declare function normalizeScopeEntry(cwd: string, entry: string): NormalizedScopeEntry;
6
- export declare function isInScope(filePath: string, scope: NormalizedScopeEntry[]): boolean;
7
- //# sourceMappingURL=scope-match.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"scope-match.d.ts","sourceRoot":"","sources":["../../src/bounded-execution/scope-match.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,oBAAoB;IACnC,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,WAAW,GAAG,MAAM,CAAC;CAC5B;AAED,wBAAgB,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,oBAAoB,CAQpF;AAED,wBAAgB,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,oBAAoB,EAAE,GAAG,OAAO,CAWlF"}