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.
- package/README.ja.md +229 -315
- package/README.ko.md +248 -315
- package/README.md +103 -186
- package/README.zh-CN.md +282 -296
- package/dist/bin/commands/browser-web-ai.js +4 -2
- package/dist/bin/commands/browser-web-ai.js.map +1 -1
- package/dist/bin/commands/browser.js +76 -0
- package/dist/bin/commands/browser.js.map +1 -1
- package/dist/bin/commands/doctor.js +122 -4
- package/dist/bin/commands/doctor.js.map +1 -1
- package/dist/bin/commands/skill.js +5 -3
- package/dist/bin/commands/skill.js.map +1 -1
- package/dist/bin/postinstall.js +507 -89
- package/dist/bin/postinstall.js.map +1 -1
- package/dist/lib/mcp/format-converters.js +32 -4
- package/dist/lib/mcp/format-converters.js.map +1 -1
- package/dist/lib/mcp/mcp-install.js +5 -0
- package/dist/lib/mcp/mcp-install.js.map +1 -1
- package/dist/lib/mcp/skills-distribution.js +52 -53
- package/dist/lib/mcp/skills-distribution.js.map +1 -1
- package/dist/lib/mcp/skills-reset.js +29 -16
- package/dist/lib/mcp/skills-reset.js.map +1 -1
- package/dist/lib/mcp/skills-utils.js +64 -2
- package/dist/lib/mcp/skills-utils.js.map +1 -1
- package/dist/lib/mcp/unified-config.js +7 -3
- package/dist/lib/mcp/unified-config.js.map +1 -1
- package/dist/scripts/fresh-install-smoke.js +1 -1
- package/dist/scripts/fresh-install-smoke.js.map +1 -1
- package/dist/server.js +44 -4
- package/dist/server.js.map +1 -1
- package/dist/src/agent/args.js +148 -1
- package/dist/src/agent/args.js.map +1 -1
- package/dist/src/agent/claude-e-runtime.js +42 -0
- package/dist/src/agent/claude-e-runtime.js.map +1 -0
- package/dist/src/agent/claude-i-runtime.js +42 -0
- package/dist/src/agent/claude-i-runtime.js.map +1 -0
- package/dist/src/agent/cli-helpers.js +9 -0
- package/dist/src/agent/cli-helpers.js.map +1 -0
- package/dist/src/agent/codex-app-client.js +240 -0
- package/dist/src/agent/codex-app-client.js.map +1 -0
- package/dist/src/agent/codex-app-events.js +268 -0
- package/dist/src/agent/codex-app-events.js.map +1 -0
- package/dist/src/agent/error-classifier.js +8 -2
- package/dist/src/agent/error-classifier.js.map +1 -1
- package/dist/src/agent/events/acp.js +200 -0
- package/dist/src/agent/events/acp.js.map +1 -0
- package/dist/src/agent/events/claude.js +200 -0
- package/dist/src/agent/events/claude.js.map +1 -0
- package/dist/src/agent/events/codex.js +118 -0
- package/dist/src/agent/events/codex.js.map +1 -0
- package/dist/src/agent/events/gemini.js +100 -0
- package/dist/src/agent/events/gemini.js.map +1 -0
- package/dist/src/agent/events/grok.js +298 -0
- package/dist/src/agent/events/grok.js.map +1 -0
- package/dist/src/agent/events/helpers.js +237 -0
- package/dist/src/agent/events/helpers.js.map +1 -0
- package/dist/src/agent/events/index.js +315 -0
- package/dist/src/agent/events/index.js.map +1 -0
- package/dist/src/agent/events/opencode.js +171 -0
- package/dist/src/agent/events/opencode.js.map +1 -0
- package/dist/src/agent/events/summary.js +128 -0
- package/dist/src/agent/events/summary.js.map +1 -0
- package/dist/src/agent/events/tool-labels.js +299 -0
- package/dist/src/agent/events/tool-labels.js.map +1 -0
- package/dist/src/agent/events/types.js +3 -0
- package/dist/src/agent/events/types.js.map +1 -0
- package/dist/src/agent/events.js +2 -1487
- package/dist/src/agent/events.js.map +1 -1
- package/dist/src/agent/grok-trace-backfill.js +153 -0
- package/dist/src/agent/grok-trace-backfill.js.map +1 -0
- package/dist/src/agent/lifecycle-handler.js +60 -16
- package/dist/src/agent/lifecycle-handler.js.map +1 -1
- package/dist/src/agent/live-run-state.js +1 -1
- package/dist/src/agent/live-run-state.js.map +1 -1
- package/dist/src/agent/memory-flush-controller.js +26 -0
- package/dist/src/agent/memory-flush-controller.js.map +1 -1
- package/dist/src/agent/resume-classifier.js +9 -0
- package/dist/src/agent/resume-classifier.js.map +1 -1
- package/dist/src/agent/session-persistence.js +7 -2
- package/dist/src/agent/session-persistence.js.map +1 -1
- package/dist/src/agent/spawn/process-kill.js +29 -0
- package/dist/src/agent/spawn/process-kill.js.map +1 -0
- package/dist/src/agent/spawn/queue.js +273 -0
- package/dist/src/agent/spawn/queue.js.map +1 -0
- package/dist/src/agent/spawn/resume.js +56 -0
- package/dist/src/agent/spawn/resume.js.map +1 -0
- package/dist/src/agent/spawn.js +435 -371
- package/dist/src/agent/spawn.js.map +1 -1
- package/dist/src/agent/watchdog.js +5 -1
- package/dist/src/agent/watchdog.js.map +1 -1
- package/dist/src/browser/adaptive-fetch/browser-escalation.js +177 -0
- package/dist/src/browser/adaptive-fetch/browser-escalation.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/browser-runtime.js +38 -0
- package/dist/src/browser/adaptive-fetch/browser-runtime.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/browser-session.js +97 -0
- package/dist/src/browser/adaptive-fetch/browser-session.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/challenge-detector.js +88 -0
- package/dist/src/browser/adaptive-fetch/challenge-detector.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/content-scorer.js +145 -0
- package/dist/src/browser/adaptive-fetch/content-scorer.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/endpoint-resolvers.js +382 -0
- package/dist/src/browser/adaptive-fetch/endpoint-resolvers.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/fetcher.js +105 -0
- package/dist/src/browser/adaptive-fetch/fetcher.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/human-loop.js +101 -0
- package/dist/src/browser/adaptive-fetch/human-loop.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/index.js +586 -0
- package/dist/src/browser/adaptive-fetch/index.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/metadata.js +169 -0
- package/dist/src/browser/adaptive-fetch/metadata.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/output.js +71 -0
- package/dist/src/browser/adaptive-fetch/output.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/reader-adapters.js +135 -0
- package/dist/src/browser/adaptive-fetch/reader-adapters.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/safety.js +296 -0
- package/dist/src/browser/adaptive-fetch/safety.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/third-party-readers.js +43 -0
- package/dist/src/browser/adaptive-fetch/third-party-readers.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/trace.js +61 -0
- package/dist/src/browser/adaptive-fetch/trace.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/transforms.js +81 -0
- package/dist/src/browser/adaptive-fetch/transforms.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/validators.js +108 -0
- package/dist/src/browser/adaptive-fetch/validators.js.map +1 -0
- package/dist/src/browser/adaptive-fetch/waf-profiles.js +135 -0
- package/dist/src/browser/adaptive-fetch/waf-profiles.js.map +1 -0
- package/dist/src/browser/index.js +1 -0
- package/dist/src/browser/index.js.map +1 -1
- package/dist/src/browser/web-ai/gemini-model.js +42 -15
- package/dist/src/browser/web-ai/gemini-model.js.map +1 -1
- package/dist/src/cli/claude-models.js +1 -1
- package/dist/src/cli/claude-models.js.map +1 -1
- package/dist/src/cli/compact.js +2 -0
- package/dist/src/cli/compact.js.map +1 -1
- package/dist/src/cli/handlers-completions.js +3 -0
- package/dist/src/cli/handlers-completions.js.map +1 -1
- package/dist/src/cli/handlers-runtime.js +5 -2
- package/dist/src/cli/handlers-runtime.js.map +1 -1
- package/dist/src/cli/readiness.js +43 -1
- package/dist/src/cli/readiness.js.map +1 -1
- package/dist/src/cli/registry.js +58 -0
- package/dist/src/cli/registry.js.map +1 -1
- package/dist/src/core/browser-open.js +4 -1
- package/dist/src/core/browser-open.js.map +1 -1
- package/dist/src/core/claude-install.js +4 -0
- package/dist/src/core/claude-install.js.map +1 -1
- package/dist/src/core/cli-detect.js +61 -13
- package/dist/src/core/cli-detect.js.map +1 -1
- package/dist/src/core/compact.js +295 -63
- package/dist/src/core/compact.js.map +1 -1
- package/dist/src/core/config.js +151 -11
- package/dist/src/core/config.js.map +1 -1
- package/dist/src/core/db.js +10 -1
- package/dist/src/core/db.js.map +1 -1
- package/dist/src/core/employees.js +1 -1
- package/dist/src/core/employees.js.map +1 -1
- package/dist/src/core/logger.js +28 -9
- package/dist/src/core/logger.js.map +1 -1
- package/dist/src/core/runtime-settings.js +32 -5
- package/dist/src/core/runtime-settings.js.map +1 -1
- package/dist/src/manager/memory/embedding/state-machine.js +2 -1
- package/dist/src/manager/memory/embedding/state-machine.js.map +1 -1
- package/dist/src/manager/memory/embedding/sync.js +52 -33
- package/dist/src/manager/memory/embedding/sync.js.map +1 -1
- package/dist/src/manager/memory/embedding/vec-store.js +10 -10
- package/dist/src/manager/memory/embedding/vec-store.js.map +1 -1
- package/dist/src/manager/routes/dashboard-memory.js +43 -16
- package/dist/src/manager/routes/dashboard-memory.js.map +1 -1
- package/dist/src/manager/server.js +11 -0
- package/dist/src/manager/server.js.map +1 -1
- package/dist/src/memory/indexing.js +6 -1
- package/dist/src/memory/indexing.js.map +1 -1
- package/dist/src/orchestrator/distribute.js +5 -4
- package/dist/src/orchestrator/distribute.js.map +1 -1
- package/dist/src/prompt/builder.js +12 -1
- package/dist/src/prompt/builder.js.map +1 -1
- package/dist/src/prompt/runtime-context.js +69 -0
- package/dist/src/prompt/runtime-context.js.map +1 -0
- package/dist/src/routes/browser.js +33 -0
- package/dist/src/routes/browser.js.map +1 -1
- package/dist/src/routes/employees.js +1 -1
- package/dist/src/routes/employees.js.map +1 -1
- package/dist/src/routes/memory.js +1 -1
- package/dist/src/routes/memory.js.map +1 -1
- package/dist/src/routes/orchestrate.js +37 -10
- package/dist/src/routes/orchestrate.js.map +1 -1
- package/dist/src/routes/quota.js +91 -1
- package/dist/src/routes/quota.js.map +1 -1
- package/dist/src/routes/runtime-context.js +43 -0
- package/dist/src/routes/runtime-context.js.map +1 -0
- package/dist/src/routes/security-audit.js +14 -0
- package/dist/src/routes/security-audit.js.map +1 -0
- package/dist/src/routes/settings.js +8 -1
- package/dist/src/routes/settings.js.map +1 -1
- package/dist/src/security/security-audit-log.js +99 -0
- package/dist/src/security/security-audit-log.js.map +1 -0
- package/dist/src/telegram/bot.js +4 -2
- package/dist/src/telegram/bot.js.map +1 -1
- package/dist/src/types/cli-engine.js +4 -0
- package/dist/src/types/cli-engine.js.map +1 -1
- package/dist/src/types/cli-events.js +1 -1
- package/dist/src/types/cli-events.js.map +1 -1
- package/package.json +9 -3
- package/public/assets/providers/antigravity-color.svg +1 -0
- package/public/assets/providers/antigravity.svg +1 -0
- package/public/assets/providers/copilot-color.svg +1 -1
- package/public/assets/providers/copilot.svg +1 -1
- package/public/assets/providers/grok-color.svg +1 -0
- package/public/assets/providers/grok.svg +1 -0
- package/public/css/chat-search.css +168 -0
- package/public/css/chat.css +43 -1
- package/public/css/modals.css +41 -0
- package/public/dist/assets/{AdvancedExport-BAdZUC-6.js → AdvancedExport-CBvz4_IZ.js} +1 -1
- package/public/dist/assets/Agent-DlUqCMXJ.js +1 -0
- package/public/dist/assets/{Browser-BsdxDVgM.js → Browser-66BpLQck.js} +1 -1
- package/public/dist/assets/{ChannelsDiscord-Dg_jto6l.js → ChannelsDiscord-BifT2Dum.js} +1 -1
- package/public/dist/assets/{ChannelsTelegram-DGyZfJGS.js → ChannelsTelegram-CK6tYQ8k.js} +1 -1
- package/public/dist/assets/DashboardEmbeddingSection-6F8zSSja.js +2 -0
- package/public/dist/assets/{DashboardMeta-CAH9ONTb.js → DashboardMeta-Cc03HT5R.js} +1 -1
- package/public/dist/assets/{Display-DM_yvyKL.js → Display-arOjcMQZ.js} +1 -1
- package/public/dist/assets/Employees-YbW-mI67.js +1 -0
- package/public/dist/assets/{HealthBadge-Dtr-dDnw.js → HealthBadge-DEPFkcA0.js} +1 -1
- package/public/dist/assets/Heartbeat-CW4eIhtJ.js +1 -0
- package/public/dist/assets/{InlineWarn-E64UaKFh.js → InlineWarn-DoJS7AgM.js} +1 -1
- package/public/dist/assets/{Mcp-Dlp2X7X7.js → Mcp-ZQ6ARQb6.js} +1 -1
- package/public/dist/assets/Memory-BAUWJMqc.js +1 -0
- package/public/dist/assets/{MilkdownWysiwygEditor-Ctww8i0L.js → MilkdownWysiwygEditor-IAqFtXvM.js} +1 -1
- package/public/dist/assets/ModelProvider-DUtmFh0J.js +1 -0
- package/public/dist/assets/{Network-Df1R2YcQ.js → Network-B_4E82zQ.js} +1 -1
- package/public/dist/assets/{Permissions-BKJ5K6EL.js → Permissions-BkADXjQ4.js} +1 -1
- package/public/dist/assets/{Permissions-CcWZoOVP.js → Permissions-DvUCB8wA.js} +1 -1
- package/public/dist/assets/{Profile-DZ7xf1WZ.js → Profile-BcnTCSYM.js} +1 -1
- package/public/dist/assets/{Prompts-Bh5DYt8e.js → Prompts-CUs_RoRE.js} +1 -1
- package/public/dist/assets/{SpeechKeys-CQwtVxOP.js → SpeechKeys-qxc-ROWN.js} +1 -1
- package/public/dist/assets/agent-meta-Du8y6mSM.js +1 -0
- package/public/dist/assets/app-CGqTcIeF.js +39 -0
- package/public/dist/assets/app-Dpk6cE6C.css +1 -0
- package/public/dist/assets/architecture-7EHR7CIX-wVaUQezY.js +1 -0
- package/public/dist/assets/architectureDiagram-3BPJPVTR-kYIVzmWe.js +36 -0
- package/public/dist/assets/blockDiagram-GPEHLZMM-B204CPhe.js +132 -0
- package/public/dist/assets/{c4Diagram-AHTNJAMY-Bp2QLC-s.js → c4Diagram-AAUBKEIU-DAv6TAjg.js} +6 -6
- package/public/dist/assets/channel-CCQujL1n.js +1 -0
- package/public/dist/assets/{chunk-EDXVE4YY-COudQKkJ.js → chunk-2J33WTMH-xiPJWKcl.js} +1 -1
- package/public/dist/assets/chunk-3OPIFGDE-DOAvk9x8.js +62 -0
- package/public/dist/assets/{chunk-4BX2VUAB-Cm3KqBkS.js → chunk-4BX2VUAB-6lTRwyT0.js} +1 -1
- package/public/dist/assets/chunk-4EGX6M5U-DXtAEgX6.js +1 -0
- package/public/dist/assets/chunk-55IACEB6-Dx2JkQLw.js +1 -0
- package/public/dist/assets/chunk-5DO6E6H7-DDcMHB95.js +1 -0
- package/public/dist/assets/chunk-5ZQYHXKU-Bd-RFO5i.js +2 -0
- package/public/dist/assets/chunk-727SXJPM-BrsRzj8z.js +206 -0
- package/public/dist/assets/{chunk-AGHRB4JF-DIMn8T3_.js → chunk-AGHRB4JF-CYdXVA2-.js} +1 -1
- package/public/dist/assets/chunk-AQP2D5EJ-Di6Gstk-.js +231 -0
- package/public/dist/assets/{chunk-LIHQZDEY-Xw9ZX8of.js → chunk-BR22UD5L-CVuYkAd1.js} +1 -1
- package/public/dist/assets/{chunk-BSJP7CBP-DnSYKjii.js → chunk-BSJP7CBP-B47GpxcW.js} +1 -1
- package/public/dist/assets/chunk-CSCIHK7Q-CAE1p4Em.js +123 -0
- package/public/dist/assets/chunk-FHYWG6QK-CxZt-yZZ.js +1 -0
- package/public/dist/assets/{chunk-FMBD7UC4-6yXYicjw.js → chunk-FMBD7UC4-CwqBlx0l.js} +1 -1
- package/public/dist/assets/chunk-KSCS5N6A-D9a4ZkOy.js +10 -0
- package/public/dist/assets/{chunk-ZZ45TVLE-D5oxCC1O.js → chunk-L5ZTLDWV-D208QbfC.js} +1 -1
- package/public/dist/assets/{chunk-336JU56O-CAt5aBOe.js → chunk-LZXEDZCA-CE2KFduj.js} +1 -1
- package/public/dist/assets/chunk-MPE355IW-Bp4qAOUf.js +1 -0
- package/public/dist/assets/chunk-MZUSXYTE-DAU-v-0c.js +1 -0
- package/public/dist/assets/chunk-N66VUXT2-CpPz1L5u.js +1 -0
- package/public/dist/assets/chunk-ND2GUHAM-zZ7h1CPf.js +1 -0
- package/public/dist/assets/chunk-NNHCCRGN-BaiX9a5F.js +159 -0
- package/public/dist/assets/{chunk-X2U36JSP-CoMFMVNF.js → chunk-NZK2D7GU-CTqFQ8K5.js} +1 -1
- package/public/dist/assets/chunk-O5CBEL6O-BTuvXKFi.js +11 -0
- package/public/dist/assets/chunk-PUPMXCY4-ppZvktf-.js +1 -0
- package/public/dist/assets/chunk-QZHKN3VN-CBAtPPT7.js +1 -0
- package/public/dist/assets/chunk-UIBZB4QT-rJZEVBX0.js +1 -0
- package/public/dist/assets/chunk-WCWK7LTN-CGvUyB8h.js +1 -0
- package/public/dist/assets/chunk-WU5MYG2G-C3fKlSvP.js +1 -0
- package/public/dist/assets/{chunk-XPW4576I-CmAz5C-j.js → chunk-XPW4576I-BaQfzRci.js} +1 -1
- package/public/dist/assets/classDiagram-4FO5ZUOK-Cb-qL5u3.js +1 -0
- package/public/dist/assets/classDiagram-v2-Q7XG4LA2-BPhGdj15.js +1 -0
- package/public/dist/assets/constants-BxG09J6S.js +1 -0
- package/public/dist/assets/cose-bilkent-S5V4N54A-D1zmarou.js +1 -0
- package/public/dist/assets/dagre-BM42HDAG-BVkBttzA.js +4 -0
- package/public/dist/assets/dagre-DnoxfNXr.js +1 -0
- package/public/dist/assets/diagram-2AECGRRQ-Bs32KPnT.js +43 -0
- package/public/dist/assets/{diagram-5BDNPKRD-Cl4PzCD0.js → diagram-5GNKFQAL-YDYgPOQj.js} +2 -2
- package/public/dist/assets/diagram-KO2AKTUF-1tIdFl26.js +3 -0
- package/public/dist/assets/{diagram-TYMM5635-B_Xoa1Gp.js → diagram-LMA3HP47-B1y15kav.js} +1 -1
- package/public/dist/assets/diagram-OG6HWLK6-C25j1jGg.js +24 -0
- package/public/dist/assets/{dist-C9LWf2uC.js → dist-0v1UKkQ3.js} +1 -1
- package/public/dist/assets/dist-BMi_buEb.js +1 -0
- package/public/dist/assets/{dist-B6G8pbap.js → dist-BQNQk-1M.js} +1 -1
- package/public/dist/assets/{dist-CCKktDoF.js → dist-BVpa_e6W.js} +1 -1
- package/public/dist/assets/dist-BkrbW_LS.js +1 -0
- package/public/dist/assets/{dist-CkMC2PPt.js → dist-C1VqWrYZ.js} +1 -1
- package/public/dist/assets/{dist-BA7sRne4.js → dist-C3vh7d65.js} +1 -1
- package/public/dist/assets/{dist-BhzKO6nt2.js → dist-CE4s7vg82.js} +1 -1
- package/public/dist/assets/{dist-BDMNMdPF.js → dist-CjPin7Mr.js} +1 -1
- package/public/dist/assets/{dist-W7IGn2ug.js → dist-Ck6PnIlo.js} +1 -1
- package/public/dist/assets/{dist-B1rKu9eP.js → dist-CnIrGAPx.js} +1 -1
- package/public/dist/assets/{dist-CEDX2HGI.js → dist-Cv8S3FhF.js} +1 -1
- package/public/dist/assets/{dist-55MYVjjj.js → dist-D0PYXGt2.js} +1 -1
- package/public/dist/assets/{dist-C0sOT_UM.js → dist-D5GUqT-6.js} +1 -1
- package/public/dist/assets/{dist-C5S-Rbvc.js → dist-D66X8iAn.js} +1 -1
- package/public/dist/assets/dist-D815C1Fv.js +1 -0
- package/public/dist/assets/{dist-Ch6JG5jE.js → dist-DDDFJ8jG.js} +1 -1
- package/public/dist/assets/{dist-2oDfqE98.js → dist-DHQI31dn.js} +1 -1
- package/public/dist/assets/{dist-BTp_Oy_x.js → dist-DTQW91xt.js} +1 -1
- package/public/dist/assets/{dist-BuaQLcgQ.js → dist-Dm7RAaUo.js} +1 -1
- package/public/dist/assets/{dist-BJyDhGpS.js → dist-DrIWh2fi.js} +1 -1
- package/public/dist/assets/{dist-BGzHP3f8.js → dist-DzT7frM2.js} +1 -1
- package/public/dist/assets/{dist-wdLr2dSH.js → dist-Qs7HHNCC.js} +1 -1
- package/public/dist/assets/{dist-BjqyutOM.js → dist-Rs_Khtjb.js} +1 -1
- package/public/dist/assets/{dist-DdhWu7OM.js → dist-fJAyK82z.js} +1 -1
- package/public/dist/assets/{dist-G7QUHtDS.js → dist-jcptfm_T.js} +1 -1
- package/public/dist/assets/dist-sOV2kBhQ.js +1 -0
- package/public/dist/assets/{dist-BoG5I6U5.js → dist-vQskrHxt.js} +1 -1
- package/public/dist/assets/{dockerfile-CrC2HXHP.js → dockerfile-DAfh5qoE.js} +1 -1
- package/public/dist/assets/{employees-CIkIyvtL.js → employees-DRmX2RDd.js} +2 -2
- package/public/dist/assets/{erDiagram-SMLLAGMA-BvtqhMsS.js → erDiagram-TEJ5UH35-CRvCbztR.js} +6 -6
- package/public/dist/assets/{error-normalize-CkhPeQYx.js → error-normalize-CNbPE4lO.js} +1 -1
- package/public/dist/assets/eventmodeling-FCH6USID-Cq0nylxO.js +1 -0
- package/public/dist/assets/{factor-1CttFx2G.js → factor-BpoYJieo.js} +1 -1
- package/public/dist/assets/fields-DUawAHWZ.js +1 -0
- package/public/dist/assets/flowDiagram-I6XJVG4X-CzvVnib_.js +162 -0
- package/public/dist/assets/ganttDiagram-6RSMTGT7-BbUYP6iv.js +292 -0
- package/public/dist/assets/gitGraph-WXDBUCRP-DDq6-3D3.js +1 -0
- package/public/dist/assets/gitGraphDiagram-PVQCEYII-CbKdM7nW.js +106 -0
- package/public/dist/assets/graphlib-BLOO0H5r.js +1 -0
- package/public/dist/assets/info-J43DQDTF-OUnqwpUV.js +1 -0
- package/public/dist/assets/infoDiagram-5YYISTIA-BrZmg1At.js +2 -0
- package/public/dist/assets/{ishikawaDiagram-UXIWVN3A-DZW-Nqsf.js → ishikawaDiagram-YF4QCWOH-BDWXqJi5.js} +2 -2
- package/public/dist/assets/javascript-CZjRNq5R.js +1 -0
- package/public/dist/assets/{journeyDiagram-VCZTEJTY-ByVRJxVF.js → journeyDiagram-JHISSGLW-CPFRd_M3.js} +6 -6
- package/public/dist/assets/{jsx-runtime-BjL7qHh8.js → jsx-runtime-BZmCptaP.js} +1 -1
- package/public/dist/assets/{kanban-definition-6JOO6SKY-xwN0YCW2.js → kanban-definition-UN3LZRKU-BcQbBplS.js} +10 -10
- package/public/dist/assets/katex-CF5bGce6.js +1 -0
- package/public/dist/assets/manager-B5OmizBL.css +1 -0
- package/public/dist/assets/manager-Cs3eMBcx.js +25 -0
- package/public/dist/assets/{memory-CnBc2_Va.js → memory-BA-ki3gn.js} +1 -1
- package/public/dist/assets/memory-DLQbyBA3.js +1 -0
- package/public/dist/assets/mermaid-loader-BVPsKrpr.js +1 -0
- package/public/dist/assets/mermaid-parser.core-C62NUJRb.js +3 -0
- package/public/dist/assets/mermaid.core-ArqR5iFa.js +9 -0
- package/public/dist/assets/mermaid.core-BAwu4U2Y.js +1 -0
- package/public/dist/assets/{mindmap-definition-QFDTVHPH-Chqgsh1N.js → mindmap-definition-RKZ34NQL-C35cGkNU.js} +29 -29
- package/public/dist/assets/{nsis-_CjIiUyF.js → nsis-Ch4QINLN.js} +1 -1
- package/public/dist/assets/packet-YPE3B663-Bb9hBQ06.js +1 -0
- package/public/dist/assets/{page-shell-CTxVDJ8Y.js → page-shell-CVAobxbP.js} +1 -1
- package/public/dist/assets/pie-LRSECV5Y-CNRQnRNZ.js +1 -0
- package/public/dist/assets/pieDiagram-4H26LBE5-B8C_hoqJ.js +30 -0
- package/public/dist/assets/provider-icons-dxT69zGg.js +8 -0
- package/public/dist/assets/{pug-CbR8lCtK.js → pug-CXYqmmpP.js} +1 -1
- package/public/dist/assets/quadrantDiagram-W4KKPZXB-BEPrine5.js +7 -0
- package/public/dist/assets/radar-GUYGQ44K-BxngU2v0.js +1 -0
- package/public/dist/assets/{render-lpTpN1El.js → render-C7_e0J_X.js} +3 -3
- package/public/dist/assets/{requirementDiagram-MS252O5E-wnPtv0LG.js → requirementDiagram-4Y6WPE33-ClDDon9c.js} +4 -4
- package/public/dist/assets/rolldown-runtime-XQCOJYun.js +1 -0
- package/public/dist/assets/sankeyDiagram-5OEKKPKP-Bjs3OE-1.js +40 -0
- package/public/dist/assets/sequenceDiagram-3UESZ5HK-BM8IAaEe.js +162 -0
- package/public/dist/assets/settings-DjyKdqev.js +1 -0
- package/public/dist/assets/settings-pUJzyeX2.js +42 -0
- package/public/dist/assets/{sidebar-Cwt0FxQl.js → sidebar-CO9Qjj6v.js} +2 -2
- package/public/dist/assets/skills-CX3qJ77s.js +1 -0
- package/public/dist/assets/{skills-DDmTyywh.js → skills-Dq7fD8I3.js} +1 -1
- package/public/dist/assets/{slash-commands-D5y5AVvS.js → slash-commands-DRsKtuGT.js} +1 -1
- package/public/dist/assets/slash-commands-UbS8w9ij.js +1 -0
- package/public/dist/assets/stateDiagram-AJRCARHV-BvNABuXE.js +1 -0
- package/public/dist/assets/stateDiagram-v2-BHNVJYJU-CCIo81qy.js +1 -0
- package/public/dist/assets/{timeline-definition-GMOUNBTQ-DUz1-iOx.js → timeline-definition-PNZ67QCA-CIvTvac3.js} +8 -8
- package/public/dist/assets/trace-drawer-DDFdU07_.js +15 -0
- package/public/dist/assets/treeView-BLDUP644-cXRzPGzz.js +1 -0
- package/public/dist/assets/treemap-LRROVOQU-BsZE5HPE.js +1 -0
- package/public/dist/assets/ui-CeBmBBZM.js +140 -0
- package/public/dist/assets/ui-TMXjvH0r.js +1 -0
- package/public/dist/assets/{vendor-render-DEStnpJ8.js → vendor-render-DCb9B75Q.js} +38 -37
- package/public/dist/assets/vendor-utils-BnxL60_-.js +1 -0
- package/public/dist/assets/vennDiagram-CIIHVFJN-C5cbS2KC.js +34 -0
- package/public/dist/assets/wardley-L42UT6IY-D_qm0cZD.js +1 -0
- package/public/dist/assets/{wardleyDiagram-NUSXRM2D-CLAhOzap.js → wardleyDiagram-YWT4CUSO-BsRBBGFP.js} +61 -3
- package/public/dist/assets/{wiki-link-suggestions-LQuYT22G.js → wiki-link-suggestions-BHwNQXT_.js} +2 -2
- package/public/dist/assets/{xychartDiagram-5P7HB3ND-DLnY9i8z.js → xychartDiagram-2RQKCTM6-B6rqui6F.js} +6 -6
- package/public/dist/index.html +102 -3
- package/public/dist/manager/index.html +2 -2
- package/public/index.html +101 -1
- package/public/js/constants.ts +72 -0
- package/public/js/diagram/iframe-renderer.ts +7 -0
- package/public/js/features/chat-scroll.ts +31 -0
- package/public/js/features/chat-search.ts +223 -0
- package/public/js/features/help-content.ts +20 -2
- package/public/js/features/help-dialog.ts +38 -2
- package/public/js/features/pending-queue.ts +6 -0
- package/public/js/features/process-block.ts +20 -0
- package/public/js/features/settings-channel.ts +3 -1
- package/public/js/features/settings-cli-status.ts +24 -3
- package/public/js/features/settings-core.ts +134 -21
- package/public/js/features/settings-types.ts +12 -1
- package/public/js/features/settings.ts +1 -1
- package/public/js/features/trace-drawer.ts +2 -1
- package/public/js/features/voice-recorder.ts +222 -42
- package/public/js/main.ts +58 -4
- package/public/js/provider-icons.ts +46 -27
- package/public/js/render/markdown.ts +6 -0
- package/public/js/ui.ts +33 -7
- package/public/js/ws.ts +5 -1
- package/public/locales/en.json +31 -7
- package/public/locales/ja.json +31 -7
- package/public/locales/ko.json +31 -7
- package/public/locales/zh.json +31 -7
- package/public/manager/src/App.tsx +19 -55
- package/public/manager/src/InstancePreview.tsx +46 -1
- package/public/manager/src/components/InstanceDetailPanel.tsx +7 -2
- package/public/manager/src/components/InstanceLogsPanel.tsx +138 -0
- package/public/manager/src/dashboard-settings/DashboardEmbeddingSection.tsx +37 -7
- package/public/manager/src/jaw-ceo/useJawCeoDashboardBridge.tsx +1 -0
- package/public/manager/src/manager-components.css +76 -0
- package/public/manager/src/preview.ts +26 -3
- package/public/manager/src/settings/fields/SelectField.tsx +51 -17
- package/public/manager/src/settings/pages/Agent.tsx +37 -2
- package/public/manager/src/settings/pages/Heartbeat.tsx +3 -2
- package/public/manager/src/settings/pages/Memory.tsx +3 -2
- package/public/manager/src/settings/pages/components/EmployeeRow.tsx +8 -4
- package/public/manager/src/settings/pages/components/PerCliRow.tsx +31 -5
- package/public/manager/src/settings/pages/components/agent/FlushAgentSection.tsx +4 -2
- package/public/manager/src/settings/pages/components/agent/RuntimeEmployeeRow.tsx +1 -1
- package/public/manager/src/settings/pages/components/agent/RuntimeHeader.tsx +23 -1
- package/public/manager/src/settings/pages/components/agent/agent-meta.ts +49 -0
- package/public/manager/src/settings/pages/components/employees-helpers.ts +6 -1
- package/public/manager/src/settings/pages/components/heartbeat-helpers.ts +11 -1
- package/public/manager/src/settings-controls.css +25 -0
- package/public/manager/src/usePreviewShortcutMessages.ts +30 -0
- package/public/manager/src/usePreviewSttLifecycle.ts +31 -0
- package/scripts/fresh-install-smoke.ts +1 -1
- package/scripts/install-officecli.ps1 +33 -5
- package/scripts/install-officecli.sh +52 -8
- package/scripts/install-wsl.sh +96 -24
- package/scripts/install.sh +82 -11
- package/scripts/postinstall-guard.cjs +57 -30
- package/public/dist/assets/Agent-DNpehKB2.js +0 -1
- package/public/dist/assets/DashboardEmbeddingSection-BYdGgqg7.js +0 -2
- package/public/dist/assets/Employees-CuYuTy0R.js +0 -1
- package/public/dist/assets/Heartbeat-C-vq02MW.js +0 -1
- package/public/dist/assets/Memory-BPKWJDXK.js +0 -1
- package/public/dist/assets/ModelProvider-Bd6vGkXT.js +0 -1
- package/public/dist/assets/agent-meta-C1pQzExf.js +0 -1
- package/public/dist/assets/app-BxsIleo0.js +0 -32
- package/public/dist/assets/app-CB9n5A77.css +0 -1
- package/public/dist/assets/architecture-YZFGNWBL-BRI-0IaU.js +0 -1
- package/public/dist/assets/architectureDiagram-Q4EWVU46-z0JCgZrJ.js +0 -36
- package/public/dist/assets/blockDiagram-DXYQGD6D-KaOz3aFS.js +0 -132
- package/public/dist/assets/channel-jLopKIgm.js +0 -1
- package/public/dist/assets/chunk-2KRD3SAO-C8hJZPJu.js +0 -1
- package/public/dist/assets/chunk-426QAEUC-atJRhvKN.js +0 -1
- package/public/dist/assets/chunk-4TB4RGXK-BD7UhIN8.js +0 -206
- package/public/dist/assets/chunk-55IACEB6-CAWcPDdr.js +0 -1
- package/public/dist/assets/chunk-5FUZZQ4R-Cg1pzs6p.js +0 -62
- package/public/dist/assets/chunk-5PVQY5BW-otv3HwE_.js +0 -2
- package/public/dist/assets/chunk-67CJDMHE-AU2iOKLT.js +0 -1
- package/public/dist/assets/chunk-7N4EOEYR-BTIS4jBw.js +0 -1
- package/public/dist/assets/chunk-AA7GKIK3-c9UUJO_T.js +0 -1
- package/public/dist/assets/chunk-CIAEETIT-Dwbln6rM.js +0 -1
- package/public/dist/assets/chunk-ENJZ2VHE-PT_jAckw.js +0 -10
- package/public/dist/assets/chunk-FOC6F5B3-BqDmFFeg.js +0 -1
- package/public/dist/assets/chunk-ICPOFSXX-P6V6jqiT.js +0 -122
- package/public/dist/assets/chunk-K5T4RW27-C42sOmZR.js +0 -27
- package/public/dist/assets/chunk-KGLVRYIC-K-BVa8b2.js +0 -1
- package/public/dist/assets/chunk-ORNJ4GCN-CEXU6WaD.js +0 -1
- package/public/dist/assets/chunk-OYMX7WX6-DmJG2z1S.js +0 -231
- package/public/dist/assets/chunk-QZHKN3VN-BkVLii_3.js +0 -1
- package/public/dist/assets/chunk-U2HBQHQK-Ny6UwUgK.js +0 -11
- package/public/dist/assets/chunk-YZCP3GAM-c7FYtZME.js +0 -1
- package/public/dist/assets/classDiagram-6PBFFD2Q-BgOyAynm.js +0 -1
- package/public/dist/assets/classDiagram-v2-HSJHXN6E-5gBdoVH9.js +0 -1
- package/public/dist/assets/constants-4A2GptQT.js +0 -1
- package/public/dist/assets/cose-bilkent-S5V4N54A-CvH6qY_r.js +0 -1
- package/public/dist/assets/dagre--20B2-ZQ.js +0 -1
- package/public/dist/assets/dagre-KV5264BT-CQ0wo0ma.js +0 -4
- package/public/dist/assets/diagram-G4DWMVQ6-_aP6kMTh.js +0 -24
- package/public/dist/assets/diagram-MMDJMWI5-J1l6Q0JG.js +0 -43
- package/public/dist/assets/dist-B1p80u1b.js +0 -1
- package/public/dist/assets/dist-BKyzWv22.js +0 -1
- package/public/dist/assets/dist-CxJpXP6s.js +0 -1
- package/public/dist/assets/dist-DNLFuTrS.js +0 -1
- package/public/dist/assets/fields-BISouxp2.js +0 -1
- package/public/dist/assets/flowDiagram-DWJPFMVM-C_F0rqqT.js +0 -162
- package/public/dist/assets/ganttDiagram-T4ZO3ILL-B5S8EZRg.js +0 -292
- package/public/dist/assets/gitGraph-7Q5UKJZL-DTTW6pxr.js +0 -1
- package/public/dist/assets/gitGraphDiagram-UUTBAWPF-DMGzYJeb.js +0 -106
- package/public/dist/assets/graphlib-CZk_Ii16.js +0 -1
- package/public/dist/assets/info-OMHHGYJF-BU-iuaSm.js +0 -1
- package/public/dist/assets/infoDiagram-42DDH7IO-dzSaYFFK.js +0 -2
- package/public/dist/assets/javascript-BhB45e0W.js +0 -1
- package/public/dist/assets/katex-DamPUmTE.js +0 -1
- package/public/dist/assets/manager-B84u-pcn.js +0 -25
- package/public/dist/assets/manager-DMg_sTEP.css +0 -1
- package/public/dist/assets/memory-BV62wlsG.js +0 -1
- package/public/dist/assets/mermaid-loader-DxFGz4EE.js +0 -1
- package/public/dist/assets/mermaid-parser.core-CMIZ0my_.js +0 -3
- package/public/dist/assets/mermaid.core-CicVBD9l.js +0 -1
- package/public/dist/assets/mermaid.core-Dj6viEzN.js +0 -11
- package/public/dist/assets/packet-4T2RLAQJ-DzmBsAf0.js +0 -1
- package/public/dist/assets/pie-ZZUOXDRM-DyG1KzTn.js +0 -1
- package/public/dist/assets/pieDiagram-DEJITSTG-DJLiSymi.js +0 -30
- package/public/dist/assets/quadrantDiagram-34T5L4WZ-qcnWmcRr.js +0 -7
- package/public/dist/assets/radar-PYXPWWZC-CEBZARUu.js +0 -1
- package/public/dist/assets/rolldown-runtime-DE9SaGGd.js +0 -1
- package/public/dist/assets/sankeyDiagram-XADWPNL6-Bn3pUd_K.js +0 -10
- package/public/dist/assets/sequenceDiagram-FGHM5R23-DfxcHSdj.js +0 -157
- package/public/dist/assets/settings-CfAXLa8a.js +0 -1
- package/public/dist/assets/settings-FWgmcubl.js +0 -40
- package/public/dist/assets/skills-D-qUVJ-e.js +0 -1
- package/public/dist/assets/slash-commands-BfI19vIz.js +0 -1
- package/public/dist/assets/stateDiagram-FHFEXIEX-CiR7P2OG.js +0 -1
- package/public/dist/assets/stateDiagram-v2-QKLJ7IA2-BaWWpysK.js +0 -1
- package/public/dist/assets/trace-drawer-DVF5F1df.js +0 -15
- package/public/dist/assets/treeView-SZITEDCU-D5-TP7Qp.js +0 -1
- package/public/dist/assets/treemap-W4RFUUIX-BQhm_ZSp.js +0 -1
- package/public/dist/assets/ui-BJXY16Dk.js +0 -140
- package/public/dist/assets/ui-BXm3OPPh.js +0 -1
- package/public/dist/assets/vendor-utils-IVTPs69f.js +0 -68
- package/public/dist/assets/vennDiagram-DHZGUBPP-CYu7SDdG.js +0 -34
- package/public/dist/assets/wardley-RL74JXVD-CpnBMRe0.js +0 -1
- package/public/manager/src/settings/pages/Embedding.tsx +0 -382
- /package/public/dist/assets/{apl-HYRstREL.js → apl-CieDeb7B.js} +0 -0
- /package/public/dist/assets/{asciiarmor-BDXCrhAK.js → asciiarmor-BRTyulZY.js} +0 -0
- /package/public/dist/assets/{asn1-CnSBhb0M.js → asn1-DoNAtQ5o.js} +0 -0
- /package/public/dist/assets/{asterisk-AqV7rnIi.js → asterisk-CR7oKPxi.js} +0 -0
- /package/public/dist/assets/{brainfuck-Dv46-iL9.js → brainfuck-abzPcrOz.js} +0 -0
- /package/public/dist/assets/{clike-GRffz5hY.js → clike-B71Zq38G.js} +0 -0
- /package/public/dist/assets/{clojure-DzgT_fqE.js → clojure-Zm0UzHPq.js} +0 -0
- /package/public/dist/assets/{cmake-Co1237r5.js → cmake-D3UNdg6L.js} +0 -0
- /package/public/dist/assets/{cobol-rUaLketb.js → cobol-4fYvwQR0.js} +0 -0
- /package/public/dist/assets/{coffeescript-DQyfHE86.js → coffeescript-Ct6bZdRU.js} +0 -0
- /package/public/dist/assets/{commonlisp-Buue1PGW.js → commonlisp-CrgXVPcd.js} +0 -0
- /package/public/dist/assets/{crystal-BMWO0kOJ.js → crystal-bGOl67VM.js} +0 -0
- /package/public/dist/assets/{css-DaxibPo5.js → css-B_EV3Xq2.js} +0 -0
- /package/public/dist/assets/{cypher-CmpGfiBR.js → cypher-DXDlHTYf.js} +0 -0
- /package/public/dist/assets/{cytoscape.esm-zT8GwLFm.js → cytoscape.esm-BK7ao2Ti.js} +0 -0
- /package/public/dist/assets/{d-qmdtoIzU.js → d-RL5ynsiz.js} +0 -0
- /package/public/dist/assets/{diff-B40m6u1h.js → diff-B5McBGjz.js} +0 -0
- /package/public/dist/assets/{dtd-569ynYVj.js → dtd-l3sK4p_C.js} +0 -0
- /package/public/dist/assets/{dylan-Dxolp30i.js → dylan-WjJGY-rW.js} +0 -0
- /package/public/dist/assets/{ebnf-BZiX9Iq3.js → ebnf-BGY79HOS.js} +0 -0
- /package/public/dist/assets/{ecl-B8F1Q0oZ.js → ecl-BKh7OE1d.js} +0 -0
- /package/public/dist/assets/{eiffel-Bv8Kvgh1.js → eiffel-Bzvlg3oK.js} +0 -0
- /package/public/dist/assets/{elm-QWXQaIis.js → elm-5_BqNmKu.js} +0 -0
- /package/public/dist/assets/{erlang-CuDGzTGm.js → erlang-BdVwz8I8.js} +0 -0
- /package/public/dist/assets/{fcl-BiFeqtHf.js → fcl-B9cnfODD.js} +0 -0
- /package/public/dist/assets/{forth-R7Uc2VcL.js → forth-wZbbnGzb.js} +0 -0
- /package/public/dist/assets/{fortran-kDRG6BzW.js → fortran-BAJZrRfU.js} +0 -0
- /package/public/dist/assets/{gas-CyRkuC5T.js → gas-D60ZhBat.js} +0 -0
- /package/public/dist/assets/{gherkin-BE0p00ey.js → gherkin-B8tKjAAi.js} +0 -0
- /package/public/dist/assets/{groovy-B_Sh3D1t.js → groovy-BAG9eJUD.js} +0 -0
- /package/public/dist/assets/{haskell-DWXgCy4o.js → haskell-Cj4TmWbg.js} +0 -0
- /package/public/dist/assets/{haxe-xGxZ54Hv.js → haxe-8chnvz-o.js} +0 -0
- /package/public/dist/assets/{http-CKv9cSBA.js → http-DDYeO71z.js} +0 -0
- /package/public/dist/assets/{idl-DmlI3XzS.js → idl-D1hY-Gp_.js} +0 -0
- /package/public/dist/assets/{javascript-j6r5uf_k.js → javascript-Sh0ZUMP2.js} +0 -0
- /package/public/dist/assets/{julia-CQSp9Qa0.js → julia-BibioBF2.js} +0 -0
- /package/public/dist/assets/{livescript-CqvtVTlb.js → livescript-CSZrB6F4.js} +0 -0
- /package/public/dist/assets/{lua-DazQKUZ0.js → lua-BvTlo5w3.js} +0 -0
- /package/public/dist/assets/{mathematica-DqhJVCs9.js → mathematica-Bexv8BWZ.js} +0 -0
- /package/public/dist/assets/{mbox-Dsyo1_UL.js → mbox-BAhbA8z2.js} +0 -0
- /package/public/dist/assets/{mirc-D7ThhoF-.js → mirc-BzT5Kh4S.js} +0 -0
- /package/public/dist/assets/{mllike-EPZ6pqQD.js → mllike-DeoJnUZQ.js} +0 -0
- /package/public/dist/assets/{modelica-PU45hbqg.js → modelica-FD_-Fxlc.js} +0 -0
- /package/public/dist/assets/{mscgen-DEnh2Ojr.js → mscgen-C-OyhbwB.js} +0 -0
- /package/public/dist/assets/{mumps-8GhR7rRa.js → mumps-BxkCDTK7.js} +0 -0
- /package/public/dist/assets/{nginx-CXwagpwp.js → nginx-2JaV__gC.js} +0 -0
- /package/public/dist/assets/{ntriples-BDQxxstw.js → ntriples--rhhCzqb.js} +0 -0
- /package/public/dist/assets/{octave-2c90WnyU.js → octave-rS4nMzRe.js} +0 -0
- /package/public/dist/assets/{oz-CO0rQ8EL.js → oz-I4fMb_NC.js} +0 -0
- /package/public/dist/assets/{pascal-CcVwOGeN.js → pascal-BEghJs8t.js} +0 -0
- /package/public/dist/assets/{path-utils-DySmCVZK.js → path-utils-r2bJIu28.js} +0 -0
- /package/public/dist/assets/{perl-B9UvGoAV.js → perl-BRO9ZFo9.js} +0 -0
- /package/public/dist/assets/{pig-Cd1f86ZJ.js → pig-L4Ii6KI0.js} +0 -0
- /package/public/dist/assets/{powershell-DV4cOnkJ.js → powershell-BBeqUCRp.js} +0 -0
- /package/public/dist/assets/{properties-DaSVPhrZ.js → properties-Boi0jF2J.js} +0 -0
- /package/public/dist/assets/{protobuf-CEtFnY22.js → protobuf-fB2aGypX.js} +0 -0
- /package/public/dist/assets/{puppet-Ca0DHfcW.js → puppet-BRmsErtO.js} +0 -0
- /package/public/dist/assets/{python-ydzCwWG-.js → python-Be4P9Dgp.js} +0 -0
- /package/public/dist/assets/{q-Cl8kzQmk.js → q-DZGhDLYt.js} +0 -0
- /package/public/dist/assets/{r-DKZPJFrD.js → r-B4NERjRM.js} +0 -0
- /package/public/dist/assets/{rough.esm-Dnk3WN4D.js → rough.esm-C0Gkx4O1.js} +0 -0
- /package/public/dist/assets/{rpm-D0lqeHoZ.js → rpm-e-QbHJ1q.js} +0 -0
- /package/public/dist/assets/{ruby-RVmtmNDw.js → ruby-BSVP_v59.js} +0 -0
- /package/public/dist/assets/{sas-CEzodAB7.js → sas-DHlU4v4g.js} +0 -0
- /package/public/dist/assets/{scheme-Pqmt6dh3.js → scheme-BGXbz5Hz.js} +0 -0
- /package/public/dist/assets/{settings-client-BN3XzwEo.js → settings-client-DPuJroyk.js} +0 -0
- /package/public/dist/assets/{shell-CLG3zy-u.js → shell-yonx6xY2.js} +0 -0
- /package/public/dist/assets/{sieve-C95IWC3O.js → sieve-ClPJUZyi.js} +0 -0
- /package/public/dist/assets/{simple-mode-B9ErAHMD.js → simple-mode-CjViblDK.js} +0 -0
- /package/public/dist/assets/{smalltalk-4cL-gRJb.js → smalltalk-CHXubeqS.js} +0 -0
- /package/public/dist/assets/{solr-CEA7oOx_.js → solr-C6q6YwPz.js} +0 -0
- /package/public/dist/assets/{sparql-w8kHjP6I.js → sparql-CcspZvEd.js} +0 -0
- /package/public/dist/assets/{spreadsheet-C8bDfTgC.js → spreadsheet-DH3a4LBS.js} +0 -0
- /package/public/dist/assets/{sql-BrKz8968.js → sql-meoY6gNi.js} +0 -0
- /package/public/dist/assets/{stex-xFw1nXeT.js → stex-D2bn6Zsh.js} +0 -0
- /package/public/dist/assets/{stylus-gS_68vPk.js → stylus-DbXGih0S.js} +0 -0
- /package/public/dist/assets/{swift-D5lXmY2d.js → swift-Ch391uOd.js} +0 -0
- /package/public/dist/assets/{tcl-D-41REtC.js → tcl-CQBgGWDP.js} +0 -0
- /package/public/dist/assets/{textile-D-Znao0j.js → textile-4i3oG3tg.js} +0 -0
- /package/public/dist/assets/{tiddlywiki-Co8lXJKd.js → tiddlywiki-CXG1-CcK.js} +0 -0
- /package/public/dist/assets/{tiki-DsiNRYMP.js → tiki-DJqKUhA-.js} +0 -0
- /package/public/dist/assets/{toml-CaVZGou4.js → toml-C1FnyICQ.js} +0 -0
- /package/public/dist/assets/{troff-DJvDVr-d.js → troff-Cp8NvRO0.js} +0 -0
- /package/public/dist/assets/{ttcn-DAC92l4d.js → ttcn-NlmW_fji.js} +0 -0
- /package/public/dist/assets/{ttcn-cfg-C0X-mYlr.js → ttcn-cfg-BVuxfGZf.js} +0 -0
- /package/public/dist/assets/{turtle-D6WHyCrL.js → turtle-Ba9ERlnm.js} +0 -0
- /package/public/dist/assets/{vb-CEo_ccq3.js → vb-DDs4gjJb.js} +0 -0
- /package/public/dist/assets/{vbscript-B_PKDV1v.js → vbscript-gOFmdMJN.js} +0 -0
- /package/public/dist/assets/{velocity-ClKnKBLH.js → velocity-DtSNZA7i.js} +0 -0
- /package/public/dist/assets/{verilog-Pnuspgw6.js → verilog-Pldmtxe7.js} +0 -0
- /package/public/dist/assets/{vhdl-CZnyY4fs.js → vhdl-BFfSgWGp.js} +0 -0
- /package/public/dist/assets/{w3c-keyname-DJlC6DTY.js → w3c-keyname-BggQEPNo.js} +0 -0
- /package/public/dist/assets/{webidl-DHr762Dm.js → webidl-B6ZFYE2L.js} +0 -0
- /package/public/dist/assets/{xquery-5-FiyUtN.js → xquery-DhxUT98N.js} +0 -0
- /package/public/dist/assets/{yacas-GlqsXIeT.js → yacas-jSkQeF1Q.js} +0 -0
- /package/public/dist/assets/{z80-CI7N40Oo.js → z80-D7Lt6v61.js} +0 -0
package/dist/src/agent/events.js
CHANGED
|
@@ -1,1488 +1,3 @@
|
|
|
1
|
-
//
|
|
2
|
-
|
|
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
|