@linghun/tui 0.1.0
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/LICENSE +190 -0
- package/dist/agent-completion-finalizer.d.ts +31 -0
- package/dist/agent-completion-finalizer.d.ts.map +1 -0
- package/dist/agent-completion-finalizer.js +20 -0
- package/dist/agent-handoff-safety.d.ts +13 -0
- package/dist/agent-handoff-safety.d.ts.map +1 -0
- package/dist/agent-handoff-safety.js +43 -0
- package/dist/agent-workflow-registry.d.ts +45 -0
- package/dist/agent-workflow-registry.d.ts.map +1 -0
- package/dist/agent-workflow-registry.js +12 -0
- package/dist/architecture-boundary.d.ts +151 -0
- package/dist/architecture-boundary.d.ts.map +1 -0
- package/dist/architecture-boundary.js +24 -0
- package/dist/architecture-runtime.d.ts +56 -0
- package/dist/architecture-runtime.d.ts.map +1 -0
- package/dist/architecture-runtime.js +18 -0
- package/dist/background-control-runtime.d.ts +29 -0
- package/dist/background-control-runtime.d.ts.map +1 -0
- package/dist/background-control-runtime.js +148 -0
- package/dist/bash-subcommand-parser.d.ts +34 -0
- package/dist/bash-subcommand-parser.d.ts.map +1 -0
- package/dist/bash-subcommand-parser.js +8 -0
- package/dist/batch-tool-confirmation.d.ts +18 -0
- package/dist/batch-tool-confirmation.d.ts.map +1 -0
- package/dist/batch-tool-confirmation.js +100 -0
- package/dist/break-cache-runtime.d.ts +40 -0
- package/dist/break-cache-runtime.d.ts.map +1 -0
- package/dist/break-cache-runtime.js +17 -0
- package/dist/btw-runtime.d.ts +45 -0
- package/dist/btw-runtime.d.ts.map +1 -0
- package/dist/btw-runtime.js +14 -0
- package/dist/cache-command-runtime.d.ts +22 -0
- package/dist/cache-command-runtime.d.ts.map +1 -0
- package/dist/cache-command-runtime.js +33 -0
- package/dist/cache-freshness.d.ts +26 -0
- package/dist/cache-freshness.d.ts.map +1 -0
- package/dist/cache-freshness.js +14 -0
- package/dist/capability-runtime.d.ts +75 -0
- package/dist/capability-runtime.d.ts.map +1 -0
- package/dist/capability-runtime.js +97 -0
- package/dist/chunk-2FVEKTKN.js +86 -0
- package/dist/chunk-2YL5VKJ5.js +531 -0
- package/dist/chunk-3AKXDMVS.js +85 -0
- package/dist/chunk-3GCIXKCI.js +221 -0
- package/dist/chunk-3LT6OWQ2.js +258 -0
- package/dist/chunk-3XNUDLOM.js +91 -0
- package/dist/chunk-4EIC5BCT.js +475 -0
- package/dist/chunk-4EP3TUFF.js +238 -0
- package/dist/chunk-4I2NWBOM.js +117 -0
- package/dist/chunk-4K6UB524.js +443 -0
- package/dist/chunk-4T5DJW54.js +88 -0
- package/dist/chunk-4WHZ6JKD.js +8105 -0
- package/dist/chunk-5H7RRF7C.js +6 -0
- package/dist/chunk-64MJP6FK.js +558 -0
- package/dist/chunk-66BNE332.js +1617 -0
- package/dist/chunk-6CI6TKLN.js +50 -0
- package/dist/chunk-6RJVTUWI.js +16 -0
- package/dist/chunk-6SMM5CMP.js +100 -0
- package/dist/chunk-6USL33ZO.js +289 -0
- package/dist/chunk-7ZE5JFAZ.js +760 -0
- package/dist/chunk-AKPXMCVF.js +1373 -0
- package/dist/chunk-AO4CXI37.js +284 -0
- package/dist/chunk-APJIC2O5.js +150 -0
- package/dist/chunk-B4GQTZMT.js +607 -0
- package/dist/chunk-BFVPLGAC.js +93 -0
- package/dist/chunk-BOV4K7FP.js +588 -0
- package/dist/chunk-CFMSB6ST.js +59 -0
- package/dist/chunk-CFXB5SE5.js +502 -0
- package/dist/chunk-CRQORMFF.js +32 -0
- package/dist/chunk-CRSLDQOA.js +146 -0
- package/dist/chunk-CRW3636S.js +214 -0
- package/dist/chunk-D3UTL2QX.js +86 -0
- package/dist/chunk-D7TCSOAZ.js +331 -0
- package/dist/chunk-DDXS2RDZ.js +228 -0
- package/dist/chunk-DICVLZHH.js +144 -0
- package/dist/chunk-DNQN74CC.js +1186 -0
- package/dist/chunk-DTK5NBTV.js +912 -0
- package/dist/chunk-E72U7WW7.js +50 -0
- package/dist/chunk-EBACIBJP.js +356 -0
- package/dist/chunk-ECFLCY5V.js +530 -0
- package/dist/chunk-EORRZP3F.js +109 -0
- package/dist/chunk-F43AMWLZ.js +115 -0
- package/dist/chunk-F46N43MG.js +56 -0
- package/dist/chunk-F6TVBCZV.js +51 -0
- package/dist/chunk-FRIMDSRU.js +242 -0
- package/dist/chunk-FTAEPAVY.js +314 -0
- package/dist/chunk-GC55DMZV.js +156 -0
- package/dist/chunk-GCMH5P4W.js +422 -0
- package/dist/chunk-GDQQNPBP.js +251 -0
- package/dist/chunk-GKZYTPN2.js +279 -0
- package/dist/chunk-GLWTWEGX.js +272 -0
- package/dist/chunk-GMUCSNUD.js +586 -0
- package/dist/chunk-GTP2KPLY.js +167 -0
- package/dist/chunk-GW5YDCRZ.js +42 -0
- package/dist/chunk-H3T4EF5F.js +87 -0
- package/dist/chunk-HAEU6OTS.js +381 -0
- package/dist/chunk-HQIJGQYU.js +172 -0
- package/dist/chunk-HW2TBXVK.js +34 -0
- package/dist/chunk-HWD22O6F.js +94 -0
- package/dist/chunk-I3NTAIMF.js +280 -0
- package/dist/chunk-IN42UISW.js +372 -0
- package/dist/chunk-IWUIOLMF.js +82 -0
- package/dist/chunk-J7ZE2JKP.js +283 -0
- package/dist/chunk-JBLVBO3U.js +109 -0
- package/dist/chunk-JDWXC2OQ.js +800 -0
- package/dist/chunk-JGDIO2NF.js +74 -0
- package/dist/chunk-JHGWGH2C.js +182 -0
- package/dist/chunk-JLCPHVBN.js +42 -0
- package/dist/chunk-JO5ANTMR.js +6027 -0
- package/dist/chunk-JPXSFZFC.js +100 -0
- package/dist/chunk-JQCRCDOC.js +1195 -0
- package/dist/chunk-K4FSYBSY.js +41 -0
- package/dist/chunk-K56D3X7S.js +1225 -0
- package/dist/chunk-KI7C6ZOD.js +92 -0
- package/dist/chunk-KO64OFSG.js +58 -0
- package/dist/chunk-KQJHVJZB.js +227 -0
- package/dist/chunk-KTWV5JC5.js +59 -0
- package/dist/chunk-L4XXW6Y5.js +374 -0
- package/dist/chunk-L5GOCMZP.js +18 -0
- package/dist/chunk-LDABZV5V.js +278 -0
- package/dist/chunk-LHHKPGLX.js +903 -0
- package/dist/chunk-LL7LBRDL.js +60 -0
- package/dist/chunk-LQTVYUT3.js +421 -0
- package/dist/chunk-LVIM2PA7.js +663 -0
- package/dist/chunk-M4AIK2SP.js +215 -0
- package/dist/chunk-MLUIOBKL.js +420 -0
- package/dist/chunk-MOJL4X4L.js +47 -0
- package/dist/chunk-MVONSJEN.js +300 -0
- package/dist/chunk-N7G2X2LK.js +709 -0
- package/dist/chunk-NKFKOEYX.js +146 -0
- package/dist/chunk-NMNOAFFT.js +167 -0
- package/dist/chunk-NSIKYD3X.js +74 -0
- package/dist/chunk-O7EFPSMC.js +60 -0
- package/dist/chunk-O7S3HYE6.js +210 -0
- package/dist/chunk-OEYW3JE3.js +262 -0
- package/dist/chunk-OF3K3CU5.js +159 -0
- package/dist/chunk-OMZYPQVA.js +298 -0
- package/dist/chunk-OZMX3E35.js +248 -0
- package/dist/chunk-P277M7Z5.js +303 -0
- package/dist/chunk-P4CPRJLI.js +65 -0
- package/dist/chunk-PBIPV4LD.js +494 -0
- package/dist/chunk-PGNALDEH.js +2003 -0
- package/dist/chunk-PGWW3DVE.js +157 -0
- package/dist/chunk-QB4VWH7W.js +515 -0
- package/dist/chunk-QBCGAIU7.js +120 -0
- package/dist/chunk-QIU3FJPC.js +99 -0
- package/dist/chunk-QLRTQHTR.js +744 -0
- package/dist/chunk-QTDGRZMZ.js +171 -0
- package/dist/chunk-RBOQJFIZ.js +183 -0
- package/dist/chunk-RDGM4RUE.js +178 -0
- package/dist/chunk-RM5JDRCW.js +71 -0
- package/dist/chunk-RM5QMOFY.js +189 -0
- package/dist/chunk-RMLTVKOY.js +588 -0
- package/dist/chunk-RVY34HK4.js +79 -0
- package/dist/chunk-S3YWTBXL.js +43 -0
- package/dist/chunk-SJOS5PM6.js +64 -0
- package/dist/chunk-SOPYWTFV.js +90 -0
- package/dist/chunk-SQIBPLLV.js +15 -0
- package/dist/chunk-SRZIA6B4.js +136 -0
- package/dist/chunk-SYBNJZEL.js +250 -0
- package/dist/chunk-TFZEFIQT.js +17 -0
- package/dist/chunk-THZBFYAH.js +136 -0
- package/dist/chunk-TJLC3QAS.js +83 -0
- package/dist/chunk-TYF4GJR3.js +598 -0
- package/dist/chunk-UDQT5CWK.js +252 -0
- package/dist/chunk-UOHZQIVL.js +168 -0
- package/dist/chunk-URNQUECO.js +187 -0
- package/dist/chunk-UT2TYK2A.js +148 -0
- package/dist/chunk-UT5BOJKU.js +190 -0
- package/dist/chunk-V7GDHHBL.js +526 -0
- package/dist/chunk-VCSRBS47.js +133 -0
- package/dist/chunk-VIBENDE3.js +152 -0
- package/dist/chunk-VTQL23UM.js +302 -0
- package/dist/chunk-W3KHJNSH.js +281 -0
- package/dist/chunk-W6NU7ZAV.js +52 -0
- package/dist/chunk-WHFDDZHY.js +407 -0
- package/dist/chunk-WJWYRBWH.js +48 -0
- package/dist/chunk-WKMBK5UP.js +145 -0
- package/dist/chunk-WQMSRO4D.js +489 -0
- package/dist/chunk-WV6YJGZR.js +81 -0
- package/dist/chunk-WVAQYKGL.js +269 -0
- package/dist/chunk-X7A22JHP.js +106 -0
- package/dist/chunk-XFPNU42I.js +59 -0
- package/dist/chunk-YH6UIHNF.js +161 -0
- package/dist/chunk-YPQFSFYK.js +19 -0
- package/dist/chunk-YTQFOZRZ.js +110 -0
- package/dist/chunk-ZJK25VFP.js +506 -0
- package/dist/chunk-ZOSK2UEU.js +1555 -0
- package/dist/chunk-ZYSN7AWW.js +336 -0
- package/dist/chunk-ZZ2CNCXJ.js +282 -0
- package/dist/command-panel-runtime.d.ts +33 -0
- package/dist/command-panel-runtime.d.ts.map +1 -0
- package/dist/command-panel-runtime.js +80 -0
- package/dist/compact-cache-command-runtime.d.ts +38 -0
- package/dist/compact-cache-command-runtime.d.ts.map +1 -0
- package/dist/compact-cache-command-runtime.js +146 -0
- package/dist/compact-context.d.ts +35 -0
- package/dist/compact-context.d.ts.map +1 -0
- package/dist/compact-context.js +16 -0
- package/dist/compact-preflight-runtime.d.ts +46 -0
- package/dist/compact-preflight-runtime.d.ts.map +1 -0
- package/dist/compact-preflight-runtime.js +62 -0
- package/dist/connector-runtime.d.ts +72 -0
- package/dist/connector-runtime.d.ts.map +1 -0
- package/dist/connector-runtime.js +88 -0
- package/dist/context-estimator.d.ts +20 -0
- package/dist/context-estimator.d.ts.map +1 -0
- package/dist/context-estimator.js +18 -0
- package/dist/context-window-runtime.d.ts +12 -0
- package/dist/context-window-runtime.d.ts.map +1 -0
- package/dist/context-window-runtime.js +10 -0
- package/dist/deep-compact-runtime.d.ts +53 -0
- package/dist/deep-compact-runtime.d.ts.map +1 -0
- package/dist/deep-compact-runtime.js +35 -0
- package/dist/deferred-tools-catalog.d.ts +52 -0
- package/dist/deferred-tools-catalog.d.ts.map +1 -0
- package/dist/deferred-tools-catalog.js +42 -0
- package/dist/details-status-runtime.d.ts +48 -0
- package/dist/details-status-runtime.d.ts.map +1 -0
- package/dist/details-status-runtime.js +102 -0
- package/dist/evidence-runtime.d.ts +48 -0
- package/dist/evidence-runtime.d.ts.map +1 -0
- package/dist/evidence-runtime.js +92 -0
- package/dist/extension-command-runtime.d.ts +63 -0
- package/dist/extension-command-runtime.d.ts.map +1 -0
- package/dist/extension-command-runtime.js +67 -0
- package/dist/extension-slash-runtime.d.ts +11 -0
- package/dist/extension-slash-runtime.d.ts.map +1 -0
- package/dist/extension-slash-runtime.js +79 -0
- package/dist/external-editor-runtime.d.ts +32 -0
- package/dist/external-editor-runtime.d.ts.map +1 -0
- package/dist/external-editor-runtime.js +71 -0
- package/dist/failure-learning-command-runtime.d.ts +10 -0
- package/dist/failure-learning-command-runtime.d.ts.map +1 -0
- package/dist/failure-learning-command-runtime.js +78 -0
- package/dist/failure-learning-presenter.d.ts +6 -0
- package/dist/failure-learning-presenter.d.ts.map +1 -0
- package/dist/failure-learning-presenter.js +12 -0
- package/dist/failure-learning-runtime.d.ts +39 -0
- package/dist/failure-learning-runtime.d.ts.map +1 -0
- package/dist/failure-learning-runtime.js +39 -0
- package/dist/feature-flag-runtime.d.ts +8 -0
- package/dist/feature-flag-runtime.d.ts.map +1 -0
- package/dist/feature-flag-runtime.js +12 -0
- package/dist/feishu-long-connection-runtime.d.ts +12 -0
- package/dist/feishu-long-connection-runtime.d.ts.map +1 -0
- package/dist/feishu-long-connection-runtime.js +7 -0
- package/dist/final-answer-gate.d.ts +24 -0
- package/dist/final-answer-gate.d.ts.map +1 -0
- package/dist/final-answer-gate.js +26 -0
- package/dist/ghost-text.d.ts +16 -0
- package/dist/ghost-text.d.ts.map +1 -0
- package/dist/ghost-text.js +8 -0
- package/dist/git-branch-runtime.d.ts +14 -0
- package/dist/git-branch-runtime.d.ts.map +1 -0
- package/dist/git-branch-runtime.js +68 -0
- package/dist/git-command-runtime.d.ts +22 -0
- package/dist/git-command-runtime.d.ts.map +1 -0
- package/dist/git-command-runtime.js +89 -0
- package/dist/git-operation-runtime.d.ts +188 -0
- package/dist/git-operation-runtime.d.ts.map +1 -0
- package/dist/git-operation-runtime.js +45 -0
- package/dist/git-runtime.d.ts +113 -0
- package/dist/git-runtime.d.ts.map +1 -0
- package/dist/git-runtime.js +16 -0
- package/dist/git-slash-runtime.d.ts +38 -0
- package/dist/git-slash-runtime.d.ts.map +1 -0
- package/dist/git-slash-runtime.js +18 -0
- package/dist/git-tool-dispatch-runtime.d.ts +108 -0
- package/dist/git-tool-dispatch-runtime.d.ts.map +1 -0
- package/dist/git-tool-dispatch-runtime.js +25 -0
- package/dist/git-tool-runtime.d.ts +64 -0
- package/dist/git-tool-runtime.d.ts.map +1 -0
- package/dist/git-tool-runtime.js +36 -0
- package/dist/guard-wiring.d.ts +67 -0
- package/dist/guard-wiring.d.ts.map +1 -0
- package/dist/guard-wiring.js +21 -0
- package/dist/handoff-session-runtime.d.ts +11 -0
- package/dist/handoff-session-runtime.d.ts.map +1 -0
- package/dist/handoff-session-runtime.js +36 -0
- package/dist/index-result-presenter.d.ts +14 -0
- package/dist/index-result-presenter.d.ts.map +1 -0
- package/dist/index-result-presenter.js +28 -0
- package/dist/index-runtime.d.ts +64 -0
- package/dist/index-runtime.d.ts.map +1 -0
- package/dist/index-runtime.js +28 -0
- package/dist/index-tool-runtime.d.ts +44 -0
- package/dist/index-tool-runtime.d.ts.map +1 -0
- package/dist/index-tool-runtime.js +24 -0
- package/dist/index.d.ts +57 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +2346 -0
- package/dist/job-agent-command-runtime.d.ts +127 -0
- package/dist/job-agent-command-runtime.d.ts.map +1 -0
- package/dist/job-agent-command-runtime.js +138 -0
- package/dist/job-runner-presenter.d.ts +32 -0
- package/dist/job-runner-presenter.d.ts.map +1 -0
- package/dist/job-runner-presenter.js +30 -0
- package/dist/job-runtime.d.ts +65 -0
- package/dist/job-runtime.d.ts.map +1 -0
- package/dist/job-runtime.js +88 -0
- package/dist/keybinding-runtime.d.ts +29 -0
- package/dist/keybinding-runtime.d.ts.map +1 -0
- package/dist/keybinding-runtime.js +14 -0
- package/dist/log-artifact.d.ts +55 -0
- package/dist/log-artifact.d.ts.map +1 -0
- package/dist/log-artifact.js +10 -0
- package/dist/mcp-index-command-runtime.d.ts +21 -0
- package/dist/mcp-index-command-runtime.d.ts.map +1 -0
- package/dist/mcp-index-command-runtime.js +18 -0
- package/dist/mcp-index-runtime.d.ts +106 -0
- package/dist/mcp-index-runtime.d.ts.map +1 -0
- package/dist/mcp-index-runtime.js +142 -0
- package/dist/mcp-sse-runtime.d.ts +13 -0
- package/dist/mcp-sse-runtime.d.ts.map +1 -0
- package/dist/mcp-sse-runtime.js +8 -0
- package/dist/mcp-stdio-runtime.d.ts +37 -0
- package/dist/mcp-stdio-runtime.d.ts.map +1 -0
- package/dist/mcp-stdio-runtime.js +15 -0
- package/dist/memory-command-runtime.d.ts +37 -0
- package/dist/memory-command-runtime.d.ts.map +1 -0
- package/dist/memory-command-runtime.js +88 -0
- package/dist/memory-eviction-runtime.d.ts +7 -0
- package/dist/memory-eviction-runtime.d.ts.map +1 -0
- package/dist/memory-eviction-runtime.js +12 -0
- package/dist/memory-extraction-runtime.d.ts +40 -0
- package/dist/memory-extraction-runtime.d.ts.map +1 -0
- package/dist/memory-extraction-runtime.js +20 -0
- package/dist/memory-rules-runtime.d.ts +15 -0
- package/dist/memory-rules-runtime.d.ts.map +1 -0
- package/dist/memory-rules-runtime.js +14 -0
- package/dist/meta-scheduler-complexity.d.ts +16 -0
- package/dist/meta-scheduler-complexity.d.ts.map +1 -0
- package/dist/meta-scheduler-complexity.js +37 -0
- package/dist/meta-scheduler-runtime.d.ts +288 -0
- package/dist/meta-scheduler-runtime.d.ts.map +1 -0
- package/dist/meta-scheduler-runtime.js +17 -0
- package/dist/model-command-runtime.d.ts +12 -0
- package/dist/model-command-runtime.d.ts.map +1 -0
- package/dist/model-command-runtime.js +84 -0
- package/dist/model-doctor-runtime.d.ts +81 -0
- package/dist/model-doctor-runtime.d.ts.map +1 -0
- package/dist/model-doctor-runtime.js +46 -0
- package/dist/model-loop-runtime.d.ts +189 -0
- package/dist/model-loop-runtime.d.ts.map +1 -0
- package/dist/model-loop-runtime.js +141 -0
- package/dist/model-prompt-runtime.d.ts +25 -0
- package/dist/model-prompt-runtime.d.ts.map +1 -0
- package/dist/model-prompt-runtime.js +33 -0
- package/dist/model-setup-runtime.d.ts +28 -0
- package/dist/model-setup-runtime.d.ts.map +1 -0
- package/dist/model-setup-runtime.js +26 -0
- package/dist/model-stream-runtime.d.ts +47 -0
- package/dist/model-stream-runtime.d.ts.map +1 -0
- package/dist/model-stream-runtime.js +136 -0
- package/dist/model-tool-runtime.d.ts +114 -0
- package/dist/model-tool-runtime.d.ts.map +1 -0
- package/dist/model-tool-runtime.js +144 -0
- package/dist/natural-command-bridge.d.ts +158 -0
- package/dist/natural-command-bridge.d.ts.map +1 -0
- package/dist/natural-command-bridge.js +36 -0
- package/dist/pending-details-presenter.d.ts +8 -0
- package/dist/pending-details-presenter.d.ts.map +1 -0
- package/dist/pending-details-presenter.js +12 -0
- package/dist/permission-approval-runtime.d.ts +28 -0
- package/dist/permission-approval-runtime.d.ts.map +1 -0
- package/dist/permission-approval-runtime.js +136 -0
- package/dist/permission-continuation-runtime.d.ts +90 -0
- package/dist/permission-continuation-runtime.d.ts.map +1 -0
- package/dist/permission-continuation-runtime.js +68 -0
- package/dist/permission-policy-engine.d.ts +51 -0
- package/dist/permission-policy-engine.d.ts.map +1 -0
- package/dist/permission-policy-engine.js +12 -0
- package/dist/permission-presenter.d.ts +13 -0
- package/dist/permission-presenter.d.ts.map +1 -0
- package/dist/permission-presenter.js +8 -0
- package/dist/persistent-history.d.ts +18 -0
- package/dist/persistent-history.d.ts.map +1 -0
- package/dist/persistent-history.js +126 -0
- package/dist/platform-security.d.ts +4 -0
- package/dist/platform-security.d.ts.map +1 -0
- package/dist/platform-security.js +10 -0
- package/dist/process-command-runtime.d.ts +9 -0
- package/dist/process-command-runtime.d.ts.map +1 -0
- package/dist/process-command-runtime.js +11 -0
- package/dist/process-guard.d.ts +56 -0
- package/dist/process-guard.d.ts.map +1 -0
- package/dist/process-guard.js +22 -0
- package/dist/prompt-command-runtime.d.ts +12 -0
- package/dist/prompt-command-runtime.d.ts.map +1 -0
- package/dist/prompt-command-runtime.js +10 -0
- package/dist/prompt-stash.d.ts +15 -0
- package/dist/prompt-stash.d.ts.map +1 -0
- package/dist/prompt-stash.js +8 -0
- package/dist/provider-circuit-breaker.d.ts +132 -0
- package/dist/provider-circuit-breaker.d.ts.map +1 -0
- package/dist/provider-circuit-breaker.js +31 -0
- package/dist/provider-loop-runtime.d.ts +18 -0
- package/dist/provider-loop-runtime.d.ts.map +1 -0
- package/dist/provider-loop-runtime.js +16 -0
- package/dist/remote-command-runtime.d.ts +47 -0
- package/dist/remote-command-runtime.d.ts.map +1 -0
- package/dist/remote-command-runtime.js +125 -0
- package/dist/remote-inbound-bridge-runtime.d.ts +152 -0
- package/dist/remote-inbound-bridge-runtime.d.ts.map +1 -0
- package/dist/remote-inbound-bridge-runtime.js +44 -0
- package/dist/remote-mcp-presenter.d.ts +5 -0
- package/dist/remote-mcp-presenter.d.ts.map +1 -0
- package/dist/remote-mcp-presenter.js +10 -0
- package/dist/remote-repl-bridge-runtime.d.ts +134 -0
- package/dist/remote-repl-bridge-runtime.d.ts.map +1 -0
- package/dist/remote-repl-bridge-runtime.js +20 -0
- package/dist/remote-transport.d.ts +50 -0
- package/dist/remote-transport.d.ts.map +1 -0
- package/dist/remote-transport.js +14 -0
- package/dist/request-lifecycle-presenter.d.ts +25 -0
- package/dist/request-lifecycle-presenter.d.ts.map +1 -0
- package/dist/request-lifecycle-presenter.js +22 -0
- package/dist/runner-runtime.d.ts +41 -0
- package/dist/runner-runtime.d.ts.map +1 -0
- package/dist/runner-runtime.js +35 -0
- package/dist/runtime-budget.d.ts +38 -0
- package/dist/runtime-budget.d.ts.map +1 -0
- package/dist/runtime-budget.js +78 -0
- package/dist/runtime-path-marker.d.ts +112 -0
- package/dist/runtime-path-marker.d.ts.map +1 -0
- package/dist/runtime-path-marker.js +18 -0
- package/dist/runtime-status-presenter.d.ts +22 -0
- package/dist/runtime-status-presenter.d.ts.map +1 -0
- package/dist/runtime-status-presenter.js +15 -0
- package/dist/runtime-status-snapshot.d.ts +52 -0
- package/dist/runtime-status-snapshot.d.ts.map +1 -0
- package/dist/runtime-status-snapshot.js +11 -0
- package/dist/runtime-utils.d.ts +2 -0
- package/dist/runtime-utils.d.ts.map +1 -0
- package/dist/runtime-utils.js +6 -0
- package/dist/shell/clipboard.d.ts +23 -0
- package/dist/shell/clipboard.d.ts.map +1 -0
- package/dist/shell/clipboard.js +8 -0
- package/dist/shell/components/AgentProgressTree.d.ts +9 -0
- package/dist/shell/components/AgentProgressTree.d.ts.map +1 -0
- package/dist/shell/components/AgentProgressTree.js +9 -0
- package/dist/shell/components/BackgroundTaskOverlay.d.ts +8 -0
- package/dist/shell/components/BackgroundTaskOverlay.d.ts.map +1 -0
- package/dist/shell/components/BackgroundTaskOverlay.js +8 -0
- package/dist/shell/components/BtwPanel.d.ts +16 -0
- package/dist/shell/components/BtwPanel.d.ts.map +1 -0
- package/dist/shell/components/BtwPanel.js +8 -0
- package/dist/shell/components/CommandPanel.d.ts +11 -0
- package/dist/shell/components/CommandPanel.d.ts.map +1 -0
- package/dist/shell/components/CommandPanel.js +8 -0
- package/dist/shell/components/Composer.d.ts +187 -0
- package/dist/shell/components/Composer.d.ts.map +1 -0
- package/dist/shell/components/Composer.js +99 -0
- package/dist/shell/components/ConfigPanel.d.ts +11 -0
- package/dist/shell/components/ConfigPanel.d.ts.map +1 -0
- package/dist/shell/components/ConfigPanel.js +8 -0
- package/dist/shell/components/CtrlOToExpand.d.ts +30 -0
- package/dist/shell/components/CtrlOToExpand.d.ts.map +1 -0
- package/dist/shell/components/CtrlOToExpand.js +16 -0
- package/dist/shell/components/HelpPanel.d.ts +19 -0
- package/dist/shell/components/HelpPanel.d.ts.map +1 -0
- package/dist/shell/components/HelpPanel.js +8 -0
- package/dist/shell/components/HistorySearchPanel.d.ts +14 -0
- package/dist/shell/components/HistorySearchPanel.d.ts.map +1 -0
- package/dist/shell/components/HistorySearchPanel.js +104 -0
- package/dist/shell/components/MessageMarkdown.d.ts +34 -0
- package/dist/shell/components/MessageMarkdown.d.ts.map +1 -0
- package/dist/shell/components/MessageMarkdown.js +18 -0
- package/dist/shell/components/MessageResponse.d.ts +14 -0
- package/dist/shell/components/MessageResponse.d.ts.map +1 -0
- package/dist/shell/components/MessageResponse.js +6 -0
- package/dist/shell/components/MouseInputRouter.d.ts +28 -0
- package/dist/shell/components/MouseInputRouter.d.ts.map +1 -0
- package/dist/shell/components/MouseInputRouter.js +84 -0
- package/dist/shell/components/NotificationStack.d.ts +19 -0
- package/dist/shell/components/NotificationStack.d.ts.map +1 -0
- package/dist/shell/components/NotificationStack.js +6 -0
- package/dist/shell/components/OutputLine.d.ts +19 -0
- package/dist/shell/components/OutputLine.d.ts.map +1 -0
- package/dist/shell/components/OutputLine.js +38 -0
- package/dist/shell/components/ProductBlock.d.ts +10 -0
- package/dist/shell/components/ProductBlock.d.ts.map +1 -0
- package/dist/shell/components/ProductBlock.js +12 -0
- package/dist/shell/components/ScrollViewport.d.ts +43 -0
- package/dist/shell/components/ScrollViewport.d.ts.map +1 -0
- package/dist/shell/components/ScrollViewport.js +86 -0
- package/dist/shell/components/SessionsPanel.d.ts +24 -0
- package/dist/shell/components/SessionsPanel.d.ts.map +1 -0
- package/dist/shell/components/SessionsPanel.js +8 -0
- package/dist/shell/components/ShellApp.d.ts +8 -0
- package/dist/shell/components/ShellApp.d.ts.map +1 -0
- package/dist/shell/components/ShellApp.js +45 -0
- package/dist/shell/components/ShortcutPanel.d.ts +14 -0
- package/dist/shell/components/ShortcutPanel.d.ts.map +1 -0
- package/dist/shell/components/ShortcutPanel.js +59 -0
- package/dist/shell/components/SlashSuggestions.d.ts +24 -0
- package/dist/shell/components/SlashSuggestions.d.ts.map +1 -0
- package/dist/shell/components/SlashSuggestions.js +7 -0
- package/dist/shell/components/StatusFooter.d.ts +30 -0
- package/dist/shell/components/StatusFooter.d.ts.map +1 -0
- package/dist/shell/components/StatusFooter.js +7 -0
- package/dist/shell/components/StatusTray.d.ts +9 -0
- package/dist/shell/components/StatusTray.d.ts.map +1 -0
- package/dist/shell/components/StatusTray.js +6 -0
- package/dist/shell/components/StructuredDiff.d.ts +9 -0
- package/dist/shell/components/StructuredDiff.d.ts.map +1 -0
- package/dist/shell/components/StructuredDiff.js +7 -0
- package/dist/shell/components/TaskListView.d.ts +9 -0
- package/dist/shell/components/TaskListView.d.ts.map +1 -0
- package/dist/shell/components/TaskListView.js +9 -0
- package/dist/shell/components/TaskSuggestionBar.d.ts +15 -0
- package/dist/shell/components/TaskSuggestionBar.d.ts.map +1 -0
- package/dist/shell/components/TaskSuggestionBar.js +8 -0
- package/dist/shell/components/UnseenMessagePill.d.ts +12 -0
- package/dist/shell/components/UnseenMessagePill.d.ts.map +1 -0
- package/dist/shell/components/UnseenMessagePill.js +6 -0
- package/dist/shell/components/WorkflowProgressView.d.ts +9 -0
- package/dist/shell/components/WorkflowProgressView.d.ts.map +1 -0
- package/dist/shell/components/WorkflowProgressView.js +9 -0
- package/dist/shell/components/useAnchoredCursor.d.ts +32 -0
- package/dist/shell/components/useAnchoredCursor.d.ts.map +1 -0
- package/dist/shell/components/useAnchoredCursor.js +6 -0
- package/dist/shell/hooks/useRenderThrottle.d.ts +2 -0
- package/dist/shell/hooks/useRenderThrottle.d.ts.map +1 -0
- package/dist/shell/hooks/useRenderThrottle.js +35 -0
- package/dist/shell/hooks/useScrollBatcher.d.ts +10 -0
- package/dist/shell/hooks/useScrollBatcher.d.ts.map +1 -0
- package/dist/shell/hooks/useScrollBatcher.js +23 -0
- package/dist/shell/hooks/useScrollRuntime.d.ts +2 -0
- package/dist/shell/hooks/useScrollRuntime.d.ts.map +1 -0
- package/dist/shell/hooks/useScrollRuntime.js +6 -0
- package/dist/shell/hyperlink-utils.d.ts +18 -0
- package/dist/shell/hyperlink-utils.d.ts.map +1 -0
- package/dist/shell/hyperlink-utils.js +8 -0
- package/dist/shell/ink-renderer.d.ts +18 -0
- package/dist/shell/ink-renderer.d.ts.map +1 -0
- package/dist/shell/ink-renderer.js +54 -0
- package/dist/shell/models/command-transcript-presenter.d.ts +73 -0
- package/dist/shell/models/command-transcript-presenter.d.ts.map +1 -0
- package/dist/shell/models/command-transcript-presenter.js +26 -0
- package/dist/shell/models/help-panel.d.ts +37 -0
- package/dist/shell/models/help-panel.d.ts.map +1 -0
- package/dist/shell/models/help-panel.js +10 -0
- package/dist/shell/models/permission-elevation.d.ts +65 -0
- package/dist/shell/models/permission-elevation.d.ts.map +1 -0
- package/dist/shell/models/permission-elevation.js +10 -0
- package/dist/shell/models/permission-explanation.d.ts +45 -0
- package/dist/shell/models/permission-explanation.d.ts.map +1 -0
- package/dist/shell/models/permission-explanation.js +14 -0
- package/dist/shell/models/session-panel.d.ts +22 -0
- package/dist/shell/models/session-panel.d.ts.map +1 -0
- package/dist/shell/models/session-panel.js +18 -0
- package/dist/shell/models/task-scroll-state.d.ts +24 -0
- package/dist/shell/models/task-scroll-state.d.ts.map +1 -0
- package/dist/shell/models/task-scroll-state.js +26 -0
- package/dist/shell/models/terminal-input-runtime.d.ts +37 -0
- package/dist/shell/models/terminal-input-runtime.d.ts.map +1 -0
- package/dist/shell/models/terminal-input-runtime.js +18 -0
- package/dist/shell/models/transcript-scroll-state.d.ts +57 -0
- package/dist/shell/models/transcript-scroll-state.d.ts.map +1 -0
- package/dist/shell/models/transcript-scroll-state.js +12 -0
- package/dist/shell/models/transcript-selection-state.d.ts +39 -0
- package/dist/shell/models/transcript-selection-state.d.ts.map +1 -0
- package/dist/shell/models/transcript-selection-state.js +25 -0
- package/dist/shell/models/wheel-acceleration.d.ts +52 -0
- package/dist/shell/models/wheel-acceleration.d.ts.map +1 -0
- package/dist/shell/models/wheel-acceleration.js +6 -0
- package/dist/shell/output-utils.d.ts +22 -0
- package/dist/shell/output-utils.d.ts.map +1 -0
- package/dist/shell/output-utils.js +12 -0
- package/dist/shell/plain-renderer.d.ts +12 -0
- package/dist/shell/plain-renderer.d.ts.map +1 -0
- package/dist/shell/plain-renderer.js +13 -0
- package/dist/shell/progress-views.d.ts +10 -0
- package/dist/shell/progress-views.d.ts.map +1 -0
- package/dist/shell/progress-views.js +17 -0
- package/dist/shell/stdout-flush-barrier.d.ts +39 -0
- package/dist/shell/stdout-flush-barrier.d.ts.map +1 -0
- package/dist/shell/stdout-flush-barrier.js +10 -0
- package/dist/shell/terminal-capability.d.ts +54 -0
- package/dist/shell/terminal-capability.d.ts.map +1 -0
- package/dist/shell/terminal-capability.js +10 -0
- package/dist/shell/terminal-interaction-runtime.d.ts +11 -0
- package/dist/shell/terminal-interaction-runtime.d.ts.map +1 -0
- package/dist/shell/terminal-interaction-runtime.js +38 -0
- package/dist/shell/terminal-state-recovery.d.ts +52 -0
- package/dist/shell/terminal-state-recovery.d.ts.map +1 -0
- package/dist/shell/terminal-state-recovery.js +11 -0
- package/dist/shell/text-utils.d.ts +40 -0
- package/dist/shell/text-utils.d.ts.map +1 -0
- package/dist/shell/text-utils.js +26 -0
- package/dist/shell/theme.d.ts +41 -0
- package/dist/shell/theme.d.ts.map +1 -0
- package/dist/shell/theme.js +8 -0
- package/dist/shell/types.d.ts +784 -0
- package/dist/shell/types.d.ts.map +1 -0
- package/dist/shell/types.js +0 -0
- package/dist/shell/view-model.d.ts +82 -0
- package/dist/shell/view-model.d.ts.map +1 -0
- package/dist/shell/view-model.js +48 -0
- package/dist/slash-command-runtime.d.ts +64 -0
- package/dist/slash-command-runtime.d.ts.map +1 -0
- package/dist/slash-command-runtime.js +186 -0
- package/dist/slash-dispatch.d.ts +48 -0
- package/dist/slash-dispatch.d.ts.map +1 -0
- package/dist/slash-dispatch.js +53 -0
- package/dist/startup-runtime.d.ts +48 -0
- package/dist/startup-runtime.d.ts.map +1 -0
- package/dist/startup-runtime.js +43 -0
- package/dist/terminal-readiness-presenter.d.ts +131 -0
- package/dist/terminal-readiness-presenter.d.ts.map +1 -0
- package/dist/terminal-readiness-presenter.js +16 -0
- package/dist/terminal-readiness-runtime.d.ts +5 -0
- package/dist/terminal-readiness-runtime.d.ts.map +1 -0
- package/dist/terminal-readiness-runtime.js +15 -0
- package/dist/terminal-setup-runtime.d.ts +34 -0
- package/dist/terminal-setup-runtime.d.ts.map +1 -0
- package/dist/terminal-setup-runtime.js +257 -0
- package/dist/tool-output-presenter.d.ts +38 -0
- package/dist/tool-output-presenter.d.ts.map +1 -0
- package/dist/tool-output-presenter.js +16 -0
- package/dist/tool-result-budget.d.ts +42 -0
- package/dist/tool-result-budget.d.ts.map +1 -0
- package/dist/tool-result-budget.js +11 -0
- package/dist/tui-agent-job-runtime.d.ts +38 -0
- package/dist/tui-agent-job-runtime.d.ts.map +1 -0
- package/dist/tui-agent-job-runtime.js +86 -0
- package/dist/tui-context-runtime.d.ts +426 -0
- package/dist/tui-context-runtime.d.ts.map +1 -0
- package/dist/tui-context-runtime.js +65 -0
- package/dist/tui-data-types.d.ts +923 -0
- package/dist/tui-data-types.d.ts.map +1 -0
- package/dist/tui-data-types.js +0 -0
- package/dist/tui-details-runtime.d.ts +25 -0
- package/dist/tui-details-runtime.d.ts.map +1 -0
- package/dist/tui-details-runtime.js +29 -0
- package/dist/tui-memory-runtime.d.ts +33 -0
- package/dist/tui-memory-runtime.d.ts.map +1 -0
- package/dist/tui-memory-runtime.js +58 -0
- package/dist/tui-messages.d.ts +4 -0
- package/dist/tui-messages.d.ts.map +1 -0
- package/dist/tui-messages.js +6 -0
- package/dist/tui-model-runtime.d.ts +30 -0
- package/dist/tui-model-runtime.d.ts.map +1 -0
- package/dist/tui-model-runtime.js +39 -0
- package/dist/tui-output-surface.d.ts +141 -0
- package/dist/tui-output-surface.d.ts.map +1 -0
- package/dist/tui-output-surface.js +55 -0
- package/dist/tui-permission-runtime.d.ts +62 -0
- package/dist/tui-permission-runtime.d.ts.map +1 -0
- package/dist/tui-permission-runtime.js +24 -0
- package/dist/tui-state-runtime.d.ts +21 -0
- package/dist/tui-state-runtime.d.ts.map +1 -0
- package/dist/tui-state-runtime.js +47 -0
- package/dist/turn-continuity-runtime.d.ts +30 -0
- package/dist/turn-continuity-runtime.d.ts.map +1 -0
- package/dist/turn-continuity-runtime.js +8 -0
- package/dist/undo-ring.d.ts +16 -0
- package/dist/undo-ring.d.ts.map +1 -0
- package/dist/undo-ring.js +12 -0
- package/dist/usage-stats-presenter.d.ts +17 -0
- package/dist/usage-stats-presenter.d.ts.map +1 -0
- package/dist/usage-stats-presenter.js +22 -0
- package/dist/user-state-signal-runtime.d.ts +33 -0
- package/dist/user-state-signal-runtime.d.ts.map +1 -0
- package/dist/user-state-signal-runtime.js +8 -0
- package/dist/verification-command-runtime.d.ts +25 -0
- package/dist/verification-command-runtime.d.ts.map +1 -0
- package/dist/verification-command-runtime.js +51 -0
- package/dist/verification-level.d.ts +93 -0
- package/dist/verification-level.d.ts.map +1 -0
- package/dist/verification-level.js +18 -0
- package/dist/workflow-agent-runtime-bridge.d.ts +169 -0
- package/dist/workflow-agent-runtime-bridge.d.ts.map +1 -0
- package/dist/workflow-agent-runtime-bridge.js +9 -0
- package/dist/workflow-command-runtime.d.ts +94 -0
- package/dist/workflow-command-runtime.d.ts.map +1 -0
- package/dist/workflow-command-runtime.js +114 -0
- package/dist/workflow-plan-schema.d.ts +161 -0
- package/dist/workflow-plan-schema.d.ts.map +1 -0
- package/dist/workflow-plan-schema.js +12 -0
- package/dist/workflow-planner-entry.d.ts +52 -0
- package/dist/workflow-planner-entry.d.ts.map +1 -0
- package/dist/workflow-planner-entry.js +328 -0
- package/dist/workflow-task-surface.d.ts +39 -0
- package/dist/workflow-task-surface.d.ts.map +1 -0
- package/dist/workflow-task-surface.js +7 -0
- package/dist/workspace-reference-cache.d.ts +110 -0
- package/dist/workspace-reference-cache.d.ts.map +1 -0
- package/dist/workspace-reference-cache.js +12 -0
- package/package.json +41 -0
|
@@ -0,0 +1,760 @@
|
|
|
1
|
+
import {
|
|
2
|
+
GIT_ROLLBACK_EXPLAIN,
|
|
3
|
+
GIT_STABLE_POINT_CREATE,
|
|
4
|
+
GIT_STATUS_INSPECT,
|
|
5
|
+
MANAGED_WORKTREE_CREATE,
|
|
6
|
+
parseStablePointInput,
|
|
7
|
+
parseWorktreeCreateInput,
|
|
8
|
+
parseWorktreeRemoveInput,
|
|
9
|
+
summarizeStablePointOutcome,
|
|
10
|
+
summarizeWorktreeContextForPrompt,
|
|
11
|
+
summarizeWorktreeCreateOutcome,
|
|
12
|
+
summarizeWorktreeRemovePlan
|
|
13
|
+
} from "./chunk-6USL33ZO.js";
|
|
14
|
+
import {
|
|
15
|
+
computeWorktreeContext,
|
|
16
|
+
createGitStablePoint,
|
|
17
|
+
createManagedWorktree,
|
|
18
|
+
defaultStablePointMessage,
|
|
19
|
+
executeManagedWorktreeRemove,
|
|
20
|
+
planManagedWorktreeRemove,
|
|
21
|
+
validateStablePointMessage
|
|
22
|
+
} from "./chunk-4EIC5BCT.js";
|
|
23
|
+
import {
|
|
24
|
+
readGitStatus,
|
|
25
|
+
readWorktreeList
|
|
26
|
+
} from "./chunk-AO4CXI37.js";
|
|
27
|
+
|
|
28
|
+
// src/git-tool-dispatch-runtime.ts
|
|
29
|
+
function extractGitToolTarget(input) {
|
|
30
|
+
if (!input || typeof input !== "object") return void 0;
|
|
31
|
+
const obj = input;
|
|
32
|
+
if (typeof obj.branch === "string") return obj.branch;
|
|
33
|
+
if (typeof obj.message === "string") {
|
|
34
|
+
const msg = obj.message.trim();
|
|
35
|
+
return msg.length > 30 ? `${msg.slice(0, 27)}\u2026` : msg;
|
|
36
|
+
}
|
|
37
|
+
if (typeof obj.ref === "string") return obj.ref;
|
|
38
|
+
return void 0;
|
|
39
|
+
}
|
|
40
|
+
async function recordGitOperationEvidence(deps, context, sessionId, operation, summary, extraClaims) {
|
|
41
|
+
const evidence = deps.createEvidenceRecord(
|
|
42
|
+
"command_output",
|
|
43
|
+
`git_operation ${operation}: ${summary}`,
|
|
44
|
+
`git-operation:${operation}`,
|
|
45
|
+
["git_operation", operation, ...extraClaims]
|
|
46
|
+
);
|
|
47
|
+
await context.store.appendEvent(sessionId, {
|
|
48
|
+
type: "evidence_record",
|
|
49
|
+
...evidence
|
|
50
|
+
});
|
|
51
|
+
deps.rememberEvidence(context, evidence);
|
|
52
|
+
return evidence;
|
|
53
|
+
}
|
|
54
|
+
async function appendGitOperationEvent(deps, context, sessionId, fields, level) {
|
|
55
|
+
const safe = Object.entries(fields).filter(([, value]) => value !== void 0 && value !== null).map(([key, value]) => `${key}=${typeof value === "string" ? value : JSON.stringify(value)}`).join("; ");
|
|
56
|
+
await deps.appendSystemEvent(context, sessionId, safe, level);
|
|
57
|
+
}
|
|
58
|
+
async function createSnapshotStablePoint(deps, context, sessionId, reason) {
|
|
59
|
+
const status = await readGitStatus(context.projectPath);
|
|
60
|
+
const changedFiles = status.kind === "ok" ? [...status.staged, ...status.unstaged, ...status.untracked].slice(0, 50) : [];
|
|
61
|
+
const checkpoint = {
|
|
62
|
+
id: deps.randomUUID(),
|
|
63
|
+
sessionId,
|
|
64
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
65
|
+
reason,
|
|
66
|
+
changedFiles,
|
|
67
|
+
restoreKind: "snapshot",
|
|
68
|
+
files: []
|
|
69
|
+
};
|
|
70
|
+
for (const file of changedFiles) {
|
|
71
|
+
const target = deps.resolvePath(context.projectPath, file);
|
|
72
|
+
try {
|
|
73
|
+
checkpoint.files.push({
|
|
74
|
+
path: file,
|
|
75
|
+
existed: true,
|
|
76
|
+
content: await deps.readFileUtf8(target)
|
|
77
|
+
});
|
|
78
|
+
} catch (error) {
|
|
79
|
+
if (error instanceof Error && "code" in error && error.code === "ENOENT") {
|
|
80
|
+
checkpoint.files.push({ path: file, existed: false });
|
|
81
|
+
continue;
|
|
82
|
+
}
|
|
83
|
+
checkpoint.files.push({ path: file, existed: false });
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
context.checkpoints.unshift(checkpoint);
|
|
87
|
+
context.checkpoints = context.checkpoints.slice(0, deps.maxCheckpoints);
|
|
88
|
+
await context.store.appendEvent(sessionId, {
|
|
89
|
+
type: "checkpoint_created",
|
|
90
|
+
checkpoint: {
|
|
91
|
+
id: checkpoint.id,
|
|
92
|
+
sessionId: checkpoint.sessionId,
|
|
93
|
+
createdAt: checkpoint.createdAt,
|
|
94
|
+
reason: checkpoint.reason,
|
|
95
|
+
changedFiles: checkpoint.changedFiles,
|
|
96
|
+
restoreKind: checkpoint.restoreKind,
|
|
97
|
+
restorable: false,
|
|
98
|
+
restoreUnavailableReason: "git stable checkpoint payload is kept in-memory only to avoid persisting broad dirty-file contents"
|
|
99
|
+
},
|
|
100
|
+
createdAt: checkpoint.createdAt
|
|
101
|
+
});
|
|
102
|
+
return checkpoint;
|
|
103
|
+
}
|
|
104
|
+
async function executeGitToolUse(toolCall, context, sessionId, output, deps, continuation) {
|
|
105
|
+
deps.startRequestActivity(output, context, "tool_running", { toolName: toolCall.name, toolTarget: extractGitToolTarget(toolCall.input) });
|
|
106
|
+
await context.store.appendEvent(sessionId, {
|
|
107
|
+
type: "tool_call_start",
|
|
108
|
+
id: toolCall.id,
|
|
109
|
+
name: toolCall.name,
|
|
110
|
+
input: toolCall.input,
|
|
111
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString()
|
|
112
|
+
});
|
|
113
|
+
try {
|
|
114
|
+
if (toolCall.name === GIT_STATUS_INSPECT) {
|
|
115
|
+
return await runGitStatusInspectTool(toolCall, context, sessionId, output, deps);
|
|
116
|
+
}
|
|
117
|
+
if (toolCall.name === GIT_ROLLBACK_EXPLAIN) {
|
|
118
|
+
return await runGitRollbackExplainTool(toolCall, context, sessionId, output, deps);
|
|
119
|
+
}
|
|
120
|
+
if (toolCall.name === GIT_STABLE_POINT_CREATE) {
|
|
121
|
+
return await runStablePointTool(
|
|
122
|
+
toolCall,
|
|
123
|
+
context,
|
|
124
|
+
sessionId,
|
|
125
|
+
output,
|
|
126
|
+
deps,
|
|
127
|
+
parseStablePointInput(toolCall.input),
|
|
128
|
+
continuation
|
|
129
|
+
);
|
|
130
|
+
}
|
|
131
|
+
if (toolCall.name === MANAGED_WORKTREE_CREATE) {
|
|
132
|
+
return await runWorktreeCreateTool(toolCall, context, sessionId, output, deps);
|
|
133
|
+
}
|
|
134
|
+
return await runWorktreeRemoveTool(toolCall, context, sessionId, output, deps, continuation);
|
|
135
|
+
} catch (error) {
|
|
136
|
+
deps.clearRequestActivity(context);
|
|
137
|
+
const text = deps.formatError(error, context.language);
|
|
138
|
+
const evidence = await deps.recordToolFailureEvidence(
|
|
139
|
+
context,
|
|
140
|
+
sessionId,
|
|
141
|
+
"Read",
|
|
142
|
+
`${toolCall.name}: ${text}`
|
|
143
|
+
);
|
|
144
|
+
await deps.appendDeferredToolResultEvent(
|
|
145
|
+
context,
|
|
146
|
+
sessionId,
|
|
147
|
+
toolCall.id,
|
|
148
|
+
toolCall.name,
|
|
149
|
+
text,
|
|
150
|
+
true,
|
|
151
|
+
evidence.id
|
|
152
|
+
);
|
|
153
|
+
return { ok: false, tool: toolCall.name, text, evidenceId: evidence.id };
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
async function runGitRollbackExplainTool(toolCall, context, sessionId, output, deps) {
|
|
157
|
+
const isEn = context.language === "en-US";
|
|
158
|
+
const text = isEn ? "Git rollback boundary: Linghun can restore in-memory snapshot checkpoints with /rewind restore, but this tool does not execute git revert/reset/checkout and does not move HEAD. For a real git rollback, inspect /git status first, then run an explicit shell/git command after choosing revert vs reset." : "Git \u56DE\u6EDA\u8FB9\u754C\uFF1ALinghun \u53EF\u7528 /rewind restore \u6062\u590D\u5185\u5B58 snapshot checkpoint\uFF0C\u4F46\u6B64\u5DE5\u5177\u4E0D\u4F1A\u6267\u884C git revert/reset/checkout\uFF0C\u4E5F\u4E0D\u4F1A\u79FB\u52A8 HEAD\u3002\u771F\u5B9E git \u56DE\u6EDA\u8BF7\u5148\u67E5\u770B /git status\uFF0C\u518D\u7531\u7528\u6237\u660E\u786E\u9009\u62E9 revert \u6216 reset \u540E\u624B\u52A8\u6267\u884C\u5BF9\u5E94 git \u547D\u4EE4\u3002";
|
|
159
|
+
const data = {
|
|
160
|
+
mutating: false,
|
|
161
|
+
movesHead: false,
|
|
162
|
+
executesGitRollback: false,
|
|
163
|
+
snapshotRestoreCommand: "/rewind restore <checkpointId>",
|
|
164
|
+
gitStatusCommand: "/git status"
|
|
165
|
+
};
|
|
166
|
+
const evidence = await deps.recordToolEvidence(context, sessionId, "Read", {
|
|
167
|
+
text: `GitRollbackExplain: ${text}`,
|
|
168
|
+
data
|
|
169
|
+
}, {
|
|
170
|
+
query: "GitRollbackExplain"
|
|
171
|
+
});
|
|
172
|
+
await deps.appendDeferredToolResultEvent(
|
|
173
|
+
context,
|
|
174
|
+
sessionId,
|
|
175
|
+
toolCall.id,
|
|
176
|
+
toolCall.name,
|
|
177
|
+
{ text, data },
|
|
178
|
+
false,
|
|
179
|
+
evidence?.id
|
|
180
|
+
);
|
|
181
|
+
deps.clearRequestActivity(context);
|
|
182
|
+
deps.writeLine(output, text);
|
|
183
|
+
return { ok: true, tool: toolCall.name, text, data, evidenceId: evidence?.id };
|
|
184
|
+
}
|
|
185
|
+
async function runGitStatusInspectTool(toolCall, context, sessionId, output, deps) {
|
|
186
|
+
const status = await readGitStatus(context.projectPath);
|
|
187
|
+
const worktrees = await readWorktreeList(context.projectPath);
|
|
188
|
+
const worktreeContext = await computeWorktreeContext(context.projectPath);
|
|
189
|
+
const summary = status.kind === "ok" ? `branch ${status.branch ?? "(detached)"}; changed ${status.changedCount}; untracked ${status.untrackedCount}; head ${status.headShort ?? "?"}` : status.kind === "not_a_git_repo" ? "not a git repository" : `git unavailable: ${status.error}`;
|
|
190
|
+
const data = {
|
|
191
|
+
status: status.kind === "ok" ? {
|
|
192
|
+
branch: status.branch,
|
|
193
|
+
head: status.headShort,
|
|
194
|
+
changedCount: status.changedCount,
|
|
195
|
+
untrackedCount: status.untrackedCount,
|
|
196
|
+
ahead: status.ahead,
|
|
197
|
+
behind: status.behind
|
|
198
|
+
} : { kind: status.kind },
|
|
199
|
+
worktree: summarizeWorktreeContextForPrompt(worktreeContext),
|
|
200
|
+
worktreeCount: worktrees.kind === "ok" ? worktrees.entries.length : 0
|
|
201
|
+
};
|
|
202
|
+
const evidence = await deps.recordToolEvidence(context, sessionId, "Read", {
|
|
203
|
+
text: `GitStatusInspect: ${summary}`,
|
|
204
|
+
data
|
|
205
|
+
});
|
|
206
|
+
await deps.appendDeferredToolResultEvent(
|
|
207
|
+
context,
|
|
208
|
+
sessionId,
|
|
209
|
+
toolCall.id,
|
|
210
|
+
toolCall.name,
|
|
211
|
+
{ text: summary, data },
|
|
212
|
+
false,
|
|
213
|
+
evidence?.id
|
|
214
|
+
);
|
|
215
|
+
deps.clearRequestActivity(context);
|
|
216
|
+
deps.writeLine(
|
|
217
|
+
output,
|
|
218
|
+
context.language === "en-US" ? `Git status: ${summary}` : `Git \u72B6\u6001\uFF1A${summary}`
|
|
219
|
+
);
|
|
220
|
+
return { ok: true, tool: toolCall.name, text: summary, data, evidenceId: evidence?.id };
|
|
221
|
+
}
|
|
222
|
+
async function runStablePointTool(toolCall, context, sessionId, output, deps, input, continuation) {
|
|
223
|
+
if (context.permissionMode === "plan") {
|
|
224
|
+
deps.clearRequestActivity(context);
|
|
225
|
+
const text = context.language === "en-US" ? "stable point was NOT created because Plan mode is read-only." : "stable point was NOT created because Plan mode is read-only. \u7A33\u5B9A\u70B9\u672A\u521B\u5EFA\uFF1A\u8BA1\u5212\u6A21\u5F0F\u53EA\u8BFB\u3002";
|
|
226
|
+
const evidence = await deps.recordToolFailureEvidence(
|
|
227
|
+
context,
|
|
228
|
+
sessionId,
|
|
229
|
+
"Read",
|
|
230
|
+
`GitStablePointCreate denied: ${text}`
|
|
231
|
+
);
|
|
232
|
+
await appendGitOperationEvent(
|
|
233
|
+
deps,
|
|
234
|
+
context,
|
|
235
|
+
sessionId,
|
|
236
|
+
{
|
|
237
|
+
operation: "stable_point_denied",
|
|
238
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
239
|
+
project: context.projectPath,
|
|
240
|
+
includeUntracked: Boolean(input.includeUntracked),
|
|
241
|
+
result: "plan_read_only"
|
|
242
|
+
},
|
|
243
|
+
"warning"
|
|
244
|
+
);
|
|
245
|
+
await deps.appendDeferredToolResultEvent(
|
|
246
|
+
context,
|
|
247
|
+
sessionId,
|
|
248
|
+
toolCall.id,
|
|
249
|
+
toolCall.name,
|
|
250
|
+
{ text, ok: false, outcome: "plan_read_only" },
|
|
251
|
+
true,
|
|
252
|
+
evidence.id
|
|
253
|
+
);
|
|
254
|
+
deps.writeLine(output, text);
|
|
255
|
+
return { ok: false, tool: toolCall.name, text, evidenceId: evidence.id };
|
|
256
|
+
}
|
|
257
|
+
if (context.permissionMode === "default") {
|
|
258
|
+
deps.clearRequestActivity(context);
|
|
259
|
+
context.pendingLocalApproval = {
|
|
260
|
+
kind: "git_stable_point",
|
|
261
|
+
sessionId,
|
|
262
|
+
message: input.message,
|
|
263
|
+
includeUntracked: input.includeUntracked,
|
|
264
|
+
continuation: continuation ? deps.createSingleToolCallContinuation(continuation, toolCall) : void 0,
|
|
265
|
+
toolCall
|
|
266
|
+
};
|
|
267
|
+
const summaryText = context.language === "en-US" ? "Confirm creating a stable point (git commit / snapshot) for the current workspace." : "\u786E\u8BA4\u4E3A\u5F53\u524D\u5DE5\u4F5C\u533A\u521B\u5EFA\u7A33\u5B9A\u70B9\uFF08git commit / snapshot\uFF09\u3002";
|
|
268
|
+
await appendGitOperationEvent(
|
|
269
|
+
deps,
|
|
270
|
+
context,
|
|
271
|
+
sessionId,
|
|
272
|
+
{
|
|
273
|
+
operation: "stable_point_requested",
|
|
274
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
275
|
+
project: context.projectPath,
|
|
276
|
+
includeUntracked: Boolean(input.includeUntracked),
|
|
277
|
+
result: "pending_confirmation"
|
|
278
|
+
},
|
|
279
|
+
"info"
|
|
280
|
+
);
|
|
281
|
+
if (!context.isInkSession) {
|
|
282
|
+
deps.writeLine(output, summaryText);
|
|
283
|
+
}
|
|
284
|
+
return { ok: false, tool: toolCall.name, text: summaryText, pendingApproval: true };
|
|
285
|
+
}
|
|
286
|
+
const result = await performStablePoint(context, sessionId, input, deps);
|
|
287
|
+
deps.clearRequestActivity(context);
|
|
288
|
+
await deps.appendDeferredToolResultEvent(
|
|
289
|
+
context,
|
|
290
|
+
sessionId,
|
|
291
|
+
toolCall.id,
|
|
292
|
+
toolCall.name,
|
|
293
|
+
{ text: result.text, ok: result.ok },
|
|
294
|
+
!result.ok,
|
|
295
|
+
result.evidenceId
|
|
296
|
+
);
|
|
297
|
+
deps.writeLine(output, result.text);
|
|
298
|
+
return { ok: result.ok, tool: toolCall.name, text: result.text, evidenceId: result.evidenceId };
|
|
299
|
+
}
|
|
300
|
+
async function performStablePoint(context, sessionId, input, deps) {
|
|
301
|
+
let message = input.message?.trim() ?? "";
|
|
302
|
+
if (message === "") {
|
|
303
|
+
message = defaultStablePointMessage();
|
|
304
|
+
} else {
|
|
305
|
+
const check = validateStablePointMessage(message);
|
|
306
|
+
if (!check.ok) {
|
|
307
|
+
return { ok: false, text: `\u7A33\u5B9A\u70B9 message \u975E\u6CD5\uFF1A${check.reason}`, outcome: "snapshot_only" };
|
|
308
|
+
}
|
|
309
|
+
message = check.message;
|
|
310
|
+
}
|
|
311
|
+
await createSnapshotStablePoint(deps, context, sessionId, `before stable point: ${message}`);
|
|
312
|
+
const outcome = await createGitStablePoint(context.projectPath, {
|
|
313
|
+
message,
|
|
314
|
+
includeUntracked: input.includeUntracked
|
|
315
|
+
});
|
|
316
|
+
const { ok, text } = summarizeStablePointOutcome(outcome, context.language);
|
|
317
|
+
if (outcome.kind === "git_commit") {
|
|
318
|
+
const evidence = await recordGitOperationEvidence(
|
|
319
|
+
deps,
|
|
320
|
+
context,
|
|
321
|
+
sessionId,
|
|
322
|
+
"stable_point_created",
|
|
323
|
+
`kind git commit; sha ${outcome.sha}; branch ${outcome.branch ?? "-"}; changed ${outcome.changedCount}`,
|
|
324
|
+
["stable_point_created"]
|
|
325
|
+
);
|
|
326
|
+
await appendGitOperationEvent(
|
|
327
|
+
deps,
|
|
328
|
+
context,
|
|
329
|
+
sessionId,
|
|
330
|
+
{
|
|
331
|
+
operation: "stable_point_created",
|
|
332
|
+
kind: "git_commit",
|
|
333
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
334
|
+
project: context.projectPath,
|
|
335
|
+
branch: outcome.branch,
|
|
336
|
+
sha: outcome.sha,
|
|
337
|
+
subject: outcome.subject,
|
|
338
|
+
changedCount: outcome.changedCount,
|
|
339
|
+
includedUntracked: outcome.includedUntracked,
|
|
340
|
+
rejectedUntracked: outcome.rejectedUntracked.length,
|
|
341
|
+
result: "ok"
|
|
342
|
+
},
|
|
343
|
+
"info"
|
|
344
|
+
);
|
|
345
|
+
return { ok, text, evidenceId: evidence.id, outcome };
|
|
346
|
+
}
|
|
347
|
+
if (outcome.kind === "skipped") {
|
|
348
|
+
await appendGitOperationEvent(
|
|
349
|
+
deps,
|
|
350
|
+
context,
|
|
351
|
+
sessionId,
|
|
352
|
+
{
|
|
353
|
+
operation: "stable_point_skipped",
|
|
354
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
355
|
+
branch: outcome.branch,
|
|
356
|
+
head: outcome.head,
|
|
357
|
+
result: "skipped"
|
|
358
|
+
},
|
|
359
|
+
"info"
|
|
360
|
+
);
|
|
361
|
+
return { ok, text, outcome };
|
|
362
|
+
}
|
|
363
|
+
if (outcome.kind === "snapshot" || outcome.kind === "not_a_git_repo") {
|
|
364
|
+
const reason = outcome.kind === "not_a_git_repo" ? "not_a_git_repo" : outcome.reason;
|
|
365
|
+
const evidence = await recordGitOperationEvidence(
|
|
366
|
+
deps,
|
|
367
|
+
context,
|
|
368
|
+
sessionId,
|
|
369
|
+
"stable_point_created",
|
|
370
|
+
`kind snapshot; reason ${reason}`,
|
|
371
|
+
["stable_point_created"]
|
|
372
|
+
);
|
|
373
|
+
await appendGitOperationEvent(
|
|
374
|
+
deps,
|
|
375
|
+
context,
|
|
376
|
+
sessionId,
|
|
377
|
+
{
|
|
378
|
+
operation: "stable_point_created",
|
|
379
|
+
kind: "snapshot",
|
|
380
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
381
|
+
reason,
|
|
382
|
+
result: "ok"
|
|
383
|
+
},
|
|
384
|
+
"info"
|
|
385
|
+
);
|
|
386
|
+
return { ok, text, evidenceId: evidence.id, outcome };
|
|
387
|
+
}
|
|
388
|
+
await appendGitOperationEvent(
|
|
389
|
+
deps,
|
|
390
|
+
context,
|
|
391
|
+
sessionId,
|
|
392
|
+
{
|
|
393
|
+
operation: "git_operation_failed",
|
|
394
|
+
target: "stable_point",
|
|
395
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
396
|
+
reason: text,
|
|
397
|
+
result: "failed"
|
|
398
|
+
},
|
|
399
|
+
"warning"
|
|
400
|
+
);
|
|
401
|
+
return { ok, text, outcome };
|
|
402
|
+
}
|
|
403
|
+
async function runWorktreeCreateTool(toolCall, context, sessionId, output, deps) {
|
|
404
|
+
const input = parseWorktreeCreateInput(toolCall.input);
|
|
405
|
+
const result = await performWorktreeCreate(
|
|
406
|
+
context,
|
|
407
|
+
sessionId,
|
|
408
|
+
{ name: input.name ?? "", branch: input.branch, fromRef: input.fromRef },
|
|
409
|
+
deps
|
|
410
|
+
);
|
|
411
|
+
deps.clearRequestActivity(context);
|
|
412
|
+
await deps.appendDeferredToolResultEvent(
|
|
413
|
+
context,
|
|
414
|
+
sessionId,
|
|
415
|
+
toolCall.id,
|
|
416
|
+
toolCall.name,
|
|
417
|
+
{ text: result.text, ok: result.ok },
|
|
418
|
+
!result.ok,
|
|
419
|
+
result.evidenceId
|
|
420
|
+
);
|
|
421
|
+
deps.writeLine(output, result.text);
|
|
422
|
+
return { ok: result.ok, tool: toolCall.name, text: result.text, evidenceId: result.evidenceId };
|
|
423
|
+
}
|
|
424
|
+
async function performWorktreeCreate(context, sessionId, input, deps) {
|
|
425
|
+
const outcome = await createManagedWorktree(context.projectPath, input);
|
|
426
|
+
const { ok, text } = summarizeWorktreeCreateOutcome(outcome, context.language);
|
|
427
|
+
if (outcome.kind === "created") {
|
|
428
|
+
const evidence = await recordGitOperationEvidence(
|
|
429
|
+
deps,
|
|
430
|
+
context,
|
|
431
|
+
sessionId,
|
|
432
|
+
"worktree_created",
|
|
433
|
+
`name ${outcome.name}; branch ${outcome.branch ?? "-"}; from ${outcome.fromRef}`,
|
|
434
|
+
["worktree_created"]
|
|
435
|
+
);
|
|
436
|
+
await appendGitOperationEvent(
|
|
437
|
+
deps,
|
|
438
|
+
context,
|
|
439
|
+
sessionId,
|
|
440
|
+
{
|
|
441
|
+
operation: "worktree_created",
|
|
442
|
+
createdAt: outcome.createdAt,
|
|
443
|
+
project: context.projectPath,
|
|
444
|
+
name: outcome.name,
|
|
445
|
+
path: outcome.path,
|
|
446
|
+
branch: outcome.branch,
|
|
447
|
+
fromRef: outcome.fromRef,
|
|
448
|
+
head: outcome.head,
|
|
449
|
+
managedRoot: outcome.managedRoot,
|
|
450
|
+
result: "ok"
|
|
451
|
+
},
|
|
452
|
+
"info"
|
|
453
|
+
);
|
|
454
|
+
return { ok, text, evidenceId: evidence.id, outcome };
|
|
455
|
+
}
|
|
456
|
+
if (outcome.kind === "resumed") {
|
|
457
|
+
const evidence = await recordGitOperationEvidence(
|
|
458
|
+
deps,
|
|
459
|
+
context,
|
|
460
|
+
sessionId,
|
|
461
|
+
"worktree_resumed",
|
|
462
|
+
`name ${outcome.name}; branch ${outcome.branch ?? "-"}`,
|
|
463
|
+
["worktree_resumed"]
|
|
464
|
+
);
|
|
465
|
+
await appendGitOperationEvent(
|
|
466
|
+
deps,
|
|
467
|
+
context,
|
|
468
|
+
sessionId,
|
|
469
|
+
{
|
|
470
|
+
operation: "worktree_resumed",
|
|
471
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
472
|
+
name: outcome.name,
|
|
473
|
+
path: outcome.path,
|
|
474
|
+
managedRoot: outcome.managedRoot,
|
|
475
|
+
result: "exists"
|
|
476
|
+
},
|
|
477
|
+
"info"
|
|
478
|
+
);
|
|
479
|
+
return { ok, text, evidenceId: evidence.id, outcome };
|
|
480
|
+
}
|
|
481
|
+
await appendGitOperationEvent(
|
|
482
|
+
deps,
|
|
483
|
+
context,
|
|
484
|
+
sessionId,
|
|
485
|
+
{
|
|
486
|
+
operation: "git_operation_failed",
|
|
487
|
+
target: "worktree_create",
|
|
488
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
489
|
+
reason: text,
|
|
490
|
+
result: "failed"
|
|
491
|
+
},
|
|
492
|
+
"warning"
|
|
493
|
+
);
|
|
494
|
+
return { ok, text, outcome };
|
|
495
|
+
}
|
|
496
|
+
async function runWorktreeRemoveTool(toolCall, context, sessionId, output, deps, continuation) {
|
|
497
|
+
const input = parseWorktreeRemoveInput(toolCall.input);
|
|
498
|
+
const plan = await planManagedWorktreeRemove(context.projectPath, {
|
|
499
|
+
name: input.name ?? "",
|
|
500
|
+
force: input.force
|
|
501
|
+
});
|
|
502
|
+
const summary = summarizeWorktreeRemovePlan(plan, context.language);
|
|
503
|
+
deps.clearRequestActivity(context);
|
|
504
|
+
if (summary.needsConfirmation && (plan.kind === "clean" || plan.kind === "dirty_force")) {
|
|
505
|
+
context.pendingLocalApproval = {
|
|
506
|
+
kind: "git_worktree_remove",
|
|
507
|
+
sessionId,
|
|
508
|
+
name: plan.name,
|
|
509
|
+
path: plan.path,
|
|
510
|
+
force: plan.kind === "dirty_force",
|
|
511
|
+
strong: summary.strong,
|
|
512
|
+
continuation: continuation ? deps.createSingleToolCallContinuation(continuation, toolCall) : void 0,
|
|
513
|
+
toolCall
|
|
514
|
+
};
|
|
515
|
+
await appendGitOperationEvent(
|
|
516
|
+
deps,
|
|
517
|
+
context,
|
|
518
|
+
sessionId,
|
|
519
|
+
{
|
|
520
|
+
operation: "worktree_remove_requested",
|
|
521
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
522
|
+
name: plan.name,
|
|
523
|
+
path: plan.path,
|
|
524
|
+
force: plan.kind === "dirty_force",
|
|
525
|
+
result: "pending_confirmation"
|
|
526
|
+
},
|
|
527
|
+
"info"
|
|
528
|
+
);
|
|
529
|
+
deps.writeLine(output, summary.text);
|
|
530
|
+
return { ok: false, tool: toolCall.name, text: summary.text, pendingApproval: true };
|
|
531
|
+
}
|
|
532
|
+
if (plan.kind === "dirty_blocked" || plan.kind === "not_managed") {
|
|
533
|
+
await appendGitOperationEvent(
|
|
534
|
+
deps,
|
|
535
|
+
context,
|
|
536
|
+
sessionId,
|
|
537
|
+
{
|
|
538
|
+
operation: "worktree_remove_denied",
|
|
539
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
540
|
+
name: input.name,
|
|
541
|
+
reason: summary.text,
|
|
542
|
+
result: "denied"
|
|
543
|
+
},
|
|
544
|
+
"warning"
|
|
545
|
+
);
|
|
546
|
+
}
|
|
547
|
+
const evidence = await deps.recordToolFailureEvidence(
|
|
548
|
+
context,
|
|
549
|
+
sessionId,
|
|
550
|
+
"Read",
|
|
551
|
+
`ManagedWorktreeRemove: ${summary.text}`
|
|
552
|
+
);
|
|
553
|
+
await deps.appendDeferredToolResultEvent(
|
|
554
|
+
context,
|
|
555
|
+
sessionId,
|
|
556
|
+
toolCall.id,
|
|
557
|
+
toolCall.name,
|
|
558
|
+
summary.text,
|
|
559
|
+
true,
|
|
560
|
+
evidence.id
|
|
561
|
+
);
|
|
562
|
+
deps.writeLine(output, summary.text);
|
|
563
|
+
return { ok: false, tool: toolCall.name, text: summary.text, evidenceId: evidence.id };
|
|
564
|
+
}
|
|
565
|
+
async function performWorktreeRemoveExecute(context, sessionId, name, path, force, deps) {
|
|
566
|
+
const result = await executeManagedWorktreeRemove(context.projectPath, path, force);
|
|
567
|
+
if (result.kind === "removed") {
|
|
568
|
+
const evidence = await recordGitOperationEvidence(
|
|
569
|
+
deps,
|
|
570
|
+
context,
|
|
571
|
+
sessionId,
|
|
572
|
+
"worktree_removed",
|
|
573
|
+
`name ${name}; force ${force}`,
|
|
574
|
+
["worktree_removed"]
|
|
575
|
+
);
|
|
576
|
+
await appendGitOperationEvent(
|
|
577
|
+
deps,
|
|
578
|
+
context,
|
|
579
|
+
sessionId,
|
|
580
|
+
{
|
|
581
|
+
operation: "worktree_removed",
|
|
582
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
583
|
+
name,
|
|
584
|
+
path,
|
|
585
|
+
force,
|
|
586
|
+
result: "ok"
|
|
587
|
+
},
|
|
588
|
+
"info"
|
|
589
|
+
);
|
|
590
|
+
const text2 = context.language === "en-US" ? `Worktree removed: "${name}".` : `\u5DF2\u5220\u9664 worktree\uFF1A\u300C${name}\u300D\u3002`;
|
|
591
|
+
return { ok: true, text: text2, evidenceId: evidence.id, result };
|
|
592
|
+
}
|
|
593
|
+
await appendGitOperationEvent(
|
|
594
|
+
deps,
|
|
595
|
+
context,
|
|
596
|
+
sessionId,
|
|
597
|
+
{
|
|
598
|
+
operation: "git_operation_failed",
|
|
599
|
+
target: "worktree_remove",
|
|
600
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
601
|
+
name,
|
|
602
|
+
reason: result.reason,
|
|
603
|
+
result: "failed"
|
|
604
|
+
},
|
|
605
|
+
"warning"
|
|
606
|
+
);
|
|
607
|
+
const text = context.language === "en-US" ? `Worktree removal failed; nothing removed: ${result.reason}` : `worktree \u5220\u9664\u5931\u8D25\uFF0C\u672A\u5220\u9664\uFF1A${result.reason}`;
|
|
608
|
+
return { ok: false, text, result };
|
|
609
|
+
}
|
|
610
|
+
var MANAGED_WORKTREE_REMOVE_TOOL = "ManagedWorktreeRemove";
|
|
611
|
+
async function resolveWorktreeRemoveApprove(approval, context, output, deps) {
|
|
612
|
+
const result = await performWorktreeRemoveExecute(
|
|
613
|
+
context,
|
|
614
|
+
approval.sessionId,
|
|
615
|
+
approval.name,
|
|
616
|
+
approval.path,
|
|
617
|
+
approval.force,
|
|
618
|
+
deps
|
|
619
|
+
);
|
|
620
|
+
deps.writeLine(output, result.text);
|
|
621
|
+
if (approval.continuation && approval.toolCall) {
|
|
622
|
+
approval.continuation.messages.push({
|
|
623
|
+
role: "tool",
|
|
624
|
+
tool_call_id: approval.toolCall.id,
|
|
625
|
+
content: JSON.stringify({
|
|
626
|
+
ok: result.ok,
|
|
627
|
+
tool: MANAGED_WORKTREE_REMOVE_TOOL,
|
|
628
|
+
text: result.text,
|
|
629
|
+
evidenceId: result.evidenceId
|
|
630
|
+
})
|
|
631
|
+
});
|
|
632
|
+
await deps.continueAfterToolResults(approval.continuation, context, output);
|
|
633
|
+
}
|
|
634
|
+
deps.writeLightHints(output, context);
|
|
635
|
+
deps.writeStatus(output, context);
|
|
636
|
+
}
|
|
637
|
+
async function resolveWorktreeRemoveDeny(approval, context, output, cancelled, deps) {
|
|
638
|
+
const outcomeText = cancelled ? "permission cancelled by user" : "permission denied by user";
|
|
639
|
+
const evidence = await deps.recordToolFailureEvidence(
|
|
640
|
+
context,
|
|
641
|
+
approval.sessionId,
|
|
642
|
+
"Read",
|
|
643
|
+
`${outcomeText}: ManagedWorktreeRemove ${approval.name}`
|
|
644
|
+
);
|
|
645
|
+
await appendGitOperationEvent(
|
|
646
|
+
deps,
|
|
647
|
+
context,
|
|
648
|
+
approval.sessionId,
|
|
649
|
+
{
|
|
650
|
+
operation: "worktree_remove_denied",
|
|
651
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
652
|
+
name: approval.name,
|
|
653
|
+
path: approval.path,
|
|
654
|
+
result: cancelled ? "cancelled" : "denied"
|
|
655
|
+
},
|
|
656
|
+
"warning"
|
|
657
|
+
);
|
|
658
|
+
const deniedText = context.language === "en-US" ? `Worktree removal ${cancelled ? "cancelled" : "denied"}; "${approval.name}" was not removed.` : `\u5DF2${cancelled ? "\u53D6\u6D88" : "\u62D2\u7EDD"}\u5220\u9664 worktree\uFF1B\u300C${approval.name}\u300D\u672A\u88AB\u5220\u9664\u3002`;
|
|
659
|
+
deps.writeLine(output, deniedText);
|
|
660
|
+
if (approval.continuation && approval.toolCall) {
|
|
661
|
+
approval.continuation.messages.push({
|
|
662
|
+
role: "tool",
|
|
663
|
+
tool_call_id: approval.toolCall.id,
|
|
664
|
+
content: JSON.stringify({
|
|
665
|
+
ok: false,
|
|
666
|
+
tool: MANAGED_WORKTREE_REMOVE_TOOL,
|
|
667
|
+
text: deniedText,
|
|
668
|
+
outcome: cancelled ? "cancelled" : "denied",
|
|
669
|
+
evidenceId: evidence.id
|
|
670
|
+
})
|
|
671
|
+
});
|
|
672
|
+
await deps.continueAfterToolResults(approval.continuation, context, output);
|
|
673
|
+
}
|
|
674
|
+
deps.writeLightHints(output, context);
|
|
675
|
+
deps.writeStatus(output, context);
|
|
676
|
+
}
|
|
677
|
+
async function resolveStablePointApprove(approval, context, output, deps) {
|
|
678
|
+
const result = await performStablePoint(
|
|
679
|
+
context,
|
|
680
|
+
approval.sessionId,
|
|
681
|
+
{ message: approval.message, includeUntracked: approval.includeUntracked },
|
|
682
|
+
deps
|
|
683
|
+
);
|
|
684
|
+
await deps.appendDeferredToolResultEvent(
|
|
685
|
+
context,
|
|
686
|
+
approval.sessionId,
|
|
687
|
+
approval.toolCall.id,
|
|
688
|
+
GIT_STABLE_POINT_CREATE,
|
|
689
|
+
{ text: result.text, ok: result.ok },
|
|
690
|
+
!result.ok,
|
|
691
|
+
result.evidenceId
|
|
692
|
+
);
|
|
693
|
+
deps.writeLine(output, result.text);
|
|
694
|
+
if (approval.continuation) {
|
|
695
|
+
approval.continuation.messages.push({
|
|
696
|
+
role: "tool",
|
|
697
|
+
tool_call_id: approval.toolCall.id,
|
|
698
|
+
content: JSON.stringify({
|
|
699
|
+
ok: result.ok,
|
|
700
|
+
tool: GIT_STABLE_POINT_CREATE,
|
|
701
|
+
text: result.text,
|
|
702
|
+
evidenceId: result.evidenceId
|
|
703
|
+
})
|
|
704
|
+
});
|
|
705
|
+
await deps.continueAfterToolResults(approval.continuation, context, output);
|
|
706
|
+
}
|
|
707
|
+
deps.writeLightHints(output, context);
|
|
708
|
+
deps.writeStatus(output, context);
|
|
709
|
+
}
|
|
710
|
+
async function resolveStablePointDeny(approval, context, output, cancelled, deps) {
|
|
711
|
+
const outcomeText = cancelled ? "permission cancelled by user" : "permission denied by user";
|
|
712
|
+
const evidence = await deps.recordToolFailureEvidence(
|
|
713
|
+
context,
|
|
714
|
+
approval.sessionId,
|
|
715
|
+
"Read",
|
|
716
|
+
`${outcomeText}: GitStablePointCreate`
|
|
717
|
+
);
|
|
718
|
+
await appendGitOperationEvent(
|
|
719
|
+
deps,
|
|
720
|
+
context,
|
|
721
|
+
approval.sessionId,
|
|
722
|
+
{
|
|
723
|
+
operation: "stable_point_denied",
|
|
724
|
+
createdAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
725
|
+
project: context.projectPath,
|
|
726
|
+
result: cancelled ? "cancelled" : "denied"
|
|
727
|
+
},
|
|
728
|
+
"warning"
|
|
729
|
+
);
|
|
730
|
+
const deniedText = context.language === "en-US" ? `Stable point ${cancelled ? "cancelled" : "denied"}; no commit or snapshot was created. The stable point was NOT created.` : `\u5DF2${cancelled ? "\u53D6\u6D88" : "\u62D2\u7EDD"}\u521B\u5EFA\u7A33\u5B9A\u70B9\uFF1B\u672A\u521B\u5EFA\u4EFB\u4F55 commit \u6216 snapshot\u3002\u7A33\u5B9A\u70B9\u672A\u521B\u5EFA\u3002`;
|
|
731
|
+
deps.writeLine(output, deniedText);
|
|
732
|
+
if (approval.continuation) {
|
|
733
|
+
approval.continuation.messages.push({
|
|
734
|
+
role: "tool",
|
|
735
|
+
tool_call_id: approval.toolCall.id,
|
|
736
|
+
content: JSON.stringify({
|
|
737
|
+
ok: false,
|
|
738
|
+
tool: GIT_STABLE_POINT_CREATE,
|
|
739
|
+
text: deniedText,
|
|
740
|
+
outcome: cancelled ? "cancelled" : "denied",
|
|
741
|
+
evidenceId: evidence.id
|
|
742
|
+
})
|
|
743
|
+
});
|
|
744
|
+
await deps.continueAfterToolResults(approval.continuation, context, output);
|
|
745
|
+
}
|
|
746
|
+
deps.writeLightHints(output, context);
|
|
747
|
+
deps.writeStatus(output, context);
|
|
748
|
+
}
|
|
749
|
+
|
|
750
|
+
export {
|
|
751
|
+
appendGitOperationEvent,
|
|
752
|
+
executeGitToolUse,
|
|
753
|
+
performStablePoint,
|
|
754
|
+
performWorktreeCreate,
|
|
755
|
+
performWorktreeRemoveExecute,
|
|
756
|
+
resolveWorktreeRemoveApprove,
|
|
757
|
+
resolveWorktreeRemoveDeny,
|
|
758
|
+
resolveStablePointApprove,
|
|
759
|
+
resolveStablePointDeny
|
|
760
|
+
};
|