cli-jaw 2.0.5 → 2.0.6

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 (614) hide show
  1. package/README.ja.md +229 -315
  2. package/README.ko.md +248 -315
  3. package/README.md +103 -186
  4. package/README.zh-CN.md +282 -296
  5. package/dist/bin/commands/browser-web-ai.js +4 -2
  6. package/dist/bin/commands/browser-web-ai.js.map +1 -1
  7. package/dist/bin/commands/browser.js +76 -0
  8. package/dist/bin/commands/browser.js.map +1 -1
  9. package/dist/bin/commands/doctor.js +122 -4
  10. package/dist/bin/commands/doctor.js.map +1 -1
  11. package/dist/bin/commands/skill.js +5 -3
  12. package/dist/bin/commands/skill.js.map +1 -1
  13. package/dist/bin/postinstall.js +507 -89
  14. package/dist/bin/postinstall.js.map +1 -1
  15. package/dist/lib/mcp/format-converters.js +32 -4
  16. package/dist/lib/mcp/format-converters.js.map +1 -1
  17. package/dist/lib/mcp/mcp-install.js +5 -0
  18. package/dist/lib/mcp/mcp-install.js.map +1 -1
  19. package/dist/lib/mcp/skills-distribution.js +52 -53
  20. package/dist/lib/mcp/skills-distribution.js.map +1 -1
  21. package/dist/lib/mcp/skills-reset.js +29 -16
  22. package/dist/lib/mcp/skills-reset.js.map +1 -1
  23. package/dist/lib/mcp/skills-utils.js +64 -2
  24. package/dist/lib/mcp/skills-utils.js.map +1 -1
  25. package/dist/lib/mcp/unified-config.js +7 -3
  26. package/dist/lib/mcp/unified-config.js.map +1 -1
  27. package/dist/scripts/fresh-install-smoke.js +1 -1
  28. package/dist/scripts/fresh-install-smoke.js.map +1 -1
  29. package/dist/server.js +44 -4
  30. package/dist/server.js.map +1 -1
  31. package/dist/src/agent/args.js +148 -1
  32. package/dist/src/agent/args.js.map +1 -1
  33. package/dist/src/agent/claude-e-runtime.js +42 -0
  34. package/dist/src/agent/claude-e-runtime.js.map +1 -0
  35. package/dist/src/agent/claude-i-runtime.js +42 -0
  36. package/dist/src/agent/claude-i-runtime.js.map +1 -0
  37. package/dist/src/agent/cli-helpers.js +9 -0
  38. package/dist/src/agent/cli-helpers.js.map +1 -0
  39. package/dist/src/agent/codex-app-client.js +240 -0
  40. package/dist/src/agent/codex-app-client.js.map +1 -0
  41. package/dist/src/agent/codex-app-events.js +268 -0
  42. package/dist/src/agent/codex-app-events.js.map +1 -0
  43. package/dist/src/agent/error-classifier.js +8 -2
  44. package/dist/src/agent/error-classifier.js.map +1 -1
  45. package/dist/src/agent/events/acp.js +200 -0
  46. package/dist/src/agent/events/acp.js.map +1 -0
  47. package/dist/src/agent/events/claude.js +200 -0
  48. package/dist/src/agent/events/claude.js.map +1 -0
  49. package/dist/src/agent/events/codex.js +118 -0
  50. package/dist/src/agent/events/codex.js.map +1 -0
  51. package/dist/src/agent/events/gemini.js +100 -0
  52. package/dist/src/agent/events/gemini.js.map +1 -0
  53. package/dist/src/agent/events/grok.js +298 -0
  54. package/dist/src/agent/events/grok.js.map +1 -0
  55. package/dist/src/agent/events/helpers.js +237 -0
  56. package/dist/src/agent/events/helpers.js.map +1 -0
  57. package/dist/src/agent/events/index.js +315 -0
  58. package/dist/src/agent/events/index.js.map +1 -0
  59. package/dist/src/agent/events/opencode.js +171 -0
  60. package/dist/src/agent/events/opencode.js.map +1 -0
  61. package/dist/src/agent/events/summary.js +128 -0
  62. package/dist/src/agent/events/summary.js.map +1 -0
  63. package/dist/src/agent/events/tool-labels.js +299 -0
  64. package/dist/src/agent/events/tool-labels.js.map +1 -0
  65. package/dist/src/agent/events/types.js +3 -0
  66. package/dist/src/agent/events/types.js.map +1 -0
  67. package/dist/src/agent/events.js +2 -1487
  68. package/dist/src/agent/events.js.map +1 -1
  69. package/dist/src/agent/grok-trace-backfill.js +153 -0
  70. package/dist/src/agent/grok-trace-backfill.js.map +1 -0
  71. package/dist/src/agent/lifecycle-handler.js +60 -16
  72. package/dist/src/agent/lifecycle-handler.js.map +1 -1
  73. package/dist/src/agent/live-run-state.js +1 -1
  74. package/dist/src/agent/live-run-state.js.map +1 -1
  75. package/dist/src/agent/memory-flush-controller.js +26 -0
  76. package/dist/src/agent/memory-flush-controller.js.map +1 -1
  77. package/dist/src/agent/resume-classifier.js +9 -0
  78. package/dist/src/agent/resume-classifier.js.map +1 -1
  79. package/dist/src/agent/session-persistence.js +7 -2
  80. package/dist/src/agent/session-persistence.js.map +1 -1
  81. package/dist/src/agent/spawn/process-kill.js +29 -0
  82. package/dist/src/agent/spawn/process-kill.js.map +1 -0
  83. package/dist/src/agent/spawn/queue.js +273 -0
  84. package/dist/src/agent/spawn/queue.js.map +1 -0
  85. package/dist/src/agent/spawn/resume.js +56 -0
  86. package/dist/src/agent/spawn/resume.js.map +1 -0
  87. package/dist/src/agent/spawn.js +435 -371
  88. package/dist/src/agent/spawn.js.map +1 -1
  89. package/dist/src/agent/watchdog.js +5 -1
  90. package/dist/src/agent/watchdog.js.map +1 -1
  91. package/dist/src/browser/adaptive-fetch/browser-escalation.js +177 -0
  92. package/dist/src/browser/adaptive-fetch/browser-escalation.js.map +1 -0
  93. package/dist/src/browser/adaptive-fetch/browser-runtime.js +38 -0
  94. package/dist/src/browser/adaptive-fetch/browser-runtime.js.map +1 -0
  95. package/dist/src/browser/adaptive-fetch/browser-session.js +97 -0
  96. package/dist/src/browser/adaptive-fetch/browser-session.js.map +1 -0
  97. package/dist/src/browser/adaptive-fetch/challenge-detector.js +88 -0
  98. package/dist/src/browser/adaptive-fetch/challenge-detector.js.map +1 -0
  99. package/dist/src/browser/adaptive-fetch/content-scorer.js +145 -0
  100. package/dist/src/browser/adaptive-fetch/content-scorer.js.map +1 -0
  101. package/dist/src/browser/adaptive-fetch/endpoint-resolvers.js +382 -0
  102. package/dist/src/browser/adaptive-fetch/endpoint-resolvers.js.map +1 -0
  103. package/dist/src/browser/adaptive-fetch/fetcher.js +105 -0
  104. package/dist/src/browser/adaptive-fetch/fetcher.js.map +1 -0
  105. package/dist/src/browser/adaptive-fetch/human-loop.js +101 -0
  106. package/dist/src/browser/adaptive-fetch/human-loop.js.map +1 -0
  107. package/dist/src/browser/adaptive-fetch/index.js +586 -0
  108. package/dist/src/browser/adaptive-fetch/index.js.map +1 -0
  109. package/dist/src/browser/adaptive-fetch/metadata.js +169 -0
  110. package/dist/src/browser/adaptive-fetch/metadata.js.map +1 -0
  111. package/dist/src/browser/adaptive-fetch/output.js +71 -0
  112. package/dist/src/browser/adaptive-fetch/output.js.map +1 -0
  113. package/dist/src/browser/adaptive-fetch/reader-adapters.js +135 -0
  114. package/dist/src/browser/adaptive-fetch/reader-adapters.js.map +1 -0
  115. package/dist/src/browser/adaptive-fetch/safety.js +296 -0
  116. package/dist/src/browser/adaptive-fetch/safety.js.map +1 -0
  117. package/dist/src/browser/adaptive-fetch/third-party-readers.js +43 -0
  118. package/dist/src/browser/adaptive-fetch/third-party-readers.js.map +1 -0
  119. package/dist/src/browser/adaptive-fetch/trace.js +61 -0
  120. package/dist/src/browser/adaptive-fetch/trace.js.map +1 -0
  121. package/dist/src/browser/adaptive-fetch/transforms.js +81 -0
  122. package/dist/src/browser/adaptive-fetch/transforms.js.map +1 -0
  123. package/dist/src/browser/adaptive-fetch/validators.js +108 -0
  124. package/dist/src/browser/adaptive-fetch/validators.js.map +1 -0
  125. package/dist/src/browser/adaptive-fetch/waf-profiles.js +135 -0
  126. package/dist/src/browser/adaptive-fetch/waf-profiles.js.map +1 -0
  127. package/dist/src/browser/index.js +1 -0
  128. package/dist/src/browser/index.js.map +1 -1
  129. package/dist/src/browser/web-ai/gemini-model.js +42 -15
  130. package/dist/src/browser/web-ai/gemini-model.js.map +1 -1
  131. package/dist/src/cli/claude-models.js +1 -1
  132. package/dist/src/cli/claude-models.js.map +1 -1
  133. package/dist/src/cli/compact.js +2 -0
  134. package/dist/src/cli/compact.js.map +1 -1
  135. package/dist/src/cli/handlers-completions.js +3 -0
  136. package/dist/src/cli/handlers-completions.js.map +1 -1
  137. package/dist/src/cli/handlers-runtime.js +5 -2
  138. package/dist/src/cli/handlers-runtime.js.map +1 -1
  139. package/dist/src/cli/readiness.js +43 -1
  140. package/dist/src/cli/readiness.js.map +1 -1
  141. package/dist/src/cli/registry.js +58 -0
  142. package/dist/src/cli/registry.js.map +1 -1
  143. package/dist/src/core/browser-open.js +4 -1
  144. package/dist/src/core/browser-open.js.map +1 -1
  145. package/dist/src/core/claude-install.js +4 -0
  146. package/dist/src/core/claude-install.js.map +1 -1
  147. package/dist/src/core/cli-detect.js +61 -13
  148. package/dist/src/core/cli-detect.js.map +1 -1
  149. package/dist/src/core/compact.js +295 -63
  150. package/dist/src/core/compact.js.map +1 -1
  151. package/dist/src/core/config.js +151 -11
  152. package/dist/src/core/config.js.map +1 -1
  153. package/dist/src/core/db.js +10 -1
  154. package/dist/src/core/db.js.map +1 -1
  155. package/dist/src/core/employees.js +1 -1
  156. package/dist/src/core/employees.js.map +1 -1
  157. package/dist/src/core/logger.js +28 -9
  158. package/dist/src/core/logger.js.map +1 -1
  159. package/dist/src/core/runtime-settings.js +32 -5
  160. package/dist/src/core/runtime-settings.js.map +1 -1
  161. package/dist/src/manager/memory/embedding/state-machine.js +2 -1
  162. package/dist/src/manager/memory/embedding/state-machine.js.map +1 -1
  163. package/dist/src/manager/memory/embedding/sync.js +52 -33
  164. package/dist/src/manager/memory/embedding/sync.js.map +1 -1
  165. package/dist/src/manager/memory/embedding/vec-store.js +10 -10
  166. package/dist/src/manager/memory/embedding/vec-store.js.map +1 -1
  167. package/dist/src/manager/routes/dashboard-memory.js +43 -16
  168. package/dist/src/manager/routes/dashboard-memory.js.map +1 -1
  169. package/dist/src/manager/server.js +11 -0
  170. package/dist/src/manager/server.js.map +1 -1
  171. package/dist/src/memory/indexing.js +6 -1
  172. package/dist/src/memory/indexing.js.map +1 -1
  173. package/dist/src/orchestrator/distribute.js +5 -4
  174. package/dist/src/orchestrator/distribute.js.map +1 -1
  175. package/dist/src/prompt/builder.js +12 -1
  176. package/dist/src/prompt/builder.js.map +1 -1
  177. package/dist/src/prompt/runtime-context.js +69 -0
  178. package/dist/src/prompt/runtime-context.js.map +1 -0
  179. package/dist/src/routes/browser.js +33 -0
  180. package/dist/src/routes/browser.js.map +1 -1
  181. package/dist/src/routes/employees.js +1 -1
  182. package/dist/src/routes/employees.js.map +1 -1
  183. package/dist/src/routes/memory.js +1 -1
  184. package/dist/src/routes/memory.js.map +1 -1
  185. package/dist/src/routes/orchestrate.js +37 -10
  186. package/dist/src/routes/orchestrate.js.map +1 -1
  187. package/dist/src/routes/quota.js +91 -1
  188. package/dist/src/routes/quota.js.map +1 -1
  189. package/dist/src/routes/runtime-context.js +43 -0
  190. package/dist/src/routes/runtime-context.js.map +1 -0
  191. package/dist/src/routes/security-audit.js +14 -0
  192. package/dist/src/routes/security-audit.js.map +1 -0
  193. package/dist/src/routes/settings.js +8 -1
  194. package/dist/src/routes/settings.js.map +1 -1
  195. package/dist/src/security/security-audit-log.js +99 -0
  196. package/dist/src/security/security-audit-log.js.map +1 -0
  197. package/dist/src/telegram/bot.js +4 -2
  198. package/dist/src/telegram/bot.js.map +1 -1
  199. package/dist/src/types/cli-engine.js +4 -0
  200. package/dist/src/types/cli-engine.js.map +1 -1
  201. package/dist/src/types/cli-events.js +1 -1
  202. package/dist/src/types/cli-events.js.map +1 -1
  203. package/package.json +9 -3
  204. package/public/assets/providers/antigravity-color.svg +1 -0
  205. package/public/assets/providers/antigravity.svg +1 -0
  206. package/public/assets/providers/copilot-color.svg +1 -1
  207. package/public/assets/providers/copilot.svg +1 -1
  208. package/public/assets/providers/grok-color.svg +1 -0
  209. package/public/assets/providers/grok.svg +1 -0
  210. package/public/css/chat-search.css +168 -0
  211. package/public/css/chat.css +43 -1
  212. package/public/css/modals.css +41 -0
  213. package/public/dist/assets/{AdvancedExport-BAdZUC-6.js → AdvancedExport-CBvz4_IZ.js} +1 -1
  214. package/public/dist/assets/Agent-DlUqCMXJ.js +1 -0
  215. package/public/dist/assets/{Browser-BsdxDVgM.js → Browser-66BpLQck.js} +1 -1
  216. package/public/dist/assets/{ChannelsDiscord-Dg_jto6l.js → ChannelsDiscord-BifT2Dum.js} +1 -1
  217. package/public/dist/assets/{ChannelsTelegram-DGyZfJGS.js → ChannelsTelegram-CK6tYQ8k.js} +1 -1
  218. package/public/dist/assets/DashboardEmbeddingSection-6F8zSSja.js +2 -0
  219. package/public/dist/assets/{DashboardMeta-CAH9ONTb.js → DashboardMeta-Cc03HT5R.js} +1 -1
  220. package/public/dist/assets/{Display-DM_yvyKL.js → Display-arOjcMQZ.js} +1 -1
  221. package/public/dist/assets/Employees-YbW-mI67.js +1 -0
  222. package/public/dist/assets/{HealthBadge-Dtr-dDnw.js → HealthBadge-DEPFkcA0.js} +1 -1
  223. package/public/dist/assets/Heartbeat-CW4eIhtJ.js +1 -0
  224. package/public/dist/assets/{InlineWarn-E64UaKFh.js → InlineWarn-DoJS7AgM.js} +1 -1
  225. package/public/dist/assets/{Mcp-Dlp2X7X7.js → Mcp-ZQ6ARQb6.js} +1 -1
  226. package/public/dist/assets/Memory-BAUWJMqc.js +1 -0
  227. package/public/dist/assets/{MilkdownWysiwygEditor-Ctww8i0L.js → MilkdownWysiwygEditor-IAqFtXvM.js} +1 -1
  228. package/public/dist/assets/ModelProvider-DUtmFh0J.js +1 -0
  229. package/public/dist/assets/{Network-Df1R2YcQ.js → Network-B_4E82zQ.js} +1 -1
  230. package/public/dist/assets/{Permissions-BKJ5K6EL.js → Permissions-BkADXjQ4.js} +1 -1
  231. package/public/dist/assets/{Permissions-CcWZoOVP.js → Permissions-DvUCB8wA.js} +1 -1
  232. package/public/dist/assets/{Profile-DZ7xf1WZ.js → Profile-BcnTCSYM.js} +1 -1
  233. package/public/dist/assets/{Prompts-Bh5DYt8e.js → Prompts-CUs_RoRE.js} +1 -1
  234. package/public/dist/assets/{SpeechKeys-CQwtVxOP.js → SpeechKeys-qxc-ROWN.js} +1 -1
  235. package/public/dist/assets/agent-meta-Du8y6mSM.js +1 -0
  236. package/public/dist/assets/app-CGqTcIeF.js +39 -0
  237. package/public/dist/assets/app-Dpk6cE6C.css +1 -0
  238. package/public/dist/assets/architecture-7EHR7CIX-wVaUQezY.js +1 -0
  239. package/public/dist/assets/architectureDiagram-3BPJPVTR-kYIVzmWe.js +36 -0
  240. package/public/dist/assets/blockDiagram-GPEHLZMM-B204CPhe.js +132 -0
  241. package/public/dist/assets/{c4Diagram-AHTNJAMY-Bp2QLC-s.js → c4Diagram-AAUBKEIU-DAv6TAjg.js} +6 -6
  242. package/public/dist/assets/channel-CCQujL1n.js +1 -0
  243. package/public/dist/assets/{chunk-EDXVE4YY-COudQKkJ.js → chunk-2J33WTMH-xiPJWKcl.js} +1 -1
  244. package/public/dist/assets/chunk-3OPIFGDE-DOAvk9x8.js +62 -0
  245. package/public/dist/assets/{chunk-4BX2VUAB-Cm3KqBkS.js → chunk-4BX2VUAB-6lTRwyT0.js} +1 -1
  246. package/public/dist/assets/chunk-4EGX6M5U-DXtAEgX6.js +1 -0
  247. package/public/dist/assets/chunk-55IACEB6-Dx2JkQLw.js +1 -0
  248. package/public/dist/assets/chunk-5DO6E6H7-DDcMHB95.js +1 -0
  249. package/public/dist/assets/chunk-5ZQYHXKU-Bd-RFO5i.js +2 -0
  250. package/public/dist/assets/chunk-727SXJPM-BrsRzj8z.js +206 -0
  251. package/public/dist/assets/{chunk-AGHRB4JF-DIMn8T3_.js → chunk-AGHRB4JF-CYdXVA2-.js} +1 -1
  252. package/public/dist/assets/chunk-AQP2D5EJ-Di6Gstk-.js +231 -0
  253. package/public/dist/assets/{chunk-LIHQZDEY-Xw9ZX8of.js → chunk-BR22UD5L-CVuYkAd1.js} +1 -1
  254. package/public/dist/assets/{chunk-BSJP7CBP-DnSYKjii.js → chunk-BSJP7CBP-B47GpxcW.js} +1 -1
  255. package/public/dist/assets/chunk-CSCIHK7Q-CAE1p4Em.js +123 -0
  256. package/public/dist/assets/chunk-FHYWG6QK-CxZt-yZZ.js +1 -0
  257. package/public/dist/assets/{chunk-FMBD7UC4-6yXYicjw.js → chunk-FMBD7UC4-CwqBlx0l.js} +1 -1
  258. package/public/dist/assets/chunk-KSCS5N6A-D9a4ZkOy.js +10 -0
  259. package/public/dist/assets/{chunk-ZZ45TVLE-D5oxCC1O.js → chunk-L5ZTLDWV-D208QbfC.js} +1 -1
  260. package/public/dist/assets/{chunk-336JU56O-CAt5aBOe.js → chunk-LZXEDZCA-CE2KFduj.js} +1 -1
  261. package/public/dist/assets/chunk-MPE355IW-Bp4qAOUf.js +1 -0
  262. package/public/dist/assets/chunk-MZUSXYTE-DAU-v-0c.js +1 -0
  263. package/public/dist/assets/chunk-N66VUXT2-CpPz1L5u.js +1 -0
  264. package/public/dist/assets/chunk-ND2GUHAM-zZ7h1CPf.js +1 -0
  265. package/public/dist/assets/chunk-NNHCCRGN-BaiX9a5F.js +159 -0
  266. package/public/dist/assets/{chunk-X2U36JSP-CoMFMVNF.js → chunk-NZK2D7GU-CTqFQ8K5.js} +1 -1
  267. package/public/dist/assets/chunk-O5CBEL6O-BTuvXKFi.js +11 -0
  268. package/public/dist/assets/chunk-PUPMXCY4-ppZvktf-.js +1 -0
  269. package/public/dist/assets/chunk-QZHKN3VN-CBAtPPT7.js +1 -0
  270. package/public/dist/assets/chunk-UIBZB4QT-rJZEVBX0.js +1 -0
  271. package/public/dist/assets/chunk-WCWK7LTN-CGvUyB8h.js +1 -0
  272. package/public/dist/assets/chunk-WU5MYG2G-C3fKlSvP.js +1 -0
  273. package/public/dist/assets/{chunk-XPW4576I-CmAz5C-j.js → chunk-XPW4576I-BaQfzRci.js} +1 -1
  274. package/public/dist/assets/classDiagram-4FO5ZUOK-Cb-qL5u3.js +1 -0
  275. package/public/dist/assets/classDiagram-v2-Q7XG4LA2-BPhGdj15.js +1 -0
  276. package/public/dist/assets/constants-BxG09J6S.js +1 -0
  277. package/public/dist/assets/cose-bilkent-S5V4N54A-D1zmarou.js +1 -0
  278. package/public/dist/assets/dagre-BM42HDAG-BVkBttzA.js +4 -0
  279. package/public/dist/assets/dagre-DnoxfNXr.js +1 -0
  280. package/public/dist/assets/diagram-2AECGRRQ-Bs32KPnT.js +43 -0
  281. package/public/dist/assets/{diagram-5BDNPKRD-Cl4PzCD0.js → diagram-5GNKFQAL-YDYgPOQj.js} +2 -2
  282. package/public/dist/assets/diagram-KO2AKTUF-1tIdFl26.js +3 -0
  283. package/public/dist/assets/{diagram-TYMM5635-B_Xoa1Gp.js → diagram-LMA3HP47-B1y15kav.js} +1 -1
  284. package/public/dist/assets/diagram-OG6HWLK6-C25j1jGg.js +24 -0
  285. package/public/dist/assets/{dist-C9LWf2uC.js → dist-0v1UKkQ3.js} +1 -1
  286. package/public/dist/assets/dist-BMi_buEb.js +1 -0
  287. package/public/dist/assets/{dist-B6G8pbap.js → dist-BQNQk-1M.js} +1 -1
  288. package/public/dist/assets/{dist-CCKktDoF.js → dist-BVpa_e6W.js} +1 -1
  289. package/public/dist/assets/dist-BkrbW_LS.js +1 -0
  290. package/public/dist/assets/{dist-CkMC2PPt.js → dist-C1VqWrYZ.js} +1 -1
  291. package/public/dist/assets/{dist-BA7sRne4.js → dist-C3vh7d65.js} +1 -1
  292. package/public/dist/assets/{dist-BhzKO6nt2.js → dist-CE4s7vg82.js} +1 -1
  293. package/public/dist/assets/{dist-BDMNMdPF.js → dist-CjPin7Mr.js} +1 -1
  294. package/public/dist/assets/{dist-W7IGn2ug.js → dist-Ck6PnIlo.js} +1 -1
  295. package/public/dist/assets/{dist-B1rKu9eP.js → dist-CnIrGAPx.js} +1 -1
  296. package/public/dist/assets/{dist-CEDX2HGI.js → dist-Cv8S3FhF.js} +1 -1
  297. package/public/dist/assets/{dist-55MYVjjj.js → dist-D0PYXGt2.js} +1 -1
  298. package/public/dist/assets/{dist-C0sOT_UM.js → dist-D5GUqT-6.js} +1 -1
  299. package/public/dist/assets/{dist-C5S-Rbvc.js → dist-D66X8iAn.js} +1 -1
  300. package/public/dist/assets/dist-D815C1Fv.js +1 -0
  301. package/public/dist/assets/{dist-Ch6JG5jE.js → dist-DDDFJ8jG.js} +1 -1
  302. package/public/dist/assets/{dist-2oDfqE98.js → dist-DHQI31dn.js} +1 -1
  303. package/public/dist/assets/{dist-BTp_Oy_x.js → dist-DTQW91xt.js} +1 -1
  304. package/public/dist/assets/{dist-BuaQLcgQ.js → dist-Dm7RAaUo.js} +1 -1
  305. package/public/dist/assets/{dist-BJyDhGpS.js → dist-DrIWh2fi.js} +1 -1
  306. package/public/dist/assets/{dist-BGzHP3f8.js → dist-DzT7frM2.js} +1 -1
  307. package/public/dist/assets/{dist-wdLr2dSH.js → dist-Qs7HHNCC.js} +1 -1
  308. package/public/dist/assets/{dist-BjqyutOM.js → dist-Rs_Khtjb.js} +1 -1
  309. package/public/dist/assets/{dist-DdhWu7OM.js → dist-fJAyK82z.js} +1 -1
  310. package/public/dist/assets/{dist-G7QUHtDS.js → dist-jcptfm_T.js} +1 -1
  311. package/public/dist/assets/dist-sOV2kBhQ.js +1 -0
  312. package/public/dist/assets/{dist-BoG5I6U5.js → dist-vQskrHxt.js} +1 -1
  313. package/public/dist/assets/{dockerfile-CrC2HXHP.js → dockerfile-DAfh5qoE.js} +1 -1
  314. package/public/dist/assets/{employees-CIkIyvtL.js → employees-DRmX2RDd.js} +2 -2
  315. package/public/dist/assets/{erDiagram-SMLLAGMA-BvtqhMsS.js → erDiagram-TEJ5UH35-CRvCbztR.js} +6 -6
  316. package/public/dist/assets/{error-normalize-CkhPeQYx.js → error-normalize-CNbPE4lO.js} +1 -1
  317. package/public/dist/assets/eventmodeling-FCH6USID-Cq0nylxO.js +1 -0
  318. package/public/dist/assets/{factor-1CttFx2G.js → factor-BpoYJieo.js} +1 -1
  319. package/public/dist/assets/fields-DUawAHWZ.js +1 -0
  320. package/public/dist/assets/flowDiagram-I6XJVG4X-CzvVnib_.js +162 -0
  321. package/public/dist/assets/ganttDiagram-6RSMTGT7-BbUYP6iv.js +292 -0
  322. package/public/dist/assets/gitGraph-WXDBUCRP-DDq6-3D3.js +1 -0
  323. package/public/dist/assets/gitGraphDiagram-PVQCEYII-CbKdM7nW.js +106 -0
  324. package/public/dist/assets/graphlib-BLOO0H5r.js +1 -0
  325. package/public/dist/assets/info-J43DQDTF-OUnqwpUV.js +1 -0
  326. package/public/dist/assets/infoDiagram-5YYISTIA-BrZmg1At.js +2 -0
  327. package/public/dist/assets/{ishikawaDiagram-UXIWVN3A-DZW-Nqsf.js → ishikawaDiagram-YF4QCWOH-BDWXqJi5.js} +2 -2
  328. package/public/dist/assets/javascript-CZjRNq5R.js +1 -0
  329. package/public/dist/assets/{journeyDiagram-VCZTEJTY-ByVRJxVF.js → journeyDiagram-JHISSGLW-CPFRd_M3.js} +6 -6
  330. package/public/dist/assets/{jsx-runtime-BjL7qHh8.js → jsx-runtime-BZmCptaP.js} +1 -1
  331. package/public/dist/assets/{kanban-definition-6JOO6SKY-xwN0YCW2.js → kanban-definition-UN3LZRKU-BcQbBplS.js} +10 -10
  332. package/public/dist/assets/katex-CF5bGce6.js +1 -0
  333. package/public/dist/assets/manager-B5OmizBL.css +1 -0
  334. package/public/dist/assets/manager-Cs3eMBcx.js +25 -0
  335. package/public/dist/assets/{memory-CnBc2_Va.js → memory-BA-ki3gn.js} +1 -1
  336. package/public/dist/assets/memory-DLQbyBA3.js +1 -0
  337. package/public/dist/assets/mermaid-loader-BVPsKrpr.js +1 -0
  338. package/public/dist/assets/mermaid-parser.core-C62NUJRb.js +3 -0
  339. package/public/dist/assets/mermaid.core-ArqR5iFa.js +9 -0
  340. package/public/dist/assets/mermaid.core-BAwu4U2Y.js +1 -0
  341. package/public/dist/assets/{mindmap-definition-QFDTVHPH-Chqgsh1N.js → mindmap-definition-RKZ34NQL-C35cGkNU.js} +29 -29
  342. package/public/dist/assets/{nsis-_CjIiUyF.js → nsis-Ch4QINLN.js} +1 -1
  343. package/public/dist/assets/packet-YPE3B663-Bb9hBQ06.js +1 -0
  344. package/public/dist/assets/{page-shell-CTxVDJ8Y.js → page-shell-CVAobxbP.js} +1 -1
  345. package/public/dist/assets/pie-LRSECV5Y-CNRQnRNZ.js +1 -0
  346. package/public/dist/assets/pieDiagram-4H26LBE5-B8C_hoqJ.js +30 -0
  347. package/public/dist/assets/provider-icons-dxT69zGg.js +8 -0
  348. package/public/dist/assets/{pug-CbR8lCtK.js → pug-CXYqmmpP.js} +1 -1
  349. package/public/dist/assets/quadrantDiagram-W4KKPZXB-BEPrine5.js +7 -0
  350. package/public/dist/assets/radar-GUYGQ44K-BxngU2v0.js +1 -0
  351. package/public/dist/assets/{render-lpTpN1El.js → render-C7_e0J_X.js} +3 -3
  352. package/public/dist/assets/{requirementDiagram-MS252O5E-wnPtv0LG.js → requirementDiagram-4Y6WPE33-ClDDon9c.js} +4 -4
  353. package/public/dist/assets/rolldown-runtime-XQCOJYun.js +1 -0
  354. package/public/dist/assets/sankeyDiagram-5OEKKPKP-Bjs3OE-1.js +40 -0
  355. package/public/dist/assets/sequenceDiagram-3UESZ5HK-BM8IAaEe.js +162 -0
  356. package/public/dist/assets/settings-DjyKdqev.js +1 -0
  357. package/public/dist/assets/settings-pUJzyeX2.js +42 -0
  358. package/public/dist/assets/{sidebar-Cwt0FxQl.js → sidebar-CO9Qjj6v.js} +2 -2
  359. package/public/dist/assets/skills-CX3qJ77s.js +1 -0
  360. package/public/dist/assets/{skills-DDmTyywh.js → skills-Dq7fD8I3.js} +1 -1
  361. package/public/dist/assets/{slash-commands-D5y5AVvS.js → slash-commands-DRsKtuGT.js} +1 -1
  362. package/public/dist/assets/slash-commands-UbS8w9ij.js +1 -0
  363. package/public/dist/assets/stateDiagram-AJRCARHV-BvNABuXE.js +1 -0
  364. package/public/dist/assets/stateDiagram-v2-BHNVJYJU-CCIo81qy.js +1 -0
  365. package/public/dist/assets/{timeline-definition-GMOUNBTQ-DUz1-iOx.js → timeline-definition-PNZ67QCA-CIvTvac3.js} +8 -8
  366. package/public/dist/assets/trace-drawer-DDFdU07_.js +15 -0
  367. package/public/dist/assets/treeView-BLDUP644-cXRzPGzz.js +1 -0
  368. package/public/dist/assets/treemap-LRROVOQU-BsZE5HPE.js +1 -0
  369. package/public/dist/assets/ui-CeBmBBZM.js +140 -0
  370. package/public/dist/assets/ui-TMXjvH0r.js +1 -0
  371. package/public/dist/assets/{vendor-render-DEStnpJ8.js → vendor-render-DCb9B75Q.js} +38 -37
  372. package/public/dist/assets/vendor-utils-BnxL60_-.js +1 -0
  373. package/public/dist/assets/vennDiagram-CIIHVFJN-C5cbS2KC.js +34 -0
  374. package/public/dist/assets/wardley-L42UT6IY-D_qm0cZD.js +1 -0
  375. package/public/dist/assets/{wardleyDiagram-NUSXRM2D-CLAhOzap.js → wardleyDiagram-YWT4CUSO-BsRBBGFP.js} +61 -3
  376. package/public/dist/assets/{wiki-link-suggestions-LQuYT22G.js → wiki-link-suggestions-BHwNQXT_.js} +2 -2
  377. package/public/dist/assets/{xychartDiagram-5P7HB3ND-DLnY9i8z.js → xychartDiagram-2RQKCTM6-B6rqui6F.js} +6 -6
  378. package/public/dist/index.html +102 -3
  379. package/public/dist/manager/index.html +2 -2
  380. package/public/index.html +101 -1
  381. package/public/js/constants.ts +72 -0
  382. package/public/js/diagram/iframe-renderer.ts +7 -0
  383. package/public/js/features/chat-scroll.ts +31 -0
  384. package/public/js/features/chat-search.ts +223 -0
  385. package/public/js/features/help-content.ts +20 -2
  386. package/public/js/features/help-dialog.ts +38 -2
  387. package/public/js/features/pending-queue.ts +6 -0
  388. package/public/js/features/process-block.ts +20 -0
  389. package/public/js/features/settings-channel.ts +3 -1
  390. package/public/js/features/settings-cli-status.ts +24 -3
  391. package/public/js/features/settings-core.ts +134 -21
  392. package/public/js/features/settings-types.ts +12 -1
  393. package/public/js/features/settings.ts +1 -1
  394. package/public/js/features/trace-drawer.ts +2 -1
  395. package/public/js/features/voice-recorder.ts +222 -42
  396. package/public/js/main.ts +58 -4
  397. package/public/js/provider-icons.ts +46 -27
  398. package/public/js/render/markdown.ts +6 -0
  399. package/public/js/ui.ts +33 -7
  400. package/public/js/ws.ts +5 -1
  401. package/public/locales/en.json +31 -7
  402. package/public/locales/ja.json +31 -7
  403. package/public/locales/ko.json +31 -7
  404. package/public/locales/zh.json +31 -7
  405. package/public/manager/src/App.tsx +19 -55
  406. package/public/manager/src/InstancePreview.tsx +46 -1
  407. package/public/manager/src/components/InstanceDetailPanel.tsx +7 -2
  408. package/public/manager/src/components/InstanceLogsPanel.tsx +138 -0
  409. package/public/manager/src/dashboard-settings/DashboardEmbeddingSection.tsx +37 -7
  410. package/public/manager/src/jaw-ceo/useJawCeoDashboardBridge.tsx +1 -0
  411. package/public/manager/src/manager-components.css +76 -0
  412. package/public/manager/src/preview.ts +26 -3
  413. package/public/manager/src/settings/fields/SelectField.tsx +51 -17
  414. package/public/manager/src/settings/pages/Agent.tsx +37 -2
  415. package/public/manager/src/settings/pages/Heartbeat.tsx +3 -2
  416. package/public/manager/src/settings/pages/Memory.tsx +3 -2
  417. package/public/manager/src/settings/pages/components/EmployeeRow.tsx +8 -4
  418. package/public/manager/src/settings/pages/components/PerCliRow.tsx +31 -5
  419. package/public/manager/src/settings/pages/components/agent/FlushAgentSection.tsx +4 -2
  420. package/public/manager/src/settings/pages/components/agent/RuntimeEmployeeRow.tsx +1 -1
  421. package/public/manager/src/settings/pages/components/agent/RuntimeHeader.tsx +23 -1
  422. package/public/manager/src/settings/pages/components/agent/agent-meta.ts +49 -0
  423. package/public/manager/src/settings/pages/components/employees-helpers.ts +6 -1
  424. package/public/manager/src/settings/pages/components/heartbeat-helpers.ts +11 -1
  425. package/public/manager/src/settings-controls.css +25 -0
  426. package/public/manager/src/usePreviewShortcutMessages.ts +30 -0
  427. package/public/manager/src/usePreviewSttLifecycle.ts +31 -0
  428. package/scripts/fresh-install-smoke.ts +1 -1
  429. package/scripts/install-officecli.ps1 +33 -5
  430. package/scripts/install-officecli.sh +52 -8
  431. package/scripts/install-wsl.sh +96 -24
  432. package/scripts/install.sh +82 -11
  433. package/scripts/postinstall-guard.cjs +57 -30
  434. package/public/dist/assets/Agent-DNpehKB2.js +0 -1
  435. package/public/dist/assets/DashboardEmbeddingSection-BYdGgqg7.js +0 -2
  436. package/public/dist/assets/Employees-CuYuTy0R.js +0 -1
  437. package/public/dist/assets/Heartbeat-C-vq02MW.js +0 -1
  438. package/public/dist/assets/Memory-BPKWJDXK.js +0 -1
  439. package/public/dist/assets/ModelProvider-Bd6vGkXT.js +0 -1
  440. package/public/dist/assets/agent-meta-C1pQzExf.js +0 -1
  441. package/public/dist/assets/app-BxsIleo0.js +0 -32
  442. package/public/dist/assets/app-CB9n5A77.css +0 -1
  443. package/public/dist/assets/architecture-YZFGNWBL-BRI-0IaU.js +0 -1
  444. package/public/dist/assets/architectureDiagram-Q4EWVU46-z0JCgZrJ.js +0 -36
  445. package/public/dist/assets/blockDiagram-DXYQGD6D-KaOz3aFS.js +0 -132
  446. package/public/dist/assets/channel-jLopKIgm.js +0 -1
  447. package/public/dist/assets/chunk-2KRD3SAO-C8hJZPJu.js +0 -1
  448. package/public/dist/assets/chunk-426QAEUC-atJRhvKN.js +0 -1
  449. package/public/dist/assets/chunk-4TB4RGXK-BD7UhIN8.js +0 -206
  450. package/public/dist/assets/chunk-55IACEB6-CAWcPDdr.js +0 -1
  451. package/public/dist/assets/chunk-5FUZZQ4R-Cg1pzs6p.js +0 -62
  452. package/public/dist/assets/chunk-5PVQY5BW-otv3HwE_.js +0 -2
  453. package/public/dist/assets/chunk-67CJDMHE-AU2iOKLT.js +0 -1
  454. package/public/dist/assets/chunk-7N4EOEYR-BTIS4jBw.js +0 -1
  455. package/public/dist/assets/chunk-AA7GKIK3-c9UUJO_T.js +0 -1
  456. package/public/dist/assets/chunk-CIAEETIT-Dwbln6rM.js +0 -1
  457. package/public/dist/assets/chunk-ENJZ2VHE-PT_jAckw.js +0 -10
  458. package/public/dist/assets/chunk-FOC6F5B3-BqDmFFeg.js +0 -1
  459. package/public/dist/assets/chunk-ICPOFSXX-P6V6jqiT.js +0 -122
  460. package/public/dist/assets/chunk-K5T4RW27-C42sOmZR.js +0 -27
  461. package/public/dist/assets/chunk-KGLVRYIC-K-BVa8b2.js +0 -1
  462. package/public/dist/assets/chunk-ORNJ4GCN-CEXU6WaD.js +0 -1
  463. package/public/dist/assets/chunk-OYMX7WX6-DmJG2z1S.js +0 -231
  464. package/public/dist/assets/chunk-QZHKN3VN-BkVLii_3.js +0 -1
  465. package/public/dist/assets/chunk-U2HBQHQK-Ny6UwUgK.js +0 -11
  466. package/public/dist/assets/chunk-YZCP3GAM-c7FYtZME.js +0 -1
  467. package/public/dist/assets/classDiagram-6PBFFD2Q-BgOyAynm.js +0 -1
  468. package/public/dist/assets/classDiagram-v2-HSJHXN6E-5gBdoVH9.js +0 -1
  469. package/public/dist/assets/constants-4A2GptQT.js +0 -1
  470. package/public/dist/assets/cose-bilkent-S5V4N54A-CvH6qY_r.js +0 -1
  471. package/public/dist/assets/dagre--20B2-ZQ.js +0 -1
  472. package/public/dist/assets/dagre-KV5264BT-CQ0wo0ma.js +0 -4
  473. package/public/dist/assets/diagram-G4DWMVQ6-_aP6kMTh.js +0 -24
  474. package/public/dist/assets/diagram-MMDJMWI5-J1l6Q0JG.js +0 -43
  475. package/public/dist/assets/dist-B1p80u1b.js +0 -1
  476. package/public/dist/assets/dist-BKyzWv22.js +0 -1
  477. package/public/dist/assets/dist-CxJpXP6s.js +0 -1
  478. package/public/dist/assets/dist-DNLFuTrS.js +0 -1
  479. package/public/dist/assets/fields-BISouxp2.js +0 -1
  480. package/public/dist/assets/flowDiagram-DWJPFMVM-C_F0rqqT.js +0 -162
  481. package/public/dist/assets/ganttDiagram-T4ZO3ILL-B5S8EZRg.js +0 -292
  482. package/public/dist/assets/gitGraph-7Q5UKJZL-DTTW6pxr.js +0 -1
  483. package/public/dist/assets/gitGraphDiagram-UUTBAWPF-DMGzYJeb.js +0 -106
  484. package/public/dist/assets/graphlib-CZk_Ii16.js +0 -1
  485. package/public/dist/assets/info-OMHHGYJF-BU-iuaSm.js +0 -1
  486. package/public/dist/assets/infoDiagram-42DDH7IO-dzSaYFFK.js +0 -2
  487. package/public/dist/assets/javascript-BhB45e0W.js +0 -1
  488. package/public/dist/assets/katex-DamPUmTE.js +0 -1
  489. package/public/dist/assets/manager-B84u-pcn.js +0 -25
  490. package/public/dist/assets/manager-DMg_sTEP.css +0 -1
  491. package/public/dist/assets/memory-BV62wlsG.js +0 -1
  492. package/public/dist/assets/mermaid-loader-DxFGz4EE.js +0 -1
  493. package/public/dist/assets/mermaid-parser.core-CMIZ0my_.js +0 -3
  494. package/public/dist/assets/mermaid.core-CicVBD9l.js +0 -1
  495. package/public/dist/assets/mermaid.core-Dj6viEzN.js +0 -11
  496. package/public/dist/assets/packet-4T2RLAQJ-DzmBsAf0.js +0 -1
  497. package/public/dist/assets/pie-ZZUOXDRM-DyG1KzTn.js +0 -1
  498. package/public/dist/assets/pieDiagram-DEJITSTG-DJLiSymi.js +0 -30
  499. package/public/dist/assets/quadrantDiagram-34T5L4WZ-qcnWmcRr.js +0 -7
  500. package/public/dist/assets/radar-PYXPWWZC-CEBZARUu.js +0 -1
  501. package/public/dist/assets/rolldown-runtime-DE9SaGGd.js +0 -1
  502. package/public/dist/assets/sankeyDiagram-XADWPNL6-Bn3pUd_K.js +0 -10
  503. package/public/dist/assets/sequenceDiagram-FGHM5R23-DfxcHSdj.js +0 -157
  504. package/public/dist/assets/settings-CfAXLa8a.js +0 -1
  505. package/public/dist/assets/settings-FWgmcubl.js +0 -40
  506. package/public/dist/assets/skills-D-qUVJ-e.js +0 -1
  507. package/public/dist/assets/slash-commands-BfI19vIz.js +0 -1
  508. package/public/dist/assets/stateDiagram-FHFEXIEX-CiR7P2OG.js +0 -1
  509. package/public/dist/assets/stateDiagram-v2-QKLJ7IA2-BaWWpysK.js +0 -1
  510. package/public/dist/assets/trace-drawer-DVF5F1df.js +0 -15
  511. package/public/dist/assets/treeView-SZITEDCU-D5-TP7Qp.js +0 -1
  512. package/public/dist/assets/treemap-W4RFUUIX-BQhm_ZSp.js +0 -1
  513. package/public/dist/assets/ui-BJXY16Dk.js +0 -140
  514. package/public/dist/assets/ui-BXm3OPPh.js +0 -1
  515. package/public/dist/assets/vendor-utils-IVTPs69f.js +0 -68
  516. package/public/dist/assets/vennDiagram-DHZGUBPP-CYu7SDdG.js +0 -34
  517. package/public/dist/assets/wardley-RL74JXVD-CpnBMRe0.js +0 -1
  518. package/public/manager/src/settings/pages/Embedding.tsx +0 -382
  519. /package/public/dist/assets/{apl-HYRstREL.js → apl-CieDeb7B.js} +0 -0
  520. /package/public/dist/assets/{asciiarmor-BDXCrhAK.js → asciiarmor-BRTyulZY.js} +0 -0
  521. /package/public/dist/assets/{asn1-CnSBhb0M.js → asn1-DoNAtQ5o.js} +0 -0
  522. /package/public/dist/assets/{asterisk-AqV7rnIi.js → asterisk-CR7oKPxi.js} +0 -0
  523. /package/public/dist/assets/{brainfuck-Dv46-iL9.js → brainfuck-abzPcrOz.js} +0 -0
  524. /package/public/dist/assets/{clike-GRffz5hY.js → clike-B71Zq38G.js} +0 -0
  525. /package/public/dist/assets/{clojure-DzgT_fqE.js → clojure-Zm0UzHPq.js} +0 -0
  526. /package/public/dist/assets/{cmake-Co1237r5.js → cmake-D3UNdg6L.js} +0 -0
  527. /package/public/dist/assets/{cobol-rUaLketb.js → cobol-4fYvwQR0.js} +0 -0
  528. /package/public/dist/assets/{coffeescript-DQyfHE86.js → coffeescript-Ct6bZdRU.js} +0 -0
  529. /package/public/dist/assets/{commonlisp-Buue1PGW.js → commonlisp-CrgXVPcd.js} +0 -0
  530. /package/public/dist/assets/{crystal-BMWO0kOJ.js → crystal-bGOl67VM.js} +0 -0
  531. /package/public/dist/assets/{css-DaxibPo5.js → css-B_EV3Xq2.js} +0 -0
  532. /package/public/dist/assets/{cypher-CmpGfiBR.js → cypher-DXDlHTYf.js} +0 -0
  533. /package/public/dist/assets/{cytoscape.esm-zT8GwLFm.js → cytoscape.esm-BK7ao2Ti.js} +0 -0
  534. /package/public/dist/assets/{d-qmdtoIzU.js → d-RL5ynsiz.js} +0 -0
  535. /package/public/dist/assets/{diff-B40m6u1h.js → diff-B5McBGjz.js} +0 -0
  536. /package/public/dist/assets/{dtd-569ynYVj.js → dtd-l3sK4p_C.js} +0 -0
  537. /package/public/dist/assets/{dylan-Dxolp30i.js → dylan-WjJGY-rW.js} +0 -0
  538. /package/public/dist/assets/{ebnf-BZiX9Iq3.js → ebnf-BGY79HOS.js} +0 -0
  539. /package/public/dist/assets/{ecl-B8F1Q0oZ.js → ecl-BKh7OE1d.js} +0 -0
  540. /package/public/dist/assets/{eiffel-Bv8Kvgh1.js → eiffel-Bzvlg3oK.js} +0 -0
  541. /package/public/dist/assets/{elm-QWXQaIis.js → elm-5_BqNmKu.js} +0 -0
  542. /package/public/dist/assets/{erlang-CuDGzTGm.js → erlang-BdVwz8I8.js} +0 -0
  543. /package/public/dist/assets/{fcl-BiFeqtHf.js → fcl-B9cnfODD.js} +0 -0
  544. /package/public/dist/assets/{forth-R7Uc2VcL.js → forth-wZbbnGzb.js} +0 -0
  545. /package/public/dist/assets/{fortran-kDRG6BzW.js → fortran-BAJZrRfU.js} +0 -0
  546. /package/public/dist/assets/{gas-CyRkuC5T.js → gas-D60ZhBat.js} +0 -0
  547. /package/public/dist/assets/{gherkin-BE0p00ey.js → gherkin-B8tKjAAi.js} +0 -0
  548. /package/public/dist/assets/{groovy-B_Sh3D1t.js → groovy-BAG9eJUD.js} +0 -0
  549. /package/public/dist/assets/{haskell-DWXgCy4o.js → haskell-Cj4TmWbg.js} +0 -0
  550. /package/public/dist/assets/{haxe-xGxZ54Hv.js → haxe-8chnvz-o.js} +0 -0
  551. /package/public/dist/assets/{http-CKv9cSBA.js → http-DDYeO71z.js} +0 -0
  552. /package/public/dist/assets/{idl-DmlI3XzS.js → idl-D1hY-Gp_.js} +0 -0
  553. /package/public/dist/assets/{javascript-j6r5uf_k.js → javascript-Sh0ZUMP2.js} +0 -0
  554. /package/public/dist/assets/{julia-CQSp9Qa0.js → julia-BibioBF2.js} +0 -0
  555. /package/public/dist/assets/{livescript-CqvtVTlb.js → livescript-CSZrB6F4.js} +0 -0
  556. /package/public/dist/assets/{lua-DazQKUZ0.js → lua-BvTlo5w3.js} +0 -0
  557. /package/public/dist/assets/{mathematica-DqhJVCs9.js → mathematica-Bexv8BWZ.js} +0 -0
  558. /package/public/dist/assets/{mbox-Dsyo1_UL.js → mbox-BAhbA8z2.js} +0 -0
  559. /package/public/dist/assets/{mirc-D7ThhoF-.js → mirc-BzT5Kh4S.js} +0 -0
  560. /package/public/dist/assets/{mllike-EPZ6pqQD.js → mllike-DeoJnUZQ.js} +0 -0
  561. /package/public/dist/assets/{modelica-PU45hbqg.js → modelica-FD_-Fxlc.js} +0 -0
  562. /package/public/dist/assets/{mscgen-DEnh2Ojr.js → mscgen-C-OyhbwB.js} +0 -0
  563. /package/public/dist/assets/{mumps-8GhR7rRa.js → mumps-BxkCDTK7.js} +0 -0
  564. /package/public/dist/assets/{nginx-CXwagpwp.js → nginx-2JaV__gC.js} +0 -0
  565. /package/public/dist/assets/{ntriples-BDQxxstw.js → ntriples--rhhCzqb.js} +0 -0
  566. /package/public/dist/assets/{octave-2c90WnyU.js → octave-rS4nMzRe.js} +0 -0
  567. /package/public/dist/assets/{oz-CO0rQ8EL.js → oz-I4fMb_NC.js} +0 -0
  568. /package/public/dist/assets/{pascal-CcVwOGeN.js → pascal-BEghJs8t.js} +0 -0
  569. /package/public/dist/assets/{path-utils-DySmCVZK.js → path-utils-r2bJIu28.js} +0 -0
  570. /package/public/dist/assets/{perl-B9UvGoAV.js → perl-BRO9ZFo9.js} +0 -0
  571. /package/public/dist/assets/{pig-Cd1f86ZJ.js → pig-L4Ii6KI0.js} +0 -0
  572. /package/public/dist/assets/{powershell-DV4cOnkJ.js → powershell-BBeqUCRp.js} +0 -0
  573. /package/public/dist/assets/{properties-DaSVPhrZ.js → properties-Boi0jF2J.js} +0 -0
  574. /package/public/dist/assets/{protobuf-CEtFnY22.js → protobuf-fB2aGypX.js} +0 -0
  575. /package/public/dist/assets/{puppet-Ca0DHfcW.js → puppet-BRmsErtO.js} +0 -0
  576. /package/public/dist/assets/{python-ydzCwWG-.js → python-Be4P9Dgp.js} +0 -0
  577. /package/public/dist/assets/{q-Cl8kzQmk.js → q-DZGhDLYt.js} +0 -0
  578. /package/public/dist/assets/{r-DKZPJFrD.js → r-B4NERjRM.js} +0 -0
  579. /package/public/dist/assets/{rough.esm-Dnk3WN4D.js → rough.esm-C0Gkx4O1.js} +0 -0
  580. /package/public/dist/assets/{rpm-D0lqeHoZ.js → rpm-e-QbHJ1q.js} +0 -0
  581. /package/public/dist/assets/{ruby-RVmtmNDw.js → ruby-BSVP_v59.js} +0 -0
  582. /package/public/dist/assets/{sas-CEzodAB7.js → sas-DHlU4v4g.js} +0 -0
  583. /package/public/dist/assets/{scheme-Pqmt6dh3.js → scheme-BGXbz5Hz.js} +0 -0
  584. /package/public/dist/assets/{settings-client-BN3XzwEo.js → settings-client-DPuJroyk.js} +0 -0
  585. /package/public/dist/assets/{shell-CLG3zy-u.js → shell-yonx6xY2.js} +0 -0
  586. /package/public/dist/assets/{sieve-C95IWC3O.js → sieve-ClPJUZyi.js} +0 -0
  587. /package/public/dist/assets/{simple-mode-B9ErAHMD.js → simple-mode-CjViblDK.js} +0 -0
  588. /package/public/dist/assets/{smalltalk-4cL-gRJb.js → smalltalk-CHXubeqS.js} +0 -0
  589. /package/public/dist/assets/{solr-CEA7oOx_.js → solr-C6q6YwPz.js} +0 -0
  590. /package/public/dist/assets/{sparql-w8kHjP6I.js → sparql-CcspZvEd.js} +0 -0
  591. /package/public/dist/assets/{spreadsheet-C8bDfTgC.js → spreadsheet-DH3a4LBS.js} +0 -0
  592. /package/public/dist/assets/{sql-BrKz8968.js → sql-meoY6gNi.js} +0 -0
  593. /package/public/dist/assets/{stex-xFw1nXeT.js → stex-D2bn6Zsh.js} +0 -0
  594. /package/public/dist/assets/{stylus-gS_68vPk.js → stylus-DbXGih0S.js} +0 -0
  595. /package/public/dist/assets/{swift-D5lXmY2d.js → swift-Ch391uOd.js} +0 -0
  596. /package/public/dist/assets/{tcl-D-41REtC.js → tcl-CQBgGWDP.js} +0 -0
  597. /package/public/dist/assets/{textile-D-Znao0j.js → textile-4i3oG3tg.js} +0 -0
  598. /package/public/dist/assets/{tiddlywiki-Co8lXJKd.js → tiddlywiki-CXG1-CcK.js} +0 -0
  599. /package/public/dist/assets/{tiki-DsiNRYMP.js → tiki-DJqKUhA-.js} +0 -0
  600. /package/public/dist/assets/{toml-CaVZGou4.js → toml-C1FnyICQ.js} +0 -0
  601. /package/public/dist/assets/{troff-DJvDVr-d.js → troff-Cp8NvRO0.js} +0 -0
  602. /package/public/dist/assets/{ttcn-DAC92l4d.js → ttcn-NlmW_fji.js} +0 -0
  603. /package/public/dist/assets/{ttcn-cfg-C0X-mYlr.js → ttcn-cfg-BVuxfGZf.js} +0 -0
  604. /package/public/dist/assets/{turtle-D6WHyCrL.js → turtle-Ba9ERlnm.js} +0 -0
  605. /package/public/dist/assets/{vb-CEo_ccq3.js → vb-DDs4gjJb.js} +0 -0
  606. /package/public/dist/assets/{vbscript-B_PKDV1v.js → vbscript-gOFmdMJN.js} +0 -0
  607. /package/public/dist/assets/{velocity-ClKnKBLH.js → velocity-DtSNZA7i.js} +0 -0
  608. /package/public/dist/assets/{verilog-Pnuspgw6.js → verilog-Pldmtxe7.js} +0 -0
  609. /package/public/dist/assets/{vhdl-CZnyY4fs.js → vhdl-BFfSgWGp.js} +0 -0
  610. /package/public/dist/assets/{w3c-keyname-DJlC6DTY.js → w3c-keyname-BggQEPNo.js} +0 -0
  611. /package/public/dist/assets/{webidl-DHr762Dm.js → webidl-B6ZFYE2L.js} +0 -0
  612. /package/public/dist/assets/{xquery-5-FiyUtN.js → xquery-DhxUT98N.js} +0 -0
  613. /package/public/dist/assets/{yacas-GlqsXIeT.js → yacas-jSkQeF1Q.js} +0 -0
  614. /package/public/dist/assets/{z80-CI7N40Oo.js → z80-D7Lt6v61.js} +0 -0
@@ -1,1488 +1,3 @@
1
- // ─── Event Extraction (NDJSON parser) ────────────────
2
- import { broadcast } from '../core/bus.js';
3
- import { stripUndefined } from '../core/strip-undefined.js';
4
- import { detectLongRunningToolTimeout } from './tool-timeout.js';
5
- import { asCliEventArray, asCliEventRecord, fieldNumber, fieldString, isCliEventRecord, } from '../types/cli-events.js';
6
- import { appendLiveRunText, replaceLiveRunTools, appendLiveRunTool } from './live-run-state.js';
7
- import { stampTraceToolEntries } from '../trace/store.js';
8
- function liveScopeOf(ctx) {
9
- return ctx.liveScope ?? null;
10
- }
11
- function syncLiveTools(ctx) {
12
- stampTraceToolEntries(ctx);
13
- const scope = liveScopeOf(ctx);
14
- if (scope)
15
- replaceLiveRunTools(scope, ctx.toolLog);
16
- if (ctx.parentLiveScope) {
17
- const synced = ctx._parentSyncedCount || 0;
18
- const total = ctx.toolLog.length;
19
- for (let i = synced; i < total; i++) {
20
- appendLiveRunTool(ctx.parentLiveScope, { ...ctx.toolLog[i], isEmployee: true });
21
- }
22
- ctx._parentSyncedCount = total;
23
- }
24
- }
25
- function emitAgentTool(ctx, agentLabel, tool, empTag) {
26
- broadcast('agent_tool', { agentId: agentLabel, ...tool, ...empTag }, ctx.traceAudience === 'internal' ? 'internal' : 'public');
27
- }
28
- /** Flush Claude-specific stream buffers (thinking + input_json).
29
- * Call on stream close to avoid data loss if content_block_stop never arrives. */
30
- export function flushClaudeBuffers(ctx, agentLabel, empTag = {}) {
31
- if (ctx.claudeThinkingBuf) {
32
- const merged = ctx.claudeThinkingBuf.trim();
33
- if (merged) {
34
- const tool = {
35
- icon: '💭',
36
- label: buildPreview(merged, 80) || 'thinking...',
37
- toolType: 'thinking',
38
- detail: merged,
39
- };
40
- ctx.toolLog.push(tool);
41
- syncLiveTools(ctx);
42
- emitAgentTool(ctx, agentLabel, tool, empTag);
43
- pushTrace(ctx, `[${agentLabel || 'agent'}] 💭 ${merged.slice(0, 200)}`);
44
- }
45
- ctx.claudeThinkingBuf = '';
46
- }
47
- if (ctx.claudeInputJsonBuf) {
48
- try {
49
- const input = JSON.parse(ctx.claudeInputJsonBuf);
50
- const toolName = ctx.claudeCurrentToolName || 'tool';
51
- const detail = summarizeToolInput(toolName, input);
52
- if (detail) {
53
- const existing = [...ctx.toolLog].reverse().find((t) => t.icon === '🔧' && t.label === toolName && !t.detail);
54
- if (existing) {
55
- existing.detail = detail;
56
- syncLiveTools(ctx);
57
- emitAgentTool(ctx, agentLabel, existing, empTag);
58
- }
59
- }
60
- }
61
- catch { /* partial JSON — best effort */ }
62
- ctx.claudeInputJsonBuf = '';
63
- ctx.claudeCurrentToolName = '';
64
- }
65
- }
66
- function flushOpenCodeStepText(ctx, agentLabel, empTag, reason) {
67
- const preToolText = ctx.opencodePreToolText || '';
68
- const postToolText = ctx.opencodePostToolText || '';
69
- const isToolCallStep = reason === 'tool-calls';
70
- const textToCommit = isToolCallStep
71
- ? postToolText
72
- : `${preToolText}${postToolText}`;
73
- const suppressedText = isToolCallStep ? preToolText : '';
74
- if (textToCommit) {
75
- const segment = appendAssistantTextSegment(ctx, textToCommit);
76
- ctx.pendingOutputChunk = (ctx.pendingOutputChunk || '') + segment;
77
- }
78
- if (suppressedText) {
79
- const thinkingTool = {
80
- icon: '💭',
81
- label: buildPreview(suppressedText, 80) || 'thinking...',
82
- toolType: 'thinking',
83
- detail: suppressedText,
84
- };
85
- ctx.toolLog.push(thinkingTool);
86
- syncLiveTools(ctx);
87
- emitAgentTool(ctx, agentLabel, thinkingTool, empTag);
88
- ctx.opencodeStepThinkingToolEmitted = true;
89
- pushTrace(ctx, `[${agentLabel || 'agent'}] opencode pre-tool intermediate text (${suppressedText.length} chars)`);
90
- }
91
- }
92
- function resetOpenCodeStepState(ctx) {
93
- ctx.opencodePreToolText = '';
94
- ctx.opencodePostToolText = '';
95
- ctx.opencodeSawToolInStep = false;
96
- ctx.opencodeHadToolErrorInStep = false;
97
- ctx.opencodePendingToolRefs = [];
98
- ctx.opencodeStepThinkingToolEmitted = false;
99
- }
100
- /** Flush OpenCode text/tool buffers when the JSON stream closes without step_finish. */
101
- export function flushOpenCodeBuffers(ctx, agentLabel, empTag = {}) {
102
- const hasBufferedText = Boolean(ctx.opencodePreToolText || ctx.opencodePostToolText);
103
- const hasPendingTools = Boolean(ctx.opencodePendingToolRefs?.length);
104
- if (!hasBufferedText && !hasPendingTools)
105
- return;
106
- const reason = ctx.opencodeSawToolInStep ? 'tool-calls' : 'stop';
107
- if (hasBufferedText) {
108
- flushOpenCodeStepText(ctx, agentLabel, empTag, reason);
109
- }
110
- finalizeOpencodePendingTools(ctx, agentLabel || 'agent', empTag);
111
- resetOpenCodeStepState(ctx);
112
- }
113
- function pushTrace(ctx, line) {
114
- if (!ctx?.traceLog || !line)
115
- return;
116
- ctx.traceLog.push(line);
117
- }
118
- function logLine(line, ctx) {
119
- console.log(line);
120
- pushTrace(ctx, line);
121
- }
122
- function toSingleLine(text) {
123
- return String(text || '').replace(/\s+/g, ' ').trim();
124
- }
125
- function clipText(text, max) {
126
- if (!max || max < 1)
127
- return text;
128
- return text.length > max ? `${text.slice(0, max - 1)}…` : text;
129
- }
130
- function buildPreview(text, max = 80) {
131
- return clipText(toSingleLine(text), max);
132
- }
133
- function appendDetail(...parts) {
134
- return parts.map(p => String(p || '').trim()).filter(Boolean).join('\n');
135
- }
136
- function formatJsonDetail(label, value) {
137
- if (value == null)
138
- return '';
139
- try {
140
- return `${label}: ${typeof value === 'string' ? value : JSON.stringify(value, null, 2)}`;
141
- }
142
- catch {
143
- return `${label}: ${String(value)}`;
144
- }
145
- }
146
- function formatAssistantTextSegment(ctx, text) {
147
- const raw = String(text || '');
148
- if (!raw)
149
- return '';
150
- if (!ctx.outputTextStarted) {
151
- ctx.outputTextStarted = true;
152
- return raw;
153
- }
154
- if (/\s$/.test(ctx.fullText) || /^\s/.test(raw) || /^[,.;:!?)]/.test(raw) || /^-\S/.test(raw))
155
- return raw;
156
- return raw.startsWith('- ') || raw.startsWith('* ')
157
- ? `\n${raw}`
158
- : `\n- ${raw}`;
159
- }
160
- function appendAssistantTextSegment(ctx, text) {
161
- const segment = formatAssistantTextSegment(ctx, text);
162
- if (!segment)
163
- return '';
164
- ctx.fullText += segment;
165
- return segment;
166
- }
167
- function appendGeminiAssistantTextSegment(ctx, text, isDelta) {
168
- const raw = String(text || '');
169
- if (!raw)
170
- return '';
171
- if (isDelta && ctx.geminiDeltaActive) {
172
- ctx.fullText += raw;
173
- return raw;
174
- }
175
- const segment = appendAssistantTextSegment(ctx, raw);
176
- ctx.geminiDeltaActive = isDelta;
177
- return segment;
178
- }
179
- function emitGeminiThought(ctx, agentLabel, empTag, text) {
180
- const detail = String(text || '').trim();
181
- if (!detail)
182
- return;
183
- const tool = {
184
- icon: '💭',
185
- label: buildPreview(detail, 80) || 'thinking...',
186
- toolType: 'thinking',
187
- detail,
188
- };
189
- ctx.toolLog.push(tool);
190
- syncLiveTools(ctx);
191
- emitAgentTool(ctx, agentLabel, tool, empTag);
192
- }
193
- function extractGeminiThoughtText(content) {
194
- if (typeof content === 'string')
195
- return content;
196
- if (Array.isArray(content)) {
197
- return content
198
- .filter(isCliEventRecord)
199
- .filter((p) => p.type === 'thought' || p.type === 'thinking')
200
- .map((p) => String(p.thought || p.text || p.content || ''))
201
- .join('');
202
- }
203
- if (isCliEventRecord(content)) {
204
- return String(content.thought || content.text || content.content || '');
205
- }
206
- return '';
207
- }
208
- function toIndentedPreview(text, max = 200) {
209
- const raw = String(text || '').trim();
210
- if (!raw)
211
- return '';
212
- const clipped = raw.length > max ? `${raw.slice(0, max)}…` : raw;
213
- return clipped.replace(/\n/g, '\n ');
214
- }
215
- function isOpencodeToolFailure(part) {
216
- const exitCode = part?.state?.metadata?.["exit"];
217
- if (exitCode != null && exitCode !== 0)
218
- return true;
219
- const status = String(part?.state?.status || '').toLowerCase();
220
- return status === 'error'
221
- || status === 'failed'
222
- || status === 'denied'
223
- || status === 'cancelled';
224
- }
225
- function cleanOpencodeTaskResult(output) {
226
- const raw = String(output || '').trim();
227
- if (!raw)
228
- return '';
229
- const match = raw.match(/<task_result>([\s\S]*?)<\/task_result>/);
230
- return (match?.[1] || raw).trim();
231
- }
232
- function formatOpenCodeTaskDetail(part) {
233
- const state = part?.state || {};
234
- const input = state.input || {};
235
- const meta = state.metadata || {};
236
- const modelInfo = asCliEventRecord(meta.model);
237
- const model = meta.model
238
- ? [modelInfo["providerID"], modelInfo["modelID"]].filter(Boolean).join('/')
239
- : '';
240
- return appendDetail(input.prompt ? `prompt: ${clipText(String(input.prompt), 300)}` : '', model ? `model: ${model}` : '', meta["sessionId"] ? `child_session: ${meta["sessionId"]}` : '', cleanOpencodeTaskResult(state.output) ? `result: ${cleanOpencodeTaskResult(state.output)}` : '');
241
- }
242
- function finalizeOpencodePendingTools(ctx, agentLabel, empTag) {
243
- const pendingRefs = ctx.opencodePendingToolRefs || [];
244
- if (!pendingRefs.length)
245
- return;
246
- const failed = !!ctx.opencodeHadToolErrorInStep;
247
- for (const ref of pendingRefs) {
248
- const existing = [...ctx.toolLog].reverse().find((t) => t.stepRef === ref && (!t.status || t.status === 'running'));
249
- if (!existing)
250
- continue;
251
- existing.status = failed ? 'error' : 'done';
252
- existing.icon = failed ? '❌' : '✅';
253
- syncLiveTools(ctx);
254
- emitAgentTool(ctx, agentLabel, existing, empTag);
255
- }
256
- }
257
- export function extractSessionId(cli, event) {
258
- switch (cli) {
259
- case 'claude': return event.type === 'system' ? event.session_id ?? null : null;
260
- case 'codex': return event.type === 'thread.started' ? event.thread_id ?? null : null;
261
- case 'gemini': return event.type === 'init' ? event.session_id ?? null : null;
262
- case 'opencode': return event.sessionID ?? null;
263
- default: return null;
264
- }
265
- }
266
- export function extractOutputChunk(cli, event, ctx) {
267
- if (cli === 'gemini') {
268
- if (ctx?.pendingOutputChunk) {
269
- const chunk = ctx.pendingOutputChunk;
270
- ctx.pendingOutputChunk = '';
271
- return chunk;
272
- }
273
- // [#107] Skip thought/thinking events (future-proofing for when Gemini CLI adds them)
274
- if (event.type === 'thought' || event.thought === true)
275
- return '';
276
- if (event.type === 'message' && event.role === 'assistant' && event.content) {
277
- // Skip message events with thought content parts (ACP path)
278
- if (Array.isArray(event.content)) {
279
- const textParts = asCliEventArray(event.content).filter((p) => p.type === 'text');
280
- return textParts.map((p) => String(p.text || '')).join('');
281
- }
282
- return String(event.content);
283
- }
284
- return '';
285
- }
286
- if (cli === 'opencode') {
287
- if (ctx?.pendingOutputChunk) {
288
- const chunk = ctx.pendingOutputChunk;
289
- ctx.pendingOutputChunk = '';
290
- return chunk;
291
- }
292
- return '';
293
- }
294
- // [P0-1.5] Codex: emit agent_message text as live chunk
295
- if (cli === 'codex') {
296
- if (ctx?.pendingOutputChunk) {
297
- const chunk = ctx.pendingOutputChunk;
298
- ctx.pendingOutputChunk = '';
299
- return chunk;
300
- }
301
- if (event.type === 'item.completed' && event.item?.type === 'agent_message') {
302
- return String(event.item.text || '');
303
- }
304
- return '';
305
- }
306
- return '';
307
- }
308
- export function extractFromEvent(cli, event, ctx, agentLabel, empTag = {}) {
309
- // [P2-3.1] Claude system/init metadata: store model, tools, version
310
- if (cli === 'claude' && event.type === 'system') {
311
- if (event.model)
312
- ctx.model = event.model;
313
- if (!ctx.metadata)
314
- ctx.metadata = {};
315
- if (event.tools)
316
- ctx.metadata["tools"] = event.tools;
317
- if (event.mcp_servers)
318
- ctx.metadata["mcp_servers"] = event.mcp_servers;
319
- if (event.version)
320
- ctx.metadata["version"] = event.version;
321
- }
322
- // ── Claude stream buffer: thinking_delta + input_json_delta ──
323
- if (cli === 'claude' && event.type === 'stream_event') {
324
- const inner = event.event;
325
- // [P0-1.1] signature_delta: discard silently, do NOT trigger thinking flush.
326
- // [encrypted-thinking] Track signature length — used as evidence opus-4-7 reasoned server-side.
327
- if (inner?.type === 'content_block_delta' && inner.delta?.type === 'signature_delta') {
328
- const sig = inner.delta.signature;
329
- if (typeof sig === 'string') {
330
- ctx.claudeSignatureLen = (ctx.claudeSignatureLen || 0) + sig.length;
331
- }
332
- return;
333
- }
334
- // [P2-3.2] message_start: capture per-message input_tokens
335
- if (inner?.type === 'message_start' && inner.message?.usage) {
336
- if (!ctx.tokens)
337
- ctx.tokens = { input_tokens: 0, output_tokens: 0 };
338
- ctx.tokens["input_tokens"] = inner.message.usage.input_tokens ?? ctx.tokens["input_tokens"] ?? 0;
339
- }
340
- // Buffer thinking deltas
341
- if (inner?.type === 'content_block_delta' && inner.delta?.type === 'thinking_delta') {
342
- if (!ctx.claudeThinkingBuf)
343
- ctx.claudeThinkingBuf = '';
344
- ctx.claudeThinkingBuf += inner.delta.thinking || '';
345
- ctx.claudeThinkingHadDelta = true;
346
- return;
347
- }
348
- // [encrypted-thinking] Mark thinking block open so we can detect empty/encrypted case on stop.
349
- if (inner?.type === 'content_block_start' && inner.content_block?.type === 'thinking') {
350
- ctx.claudeThinkingBlockOpen = true;
351
- ctx.claudeThinkingHadDelta = false;
352
- ctx.claudeSignatureLen = 0;
353
- }
354
- // Buffer tool input JSON deltas
355
- if (inner?.type === 'content_block_delta' && inner.delta?.type === 'input_json_delta') {
356
- if (!ctx.claudeInputJsonBuf)
357
- ctx.claudeInputJsonBuf = '';
358
- ctx.claudeInputJsonBuf += inner.delta.partial_json || '';
359
- return;
360
- }
361
- // Track current tool name from content_block_start
362
- if (inner?.type === 'content_block_start' && inner.content_block?.type === 'tool_use') {
363
- ctx.claudeCurrentToolName = inner.content_block.name || 'tool';
364
- }
365
- // [P1-2.1] message_delta: accumulate output_tokens from streaming usage
366
- if (inner?.type === 'message_delta' && inner.usage) {
367
- if (inner.usage.output_tokens != null) {
368
- if (!ctx.tokens)
369
- ctx.tokens = { input_tokens: 0, output_tokens: 0 };
370
- ctx.tokens["output_tokens"] = inner.usage.output_tokens;
371
- }
372
- }
373
- // content_block_stop → flush both buffers
374
- if (inner?.type === 'content_block_stop') {
375
- // Flush thinking
376
- if (ctx.claudeThinkingBuf) {
377
- const merged = ctx.claudeThinkingBuf.trim();
378
- if (merged) {
379
- const tool = {
380
- icon: '💭',
381
- label: buildPreview(merged, 80) || 'thinking...',
382
- toolType: 'thinking',
383
- detail: merged,
384
- };
385
- ctx.toolLog.push(tool);
386
- syncLiveTools(ctx);
387
- emitAgentTool(ctx, agentLabel, tool, empTag);
388
- }
389
- ctx.claudeThinkingBuf = '';
390
- }
391
- else if (ctx.claudeThinkingBlockOpen && !ctx.claudeThinkingHadDelta) {
392
- // [encrypted-thinking] opus-4-7: thinking block opened but only signature streamed, no plaintext.
393
- // Surface a badge so users know the model reasoned server-side even though the content is withheld.
394
- const sigLen = ctx.claudeSignatureLen || 0;
395
- const detail = sigLen > 0
396
- ? `server-side reasoning, plaintext withheld — signature ${sigLen}B`
397
- : 'server-side reasoning, plaintext withheld';
398
- const tool = {
399
- icon: '🔒',
400
- label: 'encrypted thinking',
401
- toolType: 'thinking',
402
- detail,
403
- };
404
- ctx.toolLog.push(tool);
405
- syncLiveTools(ctx);
406
- emitAgentTool(ctx, agentLabel, tool, empTag);
407
- pushTrace(ctx, `[${agentLabel || 'agent'}] 🔒 encrypted thinking (sig ${sigLen}B)`);
408
- }
409
- if (ctx.claudeThinkingBlockOpen) {
410
- ctx.claudeThinkingBlockOpen = false;
411
- ctx.claudeThinkingHadDelta = false;
412
- ctx.claudeSignatureLen = 0;
413
- }
414
- // Flush tool input → update existing tool label with detail
415
- if (ctx.claudeInputJsonBuf) {
416
- try {
417
- const input = JSON.parse(ctx.claudeInputJsonBuf);
418
- const toolName = ctx.claudeCurrentToolName || 'tool';
419
- const detail = summarizeToolInput(toolName, input); // full, no clip (max=0)
420
- if (detail) {
421
- // Find the last tool label for this tool and update its detail
422
- const existing = [...ctx.toolLog].reverse().find((t) => t.icon === '🔧' && t.label === toolName && !t.detail);
423
- if (existing) {
424
- existing.detail = detail;
425
- syncLiveTools(ctx);
426
- // Re-broadcast with detail
427
- emitAgentTool(ctx, agentLabel, existing, empTag);
428
- }
429
- }
430
- }
431
- catch { /* partial JSON */ }
432
- ctx.claudeInputJsonBuf = '';
433
- ctx.claudeCurrentToolName = '';
434
- }
435
- }
436
- // Non-block-stop but non-delta → flush thinking
437
- if (inner?.type !== 'content_block_stop' && ctx.claudeThinkingBuf) {
438
- const merged = ctx.claudeThinkingBuf.trim();
439
- if (merged) {
440
- const tool = {
441
- icon: '💭',
442
- label: buildPreview(merged, 80) || 'thinking...',
443
- toolType: 'thinking',
444
- detail: merged,
445
- };
446
- ctx.toolLog.push(tool);
447
- syncLiveTools(ctx);
448
- emitAgentTool(ctx, agentLabel, tool, empTag);
449
- }
450
- ctx.claudeThinkingBuf = '';
451
- }
452
- }
453
- const toolLabels = extractToolLabels(cli, event, ctx);
454
- for (const toolLabel of toolLabels) {
455
- // Dedupe: same logic as ACP path — skip already-seen tool keys
456
- const key = [
457
- toolLabel.icon,
458
- toolLabel.label,
459
- toolLabel.stepRef || '',
460
- toolLabel.status || '',
461
- ].join(':');
462
- if (ctx.seenToolKeys && ctx.seenToolKeys.has(key))
463
- continue;
464
- if (ctx.seenToolKeys)
465
- ctx.seenToolKeys.add(key);
466
- // Resolve running → done/error: replace existing running entry in toolLog
467
- if (toolLabel.stepRef && (toolLabel.status === 'done' || toolLabel.status === 'error')) {
468
- const runIdx = ctx.toolLog.findIndex((t) => t.stepRef === toolLabel.stepRef && t.status === 'running');
469
- if (runIdx !== -1) {
470
- ctx.toolLog[runIdx] = toolLabel;
471
- if (cli === 'opencode' && ctx.opencodePendingToolRefs) {
472
- ctx.opencodePendingToolRefs = ctx.opencodePendingToolRefs.filter(ref => ref !== toolLabel.stepRef);
473
- }
474
- syncLiveTools(ctx);
475
- emitAgentTool(ctx, agentLabel, toolLabel, empTag);
476
- continue;
477
- }
478
- }
479
- ctx.toolLog.push(toolLabel);
480
- if (cli === 'opencode' && toolLabel.stepRef && (!toolLabel.status || toolLabel.status === 'running')) {
481
- if (!ctx.opencodePendingToolRefs)
482
- ctx.opencodePendingToolRefs = [];
483
- if (!ctx.opencodePendingToolRefs.includes(toolLabel.stepRef))
484
- ctx.opencodePendingToolRefs.push(toolLabel.stepRef);
485
- }
486
- syncLiveTools(ctx);
487
- emitAgentTool(ctx, agentLabel, toolLabel, empTag);
488
- }
489
- switch (cli) {
490
- case 'claude':
491
- if (event.type === 'assistant' && event.message?.content) {
492
- for (const block of event.message.content) {
493
- if (block.type === 'text') {
494
- const segment = appendAssistantTextSegment(ctx, block.text);
495
- const scope = liveScopeOf(ctx);
496
- if (scope)
497
- appendLiveRunText(scope, segment);
498
- }
499
- }
500
- }
501
- else if (event.type === 'result') {
502
- ctx.cost = event.total_cost_usd ?? null;
503
- ctx.turns = event.num_turns ?? null;
504
- ctx.duration = event.duration_ms ?? null;
505
- if (event.session_id)
506
- ctx.sessionId = event.session_id;
507
- // [P1-2.3] Store modelUsage for per-model token/cache breakdown
508
- if (event.usage) {
509
- ctx.tokens = {
510
- input_tokens: event.usage.input_tokens ?? 0,
511
- output_tokens: event.usage.output_tokens ?? ctx.tokens?.["output_tokens"] ?? 0,
512
- cache_read: event.usage.cache_read_input_tokens ?? 0,
513
- cache_creation: event.usage.cache_creation_input_tokens ?? 0,
514
- };
515
- }
516
- // [P1-2.2] rate_limit_event: emit quota warning
517
- }
518
- else if (event.type === 'rate_limit_event') {
519
- const msg = event.message || event.reason || 'rate limited';
520
- const tool = { icon: '⚠️', label: buildPreview(msg, 60), toolType: 'tool', status: 'warning' };
521
- ctx.toolLog.push(tool);
522
- syncLiveTools(ctx);
523
- emitAgentTool(ctx, agentLabel, tool, empTag);
524
- // [P0-1.2] Parse user/tool_result feedback (stdout/stderr/is_error)
525
- }
526
- else if (event.type === 'user' && event.message?.content) {
527
- for (const block of event.message.content) {
528
- if (block.type === 'tool_result' && block.tool_use_id) {
529
- const existing = [...ctx.toolLog].reverse().find((t) => t.stepRef === `claude:tooluse:${block.tool_use_id}`);
530
- if (existing) {
531
- existing.status = block["is_error"] ? 'error' : 'done';
532
- existing.icon = block["is_error"] ? '❌' : '✅';
533
- const resultText = extractText(block.content);
534
- if (resultText)
535
- existing.detail = (existing.detail || '') + '\n' + resultText;
536
- syncLiveTools(ctx);
537
- emitAgentTool(ctx, agentLabel, existing, empTag);
538
- }
539
- }
540
- }
541
- }
542
- break;
543
- case 'codex':
544
- // [P2-3.4] turn.started: mark turn boundary
545
- if (event.type === 'turn.started') {
546
- pushTrace(ctx, `[${agentLabel}] codex turn started`);
547
- }
548
- if (event.type === 'item.completed') {
549
- if (event.item?.type === 'agent_message') {
550
- const text = String(event.item.text || '');
551
- const segment = appendAssistantTextSegment(ctx, text);
552
- ctx.pendingOutputChunk = (ctx.pendingOutputChunk || '') + segment;
553
- // [spark-visibility] Spark and other lightweight codex models often
554
- // emit only an agent_message (no reasoning/command_execution), so the
555
- // toolLog would be empty and the run would be invisible in the UI.
556
- // Surface the final message as a 💬 entry so every codex run shows at
557
- // least one toolLog step. Dedup is handled by seenToolKeys via stepRef.
558
- if (segment.trim()) {
559
- const itemId = event.item.id || '';
560
- const tool = stripUndefined({
561
- icon: '💬',
562
- label: buildPreview(segment, 80) || 'message',
563
- toolType: 'tool',
564
- detail: segment,
565
- stepRef: itemId ? `codex:item:${itemId}` : undefined,
566
- status: 'done',
567
- });
568
- const key = tool.stepRef || `codex:msg:${ctx.toolLog.length}:${segment.slice(0, 30)}`;
569
- if (!ctx.seenToolKeys || !ctx.seenToolKeys.has(key)) {
570
- if (ctx.seenToolKeys)
571
- ctx.seenToolKeys.add(key);
572
- ctx.toolLog.push(tool);
573
- syncLiveTools(ctx);
574
- emitAgentTool(ctx, agentLabel, tool, empTag);
575
- }
576
- }
577
- }
578
- if (event.item?.type === 'command_execution') {
579
- const cmd = (event.item.command || '').slice(0, 120);
580
- const exitCode = event.item.exit_code ?? '?';
581
- const itemId = event.item.id || '';
582
- const doneRef = itemId ? `codex:cmd:${itemId}` : `codex:cmd:done:${ctx.toolLog.length}`;
583
- const doneTool = {
584
- icon: '✅',
585
- label: 'done',
586
- toolType: 'tool',
587
- stepRef: doneRef,
588
- status: (exitCode === 0 ? 'done' : 'error'),
589
- };
590
- const doneKey = `${doneTool.icon}:${doneTool.label}:${doneRef}:${doneTool.status}`;
591
- if (!ctx.seenToolKeys?.has(doneKey)) {
592
- ctx.seenToolKeys?.add(doneKey);
593
- ctx.toolLog.push(doneTool);
594
- syncLiveTools(ctx);
595
- emitAgentTool(ctx, agentLabel, doneTool, empTag);
596
- }
597
- }
598
- if (event.item?.type === 'collab_tool_call'
599
- && ['spawn_agent', 'wait'].includes(String(event.item.tool || event.item.name || ''))) {
600
- ctx.hasActiveSubAgent = false;
601
- }
602
- }
603
- else if (event.type === 'item.started') {
604
- if (event.item?.type === 'command_execution') {
605
- const fullCommand = String(event.item.command || '');
606
- const detectedTimeout = detectLongRunningToolTimeout(fullCommand);
607
- if (detectedTimeout) {
608
- const bufferMs = 600_000;
609
- ctx.stallWatchdog?.extendDeadline(detectedTimeout.timeoutMs + bufferMs, detectedTimeout.commandKind);
610
- ctx.traceLog.push(`[watchdog] extended for ${detectedTimeout.commandKind} by ${Math.round((detectedTimeout.timeoutMs + bufferMs) / 1000)}s`);
611
- }
612
- const cmd = fullCommand.slice(0, 120);
613
- const itemId = event.item.id || '';
614
- const tool = stripUndefined({
615
- icon: '⚡',
616
- label: buildPreview(cmd, 80) || 'command',
617
- toolType: 'tool',
618
- detail: cmd,
619
- stepRef: itemId ? `codex:cmd:${itemId}` : undefined,
620
- });
621
- const key = `${tool.icon}:${tool.label}:${tool.stepRef || ''}:`;
622
- if (!ctx.seenToolKeys?.has(key)) {
623
- ctx.seenToolKeys?.add(key);
624
- ctx.toolLog.push(tool);
625
- syncLiveTools(ctx);
626
- emitAgentTool(ctx, agentLabel, tool, empTag);
627
- }
628
- }
629
- if (event.item?.type === 'collab_tool_call'
630
- && ['spawn_agent', 'wait'].includes(String(event.item.tool || event.item.name || ''))) {
631
- ctx.hasActiveSubAgent = true;
632
- }
633
- }
634
- else if (event.type === 'turn.completed' && event.usage) {
635
- // [P2-3.6] Include cached_input_tokens in token storage
636
- ctx.tokens = {
637
- input_tokens: event.usage.input_tokens ?? 0,
638
- output_tokens: event.usage.output_tokens ?? 0,
639
- cached_input_tokens: event.usage.cached_input_tokens ?? 0,
640
- };
641
- }
642
- else if (event.type === 'error' || event.type === 'turn.failed') {
643
- // codex emits {type:"error"} or {type:"turn.failed", error:{message}} for API failures
644
- // (e.g. "The 'gpt-5.3-spark' model is not supported when using Codex with a ChatGPT account.")
645
- const raw = event.error?.message ?? event.message ?? '';
646
- let msg = String(raw);
647
- try {
648
- const parsed = JSON.parse(msg);
649
- msg = parsed?.error?.message || parsed?.message || msg;
650
- }
651
- catch { /* raw string is fine */ }
652
- const tool = {
653
- icon: '❌',
654
- label: buildPreview(msg, 80) || 'codex error',
655
- toolType: 'tool',
656
- detail: msg,
657
- status: 'error',
658
- };
659
- ctx.toolLog.push(tool);
660
- syncLiveTools(ctx);
661
- emitAgentTool(ctx, agentLabel, tool, empTag);
662
- pushTrace(ctx, `[${agentLabel}] codex ${event.type}: ${msg.slice(0, 200)}`);
663
- }
664
- break;
665
- case 'gemini':
666
- // [P2-3.7] Store model from init event
667
- if (event.type === 'init' && event.model) {
668
- ctx.model = event.model;
669
- }
670
- if (event.type === 'tool_use' || event.type === 'tool_result') {
671
- ctx.geminiDeltaActive = false;
672
- }
673
- // [#107/#121] Thought content never enters fullText; optional visibility uses process steps.
674
- if (event.type === 'thought' || event.thought === true) {
675
- if (ctx.showReasoning) {
676
- emitGeminiThought(ctx, agentLabel, empTag, event.content || event.thought || event.text);
677
- pushTrace(ctx, `[${agentLabel}] gemini thought (visible)`);
678
- }
679
- else {
680
- pushTrace(ctx, `[${agentLabel}] gemini thought (hidden)`);
681
- }
682
- break;
683
- }
684
- if (event.type === 'message' && event.role === 'assistant') {
685
- // [#107] If content is an array (ACP-style), extract only text parts
686
- if (Array.isArray(event.content)) {
687
- if (ctx.showReasoning) {
688
- emitGeminiThought(ctx, agentLabel, empTag, extractGeminiThoughtText(event.content));
689
- }
690
- const textOnly = event.content
691
- .filter(isCliEventRecord)
692
- .filter((p) => p.type === 'text')
693
- .map((p) => String(p.text || ''))
694
- .join('');
695
- if (textOnly) {
696
- const segment = appendGeminiAssistantTextSegment(ctx, textOnly, !!event.delta);
697
- ctx.pendingOutputChunk = (ctx.pendingOutputChunk || '') + segment;
698
- pushTrace(ctx, `[${agentLabel}] gemini text (filtered)`);
699
- }
700
- break;
701
- }
702
- // [P2-3.8] Track delta vs full message (pre/post tool text)
703
- if (event.delta) {
704
- pushTrace(ctx, `[${agentLabel}] gemini delta text`);
705
- }
706
- const segment = appendGeminiAssistantTextSegment(ctx, event.content || '', !!event.delta);
707
- ctx.pendingOutputChunk = (ctx.pendingOutputChunk || '') + segment;
708
- }
709
- else if (event.type === 'result') {
710
- ctx.geminiDeltaActive = false;
711
- ctx.geminiResultSeen = true;
712
- ctx.duration = event.stats?.duration_ms ?? null;
713
- ctx.turns = event.stats?.tool_calls ?? null;
714
- // [P0-1.6] Store Gemini token stats
715
- if (event.stats) {
716
- ctx.tokens = {
717
- input_tokens: event.stats.input_tokens ?? event.stats.inputTokens ?? 0,
718
- output_tokens: event.stats.output_tokens ?? event.stats.outputTokens ?? 0,
719
- cached_tokens: event.stats.cached ?? 0,
720
- total_tokens: event.stats.total_tokens ?? event.stats.totalTokens ?? 0,
721
- };
722
- }
723
- }
724
- break;
725
- case 'opencode':
726
- if (typeof event.type === 'string' && ![
727
- 'step_start',
728
- 'text',
729
- 'tool_use',
730
- 'step_finish',
731
- 'reasoning',
732
- 'error',
733
- ].includes(event.type)) {
734
- pushTrace(ctx, `[${agentLabel}] opencode unknown event type=${event.type}`);
735
- }
736
- // [P2-3.10] step_start: emit UI indicator for step boundary
737
- if (event.type === 'step_start') {
738
- const model = event.part?.model || event.model;
739
- if (model)
740
- ctx.model = model;
741
- ctx.opencodePreToolText = '';
742
- ctx.opencodePostToolText = '';
743
- ctx.opencodeSawToolInStep = false;
744
- ctx.opencodeHadToolErrorInStep = false;
745
- ctx.opencodePendingToolRefs = [];
746
- ctx.opencodeStepThinkingToolEmitted = false;
747
- pushTrace(ctx, `[${agentLabel}] opencode step_start${model ? ` model=${model}` : ''}`);
748
- }
749
- if (event.type === 'reasoning') {
750
- const text = String(event.part?.text || event.text || '').trim();
751
- if (text) {
752
- const thinkingTool = {
753
- icon: '💭',
754
- label: buildPreview(text, 80) || 'thinking...',
755
- toolType: 'thinking',
756
- detail: text,
757
- status: 'done',
758
- };
759
- ctx.toolLog.push(thinkingTool);
760
- syncLiveTools(ctx);
761
- emitAgentTool(ctx, agentLabel, thinkingTool, empTag);
762
- ctx.opencodeStepThinkingToolEmitted = true;
763
- pushTrace(ctx, `[${agentLabel}] opencode reasoning (${text.length} chars)`);
764
- }
765
- }
766
- else if (event.type === 'text' && event.part?.text) {
767
- if (ctx.opencodeSawToolInStep) {
768
- ctx.opencodePostToolText = (ctx.opencodePostToolText || '') + String(event.part.text);
769
- }
770
- else {
771
- ctx.opencodePreToolText = (ctx.opencodePreToolText || '') + String(event.part.text);
772
- }
773
- }
774
- else if (event.type === 'tool_use') {
775
- ctx.opencodeSawToolInStep = true;
776
- if (isOpencodeToolFailure(asCliEventRecord(event.part)))
777
- ctx.opencodeHadToolErrorInStep = true;
778
- }
779
- else if (event.type === 'step_finish' && event.part) {
780
- ctx.sessionId = event.sessionID ?? null;
781
- // [P0-1.7] Accumulate tokens across steps (not overwrite)
782
- if (event.part.tokens) {
783
- if (!ctx.tokens)
784
- ctx.tokens = { input_tokens: 0, output_tokens: 0, cached_read: 0, cached_write: 0 };
785
- ctx.tokens["input_tokens"] = (ctx.tokens["input_tokens"] ?? 0) + (event.part.tokens.input ?? 0);
786
- ctx.tokens["output_tokens"] = (ctx.tokens["output_tokens"] ?? 0) + (event.part.tokens.output ?? 0);
787
- // [P0-1.8] Cache token accumulation
788
- if (event.part.tokens.cache) {
789
- ctx.tokens["cached_read"] = (ctx.tokens["cached_read"] ?? 0) + (event.part.tokens.cache.read ?? 0);
790
- ctx.tokens["cached_write"] = (ctx.tokens["cached_write"] ?? 0) + (event.part.tokens.cache.write ?? 0);
791
- }
792
- // [P2-3.13] Accumulate total tokens across steps
793
- if (event.part.tokens.total != null) {
794
- ctx.tokens["total_tokens"] = (ctx.tokens["total_tokens"] ?? 0) + event.part.tokens.total;
795
- }
796
- if (event.part.tokens.reasoning != null) {
797
- ctx.tokens["reasoning_tokens"] = (ctx.tokens["reasoning_tokens"] ?? 0) + event.part.tokens.reasoning;
798
- }
799
- }
800
- // Accumulate cost across steps
801
- if (event.part.cost != null) {
802
- ctx.cost = (ctx.cost ?? 0) + event.part.cost;
803
- }
804
- // [P2-3.11] Store finish reason (tool-calls vs stop)
805
- if (event.part.reason) {
806
- ctx.finishReason = event.part.reason;
807
- }
808
- flushOpenCodeStepText(ctx, agentLabel, empTag, String(event.part.reason || 'stop'));
809
- const reasoningTokens = Number(event.part.tokens?.reasoning || 0);
810
- if (reasoningTokens > 0 && !ctx.opencodeStepThinkingToolEmitted) {
811
- const reason = String(event.part.reason || 'unknown');
812
- const thinkingTool = {
813
- icon: '💭',
814
- label: `reasoning used: ${reasoningTokens.toLocaleString()} tokens`,
815
- toolType: 'thinking',
816
- detail: [
817
- `OpenCode reported ${reasoningTokens} reasoning tokens for this step, but did not emit plaintext reasoning content.`,
818
- `reason=${reason}`,
819
- ].join('\n'),
820
- status: 'done',
821
- };
822
- ctx.toolLog.push(thinkingTool);
823
- syncLiveTools(ctx);
824
- emitAgentTool(ctx, agentLabel, thinkingTool, empTag);
825
- ctx.opencodeStepThinkingToolEmitted = true;
826
- pushTrace(ctx, `[${agentLabel}] opencode reasoning token fallback (${reasoningTokens} tokens)`);
827
- }
828
- finalizeOpencodePendingTools(ctx, agentLabel, empTag);
829
- resetOpenCodeStepState(ctx);
830
- // [P2-3.12] Store step timing
831
- if (event.part["time"]) {
832
- if (!ctx.metadata)
833
- ctx.metadata = {};
834
- ctx.metadata["lastStepTime"] = event.part["time"];
835
- }
836
- }
837
- break;
838
- }
839
- }
840
- export function logEventSummary(agentLabel, cli, event, ctx = null) {
841
- const item = event.item || event.part || {};
842
- if (cli === 'codex') {
843
- if (event.type === 'item.started' && item.type === 'command_execution') {
844
- logLine(`[${agentLabel}] cmd: ${(item.command || '').slice(0, 160)}`, ctx);
845
- return;
846
- }
847
- if (event.type === 'item.completed') {
848
- if (item.type === 'reasoning') {
849
- logLine(`[${agentLabel}] reasoning: ${toSingleLine(item.text).slice(0, 200)}`, ctx);
850
- return;
851
- }
852
- if (item.type === 'agent_message') {
853
- logLine(`[${agentLabel}] agent: ${toSingleLine(item.text).slice(0, 220)}`, ctx);
854
- return;
855
- }
856
- if (item.type === 'command_execution') {
857
- const cmd = (item.command || '').slice(0, 120);
858
- const exitCode = item.exit_code ?? '?';
859
- logLine(`[${agentLabel}] cmd: ${cmd} → exit ${exitCode}`, ctx);
860
- const outPreview = toIndentedPreview(item.aggregated_output, 260);
861
- if (outPreview)
862
- logLine(` ${outPreview}`, ctx);
863
- return;
864
- }
865
- if (item.type === 'web_search') {
866
- const query = item.query || item.action?.query || '';
867
- logLine(`[${agentLabel}] search: ${toSingleLine(query).slice(0, 200)}`, ctx);
868
- return;
869
- }
870
- }
871
- if (event.type === 'turn.completed' && event.usage) {
872
- const u = event.usage;
873
- logLine(`[${agentLabel}] tokens: in=${(u.input_tokens ?? 0).toLocaleString()} `
874
- + `(cached=${(u.cached_input_tokens ?? 0).toLocaleString()}) `
875
- + `out=${(u.output_tokens ?? 0).toLocaleString()}`, ctx);
876
- return;
877
- }
878
- }
879
- if (cli === 'claude') {
880
- // Real-time streaming events (--include-partial-messages)
881
- if (event.type === 'stream_event' && event.event) {
882
- const inner = event.event;
883
- if (inner.type === 'content_block_start' && inner.content_block) {
884
- const cb = inner.content_block;
885
- if (cb.type === 'tool_use') {
886
- logLine(`[${agentLabel}] 🔧 ${cb.name || 'tool'}`, ctx);
887
- }
888
- else if (cb.type === 'thinking') {
889
- logLine(`[${agentLabel}] 💭 thinking...`, ctx);
890
- }
891
- }
892
- return;
893
- }
894
- if (event.type === 'assistant' && event.message?.content) {
895
- if (ctx?.hasClaudeStreamEvents)
896
- return;
897
- for (const block of event.message.content) {
898
- if (block.type === 'tool_use') {
899
- logLine(`[${agentLabel}] tool: ${block.name}`, ctx);
900
- }
901
- else if (block.type === 'thinking') {
902
- logLine(`[${agentLabel}] thinking: ${toSingleLine(block.thinking).slice(0, 160)}`, ctx);
903
- }
904
- }
905
- return;
906
- }
907
- if (event.type === 'result') {
908
- const cost = Number(event.total_cost_usd || 0).toFixed(4);
909
- const turns = event.num_turns ?? 0;
910
- const dur = ((event.duration_ms || 0) / 1000).toFixed(1);
911
- logLine(`[${agentLabel}] result: $${cost} / ${turns} turns / ${dur}s`, ctx);
912
- return;
913
- }
914
- }
915
- // [P2-3.9] Gemini-specific logEventSummary
916
- if (cli === 'gemini') {
917
- if (event.type === 'init') {
918
- logLine(`[${agentLabel}] gemini init model=${event.model || '?'}`, ctx);
919
- return;
920
- }
921
- if (event.type === 'tool_use') {
922
- logLine(`[${agentLabel}] 🔧 ${event.tool_name || 'tool'}${event.parameters?.command ? `: ${String(event.parameters.command).slice(0, 120)}` : ''}`, ctx);
923
- return;
924
- }
925
- if (event.type === 'tool_result') {
926
- logLine(`[${agentLabel}] tool ${event.status || 'done'}: ${(event.tool_name || '')}`, ctx);
927
- return;
928
- }
929
- if (event.type === 'result') {
930
- const dur = ((event.stats?.duration_ms || 0) / 1000).toFixed(1);
931
- const calls = event.stats?.tool_calls ?? 0;
932
- logLine(`[${agentLabel}] result: ${calls} tool calls / ${dur}s`, ctx);
933
- return;
934
- }
935
- }
936
- if (event.type !== 'system') {
937
- logLine(`[${agentLabel}] ${cli}:${event.type}`, ctx);
938
- }
939
- }
940
- function makeClaudeToolKey(event, label) {
941
- // Prefer the unique tool_use id (carried in stepRef) so multi-turn streams with
942
- // matching tool names across distinct messages don't collide on the per-message index.
943
- if (label.stepRef)
944
- return `claude:ref:${label.stepRef}:${label.icon}:${label.label}`;
945
- const msgId = event.message?.id || '';
946
- const idx = event.event?.["index"];
947
- if (msgId && idx !== undefined && idx !== null)
948
- return `claude:msg:${msgId}:${idx}:${label.icon}:${label.label}`;
949
- if (idx !== undefined && idx !== null)
950
- return `claude:idx:${idx}:${label.icon}:${label.label}`;
951
- if (msgId)
952
- return `claude:msg:${msgId}:${label.icon}:${label.label}`;
953
- return `claude:type:${event.type}:${label.icon}:${label.label}`;
954
- }
955
- function pushToolLabel(labels, label, cli, event, ctx) {
956
- if (cli !== 'claude' || !ctx?.seenToolKeys) {
957
- labels.push(label);
958
- return;
959
- }
960
- const key = makeClaudeToolKey(event, label);
961
- if (ctx.seenToolKeys.has(key))
962
- return;
963
- ctx.seenToolKeys.add(key);
964
- labels.push(label);
965
- }
966
- // Returns array of tool labels (supports multiple blocks per event)
967
- function extractToolLabels(cli, event, ctx = null) {
968
- const item = event.item || event.part || event;
969
- const labels = [];
970
- if (cli === 'codex' && (event.type === 'item.started' || event.type === 'item.completed') && item) {
971
- if (event.type === 'item.completed' && item.type === 'web_search') {
972
- const action = item.action?.type || '';
973
- if (action === 'search') {
974
- const query = item.query || item.action?.query || 'search';
975
- labels.push({ icon: '🔍', label: buildPreview(query, 60), toolType: 'search', detail: query });
976
- }
977
- else if (action === 'open_page') {
978
- const url = item.action?.url || '';
979
- try {
980
- labels.push({ icon: '🌐', label: new URL(url).hostname, toolType: 'search', detail: url });
981
- }
982
- catch {
983
- labels.push({ icon: '🌐', label: 'page', toolType: 'search', detail: url });
984
- }
985
- }
986
- else {
987
- const query = item.query || 'web';
988
- labels.push({ icon: '🔍', label: buildPreview(query, 60), toolType: 'search', detail: query });
989
- }
990
- }
991
- if (event.type === 'item.completed' && item.type === 'reasoning') {
992
- const detail = String(item.text || '').replace(/\*+/g, '').trim();
993
- labels.push({ icon: '💭', label: buildPreview(detail, 60) || 'thinking...', toolType: 'thinking', detail });
994
- }
995
- if (event.type === 'item.completed' && item.type === 'command_execution') {
996
- const command = String(item.command || 'exec');
997
- const output = item.aggregated_output ? String(item.aggregated_output) : '';
998
- const detail = output ? `$ ${command}\n${output}` : command;
999
- // [P0-1.4] Use item.id for unique stepRef (not command string)
1000
- const ref = `codex:item:${item.id || command}`;
1001
- // [P1-2.4] Include exit_code in label status
1002
- const exitCode = item.exit_code;
1003
- const failed = exitCode != null && exitCode !== 0;
1004
- labels.push({
1005
- icon: failed ? '❌' : '⚡',
1006
- label: buildPreview(command, 40) || 'exec',
1007
- toolType: 'tool',
1008
- detail,
1009
- stepRef: ref,
1010
- status: failed ? 'error' : 'done',
1011
- ...(exitCode != null ? { exitCode } : {}),
1012
- });
1013
- }
1014
- if (item.type === 'collab_tool_call') {
1015
- const tool = String(item.tool || item.name || 'subagent');
1016
- const ref = `codex:collab:${item.id || tool}`;
1017
- const isStarted = event.type === 'item.started' || item.status === 'in_progress';
1018
- const receiverIds = Array.isArray(item.receiver_thread_ids) ? item.receiver_thread_ids.join(', ') : '';
1019
- const detail = appendDetail(item["sender_thread_id"] ? `sender: ${item["sender_thread_id"]}` : '', receiverIds ? `receivers: ${receiverIds}` : '', formatJsonDetail('agents', item.agents_states), item.prompt ? `prompt: ${clipText(String(item.prompt), 300)}` : '');
1020
- labels.push({
1021
- icon: isStarted ? '🤖' : '✅',
1022
- label: isStarted ? `${tool}...` : `${tool} done`,
1023
- toolType: 'subagent',
1024
- stepRef: ref,
1025
- status: isStarted ? 'running' : 'done',
1026
- ...(detail ? { detail } : {}),
1027
- });
1028
- }
1029
- }
1030
- // [P0-1.3] Codex item.started: emit running label (paired with 1.4 stepRef)
1031
- if (cli === 'codex' && event.type === 'item.started' && item) {
1032
- if (item.type === 'command_execution') {
1033
- const command = String(item.command || 'exec');
1034
- const ref = `codex:item:${item.id || command}`;
1035
- labels.push({ icon: '🔧', label: buildPreview(command, 40) || 'exec', toolType: 'tool', stepRef: ref, status: 'running' });
1036
- }
1037
- }
1038
- if (cli === 'claude') {
1039
- if (event.type === 'system') {
1040
- const status = String(event.status || '');
1041
- const subtype = String(event.subtype || event.event || '');
1042
- if (subtype === 'task_started') {
1043
- const taskId = event.task_id || event.id || event.tool_use_id || 'unknown';
1044
- const description = event.description || event.input?.description || event.task_type || 'subagent';
1045
- const detail = appendDetail(event.task_type ? `type: ${event.task_type}` : '', event.tool_use_id ? `tool_use_id: ${event.tool_use_id}` : '', event.prompt ? `prompt: ${clipText(String(event.prompt), 300)}` : '');
1046
- pushToolLabel(labels, {
1047
- icon: '🤖',
1048
- label: `subagent: ${buildPreview(description, 60)}`,
1049
- toolType: 'subagent',
1050
- stepRef: `claude:task:${taskId}`,
1051
- status: 'running',
1052
- ...(detail ? { detail } : {}),
1053
- }, cli, event, ctx);
1054
- }
1055
- if (subtype === 'task_notification') {
1056
- const taskId = event.task_id || event.id || event.tool_use_id || 'unknown';
1057
- const rawStatus = String(event.status || 'completed');
1058
- const failed = ['failed', 'error', 'cancelled', 'canceled'].includes(rawStatus);
1059
- const description = event.description || event.summary || event.task_type || 'subagent';
1060
- const usage = event.usage || {};
1061
- const usageDetail = [
1062
- usage.total_tokens != null ? `${usage.total_tokens} tok` : '',
1063
- usage["tool_uses"] != null ? `${usage["tool_uses"]} tools` : '',
1064
- usage.duration_ms != null ? `${(Number(usage.duration_ms) / 1000).toFixed(1)}s` : '',
1065
- ].filter(Boolean).join(' · ');
1066
- const detail = appendDetail(event.summary ? `summary: ${event.summary}` : '', event.output_file ? `output_file: ${event.output_file}` : '', usageDetail);
1067
- pushToolLabel(labels, {
1068
- icon: failed ? '❌' : '✅',
1069
- label: `subagent: ${buildPreview(description, 60)}`,
1070
- toolType: 'subagent',
1071
- stepRef: `claude:task:${taskId}`,
1072
- status: failed ? 'error' : 'done',
1073
- ...(detail ? { detail } : {}),
1074
- }, cli, event, ctx);
1075
- }
1076
- if (status === 'compacting' || subtype === 'compacting') {
1077
- pushToolLabel(labels, { icon: '🗜️', label: 'compacting...', toolType: 'tool' }, cli, event, ctx);
1078
- }
1079
- if (status === 'compact_boundary' || subtype === 'compact_boundary' || event.compact_boundary === true) {
1080
- pushToolLabel(labels, { icon: '✅', label: 'conversation compacted', toolType: 'tool', status: 'done' }, cli, event, ctx);
1081
- if (ctx)
1082
- ctx.cliNativeCompactDetected = true;
1083
- }
1084
- }
1085
- if (event.type === 'stream_event' && event.event?.type === 'content_block_start') {
1086
- if (ctx)
1087
- ctx.hasClaudeStreamEvents = true;
1088
- const cb = event.event.content_block;
1089
- if (cb?.type === 'tool_use') {
1090
- const isAgent = cb.name === 'Agent';
1091
- pushToolLabel(labels, stripUndefined({
1092
- icon: isAgent ? '🤖' : '🔧',
1093
- label: isAgent ? 'subagent' : (cb.name || 'tool'),
1094
- toolType: isAgent ? 'subagent' : 'tool',
1095
- stepRef: cb.id ? `claude:tooluse:${cb.id}` : undefined,
1096
- }), cli, event, ctx);
1097
- }
1098
- // thinking: don't emit placeholder — buffer in extractFromEvent will emit with real content
1099
- }
1100
- if (event.type === 'assistant' && event.message?.content && !ctx?.hasClaudeStreamEvents) {
1101
- for (const block of event.message.content) {
1102
- if (block.type === 'tool_use') {
1103
- const isAgent = block.name === 'Agent';
1104
- const description = block.input?.description || block.input?.["subagent_type"] || 'subagent';
1105
- pushToolLabel(labels, stripUndefined({
1106
- icon: isAgent ? '🤖' : '🔧',
1107
- label: isAgent ? `subagent: ${buildPreview(description, 60)}` : (block.name || 'tool'),
1108
- toolType: isAgent ? 'subagent' : 'tool',
1109
- stepRef: block.id ? `claude:tooluse:${block.id}` : undefined,
1110
- ...(isAgent && block.input?.prompt ? { detail: `prompt: ${clipText(String(block.input.prompt), 300)}` } : {}),
1111
- }), cli, event, ctx);
1112
- }
1113
- if (block.type === 'thinking') {
1114
- const text = (block.thinking || '').trim();
1115
- pushToolLabel(labels, { icon: '💭', label: buildPreview(text, 80) || 'thinking...', toolType: 'thinking', detail: text }, cli, event, ctx);
1116
- }
1117
- }
1118
- }
1119
- }
1120
- if (cli === 'gemini') {
1121
- if (event.type === 'tool_use') {
1122
- const detail = event.parameters?.command || summarizeToolInput(event.tool_name || '', event.parameters || {}, 0);
1123
- const suffix = event.parameters?.command ? `: ${buildPreview(event.parameters.command, 40)}` : '';
1124
- const ref = event.tool_id
1125
- ? `gemini:toolid:${event.tool_id}`
1126
- : `gemini:tool:${event.tool_name || 'tool'}`;
1127
- labels.push({ icon: '🔧', label: `${event.tool_name || 'tool'}${suffix}`, toolType: 'tool', detail, stepRef: ref });
1128
- }
1129
- if (event.type === 'tool_result') {
1130
- const ref = event.tool_id
1131
- ? `gemini:toolid:${event.tool_id}`
1132
- : `gemini:tool:${event.tool_name || 'tool'}`;
1133
- // [P1-2.5] Include tool result output in detail
1134
- const output = event.output ? buildPreview(event.output, 200) : '';
1135
- labels.push({
1136
- icon: event.status === 'success' ? '✅' : '❌',
1137
- label: `${event.status || 'done'}`,
1138
- toolType: 'tool',
1139
- stepRef: ref,
1140
- status: event.status === 'success' ? 'done' : 'error',
1141
- ...(output ? { detail: output } : {}),
1142
- });
1143
- }
1144
- }
1145
- if (cli === 'opencode') {
1146
- const isTaskToolUse = event.type === 'tool_use' && event.part?.tool === 'task';
1147
- const isTaskToolResult = event.type === 'tool_result'
1148
- && event.part?.callID
1149
- && ctx?.opencodeTaskCallIds?.has(event.part.callID);
1150
- if (isTaskToolUse || isTaskToolResult) {
1151
- const part = asCliEventRecord(event.part);
1152
- const callID = part.callID || part.id || 'task';
1153
- if (isTaskToolResult && !part.state)
1154
- return labels;
1155
- if (isTaskToolUse && ctx) {
1156
- if (!ctx.opencodeTaskCallIds)
1157
- ctx.opencodeTaskCallIds = new Set();
1158
- ctx.opencodeTaskCallIds.add(callID);
1159
- }
1160
- const state = part.state || {};
1161
- const input = state.input || {};
1162
- const status = String(state.status || (event.type === 'tool_result' ? 'completed' : 'completed'));
1163
- const failed = isOpencodeToolFailure(part) || ['error', 'failed', 'cancelled', 'canceled'].includes(status);
1164
- const subagentType = input["subagent_type"] || 'general';
1165
- const description = input.description || state.title || part.tool || 'task';
1166
- const resultText = event.type === 'tool_result'
1167
- ? extractText(part.content || part.output || state.output)
1168
- : '';
1169
- const detail = appendDetail(formatOpenCodeTaskDetail(part), resultText ? `result: ${resultText}` : '');
1170
- labels.push({
1171
- icon: failed ? '❌' : (status === 'running' || status === 'in_progress' ? '🤖' : '✅'),
1172
- label: `subagent[${subagentType}]: ${buildPreview(description, 60)}`,
1173
- toolType: 'subagent',
1174
- stepRef: `opencode:call:${callID}`,
1175
- ...(detail ? { detail } : {}),
1176
- status: failed ? 'error' : (status === 'running' || status === 'in_progress' ? 'running' : 'done'),
1177
- });
1178
- return labels;
1179
- }
1180
- if (event.type === 'tool_use' && event.part) {
1181
- const ref = event.part.callID
1182
- ? `opencode:call:${event.part.callID}`
1183
- : `opencode:tool:${event.part.tool || 'tool'}`;
1184
- const detail = summarizeToolInput(event.part.tool || '', event.part.state?.input || {}, 0)
1185
- || String(event.part.state?.output || '').trim();
1186
- const isDone = event.part.state?.status === 'completed';
1187
- const exitCode = fieldNumber(event.part.state?.metadata?.["exit"]);
1188
- const isFailed = isOpencodeToolFailure(event.part);
1189
- const displayLabel = fieldString(event.part.state?.title || event.part.tool, 'tool');
1190
- labels.push(stripUndefined({
1191
- icon: isFailed ? '❌' : (isDone ? '✅' : '🔧'),
1192
- label: displayLabel,
1193
- toolType: 'tool',
1194
- stepRef: ref,
1195
- detail,
1196
- status: isFailed ? 'error' : (isDone ? 'done' : undefined),
1197
- ...(exitCode != null ? { exitCode } : {}),
1198
- }));
1199
- }
1200
- if (event.type === 'tool_result' && event.part) {
1201
- const ref = event.part.callID
1202
- ? `opencode:call:${event.part.callID}`
1203
- : `opencode:tool:${event.part.tool || 'tool'}`;
1204
- labels.push({ icon: '✅', label: fieldString(event.part.tool, 'done'), toolType: 'tool', stepRef: ref, status: 'done' });
1205
- }
1206
- }
1207
- return labels;
1208
- }
1209
- /** [P1-2.10] Map Copilot ACP tool kind to semantic icon */
1210
- function toolKindIcon(kind) {
1211
- if (!kind)
1212
- return '';
1213
- const map = {
1214
- read: '📖', view: '📖', file_read: '📖',
1215
- write: '✏️', edit: '✏️', file_write: '✏️', create: '✏️',
1216
- execute: '⚡', command: '⚡', bash: '⚡', terminal: '⚡',
1217
- search: '🔍', grep: '🔍', find: '🔍',
1218
- web: '🌐', browse: '🌐', fetch: '🌐',
1219
- };
1220
- return map[kind.toLowerCase()] || '';
1221
- }
1222
- /** Summarise a tool's input into a short one-liner for the ProcessBlock UI. */
1223
- export function summarizeToolInput(toolName, input, max = 0) {
1224
- if (!input)
1225
- return '';
1226
- if (typeof input !== 'object')
1227
- return max ? clipText(String(input), max) : String(input);
1228
- const data = asCliEventRecord(input);
1229
- const s = (v) => (typeof v === 'string' ? v : v != null ? String(v) : '');
1230
- const name = (toolName || '').toLowerCase();
1231
- let result = '';
1232
- if (name.includes('bash') || name.includes('terminal') || name === 'execute_command')
1233
- result = s(data.command || data.cmd);
1234
- else if (name.includes('read') || name === 'read_file' || name === 'view') {
1235
- const fullPath = s(data["path"] || data["file_path"] || data["filename"]);
1236
- result = max ? (fullPath.split('/').pop() || fullPath) : fullPath;
1237
- }
1238
- else if (name.includes('write') || name.includes('edit') || name === 'create_file') {
1239
- const fullPath = s(data["path"] || data["file_path"]);
1240
- result = max ? (fullPath.split('/').pop() || fullPath) : fullPath;
1241
- }
1242
- else if (name.includes('search') || name.includes('grep') || name === 'codebase_search')
1243
- result = s(data.query || data["pattern"] || data["search_query"]);
1244
- else if (name.includes('web') || name === 'web_search')
1245
- result = s(data.query);
1246
- // Fallback: show first meaningful key-value if specific extraction yielded nothing
1247
- if (!result) {
1248
- try {
1249
- result = JSON.stringify(input);
1250
- }
1251
- catch { /* ignore */ }
1252
- }
1253
- return max ? clipText(result, max) : result;
1254
- }
1255
- // Backward-compat: return first label or null
1256
- export function extractToolLabel(cli, event) {
1257
- const labels = extractToolLabels(cli, event);
1258
- return labels[0] ?? null;
1259
- }
1260
- // Test-only helpers (keep parser logic private for runtime flow)
1261
- export function extractToolLabelsForTest(cli, event, ctx = {
1262
- fullText: '',
1263
- traceLog: [],
1264
- toolLog: [],
1265
- seenToolKeys: new Set(),
1266
- hasClaudeStreamEvents: false,
1267
- sessionId: null,
1268
- cost: null,
1269
- turns: null,
1270
- duration: null,
1271
- tokens: null,
1272
- stderrBuf: '',
1273
- }) {
1274
- return extractToolLabels(cli, event, ctx);
1275
- }
1276
- export function makeClaudeToolKeyForTest(event, label) {
1277
- return makeClaudeToolKey(event, label);
1278
- }
1279
- // ─── ACP session/update → cli-jaw internal event ────────────────
1280
- // Official ACP schema: update.sessionUpdate is the discriminator field.
1281
- // Types: agent_message_chunk, agent_thought_chunk, tool_call, tool_call_update, plan
1282
- function extractText(content) {
1283
- if (typeof content === 'string')
1284
- return content;
1285
- if (Array.isArray(content)) {
1286
- return content
1287
- .filter(isCliEventRecord)
1288
- .filter(c => c.type === 'text')
1289
- .map(c => c.text || '')
1290
- .join('');
1291
- }
1292
- // Single content object: {type: 'text', text: '...'}
1293
- if (isCliEventRecord(content) && content.type === 'text') {
1294
- return content.text || '';
1295
- }
1296
- return '';
1297
- }
1298
- export function extractFromAcpUpdate(params, ctx = null) {
1299
- const envelope = asCliEventRecord(params);
1300
- const update = asCliEventRecord(envelope["update"]);
1301
- if (!isCliEventRecord(envelope["update"]))
1302
- return null;
1303
- const type = update.sessionUpdate;
1304
- switch (type) {
1305
- case 'agent_thought_chunk': {
1306
- const text = extractText(update.content);
1307
- return {
1308
- tool: {
1309
- icon: '💭',
1310
- label: buildPreview(text, 60) || 'thinking...',
1311
- toolType: 'thinking',
1312
- detail: text,
1313
- },
1314
- };
1315
- }
1316
- case 'tool_call': {
1317
- const toolName = fieldString(update.name, 'tool');
1318
- const rawInput = asCliEventRecord(update.rawInput || update.input);
1319
- const isSubagentTask = rawInput?.["agent_type"] === 'task' || rawInput?.["agentType"] === 'task';
1320
- const displayLabel = isSubagentTask
1321
- ? `subagent: ${update.title || rawInput.description || rawInput.name || toolName}`
1322
- : update.title || toolName;
1323
- if (isSubagentTask && update.toolCallId && ctx) {
1324
- if (!ctx.acpSubagentToolCallIds)
1325
- ctx.acpSubagentToolCallIds = new Set();
1326
- if (!ctx.acpSubagentLabels)
1327
- ctx.acpSubagentLabels = new Map();
1328
- ctx.acpSubagentToolCallIds.add(update.toolCallId);
1329
- ctx.acpSubagentLabels.set(update.toolCallId, fieldString(displayLabel));
1330
- }
1331
- const fullInput = update.input != null
1332
- ? (typeof update.input === 'object' ? JSON.stringify(update.input, null, 2) : String(update.input))
1333
- : update.rawInput != null
1334
- ? (typeof update.rawInput === 'object' ? JSON.stringify(update.rawInput, null, 2) : String(update.rawInput))
1335
- : '';
1336
- // [P1-2.10] Semantic icon from tool kind/title
1337
- const kindIcon = toolKindIcon(fieldString(update["kind"]) || undefined);
1338
- // [P0-1.11] Use toolCallId for unique stepRef
1339
- return {
1340
- tool: {
1341
- icon: isSubagentTask ? '🤖' : (kindIcon || '🔧'),
1342
- label: fieldString(displayLabel),
1343
- toolType: isSubagentTask ? 'subagent' : 'tool',
1344
- detail: fullInput,
1345
- stepRef: `acp:callid:${update.toolCallId || update.id || toolName}`,
1346
- ...(isSubagentTask ? { status: 'running' } : {}),
1347
- },
1348
- };
1349
- }
1350
- // [P0-1.10] Map actual status instead of hardcoding ✅/done
1351
- case 'tool_call_update': {
1352
- const statusMap = {
1353
- pending: { icon: '⏳', status: 'pending' },
1354
- running: { icon: '🔧', status: 'running' },
1355
- in_progress: { icon: '🔧', status: 'running' },
1356
- completed: { icon: '✅', status: 'done' },
1357
- failed: { icon: '❌', status: 'error' },
1358
- };
1359
- const statusKey = fieldString(update.status);
1360
- const mapped = statusMap[statusKey] || { icon: '❔', status: statusKey || 'unknown' };
1361
- const toolCallId = fieldString(update.toolCallId || update.id || update.name, 'done');
1362
- const isSubagentTask = !!(toolCallId && ctx?.acpSubagentToolCallIds?.has(toolCallId));
1363
- const subagentLabel = toolCallId ? ctx?.acpSubagentLabels?.get(toolCallId) : '';
1364
- // [P1-2.9] Extract content from tool result
1365
- const resultText = update.content ? extractText(update.content) : '';
1366
- return {
1367
- tool: {
1368
- icon: mapped.icon,
1369
- label: isSubagentTask ? (subagentLabel || `subagent: ${update.name || update.title || 'task'}`) : fieldString(update.name || update.id, 'done'),
1370
- toolType: isSubagentTask ? 'subagent' : 'tool',
1371
- stepRef: `acp:callid:${toolCallId}`,
1372
- status: mapped.status,
1373
- ...(resultText ? { detail: buildPreview(resultText, 200) } : {}),
1374
- },
1375
- };
1376
- }
1377
- case 'agent_message_chunk': {
1378
- const text = extractText(update.content);
1379
- return { text };
1380
- }
1381
- case 'plan':
1382
- return {
1383
- tool: {
1384
- icon: '📝',
1385
- label: 'planning...',
1386
- toolType: 'thinking',
1387
- },
1388
- };
1389
- // [P2-3.14] session/cancelled → UI notification
1390
- case 'session_cancelled':
1391
- case 'cancelled': {
1392
- const reason = update.reason || update.message || 'session cancelled';
1393
- return {
1394
- tool: {
1395
- icon: '⏹️',
1396
- label: buildPreview(reason, 60),
1397
- toolType: 'tool',
1398
- status: 'cancelled',
1399
- },
1400
- };
1401
- }
1402
- // [P2-3.15] session/request_permission → audit record
1403
- case 'request_permission': {
1404
- const perm = update.permission || update.scope || 'unknown';
1405
- return {
1406
- tool: {
1407
- icon: '🔐',
1408
- label: `permission: ${buildPreview(perm, 50)}`,
1409
- toolType: 'tool',
1410
- status: 'pending',
1411
- },
1412
- };
1413
- }
1414
- default:
1415
- if (process.env["DEBUG"]) {
1416
- console.log(`[acp] unknown sessionUpdate: ${type}`, JSON.stringify(update).slice(0, 100));
1417
- }
1418
- return null;
1419
- }
1420
- }
1421
- export function extractFromAcpSubagent(event) {
1422
- const record = asCliEventRecord(event);
1423
- if (!record.type || !String(record.type).startsWith('subagent.'))
1424
- return null;
1425
- const data = asCliEventRecord(record["data"]);
1426
- const display = fieldString(data.agentDisplayName || data.agentName, 'subagent');
1427
- const agentName = fieldString(data.agentName, display);
1428
- switch (record.type) {
1429
- case 'subagent.selected':
1430
- return {
1431
- tool: {
1432
- icon: '🎯',
1433
- label: `selected: ${display}`,
1434
- toolType: 'subagent',
1435
- stepRef: `acp:subagent:selection:${agentName}`,
1436
- status: 'done',
1437
- detail: `tools: ${Array.isArray(data.tools) ? data.tools.join(', ') : 'all'}`,
1438
- },
1439
- };
1440
- case 'subagent.deselected':
1441
- return {
1442
- tool: {
1443
- icon: '⏭',
1444
- label: `deselected: ${display}`,
1445
- toolType: 'subagent',
1446
- stepRef: `acp:subagent:selection:${agentName}`,
1447
- status: 'done',
1448
- },
1449
- };
1450
- case 'subagent.started': {
1451
- const agentDescription = fieldString(data["agentDescription"]);
1452
- return {
1453
- tool: {
1454
- icon: '🤖',
1455
- label: `subagent: ${display}`,
1456
- toolType: 'subagent',
1457
- stepRef: `acp:subagent:${data.toolCallId || agentName}`,
1458
- status: 'running',
1459
- ...(agentDescription ? { detail: agentDescription } : {}),
1460
- },
1461
- };
1462
- }
1463
- case 'subagent.completed':
1464
- return {
1465
- tool: {
1466
- icon: '✅',
1467
- label: `subagent: ${display}`,
1468
- toolType: 'subagent',
1469
- stepRef: `acp:subagent:${data.toolCallId || agentName}`,
1470
- status: 'done',
1471
- },
1472
- };
1473
- case 'subagent.failed':
1474
- return {
1475
- tool: {
1476
- icon: '❌',
1477
- label: `subagent: ${display}`,
1478
- toolType: 'subagent',
1479
- stepRef: `acp:subagent:${data.toolCallId || agentName}`,
1480
- status: 'error',
1481
- detail: `error: ${data.error || ''}`,
1482
- },
1483
- };
1484
- default:
1485
- return null;
1486
- }
1487
- }
1
+ // Legacy facade explicit named re-exports only. No export *.
2
+ export { flushClaudeBuffers, flushOpenCodeBuffers, extractSessionId, extractOutputChunk, extractFromEvent, logEventSummary, summarizeToolInput, extractToolLabel, extractToolLabelsForTest, makeClaudeToolKeyForTest, extractFromAcpUpdate, extractFromAcpSubagent, } from './events/index.js';
1488
3
  //# sourceMappingURL=events.js.map