voratiq 0.1.0-beta.2 → 0.1.0-beta.21

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 (527) hide show
  1. package/README.md +41 -29
  2. package/dist/agents/launch/chat.d.ts +23 -0
  3. package/dist/agents/launch/chat.js +44 -0
  4. package/dist/agents/launch/environment.d.ts +8 -0
  5. package/dist/{commands/run/agents/workspace-prep.js → agents/launch/environment.js} +5 -27
  6. package/dist/agents/launch/prompt.d.ts +6 -0
  7. package/dist/agents/launch/prompt.js +12 -0
  8. package/dist/agents/launch/provider-state.d.ts +39 -0
  9. package/dist/agents/launch/provider-state.js +103 -0
  10. package/dist/agents/runtime/auth.d.ts +27 -0
  11. package/dist/agents/runtime/auth.js +72 -0
  12. package/dist/agents/runtime/chat.d.ts +5 -0
  13. package/dist/agents/runtime/chat.js +7 -0
  14. package/dist/agents/runtime/errors.d.ts +27 -0
  15. package/dist/agents/runtime/errors.js +51 -0
  16. package/dist/{commands/run/agents → agents/runtime}/failures.d.ts +0 -1
  17. package/dist/agents/runtime/failures.js +136 -0
  18. package/dist/agents/runtime/harness.d.ts +2 -0
  19. package/dist/agents/runtime/harness.js +119 -0
  20. package/dist/{commands/run/agents/sandbox-launcher.d.ts → agents/runtime/launcher.d.ts} +18 -6
  21. package/dist/{commands/run/agents/sandbox-launcher.js → agents/runtime/launcher.js} +17 -39
  22. package/dist/{commands/run/agents/workspace-prep.d.ts → agents/runtime/manifest.d.ts} +6 -6
  23. package/dist/agents/runtime/manifest.js +34 -0
  24. package/dist/agents/runtime/policy.d.ts +32 -0
  25. package/dist/agents/runtime/policy.js +240 -0
  26. package/dist/agents/runtime/registry.d.ts +4 -0
  27. package/dist/agents/runtime/registry.js +54 -0
  28. package/dist/{commands/run → agents/runtime}/sandbox.d.ts +8 -2
  29. package/dist/{commands/run → agents/runtime}/sandbox.js +28 -67
  30. package/dist/agents/runtime/shim/run-agent-shim.d.ts +1 -0
  31. package/dist/agents/runtime/shim/run-agent-shim.js +276 -0
  32. package/dist/agents/runtime/types.d.ts +91 -0
  33. package/dist/{commands/run/agents → agents/runtime}/watchdog.d.ts +4 -3
  34. package/dist/{commands/run/agents → agents/runtime}/watchdog.js +155 -26
  35. package/dist/auth/providers/codex.js +7 -2
  36. package/dist/auth/providers/gemini.js +14 -6
  37. package/dist/auth/providers/types.d.ts +1 -0
  38. package/dist/auth/providers/utils.d.ts +0 -1
  39. package/dist/auth/providers/utils.js +1 -49
  40. package/dist/bin.js +369 -71
  41. package/dist/cli/apply.d.ts +4 -0
  42. package/dist/cli/apply.js +28 -9
  43. package/dist/cli/auto.d.ts +32 -0
  44. package/dist/cli/auto.js +232 -0
  45. package/dist/cli/contract.d.ts +328 -0
  46. package/dist/cli/contract.js +480 -0
  47. package/dist/cli/errors.d.ts +3 -0
  48. package/dist/cli/errors.js +21 -3
  49. package/dist/cli/init.d.ts +5 -0
  50. package/dist/cli/init.js +34 -6
  51. package/dist/cli/list.d.ts +6 -4
  52. package/dist/cli/list.js +39 -16
  53. package/dist/cli/mcp.d.ts +2 -0
  54. package/dist/cli/mcp.js +16 -0
  55. package/dist/cli/message.d.ts +28 -0
  56. package/dist/cli/message.js +147 -0
  57. package/dist/cli/operator-envelope.d.ts +180 -0
  58. package/dist/cli/operator-envelope.js +425 -0
  59. package/dist/cli/output.d.ts +15 -1
  60. package/dist/cli/output.js +153 -5
  61. package/dist/cli/prune.d.ts +7 -3
  62. package/dist/cli/prune.js +57 -12
  63. package/dist/cli/reduce.d.ts +29 -0
  64. package/dist/cli/reduce.js +211 -0
  65. package/dist/cli/root-launcher.d.ts +4 -0
  66. package/dist/cli/root-launcher.js +15 -0
  67. package/dist/cli/run.d.ts +27 -1
  68. package/dist/cli/run.js +108 -16
  69. package/dist/cli/spec.d.ts +31 -0
  70. package/dist/cli/spec.js +180 -0
  71. package/dist/cli/verify.d.ts +35 -0
  72. package/dist/cli/verify.js +297 -0
  73. package/dist/commands/apply/command.d.ts +2 -0
  74. package/dist/commands/apply/command.js +145 -6
  75. package/dist/commands/apply/errors.d.ts +43 -4
  76. package/dist/commands/apply/errors.js +100 -22
  77. package/dist/commands/apply/types.d.ts +2 -1
  78. package/dist/commands/auto/command.d.ts +145 -0
  79. package/dist/commands/auto/command.js +433 -0
  80. package/dist/commands/auto/errors.d.ts +19 -0
  81. package/dist/commands/auto/errors.js +19 -0
  82. package/dist/commands/auto/validation.d.ts +14 -0
  83. package/dist/commands/auto/validation.js +90 -0
  84. package/dist/commands/fetch.d.ts +2 -2
  85. package/dist/commands/fetch.js +4 -4
  86. package/dist/commands/init/agents.d.ts +2 -1
  87. package/dist/commands/init/agents.js +66 -63
  88. package/dist/commands/init/command.js +300 -16
  89. package/dist/commands/init/types.d.ts +18 -7
  90. package/dist/commands/interactive/lifecycle.d.ts +15 -0
  91. package/dist/commands/interactive/lifecycle.js +141 -0
  92. package/dist/commands/list/command.d.ts +10 -3
  93. package/dist/commands/list/command.js +597 -40
  94. package/dist/commands/message/command.d.ts +23 -0
  95. package/dist/commands/message/command.js +215 -0
  96. package/dist/commands/message/errors.d.ts +9 -0
  97. package/dist/commands/message/errors.js +20 -0
  98. package/dist/commands/message/lifecycle.d.ts +14 -0
  99. package/dist/commands/message/lifecycle.js +128 -0
  100. package/dist/commands/prune/command.d.ts +2 -1
  101. package/dist/commands/prune/command.js +61 -10
  102. package/dist/commands/prune/errors.d.ts +1 -1
  103. package/dist/commands/prune/errors.js +5 -5
  104. package/dist/commands/prune/types.d.ts +21 -0
  105. package/dist/commands/reduce/command.d.ts +26 -0
  106. package/dist/commands/reduce/command.js +145 -0
  107. package/dist/commands/reduce/errors.d.ts +17 -0
  108. package/dist/commands/reduce/errors.js +32 -0
  109. package/dist/commands/reduce/targets.d.ts +11 -0
  110. package/dist/commands/reduce/targets.js +271 -0
  111. package/dist/commands/root-launcher/command.d.ts +31 -0
  112. package/dist/commands/root-launcher/command.js +233 -0
  113. package/dist/commands/run/command.d.ts +6 -1
  114. package/dist/commands/run/command.js +70 -40
  115. package/dist/commands/run/lifecycle.d.ts +7 -5
  116. package/dist/commands/run/lifecycle.js +45 -23
  117. package/dist/commands/run/record-init.d.ts +4 -1
  118. package/dist/commands/run/record-init.js +5 -2
  119. package/dist/commands/run/shim/run-agent-shim.d.ts +2 -1
  120. package/dist/commands/run/shim/run-agent-shim.js +4 -219
  121. package/dist/commands/run/validation.d.ts +2 -3
  122. package/dist/commands/run/validation.js +54 -25
  123. package/dist/commands/shared/max-parallel.d.ts +5 -0
  124. package/dist/commands/shared/max-parallel.js +15 -0
  125. package/dist/commands/shared/preview.d.ts +10 -0
  126. package/dist/commands/shared/preview.js +60 -0
  127. package/dist/commands/shared/resolve-reduction-competitors.d.ts +15 -0
  128. package/dist/commands/shared/resolve-reduction-competitors.js +13 -0
  129. package/dist/commands/shared/resolve-stage-competitors.d.ts +19 -0
  130. package/dist/commands/shared/resolve-stage-competitors.js +171 -0
  131. package/dist/commands/shared/session-id.d.ts +1 -0
  132. package/dist/commands/shared/session-id.js +1 -0
  133. package/dist/commands/spec/command.d.ts +22 -0
  134. package/dist/commands/spec/command.js +330 -0
  135. package/dist/commands/spec/errors.d.ts +11 -0
  136. package/dist/commands/spec/errors.js +23 -0
  137. package/dist/commands/verify/agents.d.ts +8 -0
  138. package/dist/commands/verify/agents.js +29 -0
  139. package/dist/commands/verify/command.d.ts +23 -0
  140. package/dist/commands/verify/command.js +168 -0
  141. package/dist/commands/verify/lifecycle.d.ts +14 -0
  142. package/dist/commands/verify/lifecycle.js +229 -0
  143. package/dist/commands/verify/max-parallel.d.ts +7 -0
  144. package/dist/commands/verify/max-parallel.js +15 -0
  145. package/dist/commands/verify/targets.d.ts +18 -0
  146. package/dist/commands/verify/targets.js +420 -0
  147. package/dist/competition/command-adapter.d.ts +35 -0
  148. package/dist/competition/command-adapter.js +20 -0
  149. package/dist/competition/core.d.ts +41 -0
  150. package/dist/competition/core.js +181 -0
  151. package/dist/competition/shared/extra-context.d.ts +14 -0
  152. package/dist/competition/shared/extra-context.js +100 -0
  153. package/dist/competition/shared/preflight.d.ts +11 -0
  154. package/dist/competition/shared/preflight.js +39 -0
  155. package/dist/competition/shared/prompt-helpers.d.ts +16 -0
  156. package/dist/competition/shared/prompt-helpers.js +27 -0
  157. package/dist/competition/shared/prune.d.ts +1 -0
  158. package/dist/competition/shared/prune.js +4 -0
  159. package/dist/competition/shared/sandbox-policy.d.ts +9 -0
  160. package/dist/competition/shared/sandbox-policy.js +7 -0
  161. package/dist/competition/shared/teardown.d.ts +36 -0
  162. package/dist/competition/shared/teardown.js +101 -0
  163. package/dist/configs/agents/defaults.d.ts +31 -2
  164. package/dist/configs/agents/defaults.js +346 -30
  165. package/dist/configs/agents/errors.js +14 -11
  166. package/dist/configs/agents/loader.d.ts +11 -1
  167. package/dist/configs/agents/loader.js +71 -4
  168. package/dist/configs/agents/types.js +2 -2
  169. package/dist/configs/environment/detect.js +9 -4
  170. package/dist/configs/environment/errors.js +4 -4
  171. package/dist/configs/environment/loader.d.ts +1 -1
  172. package/dist/configs/environment/loader.js +3 -3
  173. package/dist/configs/orchestration/bootstrap.d.ts +16 -0
  174. package/dist/configs/orchestration/bootstrap.js +122 -0
  175. package/dist/configs/orchestration/errors.d.ts +15 -0
  176. package/dist/configs/orchestration/errors.js +28 -0
  177. package/dist/configs/orchestration/loader.d.ts +9 -0
  178. package/dist/configs/orchestration/loader.js +148 -0
  179. package/dist/configs/orchestration/types.d.ts +102 -0
  180. package/dist/configs/orchestration/types.js +65 -0
  181. package/dist/configs/sandbox/defaults.js +14 -4
  182. package/dist/configs/sandbox/errors.d.ts +1 -1
  183. package/dist/configs/sandbox/errors.js +1 -1
  184. package/dist/configs/sandbox/loader.js +6 -4
  185. package/dist/configs/sandbox/schemas.js +4 -2
  186. package/dist/configs/settings/loader.d.ts +7 -0
  187. package/dist/configs/settings/loader.js +81 -0
  188. package/dist/configs/settings/types.d.ts +47 -0
  189. package/dist/configs/settings/types.js +23 -0
  190. package/dist/configs/verification/errors.d.ts +11 -0
  191. package/dist/configs/verification/errors.js +21 -0
  192. package/dist/configs/verification/loader.d.ts +8 -0
  193. package/dist/configs/verification/loader.js +43 -0
  194. package/dist/configs/verification/methods.d.ts +35 -0
  195. package/dist/configs/verification/methods.js +41 -0
  196. package/dist/configs/verification/programmatic-defaults.d.ts +10 -0
  197. package/dist/configs/verification/programmatic-defaults.js +42 -0
  198. package/dist/configs/verification/programmatic-detect.d.ts +10 -0
  199. package/dist/configs/{evals/detect.js → verification/programmatic-detect.js} +22 -33
  200. package/dist/configs/verification/types.d.ts +49 -0
  201. package/dist/configs/verification/types.js +45 -0
  202. package/dist/contracts/list.d.ts +207 -0
  203. package/dist/contracts/list.js +154 -0
  204. package/dist/domain/interactive/model/types.d.ts +104 -0
  205. package/dist/domain/interactive/model/types.js +83 -0
  206. package/dist/domain/interactive/persistence/adapter.d.ts +39 -0
  207. package/dist/domain/interactive/persistence/adapter.js +144 -0
  208. package/dist/domain/interactive/prompt.d.ts +3 -0
  209. package/dist/domain/interactive/prompt.js +7 -0
  210. package/dist/domain/message/competition/adapter.d.ts +36 -0
  211. package/dist/domain/message/competition/adapter.js +197 -0
  212. package/dist/domain/message/competition/prompt.d.ts +8 -0
  213. package/dist/domain/message/competition/prompt.js +29 -0
  214. package/dist/domain/message/model/mutators.d.ts +17 -0
  215. package/dist/domain/message/model/mutators.js +107 -0
  216. package/dist/domain/message/model/types.d.ts +100 -0
  217. package/dist/domain/message/model/types.js +87 -0
  218. package/dist/domain/message/persistence/adapter.d.ts +43 -0
  219. package/dist/domain/message/persistence/adapter.js +124 -0
  220. package/dist/domain/reduce/competition/adapter.d.ts +42 -0
  221. package/dist/domain/reduce/competition/adapter.js +826 -0
  222. package/dist/domain/reduce/competition/output-validation.d.ts +4 -0
  223. package/dist/domain/reduce/competition/output-validation.js +18 -0
  224. package/dist/domain/reduce/competition/prompt.d.ts +10 -0
  225. package/dist/domain/reduce/competition/prompt.js +96 -0
  226. package/dist/domain/reduce/competition/reduction.d.ts +9 -0
  227. package/dist/domain/reduce/competition/reduction.js +32 -0
  228. package/dist/domain/reduce/model/types.d.ts +122 -0
  229. package/dist/domain/reduce/model/types.js +84 -0
  230. package/dist/domain/reduce/persistence/adapter.d.ts +43 -0
  231. package/dist/domain/reduce/persistence/adapter.js +126 -0
  232. package/dist/domain/run/competition/adapter.d.ts +30 -0
  233. package/dist/domain/run/competition/adapter.js +39 -0
  234. package/dist/domain/run/competition/agent-execution.d.ts +20 -0
  235. package/dist/domain/run/competition/agent-execution.js +45 -0
  236. package/dist/domain/run/competition/agent-preparation.d.ts +12 -0
  237. package/dist/domain/run/competition/agent-preparation.js +24 -0
  238. package/dist/domain/run/competition/agents/artifacts.d.ts +17 -0
  239. package/dist/domain/run/competition/agents/artifacts.js +173 -0
  240. package/dist/{commands/run → domain/run/competition}/agents/lifecycle.d.ts +3 -3
  241. package/dist/{commands/run → domain/run/competition}/agents/lifecycle.js +84 -64
  242. package/dist/domain/run/competition/agents/post-processing.d.ts +12 -0
  243. package/dist/domain/run/competition/agents/post-processing.js +4 -0
  244. package/dist/domain/run/competition/agents/preparation.js +64 -0
  245. package/dist/{commands/run → domain/run/competition}/agents/run-context.d.ts +9 -16
  246. package/dist/{commands/run → domain/run/competition}/agents/run-context.js +22 -70
  247. package/dist/{commands/run → domain/run/competition}/agents/types.d.ts +10 -13
  248. package/dist/domain/run/competition/agents/workspace.d.ts +21 -0
  249. package/dist/domain/run/competition/agents/workspace.js +47 -0
  250. package/dist/{commands/run → domain/run/competition}/errors.d.ts +8 -1
  251. package/dist/{commands/run → domain/run/competition}/errors.js +39 -9
  252. package/dist/{commands/run → domain/run/competition}/phases.d.ts +1 -2
  253. package/dist/domain/run/competition/phases.js +1 -0
  254. package/dist/domain/run/competition/prompt.d.ts +7 -0
  255. package/dist/domain/run/competition/prompt.js +27 -0
  256. package/dist/{commands/run → domain/run/competition}/reports.d.ts +5 -3
  257. package/dist/{commands/run → domain/run/competition}/reports.js +7 -19
  258. package/dist/domain/run/competition/termination-state.d.ts +4 -0
  259. package/dist/domain/run/competition/termination-state.js +12 -0
  260. package/dist/{records → domain/run/model}/enhanced.d.ts +6 -7
  261. package/dist/{records → domain/run/model}/enhanced.js +11 -11
  262. package/dist/{records → domain/run/model}/errors.d.ts +1 -1
  263. package/dist/{records → domain/run/model}/errors.js +5 -5
  264. package/dist/{records → domain/run/model}/mutators.d.ts +4 -3
  265. package/dist/{records → domain/run/model}/mutators.js +58 -36
  266. package/dist/domain/run/model/types.d.ts +376 -0
  267. package/dist/domain/run/model/types.js +192 -0
  268. package/dist/{records/persistence.d.ts → domain/run/persistence/adapter.d.ts} +9 -3
  269. package/dist/domain/run/persistence/adapter.js +340 -0
  270. package/dist/domain/run/persistence/error-mapping.d.ts +2 -0
  271. package/dist/domain/run/persistence/error-mapping.js +17 -0
  272. package/dist/domain/shared/lifecycle.d.ts +54 -0
  273. package/dist/domain/shared/lifecycle.js +165 -0
  274. package/dist/domain/shared/token-usage.d.ts +21 -0
  275. package/dist/domain/shared/token-usage.js +38 -0
  276. package/dist/domain/spec/competition/adapter.d.ts +31 -0
  277. package/dist/domain/spec/competition/adapter.js +196 -0
  278. package/dist/domain/spec/competition/prompt.d.ts +11 -0
  279. package/dist/domain/spec/competition/prompt.js +44 -0
  280. package/dist/domain/spec/model/output.d.ts +13 -0
  281. package/dist/domain/spec/model/output.js +36 -0
  282. package/dist/domain/spec/model/types.d.ts +98 -0
  283. package/dist/domain/spec/model/types.js +84 -0
  284. package/dist/domain/spec/persistence/adapter.d.ts +51 -0
  285. package/dist/domain/spec/persistence/adapter.js +140 -0
  286. package/dist/domain/verify/blinding/aliases.d.ts +7 -0
  287. package/dist/domain/verify/blinding/aliases.js +23 -0
  288. package/dist/domain/verify/competition/adapter.d.ts +54 -0
  289. package/dist/domain/verify/competition/adapter.js +444 -0
  290. package/dist/domain/verify/competition/artifacts.d.ts +6 -0
  291. package/dist/domain/verify/competition/artifacts.js +7 -0
  292. package/dist/domain/verify/competition/blinding.d.ts +24 -0
  293. package/dist/domain/verify/competition/blinding.js +109 -0
  294. package/dist/domain/verify/competition/finalize.d.ts +11 -0
  295. package/dist/domain/verify/competition/finalize.js +65 -0
  296. package/dist/domain/verify/competition/programmatic.d.ts +15 -0
  297. package/dist/domain/verify/competition/programmatic.js +352 -0
  298. package/dist/domain/verify/competition/prompt.d.ts +19 -0
  299. package/dist/domain/verify/competition/prompt.js +63 -0
  300. package/dist/domain/verify/competition/rubric.d.ts +23 -0
  301. package/dist/domain/verify/competition/rubric.js +77 -0
  302. package/dist/domain/verify/competition/shared-layout.d.ts +121 -0
  303. package/dist/domain/verify/competition/shared-layout.js +365 -0
  304. package/dist/domain/verify/competition/target.d.ts +47 -0
  305. package/dist/domain/verify/competition/target.js +1 -0
  306. package/dist/domain/verify/model/mutators.d.ts +16 -0
  307. package/dist/domain/verify/model/mutators.js +126 -0
  308. package/dist/domain/verify/model/types.d.ts +408 -0
  309. package/dist/domain/verify/model/types.js +289 -0
  310. package/dist/domain/verify/persistence/adapter.d.ts +43 -0
  311. package/dist/domain/verify/persistence/adapter.js +126 -0
  312. package/dist/domain/verify/programmatic/runner.d.ts +22 -0
  313. package/dist/domain/verify/programmatic/runner.js +209 -0
  314. package/dist/domain/verify/rubric-result.d.ts +28 -0
  315. package/dist/domain/verify/rubric-result.js +121 -0
  316. package/dist/extra-context/contract.d.ts +17 -0
  317. package/dist/extra-context/contract.js +60 -0
  318. package/dist/interactive/index.d.ts +2 -0
  319. package/dist/interactive/index.js +1 -0
  320. package/dist/interactive/providers/launch.d.ts +23 -0
  321. package/dist/interactive/providers/launch.js +203 -0
  322. package/dist/interactive/providers/mcp.d.ts +13 -0
  323. package/dist/interactive/providers/mcp.js +547 -0
  324. package/dist/interactive/providers/shared.d.ts +2 -0
  325. package/dist/interactive/providers/shared.js +1 -0
  326. package/dist/interactive/providers.d.ts +3 -0
  327. package/dist/interactive/providers.js +3 -0
  328. package/dist/interactive/records.d.ts +2 -0
  329. package/dist/interactive/records.js +1 -0
  330. package/dist/interactive/substrate.d.ts +21 -0
  331. package/dist/interactive/substrate.js +522 -0
  332. package/dist/interactive/types.d.ts +101 -0
  333. package/dist/interactive/types.js +1 -0
  334. package/dist/mcp/server.d.ts +88 -0
  335. package/dist/mcp/server.js +790 -0
  336. package/dist/persistence/error-mapping.d.ts +19 -0
  337. package/dist/persistence/error-mapping.js +44 -0
  338. package/dist/persistence/errors.d.ts +26 -0
  339. package/dist/persistence/errors.js +49 -0
  340. package/dist/persistence/extra-context.d.ts +9 -0
  341. package/dist/persistence/extra-context.js +60 -0
  342. package/dist/{records → persistence}/history-lock.js +2 -2
  343. package/dist/persistence/record-path-schema.d.ts +3 -0
  344. package/dist/persistence/record-path-schema.js +16 -0
  345. package/dist/persistence/session-store.d.ts +92 -0
  346. package/dist/persistence/session-store.js +412 -0
  347. package/dist/policy/auto.d.ts +13 -0
  348. package/dist/policy/auto.js +22 -0
  349. package/dist/policy/index.d.ts +5 -0
  350. package/dist/policy/index.js +5 -0
  351. package/dist/policy/resolution.d.ts +6 -0
  352. package/dist/policy/resolution.js +23 -0
  353. package/dist/policy/result.d.ts +53 -0
  354. package/dist/policy/result.js +15 -0
  355. package/dist/policy/selector.d.ts +11 -0
  356. package/dist/policy/selector.js +57 -0
  357. package/dist/policy/verification.d.ts +77 -0
  358. package/dist/policy/verification.js +365 -0
  359. package/dist/policy/verifier-selection.d.ts +13 -0
  360. package/dist/policy/verifier-selection.js +78 -0
  361. package/dist/preflight/branch.d.ts +9 -0
  362. package/dist/preflight/branch.js +48 -0
  363. package/dist/preflight/errors.d.ts +3 -0
  364. package/dist/preflight/errors.js +10 -3
  365. package/dist/preflight/index.d.ts +13 -0
  366. package/dist/preflight/index.js +43 -8
  367. package/dist/render/interactions/confirmation.js +4 -2
  368. package/dist/render/transcripts/apply.js +9 -10
  369. package/dist/render/transcripts/auto.d.ts +27 -0
  370. package/dist/render/transcripts/auto.js +21 -0
  371. package/dist/render/transcripts/init.d.ts +4 -15
  372. package/dist/render/transcripts/init.js +71 -72
  373. package/dist/render/transcripts/list.d.ts +10 -1
  374. package/dist/render/transcripts/list.js +121 -15
  375. package/dist/render/transcripts/message.d.ts +72 -0
  376. package/dist/render/transcripts/message.js +362 -0
  377. package/dist/render/transcripts/prune.d.ts +7 -2
  378. package/dist/render/transcripts/prune.js +64 -17
  379. package/dist/render/transcripts/reduce.d.ts +74 -0
  380. package/dist/render/transcripts/reduce.js +395 -0
  381. package/dist/render/transcripts/root-launcher.d.ts +19 -0
  382. package/dist/render/transcripts/root-launcher.js +40 -0
  383. package/dist/render/transcripts/run.d.ts +35 -6
  384. package/dist/render/transcripts/run.js +241 -165
  385. package/dist/render/transcripts/shared.d.ts +2 -0
  386. package/dist/render/transcripts/shared.js +11 -4
  387. package/dist/render/transcripts/spec.d.ts +74 -0
  388. package/dist/render/transcripts/spec.js +394 -0
  389. package/dist/render/transcripts/stage-progress.d.ts +22 -0
  390. package/dist/render/transcripts/stage-progress.js +6 -0
  391. package/dist/render/transcripts/update-check.d.ts +2 -0
  392. package/dist/render/transcripts/update-check.js +22 -0
  393. package/dist/render/transcripts/verify.d.ts +74 -0
  394. package/dist/render/transcripts/verify.js +409 -0
  395. package/dist/render/utils/agents.d.ts +10 -9
  396. package/dist/render/utils/agents.js +30 -82
  397. package/dist/render/utils/badges.d.ts +3 -20
  398. package/dist/render/utils/badges.js +3 -36
  399. package/dist/render/utils/duration.d.ts +12 -0
  400. package/dist/render/utils/duration.js +37 -0
  401. package/dist/render/utils/interactive-frame.d.ts +6 -0
  402. package/dist/render/utils/interactive-frame.js +38 -0
  403. package/dist/render/utils/records.js +4 -4
  404. package/dist/render/utils/runs.d.ts +3 -9
  405. package/dist/render/utils/runs.js +16 -48
  406. package/dist/render/utils/stage-output.d.ts +20 -0
  407. package/dist/render/utils/stage-output.js +44 -0
  408. package/dist/render/utils/timezone.d.ts +2 -0
  409. package/dist/render/utils/timezone.js +42 -0
  410. package/dist/render/utils/transcript-shell.d.ts +66 -0
  411. package/dist/render/utils/transcript-shell.js +155 -0
  412. package/dist/render/utils/transcript.d.ts +7 -1
  413. package/dist/render/utils/transcript.js +12 -2
  414. package/dist/render/utils/wrap.d.ts +1 -0
  415. package/dist/render/utils/wrap.js +20 -0
  416. package/dist/status/colors.d.ts +2 -3
  417. package/dist/status/colors.js +3 -3
  418. package/dist/status/index.d.ts +108 -8
  419. package/dist/status/index.js +164 -5
  420. package/dist/update-check/checker.d.ts +24 -0
  421. package/dist/update-check/checker.js +130 -0
  422. package/dist/update-check/prompt.d.ts +25 -0
  423. package/dist/update-check/prompt.js +62 -0
  424. package/dist/update-check/semver.d.ts +17 -0
  425. package/dist/update-check/semver.js +36 -0
  426. package/dist/update-check/state-path.d.ts +8 -0
  427. package/dist/update-check/state-path.js +18 -0
  428. package/dist/utils/binaries.js +14 -8
  429. package/dist/utils/errors.d.ts +3 -1
  430. package/dist/utils/errors.js +3 -1
  431. package/dist/utils/git.d.ts +10 -0
  432. package/dist/utils/git.js +15 -3
  433. package/dist/utils/output.d.ts +5 -1
  434. package/dist/utils/output.js +4 -2
  435. package/dist/utils/process.d.ts +2 -1
  436. package/dist/utils/process.js +7 -3
  437. package/dist/utils/session-id.d.ts +1 -0
  438. package/dist/utils/session-id.js +22 -0
  439. package/dist/utils/slug.d.ts +2 -0
  440. package/dist/utils/slug.js +15 -0
  441. package/dist/utils/voratiq-cli-target.d.ts +9 -0
  442. package/dist/utils/voratiq-cli-target.js +58 -0
  443. package/dist/workspace/agents.d.ts +13 -16
  444. package/dist/workspace/agents.js +22 -147
  445. package/dist/workspace/chat/artifacts.d.ts +9 -0
  446. package/dist/workspace/chat/artifacts.js +82 -12
  447. package/dist/workspace/chat/native-usage.d.ts +13 -0
  448. package/dist/workspace/chat/native-usage.js +60 -0
  449. package/dist/workspace/chat/sources.d.ts +9 -5
  450. package/dist/workspace/chat/sources.js +89 -23
  451. package/dist/workspace/chat/token-usage-result.d.ts +23 -0
  452. package/dist/workspace/chat/token-usage-result.js +7 -0
  453. package/dist/workspace/chat/usage-extractor.d.ts +30 -0
  454. package/dist/workspace/chat/usage-extractor.js +461 -0
  455. package/dist/workspace/chat/usage-mappings.d.ts +20 -0
  456. package/dist/workspace/chat/usage-mappings.js +136 -0
  457. package/dist/workspace/credential-guard.js +1 -1
  458. package/dist/workspace/dependencies.js +4 -4
  459. package/dist/workspace/errors.d.ts +5 -0
  460. package/dist/workspace/errors.js +13 -3
  461. package/dist/workspace/layout.d.ts +17 -6
  462. package/dist/workspace/layout.js +51 -32
  463. package/dist/workspace/promotion.d.ts +32 -0
  464. package/dist/workspace/promotion.js +34 -0
  465. package/dist/workspace/prune.d.ts +1 -1
  466. package/dist/workspace/run.d.ts +1 -3
  467. package/dist/workspace/run.js +6 -15
  468. package/dist/workspace/setup.d.ts +8 -0
  469. package/dist/workspace/setup.js +359 -56
  470. package/dist/workspace/shim.js +1 -1
  471. package/dist/workspace/structure.d.ts +91 -26
  472. package/dist/workspace/structure.js +227 -43
  473. package/dist/workspace/templates.d.ts +9 -3
  474. package/dist/workspace/templates.js +26 -15
  475. package/dist/workspace/verification-defaults.d.ts +12 -0
  476. package/dist/workspace/verification-defaults.js +1017 -0
  477. package/package.json +30 -24
  478. package/dist/cli/review.d.ts +0 -12
  479. package/dist/cli/review.js +0 -33
  480. package/dist/commands/errors.d.ts +0 -4
  481. package/dist/commands/errors.js +0 -7
  482. package/dist/commands/init/evals.d.ts +0 -4
  483. package/dist/commands/init/evals.js +0 -219
  484. package/dist/commands/review/command.d.ts +0 -10
  485. package/dist/commands/review/command.js +0 -26
  486. package/dist/commands/run/agent-execution.d.ts +0 -19
  487. package/dist/commands/run/agent-execution.js +0 -63
  488. package/dist/commands/run/agents/auth-stage.d.ts +0 -23
  489. package/dist/commands/run/agents/auth-stage.js +0 -108
  490. package/dist/commands/run/agents/chat-preserver.d.ts +0 -9
  491. package/dist/commands/run/agents/chat-preserver.js +0 -35
  492. package/dist/commands/run/agents/eval-runner.d.ts +0 -19
  493. package/dist/commands/run/agents/eval-runner.js +0 -27
  494. package/dist/commands/run/agents/failures.js +0 -32
  495. package/dist/commands/run/agents/preparation.js +0 -123
  496. package/dist/commands/run/agents.d.ts +0 -14
  497. package/dist/commands/run/agents.js +0 -47
  498. package/dist/commands/run/prompts.d.ts +0 -4
  499. package/dist/commands/run/prompts.js +0 -16
  500. package/dist/commands/run/sandbox-registry.d.ts +0 -4
  501. package/dist/commands/run/sandbox-registry.js +0 -54
  502. package/dist/configs/evals/defaults.d.ts +0 -8
  503. package/dist/configs/evals/defaults.js +0 -28
  504. package/dist/configs/evals/detect.d.ts +0 -10
  505. package/dist/configs/evals/errors.d.ts +0 -16
  506. package/dist/configs/evals/errors.js +0 -29
  507. package/dist/configs/evals/loader.d.ts +0 -9
  508. package/dist/configs/evals/loader.js +0 -46
  509. package/dist/configs/evals/types.d.ts +0 -42
  510. package/dist/configs/evals/types.js +0 -74
  511. package/dist/evals/runner.d.ts +0 -16
  512. package/dist/evals/runner.js +0 -132
  513. package/dist/records/persistence.js +0 -469
  514. package/dist/records/types.d.ts +0 -255
  515. package/dist/records/types.js +0 -160
  516. package/dist/render/transcripts/review.d.ts +0 -2
  517. package/dist/render/transcripts/review.js +0 -36
  518. /package/dist/{commands/run → agents/runtime}/shim/agent-manifest.d.ts +0 -0
  519. /package/dist/{commands/run → agents/runtime}/shim/agent-manifest.js +0 -0
  520. /package/dist/{commands/run → agents/runtime/shim}/argv.d.ts +0 -0
  521. /package/dist/{commands/run → agents/runtime/shim}/argv.js +0 -0
  522. /package/dist/{commands/run/agents → agents/runtime}/types.js +0 -0
  523. /package/dist/{commands/run → domain/run/competition}/agents/preparation.d.ts +0 -0
  524. /package/dist/{commands/run/phases.js → domain/run/competition/agents/types.js} +0 -0
  525. /package/dist/{commands/run → domain/run/model}/id.d.ts +0 -0
  526. /package/dist/{commands/run → domain/run/model}/id.js +0 -0
  527. /package/dist/{records → persistence}/history-lock.d.ts +0 -0
@@ -1,23 +1,63 @@
1
- import { getEvalStatusStyle } from "../../status/colors.js";
2
- import { colorize } from "../../utils/colors.js";
1
+ import { TERMINAL_RUN_STATUSES } from "../../status/index.js";
3
2
  import { formatCompactDiffStatistics } from "../../utils/diff.js";
4
- import { formatAgentDuration, formatAgentStatusLabel, formatDurationLabel, } from "../utils/agents.js";
3
+ import { formatAgentDuration, formatAgentStatusLabelWithStyle, } from "../utils/agents.js";
5
4
  import { formatAgentBadge } from "../utils/badges.js";
5
+ import { formatRenderLifecycleDuration } from "../utils/duration.js";
6
+ import { createInteractiveFrameRenderer } from "../utils/interactive-frame.js";
6
7
  import { formatRunTimestamp } from "../utils/records.js";
7
- import { buildRunMetadataSection } from "../utils/runs.js";
8
- import { renderTable } from "../utils/table.js";
9
- import { renderTranscript } from "../utils/transcript.js";
10
- const SUPPRESS_RUN_STATUS_TABLE_ENV = "VORATIQ_SUPPRESS_RUN_STATUS_TABLE";
11
- function shouldSuppressRunStatusTable() {
12
- const flag = process.env[SUPPRESS_RUN_STATUS_TABLE_ENV];
13
- return flag === "1" || flag?.toLowerCase() === "true";
8
+ import { buildRunMetadataSectionWithStyle } from "../utils/runs.js";
9
+ import { buildStageFrameLines, renderStageFinalFrame, } from "../utils/stage-output.js";
10
+ import { renderTranscriptStatusTable, resolveTranscriptShellStyle, resolveTranscriptShellStyleFromWriter, } from "../utils/transcript-shell.js";
11
+ const DASH = "";
12
+ export function formatRunElapsed(source, now) {
13
+ return formatRenderLifecycleDuration({
14
+ lifecycle: {
15
+ status: source.status,
16
+ startedAt: source.startedAt,
17
+ completedAt: source.completedAt,
18
+ },
19
+ terminalStatuses: TERMINAL_RUN_STATUSES,
20
+ now,
21
+ });
14
22
  }
15
- const ERASE_LINE = "\u001b[2K";
16
- const CURSOR_COLUMN_START = "\u001b[0G";
17
- function cursorUp(lines) {
18
- return `\u001b[${lines}F`;
23
+ export function renderRunTranscript(options) {
24
+ const style = resolveTranscriptShellStyle({ isTty: options.isTty });
25
+ const shell = {
26
+ metadataLines: buildRunMetadataSectionWithStyle({
27
+ runId: options.runId,
28
+ status: options.status,
29
+ workspacePath: options.workspacePath,
30
+ elapsed: formatRunElapsed({
31
+ status: options.status,
32
+ startedAt: options.startedAt,
33
+ completedAt: options.completedAt,
34
+ }, options.now) ?? DASH,
35
+ createdAt: formatRunTimestamp(options.createdAt),
36
+ }, style),
37
+ statusTableLines: options.agents.length === 0
38
+ ? []
39
+ : renderTranscriptStatusTable({
40
+ rows: options.agents.map((agent) => ({
41
+ agentId: formatAgentBadge(agent.agentId, style),
42
+ status: formatAgentStatusLabelWithStyle(agent.status, style),
43
+ duration: agent.status === "running"
44
+ ? DASH
45
+ : (formatAgentDuration(agent, {
46
+ now: options.now ?? Date.now(),
47
+ }) ?? DASH),
48
+ diff: formatCompactDiffStatistics(agent.diffStatistics) ?? DASH,
49
+ })),
50
+ agent: (row) => row.agentId,
51
+ status: (row) => row.status,
52
+ duration: (row) => row.duration,
53
+ extras: [{ header: "CHANGES", accessor: (row) => row.diff }],
54
+ }),
55
+ };
56
+ return renderStageFinalFrame({
57
+ metadataLines: shell.metadataLines,
58
+ statusTableLines: shell.statusTableLines,
59
+ });
19
60
  }
20
- const DASH = "—";
21
61
  function formatErrorDetail(error) {
22
62
  if (error instanceof Error) {
23
63
  return error.message;
@@ -53,14 +93,62 @@ export function createRunRenderer(options = {}) {
53
93
  const stdout = options.stdout ?? process.stdout;
54
94
  const stderr = options.stderr ?? process.stderr;
55
95
  const now = options.now ?? Date.now.bind(Date);
96
+ const suppressLeadingBlankLine = options.suppressLeadingBlankLine === true;
97
+ const suppressTrailingBlankLine = options.suppressTrailingBlankLine === true;
56
98
  let context;
57
- let disabled = shouldSuppressRunStatusTable();
99
+ let disabled = false;
58
100
  let warningLogged = false;
59
- let lastRenderedLines = 0;
60
- let blockInitialized = false;
61
- let metadataPrinted = false;
101
+ let refreshInterval;
102
+ let lastElapsedLabel = null;
103
+ const interactiveFrameRenderer = createInteractiveFrameRenderer(stdout);
62
104
  const agentOrder = [];
63
105
  const agentRecords = new Map();
106
+ function stopRefreshLoop() {
107
+ if (!refreshInterval) {
108
+ return;
109
+ }
110
+ clearInterval(refreshInterval);
111
+ refreshInterval = undefined;
112
+ }
113
+ function hasRunningAgents() {
114
+ for (const record of agentRecords.values()) {
115
+ if (record.status === "running") {
116
+ return true;
117
+ }
118
+ }
119
+ return false;
120
+ }
121
+ function syncRefreshLoop() {
122
+ if (!stdout.isTTY || disabled) {
123
+ stopRefreshLoop();
124
+ return;
125
+ }
126
+ if (!hasRunningAgents()) {
127
+ stopRefreshLoop();
128
+ return;
129
+ }
130
+ if (refreshInterval) {
131
+ return;
132
+ }
133
+ refreshInterval = setInterval(() => {
134
+ guard(() => {
135
+ if (!stdout.isTTY || disabled || !context) {
136
+ stopRefreshLoop();
137
+ return;
138
+ }
139
+ if (!hasRunningAgents()) {
140
+ stopRefreshLoop();
141
+ return;
142
+ }
143
+ const nextElapsed = formatRunElapsed(context);
144
+ if (nextElapsed === lastElapsedLabel) {
145
+ return;
146
+ }
147
+ render();
148
+ });
149
+ }, 1000);
150
+ refreshInterval.unref?.();
151
+ }
64
152
  function guard(action) {
65
153
  if (disabled) {
66
154
  return;
@@ -70,6 +158,7 @@ export function createRunRenderer(options = {}) {
70
158
  }
71
159
  catch (error) {
72
160
  disabled = true;
161
+ stopRefreshLoop();
73
162
  if (!warningLogged) {
74
163
  warningLogged = true;
75
164
  const detail = formatErrorDetail(error);
@@ -77,84 +166,48 @@ export function createRunRenderer(options = {}) {
77
166
  }
78
167
  }
79
168
  }
80
- function buildInteractiveLines(metadataLines, tableLines) {
81
- if (metadataLines.length === 0) {
82
- return [];
83
- }
84
- const lines = [""];
85
- lines.push(...metadataLines);
86
- if (tableLines.length > 0) {
87
- lines.push("");
88
- lines.push(...tableLines);
89
- }
90
- lines.push("");
91
- return lines;
169
+ function resolveFinalContext(report) {
170
+ return {
171
+ runId: context?.runId ?? report.runId,
172
+ status: report.status,
173
+ workspacePath: context?.workspacePath ?? "",
174
+ createdAt: context?.createdAt ?? report.createdAt,
175
+ startedAt: context?.startedAt ?? report.startedAt,
176
+ completedAt: context?.completedAt ?? report.completedAt,
177
+ };
92
178
  }
93
- function buildTableRefreshLines(tableLines) {
94
- if (tableLines.length === 0) {
95
- return [];
96
- }
97
- return ["", ...tableLines, ""];
179
+ function buildRunStageShell(source, style) {
180
+ const elapsedLabel = formatRunElapsed(source);
181
+ lastElapsedLabel = elapsedLabel ?? null;
182
+ return {
183
+ metadataLines: buildRunMetadataSectionWithStyle({
184
+ runId: source.runId,
185
+ status: source.status,
186
+ workspacePath: source.workspacePath,
187
+ elapsed: elapsedLabel,
188
+ createdAt: formatRunTimestamp(source.createdAt),
189
+ }, style),
190
+ statusTableLines: buildAgentTable(style),
191
+ };
98
192
  }
99
193
  function render() {
100
- if (!context || disabled) {
194
+ if (!context || disabled || !stdout.isTTY) {
101
195
  return;
102
196
  }
103
- const metadataLines = buildRunMetadataSection({
104
- runId: context.runId,
105
- status: context.status,
106
- specPath: context.specPath,
107
- workspacePath: context.workspacePath,
108
- createdAt: formatRunTimestamp(context.createdAt),
109
- baseRevisionSha: context.baseRevisionSha,
197
+ const style = resolveTranscriptShellStyleFromWriter(stdout, { forceTty: true });
198
+ const shell = buildRunStageShell(context, style);
199
+ const interactiveLines = buildStageFrameLines({
200
+ metadataLines: shell.metadataLines,
201
+ statusTableLines: shell.statusTableLines,
202
+ leadingBlankLine: !suppressLeadingBlankLine,
203
+ trailingBlankLine: !suppressTrailingBlankLine,
110
204
  });
111
- const tableLines = buildAgentTable();
112
- const shouldIncludeTable = tableLines.length > 0;
113
- const interactiveLines = buildInteractiveLines(metadataLines, tableLines);
114
- if (stdout.isTTY) {
115
- if (interactiveLines.length === 0) {
116
- return;
117
- }
118
- if (!blockInitialized) {
119
- stdout.write(interactiveLines.join("\n"));
120
- lastRenderedLines = interactiveLines.length;
121
- blockInitialized = true;
122
- return;
123
- }
124
- const linesToRewind = Math.max(0, lastRenderedLines - 1);
125
- if (linesToRewind > 0) {
126
- stdout.write(cursorUp(linesToRewind));
127
- }
128
- stdout.write(CURSOR_COLUMN_START);
129
- const totalLines = Math.max(lastRenderedLines, interactiveLines.length);
130
- const rewrittenLines = [];
131
- for (let index = 0; index < totalLines; index += 1) {
132
- const line = interactiveLines[index] ?? "";
133
- rewrittenLines.push(CURSOR_COLUMN_START, ERASE_LINE, line);
134
- if (index < totalLines - 1) {
135
- rewrittenLines.push("\n");
136
- }
137
- }
138
- stdout.write(rewrittenLines.join(""));
139
- lastRenderedLines = totalLines;
140
- return;
141
- }
142
- if (!metadataPrinted) {
143
- if (interactiveLines.length > 0) {
144
- stdout.write(interactiveLines.join("\n"));
145
- }
146
- metadataPrinted = true;
205
+ if (interactiveLines.length === 0) {
147
206
  return;
148
207
  }
149
- if (!shouldIncludeTable) {
150
- return;
151
- }
152
- const refreshLines = buildTableRefreshLines(tableLines);
153
- if (refreshLines.length > 0) {
154
- stdout.write(refreshLines.join("\n"));
155
- }
208
+ interactiveFrameRenderer.render(interactiveLines);
156
209
  }
157
- function buildAgentTable() {
210
+ function buildAgentTable(style) {
158
211
  if (agentRecords.size === 0) {
159
212
  return [];
160
213
  }
@@ -163,22 +216,18 @@ export function createRunRenderer(options = {}) {
163
216
  .map((agentId) => {
164
217
  const record = agentRecords.get(agentId);
165
218
  return {
166
- agentId: formatAgentBadge(agentId),
167
- status: formatAgentStatusLabel(record.status),
168
- elapsed: formatElapsed(record),
219
+ agentId: formatAgentBadge(agentId, style),
220
+ status: formatAgentStatusLabelWithStyle(record.status, style),
221
+ duration: formatDuration(record),
169
222
  diff: formatDiffCell(record.diffStatistics),
170
- evals: formatEvals(record),
171
223
  };
172
224
  });
173
- return renderTable({
174
- columns: [
175
- { header: "AGENT", accessor: (row) => row.agentId },
176
- { header: "STATUS", accessor: (row) => row.status },
177
- { header: "ELAPSED", accessor: (row) => row.elapsed },
178
- { header: "CHANGES", accessor: (row) => row.diff },
179
- { header: "EVALS", accessor: (row) => row.evals },
180
- ],
225
+ return renderTranscriptStatusTable({
181
226
  rows,
227
+ agent: (row) => row.agentId,
228
+ status: (row) => row.status,
229
+ duration: (row) => row.duration,
230
+ extras: [{ header: "CHANGES", accessor: (row) => row.diff }],
182
231
  });
183
232
  }
184
233
  function formatDiffCell(value) {
@@ -188,45 +237,23 @@ export function createRunRenderer(options = {}) {
188
237
  }
189
238
  return value ?? DASH;
190
239
  }
191
- function formatElapsed(record) {
192
- if (!record.startedAt) {
240
+ function formatDuration(record) {
241
+ if (record.status === "running") {
193
242
  return DASH;
194
243
  }
195
- const started = Date.parse(record.startedAt);
196
- if (Number.isNaN(started)) {
197
- return DASH;
198
- }
199
- if (!record.completedAt && record.status === "running") {
200
- const elapsedMs = Math.max(0, now() - started);
201
- const formattedElapsed = formatDurationLabel(elapsedMs);
202
- return formattedElapsed ?? DASH;
203
- }
204
- if (!record.completedAt) {
205
- return DASH;
206
- }
207
- const formatted = formatAgentDuration({
208
- agentId: record.agentId,
209
- status: record.status,
210
- startedAt: record.startedAt,
211
- completedAt: record.completedAt,
212
- });
213
- if (formatted) {
214
- return formatted;
215
- }
216
- const completed = Date.parse(record.completedAt);
217
- if (Number.isNaN(completed)) {
218
- return DASH;
219
- }
220
- const elapsed = formatDurationLabel(Math.max(0, completed - started));
221
- return elapsed ?? DASH;
244
+ const duration = formatAgentDuration(record, { now: now() });
245
+ return duration ?? DASH;
222
246
  }
223
- function formatEvals(record) {
224
- if (!record.evals || record.evals.length === 0) {
225
- return DASH;
226
- }
227
- return record.evals
228
- .map((evaluation) => colorize(evaluation.slug, getEvalStatusStyle(evaluation.status).cli))
229
- .join(" ");
247
+ function formatRunElapsed(source) {
248
+ return formatRenderLifecycleDuration({
249
+ lifecycle: {
250
+ status: source.status,
251
+ startedAt: source.startedAt,
252
+ completedAt: source.completedAt,
253
+ },
254
+ terminalStatuses: TERMINAL_RUN_STATUSES,
255
+ now: now(),
256
+ });
230
257
  }
231
258
  function upsertRecord(record) {
232
259
  if (!agentOrder.includes(record.agentId)) {
@@ -234,6 +261,22 @@ export function createRunRenderer(options = {}) {
234
261
  }
235
262
  agentRecords.set(record.agentId, record);
236
263
  }
264
+ function syncRecordsFromReport(report) {
265
+ const sortedAgents = [...report.agents].sort((a, b) => a.agentId.localeCompare(b.agentId));
266
+ for (const agent of sortedAgents) {
267
+ const existing = agentRecords.get(agent.agentId);
268
+ upsertRecord({
269
+ agentId: agent.agentId,
270
+ model: existing?.model ?? "unknown",
271
+ status: agent.status,
272
+ startedAt: agent.startedAt,
273
+ completedAt: agent.completedAt,
274
+ diffStatistics: agent.diffStatistics,
275
+ error: agent.error,
276
+ warnings: agent.warnings,
277
+ });
278
+ }
279
+ }
237
280
  function ensureFinalRender(report) {
238
281
  if (!context) {
239
282
  return;
@@ -241,55 +284,88 @@ export function createRunRenderer(options = {}) {
241
284
  context = {
242
285
  ...context,
243
286
  status: report.status,
287
+ startedAt: report.startedAt ?? context.startedAt,
288
+ completedAt: report.completedAt ?? context.completedAt,
244
289
  };
245
290
  render();
246
291
  }
247
292
  return {
293
+ onProgressEvent(event) {
294
+ guard(() => {
295
+ if (event.stage !== "run") {
296
+ return;
297
+ }
298
+ if (event.type === "stage.begin") {
299
+ context = { ...event.context };
300
+ render();
301
+ syncRefreshLoop();
302
+ return;
303
+ }
304
+ if (event.type === "stage.candidate") {
305
+ upsertRecord(event.candidate);
306
+ render();
307
+ syncRefreshLoop();
308
+ return;
309
+ }
310
+ if (!context) {
311
+ return;
312
+ }
313
+ context = {
314
+ ...context,
315
+ status: event.status,
316
+ };
317
+ render();
318
+ syncRefreshLoop();
319
+ });
320
+ },
248
321
  begin(beginContext) {
249
322
  guard(() => {
250
323
  if (!beginContext) {
251
324
  render();
325
+ syncRefreshLoop();
252
326
  return;
253
327
  }
254
- context = { ...beginContext };
255
- render();
328
+ this.onProgressEvent({
329
+ type: "stage.begin",
330
+ stage: "run",
331
+ context: beginContext,
332
+ });
256
333
  });
257
334
  },
258
335
  update(record) {
259
- guard(() => {
260
- upsertRecord(record);
261
- render();
336
+ this.onProgressEvent({
337
+ type: "stage.candidate",
338
+ stage: "run",
339
+ candidate: record,
262
340
  });
263
341
  },
264
- complete(report) {
265
- let transcript = "";
342
+ complete(report, options) {
343
+ stopRefreshLoop();
344
+ syncRecordsFromReport(report);
266
345
  guard(() => {
346
+ this.onProgressEvent({
347
+ type: "stage.status",
348
+ stage: "run",
349
+ status: report.status,
350
+ });
267
351
  ensureFinalRender(report);
268
352
  disabled = true;
269
353
  });
270
- const hint = {
271
- message: `To review results:\n voratiq review --run ${report.runId}`,
272
- };
273
- const sections = stdout.isTTY
354
+ const hint = options?.suppressHint
274
355
  ? undefined
275
- : buildRunTranscriptSections(report);
276
- transcript = renderTranscript({ sections, hint });
277
- return transcript;
356
+ : {
357
+ message: `To verify results:\n voratiq verify --run ${report.runId}`,
358
+ };
359
+ if (stdout.isTTY) {
360
+ return hint?.message ?? "";
361
+ }
362
+ const finalContext = resolveFinalContext(report);
363
+ const finalShell = buildRunStageShell(finalContext, { isTty: false });
364
+ return renderStageFinalFrame({
365
+ metadataLines: finalShell.metadataLines,
366
+ statusTableLines: finalShell.statusTableLines,
367
+ hint,
368
+ });
278
369
  },
279
370
  };
280
371
  }
281
- export function buildRunTranscriptSections(report) {
282
- const sections = [];
283
- const headerLines = [];
284
- headerLines.push(`${report.runId} ${report.status.toUpperCase()}`);
285
- sections.push(headerLines);
286
- const agentLines = [];
287
- const sortedAgents = [...report.agents].sort((a, b) => a.agentId.localeCompare(b.agentId));
288
- for (const agent of sortedAgents) {
289
- agentLines.push(` ${agent.agentId} ${agent.status.toUpperCase()}`);
290
- }
291
- if (agentLines.length > 0) {
292
- sections.push(agentLines);
293
- }
294
- return sections;
295
- }
@@ -8,5 +8,7 @@ export interface TranscriptScaffoldOptions {
8
8
  afterAgents?: readonly string[][];
9
9
  warnings?: readonly string[];
10
10
  hint?: TranscriptHintOptions;
11
+ isTty?: boolean;
11
12
  }
13
+ export declare function renderWorkspaceAutoInitializedNotice(): string;
12
14
  export declare function renderTranscriptWithMetadata(options: TranscriptScaffoldOptions): string;
@@ -1,19 +1,26 @@
1
- import { buildAgentSection } from "../utils/agents.js";
2
- import { buildRunMetadataSection } from "../utils/runs.js";
1
+ import { buildAgentSectionWithStyle } from "../utils/agents.js";
2
+ import { buildRunMetadataSectionWithStyle } from "../utils/runs.js";
3
3
  import { renderTranscript } from "../utils/transcript.js";
4
+ export function renderWorkspaceAutoInitializedNotice() {
5
+ return "Voratiq initialized (.voratiq/).";
6
+ }
4
7
  export function renderTranscriptWithMetadata(options) {
5
8
  const sections = buildTranscriptSections(options);
6
9
  return renderTranscript({ sections, hint: options.hint });
7
10
  }
8
11
  function buildTranscriptSections(options) {
9
12
  const sections = [];
10
- const metadataSection = buildRunMetadataSection(options.metadata);
13
+ const metadataSection = buildRunMetadataSectionWithStyle(options.metadata, {
14
+ isTty: options.isTty,
15
+ });
11
16
  if (metadataSection.length > 0) {
12
17
  sections.push(metadataSection);
13
18
  }
14
19
  appendSections(sections, options.beforeAgents);
15
20
  options.agents.forEach((agent) => {
16
- const agentSection = buildAgentSection(agent);
21
+ const agentSection = buildAgentSectionWithStyle(agent, {
22
+ isTty: options.isTty,
23
+ });
17
24
  if (agentSection.length > 0) {
18
25
  sections.push(agentSection);
19
26
  }
@@ -0,0 +1,74 @@
1
+ import type { ExtractedTokenUsage } from "../../domain/run/model/types.js";
2
+ import type { TokenUsageResult } from "../../workspace/chat/token-usage-result.js";
3
+ import type { StageProgressEventConsumer } from "./stage-progress.js";
4
+ type CliWriter = Pick<NodeJS.WriteStream, "write"> & {
5
+ isTTY?: boolean;
6
+ columns?: number;
7
+ };
8
+ export interface SpecProgressContext {
9
+ sessionId: string;
10
+ createdAt: string;
11
+ startedAt?: string;
12
+ completedAt?: string;
13
+ workspacePath: string;
14
+ status: "running" | "succeeded" | "failed" | "aborted";
15
+ }
16
+ export interface SpecProgressAgentRecord {
17
+ agentId: string;
18
+ status: "queued" | "running" | "succeeded" | "failed";
19
+ startedAt?: string;
20
+ completedAt?: string;
21
+ tokenUsage?: ExtractedTokenUsage;
22
+ tokenUsageResult?: TokenUsageResult;
23
+ }
24
+ interface SpecRendererOptions {
25
+ stdout?: CliWriter;
26
+ stderr?: CliWriter;
27
+ now?: () => number;
28
+ suppressLeadingBlankLine?: boolean;
29
+ suppressTrailingBlankLine?: boolean;
30
+ }
31
+ export interface SpecProgressRenderer extends StageProgressEventConsumer<SpecProgressContext, SpecProgressAgentRecord> {
32
+ begin(context?: SpecProgressContext): void;
33
+ update(record: SpecProgressAgentRecord): void;
34
+ complete(status?: SpecProgressContext["status"], lifecycle?: {
35
+ startedAt?: string;
36
+ completedAt?: string;
37
+ }): void;
38
+ }
39
+ export interface SpecTranscriptAgentBlock {
40
+ agentId: string;
41
+ status: "queued" | "running" | "succeeded" | "failed";
42
+ duration: string;
43
+ outputPath?: string;
44
+ dataPath?: string;
45
+ previewLines?: readonly string[];
46
+ errorLine?: string;
47
+ }
48
+ export interface SpecTranscriptOptions {
49
+ sessionId: string;
50
+ createdAt: string;
51
+ elapsed: string;
52
+ workspacePath: string;
53
+ status: "running" | "succeeded" | "failed" | "aborted";
54
+ agents: readonly SpecTranscriptAgentBlock[];
55
+ nextCommandLines?: readonly string[];
56
+ isTty?: boolean;
57
+ includeSummarySection?: boolean;
58
+ }
59
+ export declare function createSpecRenderer(options?: SpecRendererOptions): SpecProgressRenderer;
60
+ export declare function formatSpecElapsed(options: {
61
+ status: SpecProgressContext["status"];
62
+ startedAt?: string;
63
+ completedAt?: string;
64
+ }, now?: number): string | undefined;
65
+ export declare function formatSpecAgentDuration(options: {
66
+ status: SpecTranscriptAgentBlock["status"];
67
+ startedAt?: string;
68
+ completedAt?: string;
69
+ now?: number;
70
+ }): string;
71
+ export declare function renderSpecTranscript(input: SpecTranscriptOptions | string, options?: {
72
+ suppressHint?: boolean;
73
+ }): string;
74
+ export {};