@shareai-lab/kode 1.2.0 → 2.0.2
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.md +25 -388
- package/cli-acp.js +82 -0
- package/cli.js +89 -79
- package/dist/REPL-GIU4ZIXM.js +42 -0
- package/dist/acp-H3VJ77YG.js +1357 -0
- package/dist/acp-H3VJ77YG.js.map +7 -0
- package/dist/agentsValidate-XP3CFN6F.js +373 -0
- package/dist/agentsValidate-XP3CFN6F.js.map +7 -0
- package/dist/ask-3G5H5KD5.js +125 -0
- package/dist/ask-3G5H5KD5.js.map +7 -0
- package/dist/autoUpdater-DNRMJWFQ.js +17 -0
- package/dist/chunk-2KWKUXLT.js +490 -0
- package/dist/chunk-2KWKUXLT.js.map +7 -0
- package/dist/chunk-2PMO2FS2.js +1097 -0
- package/dist/chunk-2PMO2FS2.js.map +7 -0
- package/dist/chunk-3RUXVV4S.js +23 -0
- package/dist/chunk-3RUXVV4S.js.map +7 -0
- package/dist/chunk-3TXNP6HH.js +240 -0
- package/dist/chunk-3TXNP6HH.js.map +7 -0
- package/dist/chunk-4GAIJGRH.js +472 -0
- package/dist/chunk-4GAIJGRH.js.map +7 -0
- package/dist/chunk-4RTX4AG4.js +249 -0
- package/dist/chunk-4RTX4AG4.js.map +7 -0
- package/dist/chunk-54DNHKOD.js +511 -0
- package/dist/chunk-54DNHKOD.js.map +7 -0
- package/dist/chunk-67PY5IX6.js +34 -0
- package/dist/chunk-67PY5IX6.js.map +7 -0
- package/dist/chunk-6DRDLOLP.js +2613 -0
- package/dist/chunk-6DRDLOLP.js.map +7 -0
- package/dist/chunk-7CQVZNQV.js +1609 -0
- package/dist/chunk-7CQVZNQV.js.map +7 -0
- package/dist/chunk-ABLVTESJ.js +19 -0
- package/dist/chunk-ABLVTESJ.js.map +7 -0
- package/dist/{utils/config.js → chunk-AIMIPK4B.js} +351 -171
- package/dist/chunk-AIMIPK4B.js.map +7 -0
- package/dist/{utils/autoUpdater.js → chunk-BHGTA6JQ.js} +38 -21
- package/dist/chunk-BHGTA6JQ.js.map +7 -0
- package/dist/chunk-CIG63V4E.js +72 -0
- package/dist/chunk-CIG63V4E.js.map +7 -0
- package/dist/chunk-E6YNABER.js +24 -0
- package/dist/chunk-E6YNABER.js.map +7 -0
- package/dist/chunk-EH34V7CY.js +191 -0
- package/dist/chunk-EH34V7CY.js.map +7 -0
- package/dist/{cost-tracker.js → chunk-EZXMVTDU.js} +51 -32
- package/dist/chunk-EZXMVTDU.js.map +7 -0
- package/dist/chunk-FH5CHM6L.js +148 -0
- package/dist/chunk-FH5CHM6L.js.map +7 -0
- package/dist/chunk-G6I7XROM.js +138 -0
- package/dist/chunk-G6I7XROM.js.map +7 -0
- package/dist/chunk-HN4E4UUQ.js +96 -0
- package/dist/chunk-HN4E4UUQ.js.map +7 -0
- package/dist/chunk-HSPVVDIW.js +30198 -0
- package/dist/chunk-HSPVVDIW.js.map +7 -0
- package/dist/{services/systemReminder.js → chunk-IE2CG2TV.js} +221 -59
- package/dist/chunk-IE2CG2TV.js.map +7 -0
- package/dist/chunk-JC6NCUG5.js +11 -0
- package/dist/chunk-K2MI4TPB.js +1256 -0
- package/dist/chunk-K2MI4TPB.js.map +7 -0
- package/dist/chunk-KAA5BGMQ.js +12 -0
- package/dist/chunk-KAA5BGMQ.js.map +7 -0
- package/dist/chunk-MN77D2F7.js +2931 -0
- package/dist/chunk-MN77D2F7.js.map +7 -0
- package/dist/chunk-NPFOMITO.js +21 -0
- package/dist/chunk-NPFOMITO.js.map +7 -0
- package/dist/chunk-NQLEUHMS.js +196 -0
- package/dist/chunk-NQLEUHMS.js.map +7 -0
- package/dist/chunk-OIFQB3S4.js +515 -0
- package/dist/chunk-OIFQB3S4.js.map +7 -0
- package/dist/chunk-OWTG2W3A.js +164 -0
- package/dist/chunk-OWTG2W3A.js.map +7 -0
- package/dist/chunk-OZNRLY3E.js +735 -0
- package/dist/chunk-OZNRLY3E.js.map +7 -0
- package/dist/{utils/debugLogger.js → chunk-QYFKRZQC.js} +107 -204
- package/dist/chunk-QYFKRZQC.js.map +7 -0
- package/dist/chunk-S3J2TLV6.js +16 -0
- package/dist/chunk-S3J2TLV6.js.map +7 -0
- package/dist/chunk-S6HRABTA.js +95 -0
- package/dist/chunk-S6HRABTA.js.map +7 -0
- package/dist/{utils/theme.js → chunk-SDGKPKDK.js} +28 -6
- package/dist/chunk-SDGKPKDK.js.map +7 -0
- package/dist/chunk-SRZZFAS7.js +766 -0
- package/dist/chunk-SRZZFAS7.js.map +7 -0
- package/dist/chunk-UKHTVRJM.js +47 -0
- package/dist/chunk-UKHTVRJM.js.map +7 -0
- package/dist/chunk-UYXEDKOZ.js +24 -0
- package/dist/chunk-UYXEDKOZ.js.map +7 -0
- package/dist/chunk-VBXVYQYY.js +145 -0
- package/dist/chunk-VBXVYQYY.js.map +7 -0
- package/dist/chunk-WVHORZQ5.js +17 -0
- package/dist/chunk-WVHORZQ5.js.map +7 -0
- package/dist/chunk-WWUWDNWW.js +49 -0
- package/dist/chunk-WWUWDNWW.js.map +7 -0
- package/dist/{utils/model.js → chunk-Z33T5YN5.js} +194 -227
- package/dist/chunk-Z33T5YN5.js.map +7 -0
- package/dist/{services/openai.js → chunk-ZQU3TXLC.js} +168 -234
- package/dist/chunk-ZQU3TXLC.js.map +7 -0
- package/dist/cli-SRV2INSL.js +3917 -0
- package/dist/cli-SRV2INSL.js.map +7 -0
- package/dist/commands-TWH6PGVG.js +46 -0
- package/dist/config-6ZMBCL23.js +81 -0
- package/dist/context-JQIOOI4W.js +30 -0
- package/dist/costTracker-6SL26FDB.js +19 -0
- package/dist/customCommands-DNEJS3ZU.js +25 -0
- package/dist/customCommands-DNEJS3ZU.js.map +7 -0
- package/dist/env-OFAXZ3XG.js +22 -0
- package/dist/env-OFAXZ3XG.js.map +7 -0
- package/dist/index.js +34 -5
- package/dist/index.js.map +4 -4
- package/dist/kodeAgentSessionId-X6XWQW7B.js +13 -0
- package/dist/kodeAgentSessionId-X6XWQW7B.js.map +7 -0
- package/dist/kodeAgentSessionLoad-6N27AC5K.js +18 -0
- package/dist/kodeAgentSessionLoad-6N27AC5K.js.map +7 -0
- package/dist/kodeAgentSessionResume-HUSAEO24.js +16 -0
- package/dist/kodeAgentSessionResume-HUSAEO24.js.map +7 -0
- package/dist/kodeAgentStreamJson-NXFN7TXH.js +13 -0
- package/dist/kodeAgentStreamJson-NXFN7TXH.js.map +7 -0
- package/dist/kodeAgentStreamJsonSession-GRWG3SPE.js +131 -0
- package/dist/kodeAgentStreamJsonSession-GRWG3SPE.js.map +7 -0
- package/dist/kodeAgentStructuredStdio-HGWJT7CU.js +10 -0
- package/dist/kodeAgentStructuredStdio-HGWJT7CU.js.map +7 -0
- package/dist/kodeHooks-TDMXFWSO.js +36 -0
- package/dist/kodeHooks-TDMXFWSO.js.map +7 -0
- package/dist/llm-XVXWYOHK.js +3118 -0
- package/dist/llm-XVXWYOHK.js.map +7 -0
- package/dist/llmLazy-7TD5N7XP.js +15 -0
- package/dist/llmLazy-7TD5N7XP.js.map +7 -0
- package/dist/loader-AUXIJTY6.js +28 -0
- package/dist/loader-AUXIJTY6.js.map +7 -0
- package/dist/mcp-BXJ3K7NZ.js +49 -0
- package/dist/mcp-BXJ3K7NZ.js.map +7 -0
- package/dist/{services/mentionProcessor.js → mentionProcessor-YD7YXYGF.js} +61 -50
- package/dist/mentionProcessor-YD7YXYGF.js.map +7 -0
- package/dist/messages-OFUJSPRV.js +63 -0
- package/dist/messages-OFUJSPRV.js.map +7 -0
- package/dist/model-KPYCXWBK.js +30 -0
- package/dist/model-KPYCXWBK.js.map +7 -0
- package/dist/openai-5G5D5Q4B.js +29 -0
- package/dist/openai-5G5D5Q4B.js.map +7 -0
- package/dist/outputStyles-HLDXFQK3.js +28 -0
- package/dist/outputStyles-HLDXFQK3.js.map +7 -0
- package/dist/package.json +1 -1
- package/dist/pluginRuntime-FPTKK6NY.js +218 -0
- package/dist/pluginRuntime-FPTKK6NY.js.map +7 -0
- package/dist/pluginValidation-DSFXZ4GF.js +17 -0
- package/dist/pluginValidation-DSFXZ4GF.js.map +7 -0
- package/dist/prompts-LWLAJRS2.js +48 -0
- package/dist/prompts-LWLAJRS2.js.map +7 -0
- package/dist/query-HVPWL27C.js +50 -0
- package/dist/query-HVPWL27C.js.map +7 -0
- package/dist/responsesStreaming-AW344PQO.js +10 -0
- package/dist/responsesStreaming-AW344PQO.js.map +7 -0
- package/dist/ripgrep-YOPCY2GO.js +17 -0
- package/dist/ripgrep-YOPCY2GO.js.map +7 -0
- package/dist/skillMarketplace-PSNKDINM.js +37 -0
- package/dist/skillMarketplace-PSNKDINM.js.map +7 -0
- package/dist/state-KNRWP3FO.js +16 -0
- package/dist/state-KNRWP3FO.js.map +7 -0
- package/dist/theme-7S2QN2FO.js +14 -0
- package/dist/theme-7S2QN2FO.js.map +7 -0
- package/dist/toolPermissionContext-65L65VEZ.js +17 -0
- package/dist/toolPermissionContext-65L65VEZ.js.map +7 -0
- package/dist/toolPermissionSettings-GPOBH4IV.js +18 -0
- package/dist/toolPermissionSettings-GPOBH4IV.js.map +7 -0
- package/dist/tools-FZU2FZBD.js +47 -0
- package/dist/tools-FZU2FZBD.js.map +7 -0
- package/dist/userInput-VHNBN2MW.js +311 -0
- package/dist/userInput-VHNBN2MW.js.map +7 -0
- package/dist/uuid-QN2CNKKN.js +9 -0
- package/dist/uuid-QN2CNKKN.js.map +7 -0
- package/package.json +43 -14
- package/scripts/binary-utils.cjs +62 -0
- package/scripts/cli-acp-wrapper.cjs +82 -0
- package/scripts/cli-wrapper.cjs +105 -0
- package/scripts/postinstall.js +135 -9
- package/LICENSE +0 -201
- package/README.zh-CN.md +0 -312
- package/dist/ProjectOnboarding.js +0 -99
- package/dist/ProjectOnboarding.js.map +0 -7
- package/dist/Tool.js +0 -1
- package/dist/commands/agents.js +0 -2087
- package/dist/commands/agents.js.map +0 -7
- package/dist/commands/approvedTools.js +0 -36
- package/dist/commands/approvedTools.js.map +0 -7
- package/dist/commands/bug.js +0 -21
- package/dist/commands/bug.js.map +0 -7
- package/dist/commands/clear.js +0 -37
- package/dist/commands/clear.js.map +0 -7
- package/dist/commands/compact.js +0 -104
- package/dist/commands/compact.js.map +0 -7
- package/dist/commands/config.js +0 -20
- package/dist/commands/config.js.map +0 -7
- package/dist/commands/cost.js +0 -19
- package/dist/commands/cost.js.map +0 -7
- package/dist/commands/ctx_viz.js +0 -152
- package/dist/commands/ctx_viz.js.map +0 -7
- package/dist/commands/doctor.js +0 -25
- package/dist/commands/doctor.js.map +0 -7
- package/dist/commands/help.js +0 -20
- package/dist/commands/help.js.map +0 -7
- package/dist/commands/init.js +0 -38
- package/dist/commands/init.js.map +0 -7
- package/dist/commands/listen.js +0 -37
- package/dist/commands/listen.js.map +0 -7
- package/dist/commands/login.js +0 -37
- package/dist/commands/login.js.map +0 -7
- package/dist/commands/logout.js +0 -33
- package/dist/commands/logout.js.map +0 -7
- package/dist/commands/mcp.js +0 -34
- package/dist/commands/mcp.js.map +0 -7
- package/dist/commands/model.js +0 -41
- package/dist/commands/model.js.map +0 -7
- package/dist/commands/modelstatus.js +0 -21
- package/dist/commands/modelstatus.js.map +0 -7
- package/dist/commands/onboarding.js +0 -36
- package/dist/commands/onboarding.js.map +0 -7
- package/dist/commands/pr_comments.js +0 -61
- package/dist/commands/pr_comments.js.map +0 -7
- package/dist/commands/refreshCommands.js +0 -37
- package/dist/commands/refreshCommands.js.map +0 -7
- package/dist/commands/release-notes.js +0 -30
- package/dist/commands/release-notes.js.map +0 -7
- package/dist/commands/resume.js +0 -35
- package/dist/commands/resume.js.map +0 -7
- package/dist/commands/review.js +0 -51
- package/dist/commands/review.js.map +0 -7
- package/dist/commands/terminalSetup.js +0 -163
- package/dist/commands/terminalSetup.js.map +0 -7
- package/dist/commands.js +0 -84
- package/dist/commands.js.map +0 -7
- package/dist/components/ApproveApiKey.js +0 -74
- package/dist/components/ApproveApiKey.js.map +0 -7
- package/dist/components/AsciiLogo.js +0 -12
- package/dist/components/AsciiLogo.js.map +0 -7
- package/dist/components/AutoUpdater.js +0 -74
- package/dist/components/AutoUpdater.js.map +0 -7
- package/dist/components/Bug.js +0 -147
- package/dist/components/Bug.js.map +0 -7
- package/dist/components/Config.js +0 -166
- package/dist/components/Config.js.map +0 -7
- package/dist/components/ConsoleOAuthFlow.js +0 -188
- package/dist/components/ConsoleOAuthFlow.js.map +0 -7
- package/dist/components/Cost.js +0 -13
- package/dist/components/Cost.js.map +0 -7
- package/dist/components/CostThresholdDialog.js +0 -38
- package/dist/components/CostThresholdDialog.js.map +0 -7
- package/dist/components/CustomSelect/option-map.js +0 -32
- package/dist/components/CustomSelect/option-map.js.map +0 -7
- package/dist/components/CustomSelect/select-option.js +0 -34
- package/dist/components/CustomSelect/select-option.js.map +0 -7
- package/dist/components/CustomSelect/select.js +0 -64
- package/dist/components/CustomSelect/select.js.map +0 -7
- package/dist/components/CustomSelect/theme.js +0 -1
- package/dist/components/CustomSelect/use-select-state.js +0 -220
- package/dist/components/CustomSelect/use-select-state.js.map +0 -7
- package/dist/components/CustomSelect/use-select.js +0 -21
- package/dist/components/CustomSelect/use-select.js.map +0 -7
- package/dist/components/FallbackToolUseRejectedMessage.js +0 -11
- package/dist/components/FallbackToolUseRejectedMessage.js.map +0 -7
- package/dist/components/FileEditToolUpdatedMessage.js +0 -32
- package/dist/components/FileEditToolUpdatedMessage.js.map +0 -7
- package/dist/components/Help.js +0 -41
- package/dist/components/Help.js.map +0 -7
- package/dist/components/HighlightedCode.js +0 -30
- package/dist/components/HighlightedCode.js.map +0 -7
- package/dist/components/InvalidConfigDialog.js +0 -83
- package/dist/components/InvalidConfigDialog.js.map +0 -7
- package/dist/components/Link.js +0 -18
- package/dist/components/Link.js.map +0 -7
- package/dist/components/LogSelector.js +0 -50
- package/dist/components/LogSelector.js.map +0 -7
- package/dist/components/Logo.js +0 -94
- package/dist/components/Logo.js.map +0 -7
- package/dist/components/MCPServerApprovalDialog.js +0 -79
- package/dist/components/MCPServerApprovalDialog.js.map +0 -7
- package/dist/components/MCPServerDialogCopy.js +0 -11
- package/dist/components/MCPServerDialogCopy.js.map +0 -7
- package/dist/components/MCPServerMultiselectDialog.js +0 -80
- package/dist/components/MCPServerMultiselectDialog.js.map +0 -7
- package/dist/components/Message.js +0 -146
- package/dist/components/Message.js.map +0 -7
- package/dist/components/MessageResponse.js +0 -9
- package/dist/components/MessageResponse.js.map +0 -7
- package/dist/components/MessageSelector.js +0 -133
- package/dist/components/MessageSelector.js.map +0 -7
- package/dist/components/ModeIndicator.js +0 -38
- package/dist/components/ModeIndicator.js.map +0 -7
- package/dist/components/ModelConfig.js +0 -208
- package/dist/components/ModelConfig.js.map +0 -7
- package/dist/components/ModelListManager.js +0 -140
- package/dist/components/ModelListManager.js.map +0 -7
- package/dist/components/ModelSelector.js +0 -1985
- package/dist/components/ModelSelector.js.map +0 -7
- package/dist/components/ModelStatusDisplay.js +0 -87
- package/dist/components/ModelStatusDisplay.js.map +0 -7
- package/dist/components/Onboarding.js +0 -153
- package/dist/components/Onboarding.js.map +0 -7
- package/dist/components/PressEnterToContinue.js +0 -10
- package/dist/components/PressEnterToContinue.js.map +0 -7
- package/dist/components/PromptInput.js +0 -488
- package/dist/components/PromptInput.js.map +0 -7
- package/dist/components/SentryErrorBoundary.js +0 -27
- package/dist/components/SentryErrorBoundary.js.map +0 -7
- package/dist/components/Spinner.js +0 -101
- package/dist/components/Spinner.js.map +0 -7
- package/dist/components/StickerRequestForm.js +0 -7
- package/dist/components/StickerRequestForm.js.map +0 -7
- package/dist/components/StructuredDiff.js +0 -148
- package/dist/components/StructuredDiff.js.map +0 -7
- package/dist/components/TextInput.js +0 -100
- package/dist/components/TextInput.js.map +0 -7
- package/dist/components/TodoItem.js +0 -35
- package/dist/components/TodoItem.js.map +0 -7
- package/dist/components/TokenWarning.js +0 -19
- package/dist/components/TokenWarning.js.map +0 -7
- package/dist/components/ToolUseLoader.js +0 -24
- package/dist/components/ToolUseLoader.js.map +0 -7
- package/dist/components/TrustDialog.js +0 -76
- package/dist/components/TrustDialog.js.map +0 -7
- package/dist/components/binary-feedback/BinaryFeedback.js +0 -50
- package/dist/components/binary-feedback/BinaryFeedback.js.map +0 -7
- package/dist/components/binary-feedback/BinaryFeedbackOption.js +0 -94
- package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +0 -7
- package/dist/components/binary-feedback/BinaryFeedbackView.js +0 -139
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +0 -7
- package/dist/components/binary-feedback/utils.js +0 -161
- package/dist/components/binary-feedback/utils.js.map +0 -7
- package/dist/components/messages/AssistantBashOutputMessage.js +0 -23
- package/dist/components/messages/AssistantBashOutputMessage.js.map +0 -7
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js +0 -36
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +0 -7
- package/dist/components/messages/AssistantRedactedThinkingMessage.js +0 -12
- package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +0 -7
- package/dist/components/messages/AssistantTextMessage.js +0 -78
- package/dist/components/messages/AssistantTextMessage.js.map +0 -7
- package/dist/components/messages/AssistantThinkingMessage.js +0 -27
- package/dist/components/messages/AssistantThinkingMessage.js.map +0 -7
- package/dist/components/messages/AssistantToolUseMessage.js +0 -91
- package/dist/components/messages/AssistantToolUseMessage.js.map +0 -7
- package/dist/components/messages/TaskProgressMessage.js +0 -11
- package/dist/components/messages/TaskProgressMessage.js.map +0 -7
- package/dist/components/messages/TaskToolMessage.js +0 -39
- package/dist/components/messages/TaskToolMessage.js.map +0 -7
- package/dist/components/messages/UserBashInputMessage.js +0 -18
- package/dist/components/messages/UserBashInputMessage.js.map +0 -7
- package/dist/components/messages/UserCommandMessage.js +0 -20
- package/dist/components/messages/UserCommandMessage.js.map +0 -7
- package/dist/components/messages/UserKodingInputMessage.js +0 -18
- package/dist/components/messages/UserKodingInputMessage.js.map +0 -7
- package/dist/components/messages/UserPromptMessage.js +0 -20
- package/dist/components/messages/UserPromptMessage.js.map +0 -7
- package/dist/components/messages/UserTextMessage.js +0 -25
- package/dist/components/messages/UserTextMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +0 -10
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +0 -15
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +0 -25
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +0 -47
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +0 -23
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +0 -7
- package/dist/components/messages/UserToolResultMessage/utils.js +0 -42
- package/dist/components/messages/UserToolResultMessage/utils.js.map +0 -7
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +0 -112
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +0 -7
- package/dist/components/permissions/FallbackPermissionRequest.js +0 -131
- package/dist/components/permissions/FallbackPermissionRequest.js.map +0 -7
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +0 -159
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +0 -7
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +0 -58
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +0 -7
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +0 -153
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +0 -7
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +0 -70
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +0 -7
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +0 -212
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +0 -7
- package/dist/components/permissions/PermissionRequest.js +0 -70
- package/dist/components/permissions/PermissionRequest.js.map +0 -7
- package/dist/components/permissions/PermissionRequestTitle.js +0 -52
- package/dist/components/permissions/PermissionRequestTitle.js.map +0 -7
- package/dist/components/permissions/hooks.js +0 -28
- package/dist/components/permissions/hooks.js.map +0 -7
- package/dist/components/permissions/toolUseOptions.js +0 -46
- package/dist/components/permissions/toolUseOptions.js.map +0 -7
- package/dist/components/permissions/utils.js +0 -21
- package/dist/components/permissions/utils.js.map +0 -7
- package/dist/constants/betas.js +0 -11
- package/dist/constants/betas.js.map +0 -7
- package/dist/constants/claude-asterisk-ascii-art.js +0 -242
- package/dist/constants/claude-asterisk-ascii-art.js.map +0 -7
- package/dist/constants/figures.js +0 -6
- package/dist/constants/figures.js.map +0 -7
- package/dist/constants/keys.js +0 -7
- package/dist/constants/keys.js.map +0 -7
- package/dist/constants/macros.js +0 -13
- package/dist/constants/macros.js.map +0 -7
- package/dist/constants/modelCapabilities.js +0 -154
- package/dist/constants/modelCapabilities.js.map +0 -7
- package/dist/constants/models.js +0 -1034
- package/dist/constants/models.js.map +0 -7
- package/dist/constants/oauth.js +0 -18
- package/dist/constants/oauth.js.map +0 -7
- package/dist/constants/product.js +0 -26
- package/dist/constants/product.js.map +0 -7
- package/dist/constants/prompts.js +0 -168
- package/dist/constants/prompts.js.map +0 -7
- package/dist/constants/releaseNotes.js +0 -9
- package/dist/constants/releaseNotes.js.map +0 -7
- package/dist/context/PermissionContext.js +0 -111
- package/dist/context/PermissionContext.js.map +0 -7
- package/dist/context.js +0 -259
- package/dist/context.js.map +0 -7
- package/dist/cost-tracker.js.map +0 -7
- package/dist/entrypoints/cli.js +0 -1107
- package/dist/entrypoints/cli.js.map +0 -7
- package/dist/entrypoints/mcp.js +0 -150
- package/dist/entrypoints/mcp.js.map +0 -7
- package/dist/history.js +0 -25
- package/dist/history.js.map +0 -7
- package/dist/hooks/useApiKeyVerification.js +0 -12
- package/dist/hooks/useApiKeyVerification.js.map +0 -7
- package/dist/hooks/useArrowKeyHistory.js +0 -50
- package/dist/hooks/useArrowKeyHistory.js.map +0 -7
- package/dist/hooks/useCanUseTool.js +0 -112
- package/dist/hooks/useCanUseTool.js.map +0 -7
- package/dist/hooks/useCancelRequest.js +0 -30
- package/dist/hooks/useCancelRequest.js.map +0 -7
- package/dist/hooks/useDoublePress.js +0 -31
- package/dist/hooks/useDoublePress.js.map +0 -7
- package/dist/hooks/useExitOnCtrlCD.js +0 -26
- package/dist/hooks/useExitOnCtrlCD.js.map +0 -7
- package/dist/hooks/useInterval.js +0 -18
- package/dist/hooks/useInterval.js.map +0 -7
- package/dist/hooks/useLogMessages.js +0 -14
- package/dist/hooks/useLogMessages.js.map +0 -7
- package/dist/hooks/useLogStartupTime.js +0 -15
- package/dist/hooks/useLogStartupTime.js.map +0 -7
- package/dist/hooks/useNotifyAfterTimeout.js +0 -42
- package/dist/hooks/useNotifyAfterTimeout.js.map +0 -7
- package/dist/hooks/usePermissionRequestLogging.js +0 -28
- package/dist/hooks/usePermissionRequestLogging.js.map +0 -7
- package/dist/hooks/useTerminalSize.js +0 -38
- package/dist/hooks/useTerminalSize.js.map +0 -7
- package/dist/hooks/useTextInput.js +0 -250
- package/dist/hooks/useTextInput.js.map +0 -7
- package/dist/hooks/useUnifiedCompletion.js +0 -929
- package/dist/hooks/useUnifiedCompletion.js.map +0 -7
- package/dist/messages.js +0 -33
- package/dist/messages.js.map +0 -7
- package/dist/permissions.js +0 -194
- package/dist/permissions.js.map +0 -7
- package/dist/query.js +0 -492
- package/dist/query.js.map +0 -7
- package/dist/screens/ConfigureNpmPrefix.js +0 -128
- package/dist/screens/ConfigureNpmPrefix.js.map +0 -7
- package/dist/screens/Doctor.js +0 -22
- package/dist/screens/Doctor.js.map +0 -7
- package/dist/screens/LogList.js +0 -55
- package/dist/screens/LogList.js.map +0 -7
- package/dist/screens/REPL.js +0 -593
- package/dist/screens/REPL.js.map +0 -7
- package/dist/screens/ResumeConversation.js +0 -56
- package/dist/screens/ResumeConversation.js.map +0 -7
- package/dist/services/adapters/base.js +0 -29
- package/dist/services/adapters/base.js.map +0 -7
- package/dist/services/adapters/chatCompletions.js +0 -69
- package/dist/services/adapters/chatCompletions.js.map +0 -7
- package/dist/services/adapters/responsesAPI.js +0 -126
- package/dist/services/adapters/responsesAPI.js.map +0 -7
- package/dist/services/browserMocks.js +0 -48
- package/dist/services/browserMocks.js.map +0 -7
- package/dist/services/claude.js +0 -1605
- package/dist/services/claude.js.map +0 -7
- package/dist/services/customCommands.js +0 -359
- package/dist/services/customCommands.js.map +0 -7
- package/dist/services/fileFreshness.js +0 -280
- package/dist/services/fileFreshness.js.map +0 -7
- package/dist/services/gpt5ConnectionTest.js +0 -248
- package/dist/services/gpt5ConnectionTest.js.map +0 -7
- package/dist/services/mcpClient.js +0 -435
- package/dist/services/mcpClient.js.map +0 -7
- package/dist/services/mcpServerApproval.js +0 -55
- package/dist/services/mcpServerApproval.js.map +0 -7
- package/dist/services/mentionProcessor.js.map +0 -7
- package/dist/services/modelAdapterFactory.js +0 -47
- package/dist/services/modelAdapterFactory.js.map +0 -7
- package/dist/services/notifier.js +0 -35
- package/dist/services/notifier.js.map +0 -7
- package/dist/services/oauth.js +0 -259
- package/dist/services/oauth.js.map +0 -7
- package/dist/services/openai.js.map +0 -7
- package/dist/services/responseStateManager.js +0 -68
- package/dist/services/responseStateManager.js.map +0 -7
- package/dist/services/sentry.js +0 -9
- package/dist/services/sentry.js.map +0 -7
- package/dist/services/statsig.js +0 -112
- package/dist/services/statsig.js.map +0 -7
- package/dist/services/statsigStorage.js +0 -75
- package/dist/services/statsigStorage.js.map +0 -7
- package/dist/services/systemReminder.js.map +0 -7
- package/dist/services/vcr.js +0 -133
- package/dist/services/vcr.js.map +0 -7
- package/dist/tools/ArchitectTool/ArchitectTool.js +0 -119
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +0 -7
- package/dist/tools/ArchitectTool/prompt.js +0 -18
- package/dist/tools/ArchitectTool/prompt.js.map +0 -7
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +0 -423
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +0 -7
- package/dist/tools/BashTool/BashTool.js +0 -188
- package/dist/tools/BashTool/BashTool.js.map +0 -7
- package/dist/tools/BashTool/BashToolResultMessage.js +0 -21
- package/dist/tools/BashTool/BashToolResultMessage.js.map +0 -7
- package/dist/tools/BashTool/OutputLine.js +0 -30
- package/dist/tools/BashTool/OutputLine.js.map +0 -7
- package/dist/tools/BashTool/prompt.js +0 -179
- package/dist/tools/BashTool/prompt.js.map +0 -7
- package/dist/tools/BashTool/utils.js +0 -51
- package/dist/tools/BashTool/utils.js.map +0 -7
- package/dist/tools/FileEditTool/FileEditTool.js +0 -228
- package/dist/tools/FileEditTool/FileEditTool.js.map +0 -7
- package/dist/tools/FileEditTool/prompt.js +0 -54
- package/dist/tools/FileEditTool/prompt.js.map +0 -7
- package/dist/tools/FileEditTool/utils.js +0 -42
- package/dist/tools/FileEditTool/utils.js.map +0 -7
- package/dist/tools/FileReadTool/FileReadTool.js +0 -272
- package/dist/tools/FileReadTool/FileReadTool.js.map +0 -7
- package/dist/tools/FileReadTool/prompt.js +0 -10
- package/dist/tools/FileReadTool/prompt.js.map +0 -7
- package/dist/tools/FileWriteTool/FileWriteTool.js +0 -204
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +0 -7
- package/dist/tools/FileWriteTool/prompt.js +0 -14
- package/dist/tools/FileWriteTool/prompt.js.map +0 -7
- package/dist/tools/GlobTool/GlobTool.js +0 -88
- package/dist/tools/GlobTool/GlobTool.js.map +0 -7
- package/dist/tools/GlobTool/prompt.js +0 -12
- package/dist/tools/GlobTool/prompt.js.map +0 -7
- package/dist/tools/GrepTool/GrepTool.js +0 -107
- package/dist/tools/GrepTool/GrepTool.js.map +0 -7
- package/dist/tools/GrepTool/prompt.js +0 -15
- package/dist/tools/GrepTool/prompt.js.map +0 -7
- package/dist/tools/MCPTool/MCPTool.js +0 -90
- package/dist/tools/MCPTool/MCPTool.js.map +0 -7
- package/dist/tools/MCPTool/prompt.js +0 -7
- package/dist/tools/MCPTool/prompt.js.map +0 -7
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +0 -103
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +0 -7
- package/dist/tools/MemoryReadTool/prompt.js +0 -7
- package/dist/tools/MemoryReadTool/prompt.js.map +0 -7
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +0 -77
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +0 -7
- package/dist/tools/MemoryWriteTool/prompt.js +0 -7
- package/dist/tools/MemoryWriteTool/prompt.js.map +0 -7
- package/dist/tools/MultiEditTool/MultiEditTool.js +0 -308
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +0 -7
- package/dist/tools/MultiEditTool/prompt.js +0 -48
- package/dist/tools/MultiEditTool/prompt.js.map +0 -7
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +0 -238
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +0 -7
- package/dist/tools/NotebookEditTool/prompt.js +0 -7
- package/dist/tools/NotebookEditTool/prompt.js.map +0 -7
- package/dist/tools/NotebookReadTool/NotebookReadTool.js +0 -212
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +0 -7
- package/dist/tools/NotebookReadTool/prompt.js +0 -7
- package/dist/tools/NotebookReadTool/prompt.js.map +0 -7
- package/dist/tools/StickerRequestTool/StickerRequestTool.js +0 -86
- package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +0 -7
- package/dist/tools/StickerRequestTool/prompt.js +0 -23
- package/dist/tools/StickerRequestTool/prompt.js.map +0 -7
- package/dist/tools/TaskTool/TaskTool.js +0 -351
- package/dist/tools/TaskTool/TaskTool.js.map +0 -7
- package/dist/tools/TaskTool/constants.js +0 -5
- package/dist/tools/TaskTool/constants.js.map +0 -7
- package/dist/tools/TaskTool/prompt.js +0 -82
- package/dist/tools/TaskTool/prompt.js.map +0 -7
- package/dist/tools/ThinkTool/ThinkTool.js +0 -48
- package/dist/tools/ThinkTool/ThinkTool.js.map +0 -7
- package/dist/tools/ThinkTool/prompt.js +0 -16
- package/dist/tools/ThinkTool/prompt.js.map +0 -7
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +0 -216
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +0 -7
- package/dist/tools/TodoWriteTool/prompt.js +0 -66
- package/dist/tools/TodoWriteTool/prompt.js.map +0 -7
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +0 -137
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +0 -7
- package/dist/tools/URLFetcherTool/cache.js +0 -45
- package/dist/tools/URLFetcherTool/cache.js.map +0 -7
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js +0 -42
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +0 -7
- package/dist/tools/URLFetcherTool/prompt.js +0 -22
- package/dist/tools/URLFetcherTool/prompt.js.map +0 -7
- package/dist/tools/WebSearchTool/WebSearchTool.js +0 -86
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +0 -7
- package/dist/tools/WebSearchTool/prompt.js +0 -17
- package/dist/tools/WebSearchTool/prompt.js.map +0 -7
- package/dist/tools/WebSearchTool/searchProviders.js +0 -48
- package/dist/tools/WebSearchTool/searchProviders.js.map +0 -7
- package/dist/tools/lsTool/lsTool.js +0 -201
- package/dist/tools/lsTool/lsTool.js.map +0 -7
- package/dist/tools/lsTool/prompt.js +0 -5
- package/dist/tools/lsTool/prompt.js.map +0 -7
- package/dist/tools.js +0 -64
- package/dist/tools.js.map +0 -7
- package/dist/types/PermissionMode.js +0 -82
- package/dist/types/PermissionMode.js.map +0 -7
- package/dist/types/RequestContext.js +0 -47
- package/dist/types/RequestContext.js.map +0 -7
- package/dist/types/common.d.js +0 -1
- package/dist/types/conversation.js +0 -1
- package/dist/types/logs.js +0 -1
- package/dist/types/modelCapabilities.js +0 -1
- package/dist/types/notebook.js +0 -1
- package/dist/utils/Cursor.js +0 -313
- package/dist/utils/Cursor.js.map +0 -7
- package/dist/utils/PersistentShell.js +0 -382
- package/dist/utils/PersistentShell.js.map +0 -7
- package/dist/utils/advancedFuzzyMatcher.js +0 -206
- package/dist/utils/advancedFuzzyMatcher.js.map +0 -7
- package/dist/utils/agentLoader.js +0 -199
- package/dist/utils/agentLoader.js.map +0 -7
- package/dist/utils/agentStorage.js +0 -59
- package/dist/utils/agentStorage.js.map +0 -7
- package/dist/utils/array.js +0 -7
- package/dist/utils/array.js.map +0 -7
- package/dist/utils/ask.js +0 -77
- package/dist/utils/ask.js.map +0 -7
- package/dist/utils/auth.js +0 -11
- package/dist/utils/auth.js.map +0 -7
- package/dist/utils/autoCompactCore.js +0 -149
- package/dist/utils/autoCompactCore.js.map +0 -7
- package/dist/utils/autoUpdater.js.map +0 -7
- package/dist/utils/betas.js +0 -21
- package/dist/utils/betas.js.map +0 -7
- package/dist/utils/browser.js +0 -15
- package/dist/utils/browser.js.map +0 -7
- package/dist/utils/cleanup.js +0 -54
- package/dist/utils/cleanup.js.map +0 -7
- package/dist/utils/commands.js +0 -207
- package/dist/utils/commands.js.map +0 -7
- package/dist/utils/commonUnixCommands.js +0 -687
- package/dist/utils/commonUnixCommands.js.map +0 -7
- package/dist/utils/config.js.map +0 -7
- package/dist/utils/conversationRecovery.js +0 -35
- package/dist/utils/conversationRecovery.js.map +0 -7
- package/dist/utils/debugLogger.js.map +0 -7
- package/dist/utils/diff.js +0 -32
- package/dist/utils/diff.js.map +0 -7
- package/dist/utils/env.js +0 -44
- package/dist/utils/env.js.map +0 -7
- package/dist/utils/errors.js +0 -23
- package/dist/utils/errors.js.map +0 -7
- package/dist/utils/exampleCommands.js +0 -80
- package/dist/utils/exampleCommands.js.map +0 -7
- package/dist/utils/execFileNoThrow.js +0 -44
- package/dist/utils/execFileNoThrow.js.map +0 -7
- package/dist/utils/expertChatStorage.js +0 -78
- package/dist/utils/expertChatStorage.js.map +0 -7
- package/dist/utils/file.js +0 -282
- package/dist/utils/file.js.map +0 -7
- package/dist/utils/fileRecoveryCore.js +0 -41
- package/dist/utils/fileRecoveryCore.js.map +0 -7
- package/dist/utils/format.js +0 -41
- package/dist/utils/format.js.map +0 -7
- package/dist/utils/fuzzyMatcher.js +0 -252
- package/dist/utils/fuzzyMatcher.js.map +0 -7
- package/dist/utils/generators.js +0 -46
- package/dist/utils/generators.js.map +0 -7
- package/dist/utils/git.js +0 -83
- package/dist/utils/git.js.map +0 -7
- package/dist/utils/globalLogger.js +0 -54
- package/dist/utils/globalLogger.js.map +0 -7
- package/dist/utils/http.js +0 -7
- package/dist/utils/http.js.map +0 -7
- package/dist/utils/imagePaste.js +0 -29
- package/dist/utils/imagePaste.js.map +0 -7
- package/dist/utils/json.js +0 -16
- package/dist/utils/json.js.map +0 -7
- package/dist/utils/log.js +0 -298
- package/dist/utils/log.js.map +0 -7
- package/dist/utils/markdown.js +0 -187
- package/dist/utils/markdown.js.map +0 -7
- package/dist/utils/messageContextManager.js +0 -195
- package/dist/utils/messageContextManager.js.map +0 -7
- package/dist/utils/messages.js +0 -633
- package/dist/utils/messages.js.map +0 -7
- package/dist/utils/model.js.map +0 -7
- package/dist/utils/permissions/filesystem.js +0 -80
- package/dist/utils/permissions/filesystem.js.map +0 -7
- package/dist/utils/responseState.js +0 -20
- package/dist/utils/responseState.js.map +0 -7
- package/dist/utils/ripgrep.js +0 -131
- package/dist/utils/ripgrep.js.map +0 -7
- package/dist/utils/secureFile.js +0 -483
- package/dist/utils/secureFile.js.map +0 -7
- package/dist/utils/sessionState.js +0 -31
- package/dist/utils/sessionState.js.map +0 -7
- package/dist/utils/state.js +0 -24
- package/dist/utils/state.js.map +0 -7
- package/dist/utils/style.js +0 -31
- package/dist/utils/style.js.map +0 -7
- package/dist/utils/terminal.js +0 -43
- package/dist/utils/terminal.js.map +0 -7
- package/dist/utils/theme.js.map +0 -7
- package/dist/utils/thinking.js +0 -103
- package/dist/utils/thinking.js.map +0 -7
- package/dist/utils/todoStorage.js +0 -291
- package/dist/utils/todoStorage.js.map +0 -7
- package/dist/utils/tokens.js +0 -30
- package/dist/utils/tokens.js.map +0 -7
- package/dist/utils/toolExecutionController.js +0 -109
- package/dist/utils/toolExecutionController.js.map +0 -7
- package/dist/utils/unaryLogging.js +0 -14
- package/dist/utils/unaryLogging.js.map +0 -7
- package/dist/utils/user.js +0 -40
- package/dist/utils/user.js.map +0 -7
- package/dist/utils/validate.js +0 -132
- package/dist/utils/validate.js.map +0 -7
- /package/dist/{Tool.js.map → REPL-GIU4ZIXM.js.map} +0 -0
- /package/dist/{components/CustomSelect/theme.js.map → autoUpdater-DNRMJWFQ.js.map} +0 -0
- /package/dist/{types/common.d.js.map → chunk-JC6NCUG5.js.map} +0 -0
- /package/dist/{types/conversation.js.map → commands-TWH6PGVG.js.map} +0 -0
- /package/dist/{types/logs.js.map → config-6ZMBCL23.js.map} +0 -0
- /package/dist/{types/modelCapabilities.js.map → context-JQIOOI4W.js.map} +0 -0
- /package/dist/{types/notebook.js.map → costTracker-6SL26FDB.js.map} +0 -0
|
@@ -1,12 +1,48 @@
|
|
|
1
|
+
import { createRequire as __kodeCreateRequire } from "node:module";
|
|
2
|
+
const require = __kodeCreateRequire(import.meta.url);
|
|
3
|
+
|
|
4
|
+
// src/core/costTracker.ts
|
|
1
5
|
import chalk from "chalk";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
6
|
+
|
|
7
|
+
// src/utils/terminal/format.ts
|
|
8
|
+
function wrapText(text, width) {
|
|
9
|
+
const lines = [];
|
|
10
|
+
let currentLine = "";
|
|
11
|
+
for (const char of text) {
|
|
12
|
+
if ([...currentLine].length < width) {
|
|
13
|
+
currentLine += char;
|
|
14
|
+
} else {
|
|
15
|
+
lines.push(currentLine);
|
|
16
|
+
currentLine = char;
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
if (currentLine) lines.push(currentLine);
|
|
20
|
+
return lines;
|
|
21
|
+
}
|
|
22
|
+
function formatDuration(ms) {
|
|
23
|
+
if (ms < 6e4) {
|
|
24
|
+
return `${(ms / 1e3).toFixed(1)}s`;
|
|
25
|
+
}
|
|
26
|
+
const hours = Math.floor(ms / 36e5);
|
|
27
|
+
const minutes = Math.floor(ms % 36e5 / 6e4);
|
|
28
|
+
const seconds = (ms % 6e4 / 1e3).toFixed(1);
|
|
29
|
+
if (hours > 0) {
|
|
30
|
+
return `${hours}h ${minutes}m ${seconds}s`;
|
|
31
|
+
}
|
|
32
|
+
if (minutes > 0) {
|
|
33
|
+
return `${minutes}m ${seconds}s`;
|
|
34
|
+
}
|
|
35
|
+
return `${seconds}s`;
|
|
36
|
+
}
|
|
37
|
+
function formatNumber(number) {
|
|
38
|
+
return new Intl.NumberFormat("en", {
|
|
39
|
+
notation: "compact",
|
|
40
|
+
maximumFractionDigits: 1
|
|
41
|
+
}).format(number).toLowerCase();
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
// src/core/costTracker.ts
|
|
45
|
+
var STATE = {
|
|
10
46
|
totalCost: 0,
|
|
11
47
|
totalAPIDuration: 0,
|
|
12
48
|
startTime: Date.now()
|
|
@@ -34,25 +70,6 @@ Total duration (API): ${formatDuration(STATE.totalAPIDuration)}
|
|
|
34
70
|
Total duration (wall): ${formatDuration(getTotalDuration())}`
|
|
35
71
|
);
|
|
36
72
|
}
|
|
37
|
-
function useCostSummary() {
|
|
38
|
-
useEffect(() => {
|
|
39
|
-
const f = () => {
|
|
40
|
-
process.stdout.write("\n" + formatTotalCost() + "\n");
|
|
41
|
-
const projectConfig = getCurrentProjectConfig();
|
|
42
|
-
saveCurrentProjectConfig({
|
|
43
|
-
...projectConfig,
|
|
44
|
-
lastCost: STATE.totalCost,
|
|
45
|
-
lastAPIDuration: STATE.totalAPIDuration,
|
|
46
|
-
lastDuration: getTotalDuration(),
|
|
47
|
-
lastSessionId: SESSION_ID
|
|
48
|
-
});
|
|
49
|
-
};
|
|
50
|
-
process.on("exit", f);
|
|
51
|
-
return () => {
|
|
52
|
-
process.off("exit", f);
|
|
53
|
-
};
|
|
54
|
-
}, []);
|
|
55
|
-
}
|
|
56
73
|
function round(number, precision) {
|
|
57
74
|
return Math.round(number * precision) / precision;
|
|
58
75
|
}
|
|
@@ -64,13 +81,15 @@ function resetStateForTests() {
|
|
|
64
81
|
STATE.totalCost = 0;
|
|
65
82
|
STATE.totalAPIDuration = 0;
|
|
66
83
|
}
|
|
84
|
+
|
|
67
85
|
export {
|
|
86
|
+
wrapText,
|
|
87
|
+
formatDuration,
|
|
88
|
+
formatNumber,
|
|
68
89
|
addToTotalCost,
|
|
69
|
-
formatTotalCost,
|
|
70
|
-
getTotalAPIDuration,
|
|
71
90
|
getTotalCost,
|
|
72
91
|
getTotalDuration,
|
|
73
|
-
|
|
74
|
-
|
|
92
|
+
getTotalAPIDuration,
|
|
93
|
+
formatTotalCost,
|
|
94
|
+
resetStateForTests
|
|
75
95
|
};
|
|
76
|
-
//# sourceMappingURL=cost-tracker.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/core/costTracker.ts", "../src/utils/terminal/format.ts"],
|
|
4
|
+
"sourcesContent": ["import chalk from 'chalk'\nimport { formatDuration } from '@utils/terminal/format'\n\nconst STATE: {\n totalCost: number\n totalAPIDuration: number\n startTime: number\n} = {\n totalCost: 0,\n totalAPIDuration: 0,\n startTime: Date.now(),\n}\n\nexport function addToTotalCost(cost: number, duration: number): void {\n STATE.totalCost += cost\n STATE.totalAPIDuration += duration\n}\n\nexport function getTotalCost(): number {\n return STATE.totalCost\n}\n\nexport function getTotalDuration(): number {\n return Date.now() - STATE.startTime\n}\n\nexport function getTotalAPIDuration(): number {\n return STATE.totalAPIDuration\n}\n\nfunction formatCost(cost: number): string {\n return `$${cost > 0.5 ? round(cost, 100).toFixed(2) : cost.toFixed(4)}`\n}\n\nexport function formatTotalCost(): string {\n return chalk.grey(\n `Total cost: ${formatCost(STATE.totalCost)}\nTotal duration (API): ${formatDuration(STATE.totalAPIDuration)}\nTotal duration (wall): ${formatDuration(getTotalDuration())}`,\n )\n}\n\nfunction round(number: number, precision: number): number {\n return Math.round(number * precision) / precision\n}\n\nexport function resetStateForTests(): void {\n if (process.env.NODE_ENV !== 'test') {\n throw new Error('resetStateForTests can only be called in tests')\n }\n STATE.startTime = Date.now()\n STATE.totalCost = 0\n STATE.totalAPIDuration = 0\n}\n", "export function wrapText(text: string, width: number): string[] {\n const lines: string[] = []\n let currentLine = ''\n\n for (const char of text) {\n if ([...currentLine].length < width) {\n currentLine += char\n } else {\n lines.push(currentLine)\n currentLine = char\n }\n }\n\n if (currentLine) lines.push(currentLine)\n return lines\n}\n\nexport function formatDuration(ms: number): string {\n if (ms < 60000) {\n return `${(ms / 1000).toFixed(1)}s`\n }\n\n const hours = Math.floor(ms / 3600000)\n const minutes = Math.floor((ms % 3600000) / 60000)\n const seconds = ((ms % 60000) / 1000).toFixed(1)\n\n if (hours > 0) {\n return `${hours}h ${minutes}m ${seconds}s`\n }\n if (minutes > 0) {\n return `${minutes}m ${seconds}s`\n }\n return `${seconds}s`\n}\n\nexport function formatNumber(number: number): string {\n return new Intl.NumberFormat('en', {\n notation: 'compact',\n maximumFractionDigits: 1,\n })\n .format(number)\n .toLowerCase()\n}\n"],
|
|
5
|
+
"mappings": ";;;;AAAA,OAAO,WAAW;;;ACAX,SAAS,SAAS,MAAc,OAAyB;AAC9D,QAAM,QAAkB,CAAC;AACzB,MAAI,cAAc;AAElB,aAAW,QAAQ,MAAM;AACvB,QAAI,CAAC,GAAG,WAAW,EAAE,SAAS,OAAO;AACnC,qBAAe;AAAA,IACjB,OAAO;AACL,YAAM,KAAK,WAAW;AACtB,oBAAc;AAAA,IAChB;AAAA,EACF;AAEA,MAAI,YAAa,OAAM,KAAK,WAAW;AACvC,SAAO;AACT;AAEO,SAAS,eAAe,IAAoB;AACjD,MAAI,KAAK,KAAO;AACd,WAAO,IAAI,KAAK,KAAM,QAAQ,CAAC,CAAC;AAAA,EAClC;AAEA,QAAM,QAAQ,KAAK,MAAM,KAAK,IAAO;AACrC,QAAM,UAAU,KAAK,MAAO,KAAK,OAAW,GAAK;AACjD,QAAM,WAAY,KAAK,MAAS,KAAM,QAAQ,CAAC;AAE/C,MAAI,QAAQ,GAAG;AACb,WAAO,GAAG,KAAK,KAAK,OAAO,KAAK,OAAO;AAAA,EACzC;AACA,MAAI,UAAU,GAAG;AACf,WAAO,GAAG,OAAO,KAAK,OAAO;AAAA,EAC/B;AACA,SAAO,GAAG,OAAO;AACnB;AAEO,SAAS,aAAa,QAAwB;AACnD,SAAO,IAAI,KAAK,aAAa,MAAM;AAAA,IACjC,UAAU;AAAA,IACV,uBAAuB;AAAA,EACzB,CAAC,EACE,OAAO,MAAM,EACb,YAAY;AACjB;;;ADvCA,IAAM,QAIF;AAAA,EACF,WAAW;AAAA,EACX,kBAAkB;AAAA,EAClB,WAAW,KAAK,IAAI;AACtB;AAEO,SAAS,eAAe,MAAc,UAAwB;AACnE,QAAM,aAAa;AACnB,QAAM,oBAAoB;AAC5B;AAEO,SAAS,eAAuB;AACrC,SAAO,MAAM;AACf;AAEO,SAAS,mBAA2B;AACzC,SAAO,KAAK,IAAI,IAAI,MAAM;AAC5B;AAEO,SAAS,sBAA8B;AAC5C,SAAO,MAAM;AACf;AAEA,SAAS,WAAW,MAAsB;AACxC,SAAO,IAAI,OAAO,MAAM,MAAM,MAAM,GAAG,EAAE,QAAQ,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;AACvE;AAEO,SAAS,kBAA0B;AACxC,SAAO,MAAM;AAAA,IACX,eAAe,WAAW,MAAM,SAAS,CAAC;AAAA,wBACtB,eAAe,MAAM,gBAAgB,CAAC;AAAA,yBACrC,eAAe,iBAAiB,CAAC,CAAC;AAAA,EACzD;AACF;AAEA,SAAS,MAAM,QAAgB,WAA2B;AACxD,SAAO,KAAK,MAAM,SAAS,SAAS,IAAI;AAC1C;AAEO,SAAS,qBAA2B;AACzC,MAAI,QAAQ,IAAI,aAAa,QAAQ;AACnC,UAAM,IAAI,MAAM,gDAAgD;AAAA,EAClE;AACA,QAAM,YAAY,KAAK,IAAI;AAC3B,QAAM,YAAY;AAClB,QAAM,mBAAmB;AAC3B;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import { createRequire as __kodeCreateRequire } from "node:module";
|
|
2
|
+
const require = __kodeCreateRequire(import.meta.url);
|
|
3
|
+
|
|
4
|
+
// package.json
|
|
5
|
+
var package_default = {
|
|
6
|
+
name: "@shareai-lab/kode",
|
|
7
|
+
version: "2.0.2",
|
|
8
|
+
bin: {
|
|
9
|
+
kode: "cli.js",
|
|
10
|
+
kwa: "cli.js",
|
|
11
|
+
kd: "cli.js",
|
|
12
|
+
"kode-acp": "cli-acp.js"
|
|
13
|
+
},
|
|
14
|
+
engines: {
|
|
15
|
+
node: ">=20.18.1"
|
|
16
|
+
},
|
|
17
|
+
main: "cli.js",
|
|
18
|
+
author: "ShareAI-lab <ai-lab@foxmail.com>",
|
|
19
|
+
license: "Apache-2.0",
|
|
20
|
+
description: "AI-powered terminal assistant that understands your codebase, edits files, runs commands, and automates development workflows.",
|
|
21
|
+
homepage: "https://github.com/shareAI-lab/kode",
|
|
22
|
+
repository: {
|
|
23
|
+
type: "git",
|
|
24
|
+
url: "git+https://github.com/shareAI-lab/kode.git"
|
|
25
|
+
},
|
|
26
|
+
bugs: {
|
|
27
|
+
url: "https://github.com/shareAI-lab/kode/issues"
|
|
28
|
+
},
|
|
29
|
+
files: [
|
|
30
|
+
"cli.js",
|
|
31
|
+
"cli-acp.js",
|
|
32
|
+
"yoga.wasm",
|
|
33
|
+
"dist/**/*",
|
|
34
|
+
"scripts/binary-utils.cjs",
|
|
35
|
+
"scripts/cli-wrapper.cjs",
|
|
36
|
+
"scripts/cli-acp-wrapper.cjs",
|
|
37
|
+
"scripts/postinstall.js",
|
|
38
|
+
".npmrc"
|
|
39
|
+
],
|
|
40
|
+
scripts: {
|
|
41
|
+
dev: "bun run ./src/entrypoints/cli.tsx --verbose",
|
|
42
|
+
"build:npm": "bun run scripts/build.mjs",
|
|
43
|
+
build: "bun run build:npm",
|
|
44
|
+
"build:binary": "bun run scripts/build-binary.mjs",
|
|
45
|
+
clean: "bun run scripts/clean.mjs",
|
|
46
|
+
prepublishOnly: "bun run build:npm && bun run scripts/prepublish-check.js",
|
|
47
|
+
postinstall: "node scripts/postinstall.js || true",
|
|
48
|
+
format: 'prettier --write "src/**/*.{ts,tsx,js,jsx,json}" "tests/**/*.{ts,tsx,js,jsx,json}"',
|
|
49
|
+
"format:check": 'prettier --check "src/**/*.{ts,tsx,js,jsx,json}" "tests/**/*.{ts,tsx,js,jsx,json}"',
|
|
50
|
+
lint: "eslint . --ext .ts,.tsx,.js --max-warnings 0",
|
|
51
|
+
"lint:fix": "eslint . --ext .ts,.tsx,.js --fix",
|
|
52
|
+
test: "bun test",
|
|
53
|
+
"test:unit": "bun test tests/unit",
|
|
54
|
+
"test:integration": "bun test tests/integration",
|
|
55
|
+
"test:e2e": "bun test tests/e2e",
|
|
56
|
+
typecheck: "tsc --noEmit",
|
|
57
|
+
prepare: "bun run scripts/install-hooks.mjs",
|
|
58
|
+
"publish:dev": "bun run scripts/publish-dev.js",
|
|
59
|
+
"publish:release": "bun run scripts/publish-release.js",
|
|
60
|
+
"bench:startup": "bun run scripts/bench-startup.mjs",
|
|
61
|
+
"parity:reference": "bun run scripts/reference-parity-check.mjs"
|
|
62
|
+
},
|
|
63
|
+
dependencies: {
|
|
64
|
+
"@anthropic-ai/bedrock-sdk": "^0.12.6",
|
|
65
|
+
"@anthropic-ai/sdk": "^0.39.0",
|
|
66
|
+
"@anthropic-ai/vertex-sdk": "^0.7.0",
|
|
67
|
+
"@aws-sdk/client-bedrock-runtime": "3.797.0",
|
|
68
|
+
"@commander-js/extra-typings": "^13.1.0",
|
|
69
|
+
"@inkjs/ui": "^2.0.0",
|
|
70
|
+
"@modelcontextprotocol/sdk": "^1.15.1",
|
|
71
|
+
"@types/lodash-es": "^4.17.12",
|
|
72
|
+
"@types/react": "^19.1.8",
|
|
73
|
+
"@vscode/ripgrep": "^1.17.0",
|
|
74
|
+
ajv: "^8.17.1",
|
|
75
|
+
"ansi-escapes": "^7.0.0",
|
|
76
|
+
chalk: "^5.4.1",
|
|
77
|
+
"cli-highlight": "^2.1.11",
|
|
78
|
+
"cli-table3": "^0.6.5",
|
|
79
|
+
commander: "^13.1.0",
|
|
80
|
+
debug: "^4.4.1",
|
|
81
|
+
diff: "^7.0.0",
|
|
82
|
+
dotenv: "^16.6.1",
|
|
83
|
+
"env-paths": "^3.0.0",
|
|
84
|
+
fflate: "^0.8.2",
|
|
85
|
+
figures: "^6.1.0",
|
|
86
|
+
glob: "^11.0.3",
|
|
87
|
+
"gray-matter": "^4.0.3",
|
|
88
|
+
"highlight.js": "^11.11.1",
|
|
89
|
+
ignore: "^7.0.5",
|
|
90
|
+
ink: "5.2.1",
|
|
91
|
+
"ink-link": "^4.1.0",
|
|
92
|
+
"ink-select-input": "^6.2.0",
|
|
93
|
+
"ink-text-input": "^6.0.0",
|
|
94
|
+
"js-yaml": "^4.1.1",
|
|
95
|
+
"lodash-es": "^4.17.21",
|
|
96
|
+
"lru-cache": "^11.1.0",
|
|
97
|
+
marked: "^15.0.12",
|
|
98
|
+
minimatch: "^10.1.1",
|
|
99
|
+
nanoid: "^5.1.5",
|
|
100
|
+
"node-fetch": "^3.3.2",
|
|
101
|
+
"node-html-parser": "^7.0.1",
|
|
102
|
+
openai: "^4.104.0",
|
|
103
|
+
react: "18.3.1",
|
|
104
|
+
semver: "^7.7.2",
|
|
105
|
+
"shell-quote": "^1.8.3",
|
|
106
|
+
"spawn-rx": "^5.1.2",
|
|
107
|
+
"string-width": "^7.2.0",
|
|
108
|
+
"strip-ansi": "^7.1.0",
|
|
109
|
+
tsx: "^4.20.3",
|
|
110
|
+
turndown: "^7.2.0",
|
|
111
|
+
undici: "^7.11.0",
|
|
112
|
+
which: "^6.0.0",
|
|
113
|
+
"wrap-ansi": "^9.0.0",
|
|
114
|
+
zod: "^3.25.76",
|
|
115
|
+
"zod-to-json-schema": "^3.24.6"
|
|
116
|
+
},
|
|
117
|
+
devDependencies: {
|
|
118
|
+
"@types/bun": "latest",
|
|
119
|
+
"@types/jest": "^30.0.0",
|
|
120
|
+
"@types/node": "^24.1.0",
|
|
121
|
+
"@types/which": "^3.0.4",
|
|
122
|
+
"@typescript-eslint/eslint-plugin": "^8.50.1",
|
|
123
|
+
"@typescript-eslint/parser": "^8.50.1",
|
|
124
|
+
"bun-types": "latest",
|
|
125
|
+
esbuild: "^0.25.9",
|
|
126
|
+
eslint: "8.57.0",
|
|
127
|
+
"eslint-plugin-react-hooks": "^7.0.1",
|
|
128
|
+
prettier: "^3.6.2",
|
|
129
|
+
"react-devtools-core": "^7.0.1",
|
|
130
|
+
typescript: "^5.9.2"
|
|
131
|
+
},
|
|
132
|
+
overrides: {
|
|
133
|
+
"@aws-sdk/client-bedrock-runtime": "3.797.0",
|
|
134
|
+
"@smithy/smithy-client": "2.5.1"
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
|
|
138
|
+
// src/constants/macros.ts
|
|
139
|
+
var MACRO = {
|
|
140
|
+
VERSION: package_default.version,
|
|
141
|
+
README_URL: "https://github.com/shareAI-lab/kode#readme",
|
|
142
|
+
PACKAGE_URL: "@shareai-lab/kode",
|
|
143
|
+
ISSUES_EXPLAINER: "report the issue at https://github.com/shareAI-lab/kode/issues"
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
export {
|
|
147
|
+
MACRO
|
|
148
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../package.json", "../src/constants/macros.ts"],
|
|
4
|
+
"sourcesContent": ["{\n \"name\": \"@shareai-lab/kode\",\n \"version\": \"2.0.2\",\n \"bin\": {\n \"kode\": \"cli.js\",\n \"kwa\": \"cli.js\",\n \"kd\": \"cli.js\",\n \"kode-acp\": \"cli-acp.js\"\n },\n \"engines\": {\n \"node\": \">=20.18.1\"\n },\n \"main\": \"cli.js\",\n \"author\": \"ShareAI-lab <ai-lab@foxmail.com>\",\n \"license\": \"Apache-2.0\",\n \"description\": \"AI-powered terminal assistant that understands your codebase, edits files, runs commands, and automates development workflows.\",\n \"homepage\": \"https://github.com/shareAI-lab/kode\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"git+https://github.com/shareAI-lab/kode.git\"\n },\n \"bugs\": {\n \"url\": \"https://github.com/shareAI-lab/kode/issues\"\n },\n \"files\": [\n \"cli.js\",\n \"cli-acp.js\",\n \"yoga.wasm\",\n \"dist/**/*\",\n \"scripts/binary-utils.cjs\",\n \"scripts/cli-wrapper.cjs\",\n \"scripts/cli-acp-wrapper.cjs\",\n \"scripts/postinstall.js\",\n \".npmrc\"\n ],\n \"scripts\": {\n \"dev\": \"bun run ./src/entrypoints/cli.tsx --verbose\",\n \"build:npm\": \"bun run scripts/build.mjs\",\n \"build\": \"bun run build:npm\",\n \"build:binary\": \"bun run scripts/build-binary.mjs\",\n \"clean\": \"bun run scripts/clean.mjs\",\n \"prepublishOnly\": \"bun run build:npm && bun run scripts/prepublish-check.js\",\n \"postinstall\": \"node scripts/postinstall.js || true\",\n \"format\": \"prettier --write \\\"src/**/*.{ts,tsx,js,jsx,json}\\\" \\\"tests/**/*.{ts,tsx,js,jsx,json}\\\"\",\n \"format:check\": \"prettier --check \\\"src/**/*.{ts,tsx,js,jsx,json}\\\" \\\"tests/**/*.{ts,tsx,js,jsx,json}\\\"\",\n \"lint\": \"eslint . --ext .ts,.tsx,.js --max-warnings 0\",\n \"lint:fix\": \"eslint . --ext .ts,.tsx,.js --fix\",\n \"test\": \"bun test\",\n \"test:unit\": \"bun test tests/unit\",\n \"test:integration\": \"bun test tests/integration\",\n \"test:e2e\": \"bun test tests/e2e\",\n \"typecheck\": \"tsc --noEmit\",\n \"prepare\": \"bun run scripts/install-hooks.mjs\",\n \"publish:dev\": \"bun run scripts/publish-dev.js\",\n \"publish:release\": \"bun run scripts/publish-release.js\",\n \"bench:startup\": \"bun run scripts/bench-startup.mjs\",\n \"parity:reference\": \"bun run scripts/reference-parity-check.mjs\"\n },\n \"dependencies\": {\n \"@anthropic-ai/bedrock-sdk\": \"^0.12.6\",\n \"@anthropic-ai/sdk\": \"^0.39.0\",\n \"@anthropic-ai/vertex-sdk\": \"^0.7.0\",\n \"@aws-sdk/client-bedrock-runtime\": \"3.797.0\",\n \"@commander-js/extra-typings\": \"^13.1.0\",\n \"@inkjs/ui\": \"^2.0.0\",\n \"@modelcontextprotocol/sdk\": \"^1.15.1\",\n \"@types/lodash-es\": \"^4.17.12\",\n \"@types/react\": \"^19.1.8\",\n \"@vscode/ripgrep\": \"^1.17.0\",\n \"ajv\": \"^8.17.1\",\n \"ansi-escapes\": \"^7.0.0\",\n \"chalk\": \"^5.4.1\",\n \"cli-highlight\": \"^2.1.11\",\n \"cli-table3\": \"^0.6.5\",\n \"commander\": \"^13.1.0\",\n \"debug\": \"^4.4.1\",\n \"diff\": \"^7.0.0\",\n \"dotenv\": \"^16.6.1\",\n \"env-paths\": \"^3.0.0\",\n \"fflate\": \"^0.8.2\",\n \"figures\": \"^6.1.0\",\n \"glob\": \"^11.0.3\",\n \"gray-matter\": \"^4.0.3\",\n \"highlight.js\": \"^11.11.1\",\n \"ignore\": \"^7.0.5\",\n \"ink\": \"5.2.1\",\n \"ink-link\": \"^4.1.0\",\n \"ink-select-input\": \"^6.2.0\",\n \"ink-text-input\": \"^6.0.0\",\n \"js-yaml\": \"^4.1.1\",\n \"lodash-es\": \"^4.17.21\",\n \"lru-cache\": \"^11.1.0\",\n \"marked\": \"^15.0.12\",\n \"minimatch\": \"^10.1.1\",\n \"nanoid\": \"^5.1.5\",\n \"node-fetch\": \"^3.3.2\",\n \"node-html-parser\": \"^7.0.1\",\n \"openai\": \"^4.104.0\",\n \"react\": \"18.3.1\",\n \"semver\": \"^7.7.2\",\n \"shell-quote\": \"^1.8.3\",\n \"spawn-rx\": \"^5.1.2\",\n \"string-width\": \"^7.2.0\",\n \"strip-ansi\": \"^7.1.0\",\n \"tsx\": \"^4.20.3\",\n \"turndown\": \"^7.2.0\",\n \"undici\": \"^7.11.0\",\n \"which\": \"^6.0.0\",\n \"wrap-ansi\": \"^9.0.0\",\n \"zod\": \"^3.25.76\",\n \"zod-to-json-schema\": \"^3.24.6\"\n },\n \"devDependencies\": {\n \"@types/bun\": \"latest\",\n \"@types/jest\": \"^30.0.0\",\n \"@types/node\": \"^24.1.0\",\n \"@types/which\": \"^3.0.4\",\n \"@typescript-eslint/eslint-plugin\": \"^8.50.1\",\n \"@typescript-eslint/parser\": \"^8.50.1\",\n \"bun-types\": \"latest\",\n \"esbuild\": \"^0.25.9\",\n \"eslint\": \"8.57.0\",\n \"eslint-plugin-react-hooks\": \"^7.0.1\",\n \"prettier\": \"^3.6.2\",\n \"react-devtools-core\": \"^7.0.1\",\n \"typescript\": \"^5.9.2\"\n },\n \"overrides\": {\n \"@aws-sdk/client-bedrock-runtime\": \"3.797.0\",\n \"@smithy/smithy-client\": \"2.5.1\"\n }\n}\n", "import pkg from '../../package.json'\n\nexport const MACRO = {\n VERSION: pkg.version,\n README_URL: 'https://github.com/shareAI-lab/kode#readme',\n PACKAGE_URL: '@shareai-lab/kode',\n ISSUES_EXPLAINER:\n 'report the issue at https://github.com/shareAI-lab/kode/issues',\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,138 @@
|
|
|
1
|
+
import { createRequire as __kodeCreateRequire } from "node:module";
|
|
2
|
+
const require = __kodeCreateRequire(import.meta.url);
|
|
3
|
+
import {
|
|
4
|
+
getSessionProjectDir
|
|
5
|
+
} from "./chunk-3TXNP6HH.js";
|
|
6
|
+
import {
|
|
7
|
+
isUuid
|
|
8
|
+
} from "./chunk-KAA5BGMQ.js";
|
|
9
|
+
|
|
10
|
+
// src/utils/protocol/kodeAgentSessionLoad.ts
|
|
11
|
+
import { existsSync, readdirSync, readFileSync, statSync } from "fs";
|
|
12
|
+
import { basename, join } from "path";
|
|
13
|
+
function safeParseJson(line) {
|
|
14
|
+
try {
|
|
15
|
+
return JSON.parse(line);
|
|
16
|
+
} catch {
|
|
17
|
+
return null;
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
function isUserEntry(entry) {
|
|
21
|
+
return typeof entry?.type === "string" && entry.type === "user";
|
|
22
|
+
}
|
|
23
|
+
function isAssistantEntry(entry) {
|
|
24
|
+
return typeof entry?.type === "string" && entry.type === "assistant";
|
|
25
|
+
}
|
|
26
|
+
function isSummaryEntry(entry) {
|
|
27
|
+
return typeof entry?.type === "string" && entry.type === "summary";
|
|
28
|
+
}
|
|
29
|
+
function isCustomTitleEntry(entry) {
|
|
30
|
+
return typeof entry?.type === "string" && entry.type === "custom-title";
|
|
31
|
+
}
|
|
32
|
+
function isTagEntry(entry) {
|
|
33
|
+
return typeof entry?.type === "string" && entry.type === "tag";
|
|
34
|
+
}
|
|
35
|
+
function isFileHistorySnapshotEntry(entry) {
|
|
36
|
+
return typeof entry?.type === "string" && entry.type === "file-history-snapshot";
|
|
37
|
+
}
|
|
38
|
+
function normalizeLoadedUser(entry) {
|
|
39
|
+
if (!entry.uuid || !entry.message) return null;
|
|
40
|
+
return {
|
|
41
|
+
type: "user",
|
|
42
|
+
uuid: entry.uuid,
|
|
43
|
+
message: entry.message
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
function normalizeLoadedAssistant(entry) {
|
|
47
|
+
if (!entry.uuid || !entry.message) return null;
|
|
48
|
+
return {
|
|
49
|
+
type: "assistant",
|
|
50
|
+
uuid: entry.uuid,
|
|
51
|
+
costUSD: 0,
|
|
52
|
+
durationMs: 0,
|
|
53
|
+
message: entry.message,
|
|
54
|
+
...entry.isApiErrorMessage ? { isApiErrorMessage: true } : {},
|
|
55
|
+
...typeof entry.requestId === "string" ? { requestId: entry.requestId } : {}
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
function loadKodeAgentSessionLogData(args) {
|
|
59
|
+
const { cwd, sessionId } = args;
|
|
60
|
+
const projectDir = getSessionProjectDir(cwd);
|
|
61
|
+
const filePath = join(projectDir, `${sessionId}.jsonl`);
|
|
62
|
+
if (!existsSync(filePath)) {
|
|
63
|
+
throw new Error(`No conversation found with session ID: ${sessionId}`);
|
|
64
|
+
}
|
|
65
|
+
const lines = readFileSync(filePath, "utf8").split("\n");
|
|
66
|
+
const messages = [];
|
|
67
|
+
const summaries = /* @__PURE__ */ new Map();
|
|
68
|
+
const customTitles = /* @__PURE__ */ new Map();
|
|
69
|
+
const tags = /* @__PURE__ */ new Map();
|
|
70
|
+
const fileHistorySnapshots = /* @__PURE__ */ new Map();
|
|
71
|
+
for (const line of lines) {
|
|
72
|
+
const raw = safeParseJson(line.trim());
|
|
73
|
+
if (!raw || typeof raw !== "object") continue;
|
|
74
|
+
const entry = raw;
|
|
75
|
+
if (isUserEntry(entry)) {
|
|
76
|
+
if (entry.sessionId && entry.sessionId !== sessionId) continue;
|
|
77
|
+
const msg = normalizeLoadedUser(entry);
|
|
78
|
+
if (msg) messages.push(msg);
|
|
79
|
+
continue;
|
|
80
|
+
}
|
|
81
|
+
if (isAssistantEntry(entry)) {
|
|
82
|
+
if (entry.sessionId && entry.sessionId !== sessionId) continue;
|
|
83
|
+
const msg = normalizeLoadedAssistant(entry);
|
|
84
|
+
if (msg) messages.push(msg);
|
|
85
|
+
continue;
|
|
86
|
+
}
|
|
87
|
+
if (isSummaryEntry(entry)) {
|
|
88
|
+
const leafUuid = typeof entry.leafUuid === "string" ? entry.leafUuid : "";
|
|
89
|
+
const summary = typeof entry.summary === "string" ? entry.summary : "";
|
|
90
|
+
if (leafUuid && summary) summaries.set(leafUuid, summary);
|
|
91
|
+
continue;
|
|
92
|
+
}
|
|
93
|
+
if (isCustomTitleEntry(entry)) {
|
|
94
|
+
const id = typeof entry.sessionId === "string" ? entry.sessionId : "";
|
|
95
|
+
const title = typeof entry.customTitle === "string" ? entry.customTitle : "";
|
|
96
|
+
if (id && title) customTitles.set(id, title);
|
|
97
|
+
continue;
|
|
98
|
+
}
|
|
99
|
+
if (isTagEntry(entry)) {
|
|
100
|
+
const id = typeof entry.sessionId === "string" ? entry.sessionId : "";
|
|
101
|
+
const tag = typeof entry.tag === "string" ? entry.tag : "";
|
|
102
|
+
if (id && tag) tags.set(id, tag);
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
if (isFileHistorySnapshotEntry(entry)) {
|
|
106
|
+
const messageId = typeof entry.messageId === "string" ? entry.messageId : "";
|
|
107
|
+
if (messageId) fileHistorySnapshots.set(messageId, entry);
|
|
108
|
+
continue;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
return { messages, summaries, customTitles, tags, fileHistorySnapshots };
|
|
112
|
+
}
|
|
113
|
+
function loadKodeAgentSessionMessages(args) {
|
|
114
|
+
return loadKodeAgentSessionLogData(args).messages;
|
|
115
|
+
}
|
|
116
|
+
function findMostRecentKodeAgentSessionId(cwd) {
|
|
117
|
+
const projectDir = getSessionProjectDir(cwd);
|
|
118
|
+
if (!existsSync(projectDir)) return null;
|
|
119
|
+
const candidates = readdirSync(projectDir).filter((name) => name.endsWith(".jsonl")).filter((name) => !name.startsWith("agent-")).map((name) => ({
|
|
120
|
+
sessionId: basename(name, ".jsonl"),
|
|
121
|
+
path: join(projectDir, name)
|
|
122
|
+
})).filter((c) => isUuid(c.sessionId));
|
|
123
|
+
if (candidates.length === 0) return null;
|
|
124
|
+
candidates.sort((a, b) => {
|
|
125
|
+
try {
|
|
126
|
+
return statSync(b.path).mtimeMs - statSync(a.path).mtimeMs;
|
|
127
|
+
} catch {
|
|
128
|
+
return 0;
|
|
129
|
+
}
|
|
130
|
+
});
|
|
131
|
+
return candidates[0]?.sessionId ?? null;
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
export {
|
|
135
|
+
loadKodeAgentSessionLogData,
|
|
136
|
+
loadKodeAgentSessionMessages,
|
|
137
|
+
findMostRecentKodeAgentSessionId
|
|
138
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/utils/protocol/kodeAgentSessionLoad.ts"],
|
|
4
|
+
"sourcesContent": ["import { existsSync, readdirSync, readFileSync, statSync } from 'fs'\nimport { basename, join } from 'path'\nimport type { Message } from '@query'\nimport type {\n Message as APIMessage,\n MessageParam,\n} from '@anthropic-ai/sdk/resources/index.mjs'\nimport { getSessionProjectDir } from './kodeAgentSessionLog'\nimport { isUuid } from '@utils/text/uuid'\n\ntype JsonlUserEntry = {\n type: 'user'\n sessionId?: string\n uuid?: string\n message?: MessageParam\n isApiErrorMessage?: boolean\n toolUseResult?: unknown\n}\n\ntype JsonlAssistantEntry = {\n type: 'assistant'\n sessionId?: string\n uuid?: string\n message?: APIMessage\n isApiErrorMessage?: boolean\n requestId?: string\n}\n\ntype JsonlSummaryEntry = {\n type: 'summary'\n summary?: string\n leafUuid?: string\n}\n\ntype JsonlCustomTitleEntry = {\n type: 'custom-title'\n sessionId?: string\n customTitle?: string\n}\n\ntype JsonlTagEntry = {\n type: 'tag'\n sessionId?: string\n tag?: string\n}\n\ntype JsonlFileHistorySnapshotEntry = {\n type: 'file-history-snapshot'\n messageId?: string\n snapshot?: unknown\n isSnapshotUpdate?: boolean\n}\n\ntype JsonlEntry =\n | JsonlUserEntry\n | JsonlAssistantEntry\n | JsonlSummaryEntry\n | JsonlCustomTitleEntry\n | JsonlTagEntry\n | JsonlFileHistorySnapshotEntry\n | Record<string, unknown>\n\nfunction safeParseJson(line: string): unknown | null {\n try {\n return JSON.parse(line)\n } catch {\n return null\n }\n}\n\nfunction isUserEntry(entry: JsonlEntry): entry is JsonlUserEntry {\n return (\n typeof (entry as any)?.type === 'string' && (entry as any).type === 'user'\n )\n}\n\nfunction isAssistantEntry(entry: JsonlEntry): entry is JsonlAssistantEntry {\n return (\n typeof (entry as any)?.type === 'string' &&\n (entry as any).type === 'assistant'\n )\n}\n\nfunction isSummaryEntry(entry: JsonlEntry): entry is JsonlSummaryEntry {\n return (\n typeof (entry as any)?.type === 'string' &&\n (entry as any).type === 'summary'\n )\n}\n\nfunction isCustomTitleEntry(entry: JsonlEntry): entry is JsonlCustomTitleEntry {\n return (\n typeof (entry as any)?.type === 'string' &&\n (entry as any).type === 'custom-title'\n )\n}\n\nfunction isTagEntry(entry: JsonlEntry): entry is JsonlTagEntry {\n return (\n typeof (entry as any)?.type === 'string' && (entry as any).type === 'tag'\n )\n}\n\nfunction isFileHistorySnapshotEntry(\n entry: JsonlEntry,\n): entry is JsonlFileHistorySnapshotEntry {\n return (\n typeof (entry as any)?.type === 'string' &&\n (entry as any).type === 'file-history-snapshot'\n )\n}\n\nfunction normalizeLoadedUser(entry: JsonlUserEntry): Message | null {\n if (!entry.uuid || !entry.message) return null\n return {\n type: 'user',\n uuid: entry.uuid as any,\n message: entry.message as any,\n }\n}\n\nfunction normalizeLoadedAssistant(entry: JsonlAssistantEntry): Message | null {\n if (!entry.uuid || !entry.message) return null\n return {\n type: 'assistant',\n uuid: entry.uuid as any,\n costUSD: 0,\n durationMs: 0,\n message: entry.message as any,\n ...(entry.isApiErrorMessage ? { isApiErrorMessage: true } : {}),\n ...(typeof entry.requestId === 'string'\n ? { requestId: entry.requestId }\n : {}),\n } as any\n}\n\nexport type KodeAgentSessionLogData = {\n messages: Message[]\n summaries: Map<string, string>\n customTitles: Map<string, string>\n tags: Map<string, string>\n fileHistorySnapshots: Map<string, JsonlFileHistorySnapshotEntry>\n}\n\nexport function loadKodeAgentSessionLogData(args: {\n cwd: string\n sessionId: string\n}): KodeAgentSessionLogData {\n const { cwd, sessionId } = args\n const projectDir = getSessionProjectDir(cwd)\n const filePath = join(projectDir, `${sessionId}.jsonl`)\n if (!existsSync(filePath)) {\n throw new Error(`No conversation found with session ID: ${sessionId}`)\n }\n\n const lines = readFileSync(filePath, 'utf8').split('\\n')\n const messages: Message[] = []\n const summaries = new Map<string, string>()\n const customTitles = new Map<string, string>()\n const tags = new Map<string, string>()\n const fileHistorySnapshots = new Map<string, JsonlFileHistorySnapshotEntry>()\n\n for (const line of lines) {\n const raw = safeParseJson(line.trim())\n if (!raw || typeof raw !== 'object') continue\n const entry = raw as JsonlEntry\n\n if (isUserEntry(entry)) {\n if (entry.sessionId && entry.sessionId !== sessionId) continue\n const msg = normalizeLoadedUser(entry)\n if (msg) messages.push(msg)\n continue\n }\n\n if (isAssistantEntry(entry)) {\n if (entry.sessionId && entry.sessionId !== sessionId) continue\n const msg = normalizeLoadedAssistant(entry)\n if (msg) messages.push(msg)\n continue\n }\n\n if (isSummaryEntry(entry)) {\n const leafUuid = typeof entry.leafUuid === 'string' ? entry.leafUuid : ''\n const summary = typeof entry.summary === 'string' ? entry.summary : ''\n if (leafUuid && summary) summaries.set(leafUuid, summary)\n continue\n }\n\n if (isCustomTitleEntry(entry)) {\n const id = typeof entry.sessionId === 'string' ? entry.sessionId : ''\n const title =\n typeof entry.customTitle === 'string' ? entry.customTitle : ''\n if (id && title) customTitles.set(id, title)\n continue\n }\n\n if (isTagEntry(entry)) {\n const id = typeof entry.sessionId === 'string' ? entry.sessionId : ''\n const tag = typeof entry.tag === 'string' ? entry.tag : ''\n if (id && tag) tags.set(id, tag)\n continue\n }\n\n if (isFileHistorySnapshotEntry(entry)) {\n const messageId =\n typeof entry.messageId === 'string' ? entry.messageId : ''\n if (messageId) fileHistorySnapshots.set(messageId, entry)\n continue\n }\n }\n\n return { messages, summaries, customTitles, tags, fileHistorySnapshots }\n}\n\nexport function loadKodeAgentSessionMessages(args: {\n cwd: string\n sessionId: string\n}): Message[] {\n return loadKodeAgentSessionLogData(args).messages\n}\n\nexport function findMostRecentKodeAgentSessionId(cwd: string): string | null {\n const projectDir = getSessionProjectDir(cwd)\n if (!existsSync(projectDir)) return null\n\n const candidates = readdirSync(projectDir)\n .filter(name => name.endsWith('.jsonl'))\n .filter(name => !name.startsWith('agent-'))\n .map(name => ({\n sessionId: basename(name, '.jsonl'),\n path: join(projectDir, name),\n }))\n .filter(c => isUuid(c.sessionId))\n\n if (candidates.length === 0) return null\n\n candidates.sort((a, b) => {\n try {\n return statSync(b.path).mtimeMs - statSync(a.path).mtimeMs\n } catch {\n return 0\n }\n })\n\n return candidates[0]?.sessionId ?? null\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { createRequire as __kodeCreateRequire } from "node:module";
|
|
2
|
+
const require = __kodeCreateRequire(import.meta.url);
|
|
3
|
+
import {
|
|
4
|
+
setRequestStatus
|
|
5
|
+
} from "./chunk-3RUXVV4S.js";
|
|
6
|
+
|
|
7
|
+
// src/services/ai/adapters/responsesStreaming.ts
|
|
8
|
+
async function processResponsesStream(stream, startTime, fallbackResponseId) {
|
|
9
|
+
const contentBlocks = [];
|
|
10
|
+
const usage = {
|
|
11
|
+
prompt_tokens: 0,
|
|
12
|
+
completion_tokens: 0
|
|
13
|
+
};
|
|
14
|
+
let responseId = fallbackResponseId;
|
|
15
|
+
const pendingToolCalls = [];
|
|
16
|
+
let hasMarkedStreaming = false;
|
|
17
|
+
for await (const event of stream) {
|
|
18
|
+
if (event.type === "message_start") {
|
|
19
|
+
responseId = event.responseId || responseId;
|
|
20
|
+
continue;
|
|
21
|
+
}
|
|
22
|
+
if (event.type === "text_delta") {
|
|
23
|
+
if (!hasMarkedStreaming) {
|
|
24
|
+
setRequestStatus({ kind: "streaming" });
|
|
25
|
+
hasMarkedStreaming = true;
|
|
26
|
+
}
|
|
27
|
+
const last = contentBlocks[contentBlocks.length - 1];
|
|
28
|
+
if (!last || last.type !== "text") {
|
|
29
|
+
contentBlocks.push({ type: "text", text: event.delta, citations: [] });
|
|
30
|
+
} else {
|
|
31
|
+
last.text += event.delta;
|
|
32
|
+
}
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
if (event.type === "tool_request") {
|
|
36
|
+
setRequestStatus({ kind: "tool", detail: event.tool?.name });
|
|
37
|
+
pendingToolCalls.push(event.tool);
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
if (event.type === "usage") {
|
|
41
|
+
usage.prompt_tokens = event.usage.input;
|
|
42
|
+
usage.completion_tokens = event.usage.output;
|
|
43
|
+
usage.promptTokens = event.usage.input;
|
|
44
|
+
usage.completionTokens = event.usage.output;
|
|
45
|
+
usage.totalTokens = event.usage.total ?? event.usage.input + event.usage.output;
|
|
46
|
+
if (event.usage.reasoning !== void 0) {
|
|
47
|
+
usage.reasoningTokens = event.usage.reasoning;
|
|
48
|
+
}
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
for (const toolCall of pendingToolCalls) {
|
|
53
|
+
let toolArgs = {};
|
|
54
|
+
try {
|
|
55
|
+
toolArgs = toolCall.input ? JSON.parse(toolCall.input) : {};
|
|
56
|
+
} catch {
|
|
57
|
+
}
|
|
58
|
+
contentBlocks.push({
|
|
59
|
+
type: "tool_use",
|
|
60
|
+
id: toolCall.id,
|
|
61
|
+
name: toolCall.name,
|
|
62
|
+
input: toolArgs
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
const assistantMessage = {
|
|
66
|
+
type: "assistant",
|
|
67
|
+
message: {
|
|
68
|
+
role: "assistant",
|
|
69
|
+
content: contentBlocks,
|
|
70
|
+
usage: {
|
|
71
|
+
input_tokens: usage.prompt_tokens ?? 0,
|
|
72
|
+
output_tokens: usage.completion_tokens ?? 0,
|
|
73
|
+
prompt_tokens: usage.prompt_tokens ?? 0,
|
|
74
|
+
completion_tokens: usage.completion_tokens ?? 0,
|
|
75
|
+
totalTokens: usage.totalTokens ?? (usage.prompt_tokens || 0) + (usage.completion_tokens || 0),
|
|
76
|
+
reasoningTokens: usage.reasoningTokens
|
|
77
|
+
}
|
|
78
|
+
},
|
|
79
|
+
costUSD: 0,
|
|
80
|
+
durationMs: Date.now() - startTime,
|
|
81
|
+
uuid: `${Date.now()}-${Math.random().toString(36).slice(2, 11)}`,
|
|
82
|
+
responseId
|
|
83
|
+
};
|
|
84
|
+
return {
|
|
85
|
+
assistantMessage,
|
|
86
|
+
rawResponse: {
|
|
87
|
+
id: responseId,
|
|
88
|
+
content: contentBlocks,
|
|
89
|
+
usage
|
|
90
|
+
}
|
|
91
|
+
};
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export {
|
|
95
|
+
processResponsesStream
|
|
96
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../src/services/ai/adapters/responsesStreaming.ts"],
|
|
4
|
+
"sourcesContent": ["import { StreamingEvent } from './base'\nimport { AssistantMessage } from '@query'\nimport { setRequestStatus } from '@utils/session/requestStatus'\n\nexport async function processResponsesStream(\n stream: AsyncGenerator<StreamingEvent>,\n startTime: number,\n fallbackResponseId: string,\n): Promise<{ assistantMessage: AssistantMessage; rawResponse: any }> {\n const contentBlocks: any[] = []\n const usage: any = {\n prompt_tokens: 0,\n completion_tokens: 0,\n }\n\n let responseId = fallbackResponseId\n const pendingToolCalls: any[] = []\n let hasMarkedStreaming = false\n\n for await (const event of stream) {\n if (event.type === 'message_start') {\n responseId = event.responseId || responseId\n continue\n }\n\n if (event.type === 'text_delta') {\n if (!hasMarkedStreaming) {\n setRequestStatus({ kind: 'streaming' })\n hasMarkedStreaming = true\n }\n const last = contentBlocks[contentBlocks.length - 1]\n if (!last || last.type !== 'text') {\n contentBlocks.push({ type: 'text', text: event.delta, citations: [] })\n } else {\n last.text += event.delta\n }\n continue\n }\n\n if (event.type === 'tool_request') {\n setRequestStatus({ kind: 'tool', detail: event.tool?.name })\n pendingToolCalls.push(event.tool)\n continue\n }\n\n if (event.type === 'usage') {\n usage.prompt_tokens = event.usage.input\n usage.completion_tokens = event.usage.output\n usage.promptTokens = event.usage.input\n usage.completionTokens = event.usage.output\n usage.totalTokens =\n event.usage.total ?? event.usage.input + event.usage.output\n if (event.usage.reasoning !== undefined) {\n usage.reasoningTokens = event.usage.reasoning\n }\n continue\n }\n }\n\n for (const toolCall of pendingToolCalls) {\n let toolArgs = {}\n try {\n toolArgs = toolCall.input ? JSON.parse(toolCall.input) : {}\n } catch {}\n\n contentBlocks.push({\n type: 'tool_use',\n id: toolCall.id,\n name: toolCall.name,\n input: toolArgs,\n })\n }\n\n const assistantMessage: AssistantMessage = {\n type: 'assistant',\n message: {\n role: 'assistant',\n content: contentBlocks,\n usage: {\n input_tokens: usage.prompt_tokens ?? 0,\n output_tokens: usage.completion_tokens ?? 0,\n prompt_tokens: usage.prompt_tokens ?? 0,\n completion_tokens: usage.completion_tokens ?? 0,\n totalTokens:\n usage.totalTokens ??\n (usage.prompt_tokens || 0) + (usage.completion_tokens || 0),\n reasoningTokens: usage.reasoningTokens,\n },\n },\n costUSD: 0,\n durationMs: Date.now() - startTime,\n uuid: `${Date.now()}-${Math.random().toString(36).slice(2, 11)}` as any,\n responseId,\n }\n\n return {\n assistantMessage,\n rawResponse: {\n id: responseId,\n content: contentBlocks,\n usage,\n },\n }\n}\n"],
|
|
5
|
+
"mappings": ";;;;;;;AAIA,eAAsB,uBACpB,QACA,WACA,oBACmE;AACnE,QAAM,gBAAuB,CAAC;AAC9B,QAAM,QAAa;AAAA,IACjB,eAAe;AAAA,IACf,mBAAmB;AAAA,EACrB;AAEA,MAAI,aAAa;AACjB,QAAM,mBAA0B,CAAC;AACjC,MAAI,qBAAqB;AAEzB,mBAAiB,SAAS,QAAQ;AAChC,QAAI,MAAM,SAAS,iBAAiB;AAClC,mBAAa,MAAM,cAAc;AACjC;AAAA,IACF;AAEA,QAAI,MAAM,SAAS,cAAc;AAC/B,UAAI,CAAC,oBAAoB;AACvB,yBAAiB,EAAE,MAAM,YAAY,CAAC;AACtC,6BAAqB;AAAA,MACvB;AACA,YAAM,OAAO,cAAc,cAAc,SAAS,CAAC;AACnD,UAAI,CAAC,QAAQ,KAAK,SAAS,QAAQ;AACjC,sBAAc,KAAK,EAAE,MAAM,QAAQ,MAAM,MAAM,OAAO,WAAW,CAAC,EAAE,CAAC;AAAA,MACvE,OAAO;AACL,aAAK,QAAQ,MAAM;AAAA,MACrB;AACA;AAAA,IACF;AAEA,QAAI,MAAM,SAAS,gBAAgB;AACjC,uBAAiB,EAAE,MAAM,QAAQ,QAAQ,MAAM,MAAM,KAAK,CAAC;AAC3D,uBAAiB,KAAK,MAAM,IAAI;AAChC;AAAA,IACF;AAEA,QAAI,MAAM,SAAS,SAAS;AAC1B,YAAM,gBAAgB,MAAM,MAAM;AAClC,YAAM,oBAAoB,MAAM,MAAM;AACtC,YAAM,eAAe,MAAM,MAAM;AACjC,YAAM,mBAAmB,MAAM,MAAM;AACrC,YAAM,cACJ,MAAM,MAAM,SAAS,MAAM,MAAM,QAAQ,MAAM,MAAM;AACvD,UAAI,MAAM,MAAM,cAAc,QAAW;AACvC,cAAM,kBAAkB,MAAM,MAAM;AAAA,MACtC;AACA;AAAA,IACF;AAAA,EACF;AAEA,aAAW,YAAY,kBAAkB;AACvC,QAAI,WAAW,CAAC;AAChB,QAAI;AACF,iBAAW,SAAS,QAAQ,KAAK,MAAM,SAAS,KAAK,IAAI,CAAC;AAAA,IAC5D,QAAQ;AAAA,IAAC;AAET,kBAAc,KAAK;AAAA,MACjB,MAAM;AAAA,MACN,IAAI,SAAS;AAAA,MACb,MAAM,SAAS;AAAA,MACf,OAAO;AAAA,IACT,CAAC;AAAA,EACH;AAEA,QAAM,mBAAqC;AAAA,IACzC,MAAM;AAAA,IACN,SAAS;AAAA,MACP,MAAM;AAAA,MACN,SAAS;AAAA,MACT,OAAO;AAAA,QACL,cAAc,MAAM,iBAAiB;AAAA,QACrC,eAAe,MAAM,qBAAqB;AAAA,QAC1C,eAAe,MAAM,iBAAiB;AAAA,QACtC,mBAAmB,MAAM,qBAAqB;AAAA,QAC9C,aACE,MAAM,gBACL,MAAM,iBAAiB,MAAM,MAAM,qBAAqB;AAAA,QAC3D,iBAAiB,MAAM;AAAA,MACzB;AAAA,IACF;AAAA,IACA,SAAS;AAAA,IACT,YAAY,KAAK,IAAI,IAAI;AAAA,IACzB,MAAM,GAAG,KAAK,IAAI,CAAC,IAAI,KAAK,OAAO,EAAE,SAAS,EAAE,EAAE,MAAM,GAAG,EAAE,CAAC;AAAA,IAC9D;AAAA,EACF;AAEA,SAAO;AAAA,IACL;AAAA,IACA,aAAa;AAAA,MACX,IAAI;AAAA,MACJ,SAAS;AAAA,MACT;AAAA,IACF;AAAA,EACF;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|