@shareai-lab/kode 1.1.12 → 1.1.13
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/cli.js +44 -23
- package/dist/ProjectOnboarding.js +99 -0
- package/dist/ProjectOnboarding.js.map +7 -0
- package/dist/Tool.js +1 -0
- package/dist/Tool.js.map +7 -0
- package/dist/commands/agents.js +2087 -0
- package/dist/commands/agents.js.map +7 -0
- package/dist/commands/approvedTools.js +36 -0
- package/dist/commands/approvedTools.js.map +7 -0
- package/dist/commands/bug.js +21 -0
- package/dist/commands/bug.js.map +7 -0
- package/dist/commands/clear.js +37 -0
- package/dist/commands/clear.js.map +7 -0
- package/dist/commands/compact.js +104 -0
- package/dist/commands/compact.js.map +7 -0
- package/dist/commands/config.js +20 -0
- package/dist/commands/config.js.map +7 -0
- package/dist/commands/cost.js +19 -0
- package/dist/commands/cost.js.map +7 -0
- package/dist/commands/ctx_viz.js +152 -0
- package/dist/commands/ctx_viz.js.map +7 -0
- package/dist/commands/doctor.js +25 -0
- package/dist/commands/doctor.js.map +7 -0
- package/dist/commands/help.js +20 -0
- package/dist/commands/help.js.map +7 -0
- package/dist/commands/init.js +38 -0
- package/dist/commands/init.js.map +7 -0
- package/dist/commands/listen.js +37 -0
- package/dist/commands/listen.js.map +7 -0
- package/dist/commands/login.js +37 -0
- package/dist/commands/login.js.map +7 -0
- package/dist/commands/logout.js +33 -0
- package/dist/commands/logout.js.map +7 -0
- package/dist/commands/mcp.js +34 -0
- package/dist/commands/mcp.js.map +7 -0
- package/dist/commands/model.js +41 -0
- package/dist/commands/model.js.map +7 -0
- package/dist/commands/modelstatus.js +21 -0
- package/dist/commands/modelstatus.js.map +7 -0
- package/dist/commands/onboarding.js +36 -0
- package/dist/commands/onboarding.js.map +7 -0
- package/dist/commands/pr_comments.js +61 -0
- package/dist/commands/pr_comments.js.map +7 -0
- package/dist/commands/refreshCommands.js +37 -0
- package/dist/commands/refreshCommands.js.map +7 -0
- package/dist/commands/release-notes.js +30 -0
- package/dist/commands/release-notes.js.map +7 -0
- package/dist/commands/resume.js +35 -0
- package/dist/commands/resume.js.map +7 -0
- package/dist/commands/review.js +51 -0
- package/dist/commands/review.js.map +7 -0
- package/dist/commands/terminalSetup.js +163 -0
- package/dist/commands/terminalSetup.js.map +7 -0
- package/dist/commands.js +84 -0
- package/dist/commands.js.map +7 -0
- package/dist/components/ApproveApiKey.js +74 -0
- package/dist/components/ApproveApiKey.js.map +7 -0
- package/dist/components/AsciiLogo.js +12 -0
- package/dist/components/AsciiLogo.js.map +7 -0
- package/dist/components/AutoUpdater.js +74 -0
- package/dist/components/AutoUpdater.js.map +7 -0
- package/dist/components/Bug.js +147 -0
- package/dist/components/Bug.js.map +7 -0
- package/dist/components/Config.js +166 -0
- package/dist/components/Config.js.map +7 -0
- package/dist/components/ConsoleOAuthFlow.js +188 -0
- package/dist/components/ConsoleOAuthFlow.js.map +7 -0
- package/dist/components/Cost.js +13 -0
- package/dist/components/Cost.js.map +7 -0
- package/dist/components/CostThresholdDialog.js +38 -0
- package/dist/components/CostThresholdDialog.js.map +7 -0
- package/dist/components/CustomSelect/option-map.js +32 -0
- package/dist/components/CustomSelect/option-map.js.map +7 -0
- package/dist/components/CustomSelect/select-option.js +34 -0
- package/dist/components/CustomSelect/select-option.js.map +7 -0
- package/dist/components/CustomSelect/select.js +64 -0
- package/dist/components/CustomSelect/select.js.map +7 -0
- package/dist/components/CustomSelect/theme.js +1 -0
- package/dist/components/CustomSelect/theme.js.map +7 -0
- package/dist/components/CustomSelect/use-select-state.js +220 -0
- package/dist/components/CustomSelect/use-select-state.js.map +7 -0
- package/dist/components/CustomSelect/use-select.js +21 -0
- package/dist/components/CustomSelect/use-select.js.map +7 -0
- package/dist/components/FallbackToolUseRejectedMessage.js +11 -0
- package/dist/components/FallbackToolUseRejectedMessage.js.map +7 -0
- package/dist/components/FileEditToolUpdatedMessage.js +31 -0
- package/dist/components/FileEditToolUpdatedMessage.js.map +7 -0
- package/dist/components/Help.js +41 -0
- package/dist/components/Help.js.map +7 -0
- package/dist/components/HighlightedCode.js +30 -0
- package/dist/components/HighlightedCode.js.map +7 -0
- package/dist/components/InvalidConfigDialog.js +83 -0
- package/dist/components/InvalidConfigDialog.js.map +7 -0
- package/dist/components/Link.js +18 -0
- package/dist/components/Link.js.map +7 -0
- package/dist/components/LogSelector.js +50 -0
- package/dist/components/LogSelector.js.map +7 -0
- package/dist/components/Logo.js +89 -0
- package/dist/components/Logo.js.map +7 -0
- package/dist/components/MCPServerApprovalDialog.js +79 -0
- package/dist/components/MCPServerApprovalDialog.js.map +7 -0
- package/dist/components/MCPServerDialogCopy.js +11 -0
- package/dist/components/MCPServerDialogCopy.js.map +7 -0
- package/dist/components/MCPServerMultiselectDialog.js +80 -0
- package/dist/components/MCPServerMultiselectDialog.js.map +7 -0
- package/dist/components/Message.js +146 -0
- package/dist/components/Message.js.map +7 -0
- package/dist/components/MessageResponse.js +9 -0
- package/dist/components/MessageResponse.js.map +7 -0
- package/dist/components/MessageSelector.js +133 -0
- package/dist/components/MessageSelector.js.map +7 -0
- package/dist/components/ModeIndicator.js +38 -0
- package/dist/components/ModeIndicator.js.map +7 -0
- package/dist/components/ModelConfig.js +208 -0
- package/dist/components/ModelConfig.js.map +7 -0
- package/dist/components/ModelListManager.js +140 -0
- package/dist/components/ModelListManager.js.map +7 -0
- package/dist/components/ModelSelector.js +1985 -0
- package/dist/components/ModelSelector.js.map +7 -0
- package/dist/components/ModelStatusDisplay.js +87 -0
- package/dist/components/ModelStatusDisplay.js.map +7 -0
- package/dist/components/Onboarding.js +153 -0
- package/dist/components/Onboarding.js.map +7 -0
- package/dist/components/PressEnterToContinue.js +10 -0
- package/dist/components/PressEnterToContinue.js.map +7 -0
- package/dist/components/PromptInput.js +501 -0
- package/dist/components/PromptInput.js.map +7 -0
- package/dist/components/SentryErrorBoundary.js +27 -0
- package/dist/components/SentryErrorBoundary.js.map +7 -0
- package/dist/components/Spinner.js +101 -0
- package/dist/components/Spinner.js.map +7 -0
- package/dist/components/StickerRequestForm.js +7 -0
- package/dist/components/StickerRequestForm.js.map +7 -0
- package/dist/components/StructuredDiff.js +148 -0
- package/dist/components/StructuredDiff.js.map +7 -0
- package/dist/components/TextInput.js +100 -0
- package/dist/components/TextInput.js.map +7 -0
- package/dist/components/TodoItem.js +35 -0
- package/dist/components/TodoItem.js.map +7 -0
- package/dist/components/TokenWarning.js +19 -0
- package/dist/components/TokenWarning.js.map +7 -0
- package/dist/components/ToolUseLoader.js +24 -0
- package/dist/components/ToolUseLoader.js.map +7 -0
- package/dist/components/TrustDialog.js +76 -0
- package/dist/components/TrustDialog.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedback.js +50 -0
- package/dist/components/binary-feedback/BinaryFeedback.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js +94 -0
- package/dist/components/binary-feedback/BinaryFeedbackOption.js.map +7 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js +139 -0
- package/dist/components/binary-feedback/BinaryFeedbackView.js.map +7 -0
- package/dist/components/binary-feedback/utils.js +161 -0
- package/dist/components/binary-feedback/utils.js.map +7 -0
- package/dist/components/messages/AssistantBashOutputMessage.js +23 -0
- package/dist/components/messages/AssistantBashOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js +36 -0
- package/dist/components/messages/AssistantLocalCommandOutputMessage.js.map +7 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js +12 -0
- package/dist/components/messages/AssistantRedactedThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantTextMessage.js +78 -0
- package/dist/components/messages/AssistantTextMessage.js.map +7 -0
- package/dist/components/messages/AssistantThinkingMessage.js +27 -0
- package/dist/components/messages/AssistantThinkingMessage.js.map +7 -0
- package/dist/components/messages/AssistantToolUseMessage.js +91 -0
- package/dist/components/messages/AssistantToolUseMessage.js.map +7 -0
- package/dist/components/messages/TaskProgressMessage.js +11 -0
- package/dist/components/messages/TaskProgressMessage.js.map +7 -0
- package/dist/components/messages/TaskToolMessage.js +39 -0
- package/dist/components/messages/TaskToolMessage.js.map +7 -0
- package/dist/components/messages/UserBashInputMessage.js +18 -0
- package/dist/components/messages/UserBashInputMessage.js.map +7 -0
- package/dist/components/messages/UserCommandMessage.js +20 -0
- package/dist/components/messages/UserCommandMessage.js.map +7 -0
- package/dist/components/messages/UserKodingInputMessage.js +18 -0
- package/dist/components/messages/UserKodingInputMessage.js.map +7 -0
- package/dist/components/messages/UserPromptMessage.js +20 -0
- package/dist/components/messages/UserPromptMessage.js.map +7 -0
- package/dist/components/messages/UserTextMessage.js +25 -0
- package/dist/components/messages/UserTextMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js +10 -0
- package/dist/components/messages/UserToolResultMessage/UserToolCanceledMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js +15 -0
- package/dist/components/messages/UserToolResultMessage/UserToolErrorMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js +25 -0
- package/dist/components/messages/UserToolResultMessage/UserToolRejectMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js +47 -0
- package/dist/components/messages/UserToolResultMessage/UserToolResultMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js +23 -0
- package/dist/components/messages/UserToolResultMessage/UserToolSuccessMessage.js.map +7 -0
- package/dist/components/messages/UserToolResultMessage/utils.js +42 -0
- package/dist/components/messages/UserToolResultMessage/utils.js.map +7 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js +112 -0
- package/dist/components/permissions/BashPermissionRequest/BashPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FallbackPermissionRequest.js +131 -0
- package/dist/components/permissions/FallbackPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js +159 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditPermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js +58 -0
- package/dist/components/permissions/FileEditPermissionRequest/FileEditToolDiff.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js +153 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWritePermissionRequest.js.map +7 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js +70 -0
- package/dist/components/permissions/FileWritePermissionRequest/FileWriteToolDiff.js.map +7 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js +212 -0
- package/dist/components/permissions/FilesystemPermissionRequest/FilesystemPermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequest.js +70 -0
- package/dist/components/permissions/PermissionRequest.js.map +7 -0
- package/dist/components/permissions/PermissionRequestTitle.js +52 -0
- package/dist/components/permissions/PermissionRequestTitle.js.map +7 -0
- package/dist/components/permissions/hooks.js +28 -0
- package/dist/components/permissions/hooks.js.map +7 -0
- package/dist/components/permissions/toolUseOptions.js +46 -0
- package/dist/components/permissions/toolUseOptions.js.map +7 -0
- package/dist/components/permissions/utils.js +21 -0
- package/dist/components/permissions/utils.js.map +7 -0
- package/dist/constants/betas.js +11 -0
- package/dist/constants/betas.js.map +7 -0
- package/dist/constants/claude-asterisk-ascii-art.js +242 -0
- package/dist/constants/claude-asterisk-ascii-art.js.map +7 -0
- package/dist/constants/figures.js +6 -0
- package/dist/constants/figures.js.map +7 -0
- package/dist/constants/keys.js +7 -0
- package/dist/constants/keys.js.map +7 -0
- package/dist/constants/macros.js +13 -0
- package/dist/constants/macros.js.map +7 -0
- package/dist/constants/modelCapabilities.js +154 -0
- package/dist/constants/modelCapabilities.js.map +7 -0
- package/dist/constants/models.js +1029 -0
- package/dist/constants/models.js.map +7 -0
- package/dist/constants/oauth.js +18 -0
- package/dist/constants/oauth.js.map +7 -0
- package/dist/constants/product.js +26 -0
- package/dist/constants/product.js.map +7 -0
- package/dist/constants/prompts.js +168 -0
- package/dist/constants/prompts.js.map +7 -0
- package/dist/constants/releaseNotes.js +9 -0
- package/dist/constants/releaseNotes.js.map +7 -0
- package/dist/context/PermissionContext.js +111 -0
- package/dist/context/PermissionContext.js.map +7 -0
- package/dist/context.js +259 -0
- package/dist/context.js.map +7 -0
- package/dist/cost-tracker.js +76 -0
- package/dist/cost-tracker.js.map +7 -0
- package/dist/entrypoints/cli.js +1101 -0
- package/dist/entrypoints/cli.js.map +7 -0
- package/dist/entrypoints/mcp.js +150 -0
- package/dist/entrypoints/mcp.js.map +7 -0
- package/dist/history.js +25 -0
- package/dist/history.js.map +7 -0
- package/dist/hooks/useApiKeyVerification.js +12 -0
- package/dist/hooks/useApiKeyVerification.js.map +7 -0
- package/dist/hooks/useArrowKeyHistory.js +50 -0
- package/dist/hooks/useArrowKeyHistory.js.map +7 -0
- package/dist/hooks/useCanUseTool.js +112 -0
- package/dist/hooks/useCanUseTool.js.map +7 -0
- package/dist/hooks/useCancelRequest.js +30 -0
- package/dist/hooks/useCancelRequest.js.map +7 -0
- package/dist/hooks/useDoublePress.js +31 -0
- package/dist/hooks/useDoublePress.js.map +7 -0
- package/dist/hooks/useExitOnCtrlCD.js +26 -0
- package/dist/hooks/useExitOnCtrlCD.js.map +7 -0
- package/dist/hooks/useInterval.js +18 -0
- package/dist/hooks/useInterval.js.map +7 -0
- package/dist/hooks/useLogMessages.js +14 -0
- package/dist/hooks/useLogMessages.js.map +7 -0
- package/dist/hooks/useLogStartupTime.js +15 -0
- package/dist/hooks/useLogStartupTime.js.map +7 -0
- package/dist/hooks/useNotifyAfterTimeout.js +42 -0
- package/dist/hooks/useNotifyAfterTimeout.js.map +7 -0
- package/dist/hooks/usePermissionRequestLogging.js +28 -0
- package/dist/hooks/usePermissionRequestLogging.js.map +7 -0
- package/dist/hooks/useTerminalSize.js +38 -0
- package/dist/hooks/useTerminalSize.js.map +7 -0
- package/dist/hooks/useTextInput.js +250 -0
- package/dist/hooks/useTextInput.js.map +7 -0
- package/dist/hooks/useUnifiedCompletion.js +929 -0
- package/dist/hooks/useUnifiedCompletion.js.map +7 -0
- package/dist/index.js +26 -0
- package/dist/index.js.map +7 -0
- package/dist/messages.js +33 -0
- package/dist/messages.js.map +7 -0
- package/dist/package.json +1 -0
- package/dist/permissions.js +194 -0
- package/dist/permissions.js.map +7 -0
- package/dist/query.js +492 -0
- package/dist/query.js.map +7 -0
- package/dist/screens/ConfigureNpmPrefix.js +128 -0
- package/dist/screens/ConfigureNpmPrefix.js.map +7 -0
- package/dist/screens/Doctor.js +143 -0
- package/dist/screens/Doctor.js.map +7 -0
- package/dist/screens/LogList.js +55 -0
- package/dist/screens/LogList.js.map +7 -0
- package/dist/screens/REPL.js +596 -0
- package/dist/screens/REPL.js.map +7 -0
- package/dist/screens/ResumeConversation.js +56 -0
- package/dist/screens/ResumeConversation.js.map +7 -0
- package/dist/services/adapters/base.js +29 -0
- package/dist/services/adapters/base.js.map +7 -0
- package/dist/services/adapters/chatCompletions.js +69 -0
- package/dist/services/adapters/chatCompletions.js.map +7 -0
- package/dist/services/adapters/responsesAPI.js +126 -0
- package/dist/services/adapters/responsesAPI.js.map +7 -0
- package/dist/services/browserMocks.js +48 -0
- package/dist/services/browserMocks.js.map +7 -0
- package/dist/services/claude.js +1605 -0
- package/dist/services/claude.js.map +7 -0
- package/dist/services/customCommands.js +359 -0
- package/dist/services/customCommands.js.map +7 -0
- package/dist/services/fileFreshness.js +280 -0
- package/dist/services/fileFreshness.js.map +7 -0
- package/dist/services/gpt5ConnectionTest.js +248 -0
- package/dist/services/gpt5ConnectionTest.js.map +7 -0
- package/dist/services/mcpClient.js +435 -0
- package/dist/services/mcpClient.js.map +7 -0
- package/dist/services/mcpServerApproval.js +55 -0
- package/dist/services/mcpServerApproval.js.map +7 -0
- package/dist/services/mentionProcessor.js +200 -0
- package/dist/services/mentionProcessor.js.map +7 -0
- package/dist/services/modelAdapterFactory.js +47 -0
- package/dist/services/modelAdapterFactory.js.map +7 -0
- package/dist/services/notifier.js +35 -0
- package/dist/services/notifier.js.map +7 -0
- package/dist/services/oauth.js +259 -0
- package/dist/services/oauth.js.map +7 -0
- package/dist/services/openai.js +998 -0
- package/dist/services/openai.js.map +7 -0
- package/dist/services/responseStateManager.js +68 -0
- package/dist/services/responseStateManager.js.map +7 -0
- package/dist/services/sentry.js +9 -0
- package/dist/services/sentry.js.map +7 -0
- package/dist/services/statsig.js +112 -0
- package/dist/services/statsig.js.map +7 -0
- package/dist/services/statsigStorage.js +75 -0
- package/dist/services/statsigStorage.js.map +7 -0
- package/dist/services/systemReminder.js +353 -0
- package/dist/services/systemReminder.js.map +7 -0
- package/dist/services/vcr.js +133 -0
- package/dist/services/vcr.js.map +7 -0
- package/dist/test/testAdapters.js +88 -0
- package/dist/test/testAdapters.js.map +1 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js +119 -0
- package/dist/tools/ArchitectTool/ArchitectTool.js.map +7 -0
- package/dist/tools/ArchitectTool/prompt.js +18 -0
- package/dist/tools/ArchitectTool/prompt.js.map +7 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js +423 -0
- package/dist/tools/AskExpertModelTool/AskExpertModelTool.js.map +7 -0
- package/dist/tools/BashTool/BashTool.js +188 -0
- package/dist/tools/BashTool/BashTool.js.map +7 -0
- package/dist/tools/BashTool/BashToolResultMessage.js +21 -0
- package/dist/tools/BashTool/BashToolResultMessage.js.map +7 -0
- package/dist/tools/BashTool/OutputLine.js +30 -0
- package/dist/tools/BashTool/OutputLine.js.map +7 -0
- package/dist/tools/BashTool/prompt.js +179 -0
- package/dist/tools/BashTool/prompt.js.map +7 -0
- package/dist/tools/BashTool/utils.js +51 -0
- package/dist/tools/BashTool/utils.js.map +7 -0
- package/dist/tools/FileEditTool/FileEditTool.js +228 -0
- package/dist/tools/FileEditTool/FileEditTool.js.map +7 -0
- package/dist/tools/FileEditTool/prompt.js +54 -0
- package/dist/tools/FileEditTool/prompt.js.map +7 -0
- package/dist/tools/FileEditTool/utils.js +42 -0
- package/dist/tools/FileEditTool/utils.js.map +7 -0
- package/dist/tools/FileReadTool/FileReadTool.js +272 -0
- package/dist/tools/FileReadTool/FileReadTool.js.map +7 -0
- package/dist/tools/FileReadTool/prompt.js +10 -0
- package/dist/tools/FileReadTool/prompt.js.map +7 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js +204 -0
- package/dist/tools/FileWriteTool/FileWriteTool.js.map +7 -0
- package/dist/tools/FileWriteTool/prompt.js +14 -0
- package/dist/tools/FileWriteTool/prompt.js.map +7 -0
- package/dist/tools/GlobTool/GlobTool.js +88 -0
- package/dist/tools/GlobTool/GlobTool.js.map +7 -0
- package/dist/tools/GlobTool/prompt.js +12 -0
- package/dist/tools/GlobTool/prompt.js.map +7 -0
- package/dist/tools/GrepTool/GrepTool.js +107 -0
- package/dist/tools/GrepTool/GrepTool.js.map +7 -0
- package/dist/tools/GrepTool/prompt.js +15 -0
- package/dist/tools/GrepTool/prompt.js.map +7 -0
- package/dist/tools/MCPTool/MCPTool.js +90 -0
- package/dist/tools/MCPTool/MCPTool.js.map +7 -0
- package/dist/tools/MCPTool/prompt.js +7 -0
- package/dist/tools/MCPTool/prompt.js.map +7 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js +103 -0
- package/dist/tools/MemoryReadTool/MemoryReadTool.js.map +7 -0
- package/dist/tools/MemoryReadTool/prompt.js +7 -0
- package/dist/tools/MemoryReadTool/prompt.js.map +7 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js +77 -0
- package/dist/tools/MemoryWriteTool/MemoryWriteTool.js.map +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js +7 -0
- package/dist/tools/MemoryWriteTool/prompt.js.map +7 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js +293 -0
- package/dist/tools/MultiEditTool/MultiEditTool.js.map +7 -0
- package/dist/tools/MultiEditTool/prompt.js +48 -0
- package/dist/tools/MultiEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js +238 -0
- package/dist/tools/NotebookEditTool/NotebookEditTool.js.map +7 -0
- package/dist/tools/NotebookEditTool/prompt.js +7 -0
- package/dist/tools/NotebookEditTool/prompt.js.map +7 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js +212 -0
- package/dist/tools/NotebookReadTool/NotebookReadTool.js.map +7 -0
- package/dist/tools/NotebookReadTool/prompt.js +7 -0
- package/dist/tools/NotebookReadTool/prompt.js.map +7 -0
- package/dist/tools/StickerRequestTool/StickerRequestTool.js +86 -0
- package/dist/tools/StickerRequestTool/StickerRequestTool.js.map +7 -0
- package/dist/tools/StickerRequestTool/prompt.js +23 -0
- package/dist/tools/StickerRequestTool/prompt.js.map +7 -0
- package/dist/tools/TaskTool/TaskTool.js +308 -0
- package/dist/tools/TaskTool/TaskTool.js.map +7 -0
- package/dist/tools/TaskTool/constants.js +5 -0
- package/dist/tools/TaskTool/constants.js.map +7 -0
- package/dist/tools/TaskTool/prompt.js +82 -0
- package/dist/tools/TaskTool/prompt.js.map +7 -0
- package/dist/tools/ThinkTool/ThinkTool.js +48 -0
- package/dist/tools/ThinkTool/ThinkTool.js.map +7 -0
- package/dist/tools/ThinkTool/prompt.js +16 -0
- package/dist/tools/ThinkTool/prompt.js.map +7 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js +216 -0
- package/dist/tools/TodoWriteTool/TodoWriteTool.js.map +7 -0
- package/dist/tools/TodoWriteTool/prompt.js +66 -0
- package/dist/tools/TodoWriteTool/prompt.js.map +7 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js +137 -0
- package/dist/tools/URLFetcherTool/URLFetcherTool.js.map +7 -0
- package/dist/tools/URLFetcherTool/cache.js +45 -0
- package/dist/tools/URLFetcherTool/cache.js.map +7 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js +42 -0
- package/dist/tools/URLFetcherTool/htmlToMarkdown.js.map +7 -0
- package/dist/tools/URLFetcherTool/prompt.js +22 -0
- package/dist/tools/URLFetcherTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js +86 -0
- package/dist/tools/WebSearchTool/WebSearchTool.js.map +7 -0
- package/dist/tools/WebSearchTool/prompt.js +17 -0
- package/dist/tools/WebSearchTool/prompt.js.map +7 -0
- package/dist/tools/WebSearchTool/searchProviders.js +48 -0
- package/dist/tools/WebSearchTool/searchProviders.js.map +7 -0
- package/dist/tools/lsTool/lsTool.js +201 -0
- package/dist/tools/lsTool/lsTool.js.map +7 -0
- package/dist/tools/lsTool/prompt.js +5 -0
- package/dist/tools/lsTool/prompt.js.map +7 -0
- package/dist/tools.js +64 -0
- package/dist/tools.js.map +7 -0
- package/dist/types/PermissionMode.js +82 -0
- package/dist/types/PermissionMode.js.map +7 -0
- package/dist/types/RequestContext.js +47 -0
- package/dist/types/RequestContext.js.map +7 -0
- package/dist/types/common.d.js +1 -0
- package/dist/types/common.d.js.map +7 -0
- package/dist/types/conversation.js +1 -0
- package/dist/types/conversation.js.map +7 -0
- package/dist/types/logs.js +1 -0
- package/dist/types/logs.js.map +7 -0
- package/dist/types/modelCapabilities.js +1 -0
- package/dist/types/modelCapabilities.js.map +7 -0
- package/dist/types/notebook.js +1 -0
- package/dist/types/notebook.js.map +7 -0
- package/dist/utils/Cursor.js +313 -0
- package/dist/utils/Cursor.js.map +7 -0
- package/dist/utils/PersistentShell.js +382 -0
- package/dist/utils/PersistentShell.js.map +7 -0
- package/dist/utils/advancedFuzzyMatcher.js +206 -0
- package/dist/utils/advancedFuzzyMatcher.js.map +7 -0
- package/dist/utils/agentLoader.js +199 -0
- package/dist/utils/agentLoader.js.map +7 -0
- package/dist/utils/agentStorage.js +59 -0
- package/dist/utils/agentStorage.js.map +7 -0
- package/dist/utils/array.js +7 -0
- package/dist/utils/array.js.map +7 -0
- package/dist/utils/ask.js +77 -0
- package/dist/utils/ask.js.map +7 -0
- package/dist/utils/auth.js +11 -0
- package/dist/utils/auth.js.map +7 -0
- package/dist/utils/autoCompactCore.js +149 -0
- package/dist/utils/autoCompactCore.js.map +7 -0
- package/dist/utils/autoUpdater.js +362 -0
- package/dist/utils/autoUpdater.js.map +7 -0
- package/dist/utils/betas.js +21 -0
- package/dist/utils/betas.js.map +7 -0
- package/dist/utils/browser.js +15 -0
- package/dist/utils/browser.js.map +7 -0
- package/dist/utils/cleanup.js +54 -0
- package/dist/utils/cleanup.js.map +7 -0
- package/dist/utils/commands.js +207 -0
- package/dist/utils/commands.js.map +7 -0
- package/dist/utils/commonUnixCommands.js +687 -0
- package/dist/utils/commonUnixCommands.js.map +7 -0
- package/dist/utils/config.js +655 -0
- package/dist/utils/config.js.map +7 -0
- package/dist/utils/conversationRecovery.js +35 -0
- package/dist/utils/conversationRecovery.js.map +7 -0
- package/dist/utils/debugLogger.js +891 -0
- package/dist/utils/debugLogger.js.map +7 -0
- package/dist/utils/diff.js +32 -0
- package/dist/utils/diff.js.map +7 -0
- package/dist/utils/env.js +44 -0
- package/dist/utils/env.js.map +7 -0
- package/dist/utils/errors.js +23 -0
- package/dist/utils/errors.js.map +7 -0
- package/dist/utils/exampleCommands.js +80 -0
- package/dist/utils/exampleCommands.js.map +7 -0
- package/dist/utils/execFileNoThrow.js +44 -0
- package/dist/utils/execFileNoThrow.js.map +7 -0
- package/dist/utils/expertChatStorage.js +78 -0
- package/dist/utils/expertChatStorage.js.map +7 -0
- package/dist/utils/file.js +282 -0
- package/dist/utils/file.js.map +7 -0
- package/dist/utils/fileRecoveryCore.js +41 -0
- package/dist/utils/fileRecoveryCore.js.map +7 -0
- package/dist/utils/format.js +41 -0
- package/dist/utils/format.js.map +7 -0
- package/dist/utils/fuzzyMatcher.js +252 -0
- package/dist/utils/fuzzyMatcher.js.map +7 -0
- package/dist/utils/generators.js +46 -0
- package/dist/utils/generators.js.map +7 -0
- package/dist/utils/git.js +83 -0
- package/dist/utils/git.js.map +7 -0
- package/dist/utils/globalLogger.js +54 -0
- package/dist/utils/globalLogger.js.map +7 -0
- package/dist/utils/http.js +7 -0
- package/dist/utils/http.js.map +7 -0
- package/dist/utils/imagePaste.js +29 -0
- package/dist/utils/imagePaste.js.map +7 -0
- package/dist/utils/json.js +16 -0
- package/dist/utils/json.js.map +7 -0
- package/dist/utils/log.js +298 -0
- package/dist/utils/log.js.map +7 -0
- package/dist/utils/markdown.js +187 -0
- package/dist/utils/markdown.js.map +7 -0
- package/dist/utils/messageContextManager.js +195 -0
- package/dist/utils/messageContextManager.js.map +7 -0
- package/dist/utils/messages.js +633 -0
- package/dist/utils/messages.js.map +7 -0
- package/dist/utils/model.js +687 -0
- package/dist/utils/model.js.map +7 -0
- package/dist/utils/permissions/filesystem.js +80 -0
- package/dist/utils/permissions/filesystem.js.map +7 -0
- package/dist/utils/responseState.js +20 -0
- package/dist/utils/responseState.js.map +7 -0
- package/dist/utils/ripgrep.js +131 -0
- package/dist/utils/ripgrep.js.map +7 -0
- package/dist/utils/secureFile.js +483 -0
- package/dist/utils/secureFile.js.map +7 -0
- package/dist/utils/sessionState.js +31 -0
- package/dist/utils/sessionState.js.map +7 -0
- package/dist/utils/state.js +24 -0
- package/dist/utils/state.js.map +7 -0
- package/dist/utils/style.js +31 -0
- package/dist/utils/style.js.map +7 -0
- package/dist/utils/terminal.js +43 -0
- package/dist/utils/terminal.js.map +7 -0
- package/dist/utils/theme.js +102 -0
- package/dist/utils/theme.js.map +7 -0
- package/dist/utils/thinking.js +103 -0
- package/dist/utils/thinking.js.map +7 -0
- package/dist/utils/todoStorage.js +291 -0
- package/dist/utils/todoStorage.js.map +7 -0
- package/dist/utils/tokens.js +30 -0
- package/dist/utils/tokens.js.map +7 -0
- package/dist/utils/toolExecutionController.js +109 -0
- package/dist/utils/toolExecutionController.js.map +7 -0
- package/dist/utils/unaryLogging.js +14 -0
- package/dist/utils/unaryLogging.js.map +7 -0
- package/dist/utils/user.js +40 -0
- package/dist/utils/user.js.map +7 -0
- package/dist/utils/validate.js +132 -0
- package/dist/utils/validate.js.map +7 -0
- package/dist/yoga.wasm +0 -0
- package/package.json +28 -7
- package/src/Tool.ts +4 -3
- package/src/commands/agents.tsx +10 -4
- package/src/components/messages/AssistantToolUseMessage.tsx +5 -6
- package/src/constants/macros.ts +5 -2
- package/src/entrypoints/cli.tsx +38 -19
- package/src/entrypoints/mcp.ts +1 -2
- package/src/hooks/useDoublePress.ts +0 -1
- package/src/hooks/useTextInput.ts +4 -5
- package/src/hooks/useUnifiedCompletion.ts +2 -2
- package/src/index.ts +34 -0
- package/src/query.ts +13 -8
- package/src/screens/Doctor.tsx +1 -1
- package/src/screens/REPL.tsx +13 -9
- package/src/services/openai.ts +25 -4
- package/src/tools/ArchitectTool/ArchitectTool.tsx +18 -5
- package/src/tools/AskExpertModelTool/AskExpertModelTool.tsx +21 -14
- package/src/tools/FileEditTool/FileEditTool.tsx +6 -2
- package/src/tools/FileWriteTool/FileWriteTool.tsx +7 -3
- package/src/tools/MultiEditTool/MultiEditTool.tsx +26 -4
- package/src/tools/NotebookReadTool/NotebookReadTool.tsx +1 -1
- package/src/tools/StickerRequestTool/StickerRequestTool.tsx +28 -14
- package/src/tools/TaskTool/TaskTool.tsx +8 -36
- package/src/types/common.d.ts +2 -0
- package/src/utils/generators.ts +1 -1
- package/src/utils/messageContextManager.ts +5 -0
- package/src/utils/messages.tsx +8 -2
- package/src/utils/thinking.ts +1 -1
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { default as React, useCallback } from "react";
|
|
2
|
+
import { useNotifyAfterTimeout } from "../../hooks/useNotifyAfterTimeout.js";
|
|
3
|
+
import { BinaryFeedbackView } from "./BinaryFeedbackView.js";
|
|
4
|
+
import {
|
|
5
|
+
getBinaryFeedbackResultForChoice,
|
|
6
|
+
logBinaryFeedbackEvent
|
|
7
|
+
} from "./utils.js";
|
|
8
|
+
import { PRODUCT_NAME } from "../../constants/product.js";
|
|
9
|
+
function BinaryFeedback({
|
|
10
|
+
m1,
|
|
11
|
+
m2,
|
|
12
|
+
resolve,
|
|
13
|
+
debug,
|
|
14
|
+
erroredToolUseIDs,
|
|
15
|
+
inProgressToolUseIDs,
|
|
16
|
+
normalizedMessages,
|
|
17
|
+
tools,
|
|
18
|
+
unresolvedToolUseIDs,
|
|
19
|
+
verbose
|
|
20
|
+
}) {
|
|
21
|
+
const onChoose = useCallback(
|
|
22
|
+
(choice) => {
|
|
23
|
+
logBinaryFeedbackEvent(m1, m2, choice);
|
|
24
|
+
resolve(getBinaryFeedbackResultForChoice(m1, m2, choice));
|
|
25
|
+
},
|
|
26
|
+
[m1, m2, resolve]
|
|
27
|
+
);
|
|
28
|
+
useNotifyAfterTimeout(
|
|
29
|
+
`${PRODUCT_NAME} needs your input on a response comparison`
|
|
30
|
+
);
|
|
31
|
+
return /* @__PURE__ */ React.createElement(
|
|
32
|
+
BinaryFeedbackView,
|
|
33
|
+
{
|
|
34
|
+
debug,
|
|
35
|
+
erroredToolUseIDs,
|
|
36
|
+
inProgressToolUseIDs,
|
|
37
|
+
m1,
|
|
38
|
+
m2,
|
|
39
|
+
normalizedMessages,
|
|
40
|
+
tools,
|
|
41
|
+
unresolvedToolUseIDs,
|
|
42
|
+
verbose,
|
|
43
|
+
onChoose
|
|
44
|
+
}
|
|
45
|
+
);
|
|
46
|
+
}
|
|
47
|
+
export {
|
|
48
|
+
BinaryFeedback
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=BinaryFeedback.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/binary-feedback/BinaryFeedback.tsx"],
|
|
4
|
+
"sourcesContent": ["import { default as React, useCallback } from 'react'\nimport { useNotifyAfterTimeout } from '../../hooks/useNotifyAfterTimeout'\nimport { AssistantMessage, BinaryFeedbackResult } from '../../query'\nimport type { Tool } from '../../Tool'\nimport type { NormalizedMessage } from '../../utils/messages'\nimport { BinaryFeedbackView } from './BinaryFeedbackView'\nimport {\n type BinaryFeedbackChoose,\n getBinaryFeedbackResultForChoice,\n logBinaryFeedbackEvent,\n} from './utils.js'\nimport { PRODUCT_NAME } from '../../constants/product'\n\ntype Props = {\n m1: AssistantMessage\n m2: AssistantMessage\n resolve: (result: BinaryFeedbackResult) => void\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n normalizedMessages: NormalizedMessage[]\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n verbose: boolean\n}\n\nexport function BinaryFeedback({\n m1,\n m2,\n resolve,\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n normalizedMessages,\n tools,\n unresolvedToolUseIDs,\n verbose,\n}: Props): React.ReactNode {\n const onChoose = useCallback<BinaryFeedbackChoose>(\n choice => {\n logBinaryFeedbackEvent(m1, m2, choice)\n resolve(getBinaryFeedbackResultForChoice(m1, m2, choice))\n },\n [m1, m2, resolve],\n )\n useNotifyAfterTimeout(\n `${PRODUCT_NAME} needs your input on a response comparison`,\n )\n return (\n <BinaryFeedbackView\n debug={debug}\n erroredToolUseIDs={erroredToolUseIDs}\n inProgressToolUseIDs={inProgressToolUseIDs}\n m1={m1}\n m2={m2}\n normalizedMessages={normalizedMessages}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n onChoose={onChoose}\n />\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,WAAW,OAAO,mBAAmB;AAC9C,SAAS,6BAA6B;AAItC,SAAS,0BAA0B;AACnC;AAAA,EAEE;AAAA,EACA;AAAA,OACK;AACP,SAAS,oBAAoB;AAetB,SAAS,eAAe;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,WAAW;AAAA,IACf,YAAU;AACR,6BAAuB,IAAI,IAAI,MAAM;AACrC,cAAQ,iCAAiC,IAAI,IAAI,MAAM,CAAC;AAAA,IAC1D;AAAA,IACA,CAAC,IAAI,IAAI,OAAO;AAAA,EAClB;AACA;AAAA,IACE,GAAG,YAAY;AAAA,EACjB;AACA,SACE;AAAA,IAAC;AAAA;AAAA,MACC;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA;AAAA,EACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { FileEditTool } from "../../tools/FileEditTool/FileEditTool.js";
|
|
2
|
+
import { FileEditToolDiff } from "../permissions/FileEditPermissionRequest/FileEditToolDiff.js";
|
|
3
|
+
import { Message } from "../Message.js";
|
|
4
|
+
import {
|
|
5
|
+
normalizeMessages
|
|
6
|
+
} from "../../utils/messages.js";
|
|
7
|
+
import { useTerminalSize } from "../../hooks/useTerminalSize.js";
|
|
8
|
+
import { FileWriteTool } from "../../tools/FileWriteTool/FileWriteTool.js";
|
|
9
|
+
import { FileWriteToolDiff } from "../permissions/FileWritePermissionRequest/FileWriteToolDiff.js";
|
|
10
|
+
import * as React from "react";
|
|
11
|
+
import { Box } from "ink";
|
|
12
|
+
function BinaryFeedbackOption({
|
|
13
|
+
debug,
|
|
14
|
+
erroredToolUseIDs,
|
|
15
|
+
inProgressToolUseIDs,
|
|
16
|
+
message,
|
|
17
|
+
normalizedMessages,
|
|
18
|
+
tools,
|
|
19
|
+
unresolvedToolUseIDs,
|
|
20
|
+
verbose
|
|
21
|
+
}) {
|
|
22
|
+
const { columns } = useTerminalSize();
|
|
23
|
+
return normalizeMessages([message]).filter((_) => _.type !== "progress").map((_, index) => /* @__PURE__ */ React.createElement(Box, { flexDirection: "column", key: index }, /* @__PURE__ */ React.createElement(
|
|
24
|
+
Message,
|
|
25
|
+
{
|
|
26
|
+
addMargin: false,
|
|
27
|
+
erroredToolUseIDs,
|
|
28
|
+
debug,
|
|
29
|
+
inProgressToolUseIDs,
|
|
30
|
+
message: _,
|
|
31
|
+
messages: normalizedMessages,
|
|
32
|
+
shouldAnimate: false,
|
|
33
|
+
shouldShowDot: true,
|
|
34
|
+
tools,
|
|
35
|
+
unresolvedToolUseIDs,
|
|
36
|
+
verbose,
|
|
37
|
+
width: columns / 2 - 6
|
|
38
|
+
}
|
|
39
|
+
), /* @__PURE__ */ React.createElement(AdditionalContext, { message: _, verbose })));
|
|
40
|
+
}
|
|
41
|
+
function AdditionalContext({
|
|
42
|
+
message,
|
|
43
|
+
verbose
|
|
44
|
+
}) {
|
|
45
|
+
const { columns } = useTerminalSize();
|
|
46
|
+
if (message.type !== "assistant") {
|
|
47
|
+
return null;
|
|
48
|
+
}
|
|
49
|
+
const content = message.message.content[0];
|
|
50
|
+
switch (content.type) {
|
|
51
|
+
case "tool_use":
|
|
52
|
+
switch (content.name) {
|
|
53
|
+
case FileEditTool.name: {
|
|
54
|
+
const input = FileEditTool.inputSchema.safeParse(content.input);
|
|
55
|
+
if (!input.success) {
|
|
56
|
+
return null;
|
|
57
|
+
}
|
|
58
|
+
return /* @__PURE__ */ React.createElement(
|
|
59
|
+
FileEditToolDiff,
|
|
60
|
+
{
|
|
61
|
+
file_path: input.data.file_path,
|
|
62
|
+
new_string: input.data.new_string,
|
|
63
|
+
old_string: input.data.old_string,
|
|
64
|
+
verbose,
|
|
65
|
+
width: columns / 2 - 12
|
|
66
|
+
}
|
|
67
|
+
);
|
|
68
|
+
}
|
|
69
|
+
case FileWriteTool.name: {
|
|
70
|
+
const input = FileWriteTool.inputSchema.safeParse(content.input);
|
|
71
|
+
if (!input.success) {
|
|
72
|
+
return null;
|
|
73
|
+
}
|
|
74
|
+
return /* @__PURE__ */ React.createElement(
|
|
75
|
+
FileWriteToolDiff,
|
|
76
|
+
{
|
|
77
|
+
file_path: input.data.file_path,
|
|
78
|
+
content: input.data.content,
|
|
79
|
+
verbose,
|
|
80
|
+
width: columns / 2 - 12
|
|
81
|
+
}
|
|
82
|
+
);
|
|
83
|
+
}
|
|
84
|
+
default:
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
default:
|
|
88
|
+
return null;
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
export {
|
|
92
|
+
BinaryFeedbackOption
|
|
93
|
+
};
|
|
94
|
+
//# sourceMappingURL=BinaryFeedbackOption.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/binary-feedback/BinaryFeedbackOption.tsx"],
|
|
4
|
+
"sourcesContent": ["import { FileEditTool } from '../../tools/FileEditTool/FileEditTool'\nimport { FileEditToolDiff } from '../permissions/FileEditPermissionRequest/FileEditToolDiff'\nimport { Message } from '../Message'\nimport {\n normalizeMessages,\n type NormalizedMessage,\n} from '../../utils/messages.js'\nimport type { Tool } from '../../Tool'\nimport { useTerminalSize } from '../../hooks/useTerminalSize'\nimport { FileWriteTool } from '../../tools/FileWriteTool/FileWriteTool'\nimport { FileWriteToolDiff } from '../permissions/FileWritePermissionRequest/FileWriteToolDiff'\nimport type { AssistantMessage } from '../../query'\nimport * as React from 'react'\nimport { Box } from 'ink'\n\ntype Props = {\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n message: AssistantMessage\n normalizedMessages: NormalizedMessage[]\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n verbose: boolean\n}\n\nexport function BinaryFeedbackOption({\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n message,\n normalizedMessages,\n tools,\n unresolvedToolUseIDs,\n verbose,\n}: Props): React.ReactNode {\n const { columns } = useTerminalSize()\n return normalizeMessages([message])\n .filter(_ => _.type !== 'progress')\n .map((_, index) => (\n <Box flexDirection=\"column\" key={index}>\n <Message\n addMargin={false}\n erroredToolUseIDs={erroredToolUseIDs}\n debug={debug}\n inProgressToolUseIDs={inProgressToolUseIDs}\n message={_}\n messages={normalizedMessages}\n shouldAnimate={false}\n shouldShowDot={true}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n width={columns / 2 - 6}\n />\n <AdditionalContext message={_} verbose={verbose} />\n </Box>\n ))\n}\n\nfunction AdditionalContext({\n message,\n verbose,\n}: {\n message: NormalizedMessage\n verbose: boolean\n}) {\n const { columns } = useTerminalSize()\n if (message.type !== 'assistant') {\n return null\n }\n const content = message.message.content[0]!\n switch (content.type) {\n case 'tool_use':\n switch (content.name) {\n case FileEditTool.name: {\n const input = FileEditTool.inputSchema.safeParse(content.input)\n if (!input.success) {\n return null\n }\n return (\n <FileEditToolDiff\n file_path={input.data.file_path}\n new_string={input.data.new_string}\n old_string={input.data.old_string}\n verbose={verbose}\n width={columns / 2 - 12}\n />\n )\n }\n case FileWriteTool.name: {\n const input = FileWriteTool.inputSchema.safeParse(content.input)\n if (!input.success) {\n return null\n }\n return (\n <FileWriteToolDiff\n file_path={input.data.file_path}\n content={input.data.content}\n verbose={verbose}\n width={columns / 2 - 12}\n />\n )\n }\n default:\n return null\n }\n default:\n return null\n }\n}\n"],
|
|
5
|
+
"mappings": "AAAA,SAAS,oBAAoB;AAC7B,SAAS,wBAAwB;AACjC,SAAS,eAAe;AACxB;AAAA,EACE;AAAA,OAEK;AAEP,SAAS,uBAAuB;AAChC,SAAS,qBAAqB;AAC9B,SAAS,yBAAyB;AAElC,YAAY,WAAW;AACvB,SAAS,WAAW;AAab,SAAS,qBAAqB;AAAA,EACnC;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF,GAA2B;AACzB,QAAM,EAAE,QAAQ,IAAI,gBAAgB;AACpC,SAAO,kBAAkB,CAAC,OAAO,CAAC,EAC/B,OAAO,OAAK,EAAE,SAAS,UAAU,EACjC,IAAI,CAAC,GAAG,UACP,oCAAC,OAAI,eAAc,UAAS,KAAK,SAC/B;AAAA,IAAC;AAAA;AAAA,MACC,WAAW;AAAA,MACX;AAAA,MACA;AAAA,MACA;AAAA,MACA,SAAS;AAAA,MACT,UAAU;AAAA,MACV,eAAe;AAAA,MACf,eAAe;AAAA,MACf;AAAA,MACA;AAAA,MACA;AAAA,MACA,OAAO,UAAU,IAAI;AAAA;AAAA,EACvB,GACA,oCAAC,qBAAkB,SAAS,GAAG,SAAkB,CACnD,CACD;AACL;AAEA,SAAS,kBAAkB;AAAA,EACzB;AAAA,EACA;AACF,GAGG;AACD,QAAM,EAAE,QAAQ,IAAI,gBAAgB;AACpC,MAAI,QAAQ,SAAS,aAAa;AAChC,WAAO;AAAA,EACT;AACA,QAAM,UAAU,QAAQ,QAAQ,QAAQ,CAAC;AACzC,UAAQ,QAAQ,MAAM;AAAA,IACpB,KAAK;AACH,cAAQ,QAAQ,MAAM;AAAA,QACpB,KAAK,aAAa,MAAM;AACtB,gBAAM,QAAQ,aAAa,YAAY,UAAU,QAAQ,KAAK;AAC9D,cAAI,CAAC,MAAM,SAAS;AAClB,mBAAO;AAAA,UACT;AACA,iBACE;AAAA,YAAC;AAAA;AAAA,cACC,WAAW,MAAM,KAAK;AAAA,cACtB,YAAY,MAAM,KAAK;AAAA,cACvB,YAAY,MAAM,KAAK;AAAA,cACvB;AAAA,cACA,OAAO,UAAU,IAAI;AAAA;AAAA,UACvB;AAAA,QAEJ;AAAA,QACA,KAAK,cAAc,MAAM;AACvB,gBAAM,QAAQ,cAAc,YAAY,UAAU,QAAQ,KAAK;AAC/D,cAAI,CAAC,MAAM,SAAS;AAClB,mBAAO;AAAA,UACT;AACA,iBACE;AAAA,YAAC;AAAA;AAAA,cACC,WAAW,MAAM,KAAK;AAAA,cACtB,SAAS,MAAM,KAAK;AAAA,cACpB;AAAA,cACA,OAAO,UAAU,IAAI;AAAA;AAAA,UACvB;AAAA,QAEJ;AAAA,QACA;AACE,iBAAO;AAAA,MACX;AAAA,IACF;AACE,aAAO;AAAA,EACX;AACF;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,139 @@
|
|
|
1
|
+
import chalk from "chalk";
|
|
2
|
+
import { Box, Text, useInput } from "ink";
|
|
3
|
+
import Link from "ink-link";
|
|
4
|
+
import React, { useState } from "react";
|
|
5
|
+
import { getTheme } from "../../utils/theme.js";
|
|
6
|
+
import { Select } from "../CustomSelect/select.js";
|
|
7
|
+
import { BinaryFeedbackOption } from "./BinaryFeedbackOption.js";
|
|
8
|
+
import { useExitOnCtrlCD } from "../../hooks/useExitOnCtrlCD.js";
|
|
9
|
+
import { PRODUCT_NAME } from "../../constants/product.js";
|
|
10
|
+
const HELP_URL = "https://go/cli-feedback";
|
|
11
|
+
function getOptions() {
|
|
12
|
+
return [
|
|
13
|
+
{
|
|
14
|
+
// This option combines the follow user intents:
|
|
15
|
+
// - The two options look about equally good to me
|
|
16
|
+
// - I don't feel confident enough to choose
|
|
17
|
+
// - I don't want to choose right now
|
|
18
|
+
label: "Choose for me",
|
|
19
|
+
value: "no-preference"
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
label: "Left option looks better",
|
|
23
|
+
value: "prefer-left"
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
label: "Right option looks better",
|
|
27
|
+
value: "prefer-right"
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
label: `Neither, and tell ${PRODUCT_NAME} what to do differently (${chalk.bold.hex(getTheme().warning)("esc")})`,
|
|
31
|
+
value: "neither"
|
|
32
|
+
}
|
|
33
|
+
];
|
|
34
|
+
}
|
|
35
|
+
function BinaryFeedbackView({
|
|
36
|
+
m1,
|
|
37
|
+
m2,
|
|
38
|
+
onChoose,
|
|
39
|
+
debug,
|
|
40
|
+
erroredToolUseIDs,
|
|
41
|
+
inProgressToolUseIDs,
|
|
42
|
+
normalizedMessages,
|
|
43
|
+
tools,
|
|
44
|
+
unresolvedToolUseIDs,
|
|
45
|
+
verbose
|
|
46
|
+
}) {
|
|
47
|
+
const theme = getTheme();
|
|
48
|
+
const [focused, setFocus] = useState("no-preference");
|
|
49
|
+
const [focusValue, setFocusValue] = useState(void 0);
|
|
50
|
+
const exitState = useExitOnCtrlCD(() => process.exit(1));
|
|
51
|
+
useInput((_input, key) => {
|
|
52
|
+
if (key.leftArrow) {
|
|
53
|
+
setFocusValue("prefer-left");
|
|
54
|
+
} else if (key.rightArrow) {
|
|
55
|
+
setFocusValue("prefer-right");
|
|
56
|
+
} else if (key.escape) {
|
|
57
|
+
onChoose?.("neither");
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(
|
|
61
|
+
Box,
|
|
62
|
+
{
|
|
63
|
+
flexDirection: "column",
|
|
64
|
+
height: "100%",
|
|
65
|
+
width: "100%",
|
|
66
|
+
borderStyle: "round",
|
|
67
|
+
borderColor: theme.permission
|
|
68
|
+
},
|
|
69
|
+
/* @__PURE__ */ React.createElement(Box, { width: "100%", justifyContent: "space-between", paddingX: 1 }, /* @__PURE__ */ React.createElement(Text, { bold: true, color: theme.permission }, "[ANT-ONLY] Help train ", PRODUCT_NAME), /* @__PURE__ */ React.createElement(Text, null, /* @__PURE__ */ React.createElement(Link, { url: HELP_URL }, "[?]"))),
|
|
70
|
+
/* @__PURE__ */ React.createElement(Box, { flexDirection: "row", width: "100%", flexGrow: 1, paddingTop: 1 }, /* @__PURE__ */ React.createElement(
|
|
71
|
+
Box,
|
|
72
|
+
{
|
|
73
|
+
flexDirection: "column",
|
|
74
|
+
flexGrow: 1,
|
|
75
|
+
flexBasis: 1,
|
|
76
|
+
gap: 1,
|
|
77
|
+
borderStyle: focused === "prefer-left" ? "bold" : "single",
|
|
78
|
+
borderColor: focused === "prefer-left" ? theme.success : theme.secondaryBorder,
|
|
79
|
+
marginRight: 1,
|
|
80
|
+
padding: 1
|
|
81
|
+
},
|
|
82
|
+
/* @__PURE__ */ React.createElement(
|
|
83
|
+
BinaryFeedbackOption,
|
|
84
|
+
{
|
|
85
|
+
erroredToolUseIDs,
|
|
86
|
+
debug,
|
|
87
|
+
inProgressToolUseIDs,
|
|
88
|
+
message: m1,
|
|
89
|
+
normalizedMessages,
|
|
90
|
+
tools,
|
|
91
|
+
unresolvedToolUseIDs,
|
|
92
|
+
verbose
|
|
93
|
+
}
|
|
94
|
+
)
|
|
95
|
+
), /* @__PURE__ */ React.createElement(
|
|
96
|
+
Box,
|
|
97
|
+
{
|
|
98
|
+
flexDirection: "column",
|
|
99
|
+
flexGrow: 1,
|
|
100
|
+
flexBasis: 1,
|
|
101
|
+
gap: 1,
|
|
102
|
+
borderStyle: focused === "prefer-right" ? "bold" : "single",
|
|
103
|
+
borderColor: focused === "prefer-right" ? theme.success : theme.secondaryBorder,
|
|
104
|
+
marginLeft: 1,
|
|
105
|
+
padding: 1
|
|
106
|
+
},
|
|
107
|
+
/* @__PURE__ */ React.createElement(
|
|
108
|
+
BinaryFeedbackOption,
|
|
109
|
+
{
|
|
110
|
+
erroredToolUseIDs,
|
|
111
|
+
debug,
|
|
112
|
+
inProgressToolUseIDs,
|
|
113
|
+
message: m2,
|
|
114
|
+
normalizedMessages,
|
|
115
|
+
tools,
|
|
116
|
+
unresolvedToolUseIDs,
|
|
117
|
+
verbose
|
|
118
|
+
}
|
|
119
|
+
)
|
|
120
|
+
)),
|
|
121
|
+
/* @__PURE__ */ React.createElement(Box, { flexDirection: "column", paddingTop: 1, paddingX: 1 }, /* @__PURE__ */ React.createElement(Text, null, "How do you want to proceed?"), /* @__PURE__ */ React.createElement(
|
|
122
|
+
Select,
|
|
123
|
+
{
|
|
124
|
+
options: getOptions(),
|
|
125
|
+
onFocus: setFocus,
|
|
126
|
+
focusValue,
|
|
127
|
+
onChange: onChoose
|
|
128
|
+
}
|
|
129
|
+
))
|
|
130
|
+
), exitState.pending ? /* @__PURE__ */ React.createElement(Box, { marginLeft: 3 }, /* @__PURE__ */ React.createElement(Text, { dimColor: true }, "Press ", exitState.keyName, " again to exit")) : (
|
|
131
|
+
// Render a blank line so that the UI doesn't reflow when the exit message is shown
|
|
132
|
+
/* @__PURE__ */ React.createElement(Text, null, " ")
|
|
133
|
+
));
|
|
134
|
+
}
|
|
135
|
+
export {
|
|
136
|
+
BinaryFeedbackView,
|
|
137
|
+
getOptions
|
|
138
|
+
};
|
|
139
|
+
//# sourceMappingURL=BinaryFeedbackView.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/binary-feedback/BinaryFeedbackView.tsx"],
|
|
4
|
+
"sourcesContent": ["import { Option, SelectProps } from '@inkjs/ui'\nimport chalk from 'chalk'\nimport { Box, Text, useInput } from 'ink'\nimport Link from 'ink-link'\nimport React, { useState } from 'react'\nimport { getTheme } from '../../utils/theme'\nimport { Select } from '../CustomSelect/select'\nimport type { Tool } from '../../Tool'\nimport type { NormalizedMessage } from '../../utils/messages'\nimport { BinaryFeedbackOption } from './BinaryFeedbackOption'\nimport type { AssistantMessage } from '../../query'\nimport type { BinaryFeedbackChoose } from './utils'\nimport { useExitOnCtrlCD } from '../../hooks/useExitOnCtrlCD'\nimport { BinaryFeedbackChoice } from './utils'\nimport { PRODUCT_NAME } from '../../constants/product'\n\nconst HELP_URL = 'https://go/cli-feedback'\n\ntype BinaryFeedbackOption = Option & { value: BinaryFeedbackChoice }\n\n// Make options a function to avoid early theme access during module initialization\nexport function getOptions(): BinaryFeedbackOption[] {\n return [\n {\n // This option combines the follow user intents:\n // - The two options look about equally good to me\n // - I don't feel confident enough to choose\n // - I don't want to choose right now\n label: 'Choose for me',\n value: 'no-preference',\n },\n {\n label: 'Left option looks better',\n value: 'prefer-left',\n },\n {\n label: 'Right option looks better',\n value: 'prefer-right',\n },\n {\n label: `Neither, and tell ${PRODUCT_NAME} what to do differently (${chalk.bold.hex(getTheme().warning)('esc')})`,\n value: 'neither',\n },\n ]\n}\n\ntype Props = {\n m1: AssistantMessage\n m2: AssistantMessage\n onChoose?: BinaryFeedbackChoose\n debug: boolean\n erroredToolUseIDs: Set<string>\n inProgressToolUseIDs: Set<string>\n normalizedMessages: NormalizedMessage[]\n tools: Tool[]\n unresolvedToolUseIDs: Set<string>\n verbose: boolean\n}\n\nexport function BinaryFeedbackView({\n m1,\n m2,\n onChoose,\n debug,\n erroredToolUseIDs,\n inProgressToolUseIDs,\n normalizedMessages,\n tools,\n unresolvedToolUseIDs,\n verbose,\n}: Props) {\n const theme = getTheme()\n const [focused, setFocus] = useState('no-preference')\n const [focusValue, setFocusValue] = useState<string | undefined>(undefined)\n const exitState = useExitOnCtrlCD(() => process.exit(1))\n\n useInput((_input, key) => {\n if (key.leftArrow) {\n setFocusValue('prefer-left')\n } else if (key.rightArrow) {\n setFocusValue('prefer-right')\n } else if (key.escape) {\n onChoose?.('neither')\n }\n })\n\n return (\n <>\n <Box\n flexDirection=\"column\"\n height=\"100%\"\n width=\"100%\"\n borderStyle=\"round\"\n borderColor={theme.permission}\n >\n <Box width=\"100%\" justifyContent=\"space-between\" paddingX={1}>\n <Text bold color={theme.permission}>\n [ANT-ONLY] Help train {PRODUCT_NAME}\n </Text>\n <Text>\n <Link url={HELP_URL}>[?]</Link>\n </Text>\n </Box>\n <Box flexDirection=\"row\" width=\"100%\" flexGrow={1} paddingTop={1}>\n <Box\n flexDirection=\"column\"\n flexGrow={1}\n flexBasis={1}\n gap={1}\n borderStyle={focused === 'prefer-left' ? 'bold' : 'single'}\n borderColor={\n focused === 'prefer-left' ? theme.success : theme.secondaryBorder\n }\n marginRight={1}\n padding={1}\n >\n <BinaryFeedbackOption\n erroredToolUseIDs={erroredToolUseIDs}\n debug={debug}\n inProgressToolUseIDs={inProgressToolUseIDs}\n message={m1}\n normalizedMessages={normalizedMessages}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n />\n </Box>\n <Box\n flexDirection=\"column\"\n flexGrow={1}\n flexBasis={1}\n gap={1}\n borderStyle={focused === 'prefer-right' ? 'bold' : 'single'}\n borderColor={\n focused === 'prefer-right' ? theme.success : theme.secondaryBorder\n }\n marginLeft={1}\n padding={1}\n >\n <BinaryFeedbackOption\n erroredToolUseIDs={erroredToolUseIDs}\n debug={debug}\n inProgressToolUseIDs={inProgressToolUseIDs}\n message={m2}\n normalizedMessages={normalizedMessages}\n tools={tools}\n unresolvedToolUseIDs={unresolvedToolUseIDs}\n verbose={verbose}\n />\n </Box>\n </Box>\n <Box flexDirection=\"column\" paddingTop={1} paddingX={1}>\n <Text>How do you want to proceed?</Text>\n <Select\n options={getOptions()}\n onFocus={setFocus}\n focusValue={focusValue}\n onChange={onChoose as SelectProps['onChange']}\n />\n </Box>\n </Box>\n {exitState.pending ? (\n <Box marginLeft={3}>\n <Text dimColor>Press {exitState.keyName} again to exit</Text>\n </Box>\n ) : (\n // Render a blank line so that the UI doesn't reflow when the exit message is shown\n <Text> </Text>\n )}\n </>\n )\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { MAIN_QUERY_TEMPERATURE } from "../../services/claude.js";
|
|
2
|
+
import { getDynamicConfig, logEvent } from "../../services/statsig.js";
|
|
3
|
+
import { isEqual, zip } from "lodash-es";
|
|
4
|
+
import { getGitState } from "../../utils/git.js";
|
|
5
|
+
async function getBinaryFeedbackStatsigConfig() {
|
|
6
|
+
return await getDynamicConfig("tengu-binary-feedback-config", {
|
|
7
|
+
sampleFrequency: 0
|
|
8
|
+
});
|
|
9
|
+
}
|
|
10
|
+
function getMessageBlockSequence(m) {
|
|
11
|
+
return m.message.content.map((cb) => {
|
|
12
|
+
if (cb.type === "text") return "text";
|
|
13
|
+
if (cb.type === "tool_use") return cb.name;
|
|
14
|
+
return cb.type;
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
async function logBinaryFeedbackEvent(m1, m2, choice) {
|
|
18
|
+
const modelA = m1.message.model;
|
|
19
|
+
const modelB = m2.message.model;
|
|
20
|
+
const gitState = await getGitState();
|
|
21
|
+
logEvent("tengu_binary_feedback", {
|
|
22
|
+
msg_id_A: m1.message.id,
|
|
23
|
+
msg_id_B: m2.message.id,
|
|
24
|
+
choice: {
|
|
25
|
+
"prefer-left": m1.message.id,
|
|
26
|
+
"prefer-right": m2.message.id,
|
|
27
|
+
neither: void 0,
|
|
28
|
+
"no-preference": void 0
|
|
29
|
+
}[choice],
|
|
30
|
+
choiceStr: choice,
|
|
31
|
+
gitHead: gitState?.commitHash,
|
|
32
|
+
gitBranch: gitState?.branchName,
|
|
33
|
+
gitRepoRemoteUrl: gitState?.remoteUrl || void 0,
|
|
34
|
+
gitRepoIsHeadOnRemote: gitState?.isHeadOnRemote?.toString(),
|
|
35
|
+
gitRepoIsClean: gitState?.isClean?.toString(),
|
|
36
|
+
modelA,
|
|
37
|
+
modelB,
|
|
38
|
+
temperatureA: String(MAIN_QUERY_TEMPERATURE),
|
|
39
|
+
temperatureB: String(MAIN_QUERY_TEMPERATURE),
|
|
40
|
+
seqA: String(getMessageBlockSequence(m1)),
|
|
41
|
+
seqB: String(getMessageBlockSequence(m2))
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
async function logBinaryFeedbackSamplingDecision(decision, reason) {
|
|
45
|
+
logEvent("tengu_binary_feedback_sampling_decision", {
|
|
46
|
+
decision: decision.toString(),
|
|
47
|
+
reason
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
async function logBinaryFeedbackDisplayDecision(decision, m1, m2, reason) {
|
|
51
|
+
logEvent("tengu_binary_feedback_display_decision", {
|
|
52
|
+
decision: decision.toString(),
|
|
53
|
+
reason,
|
|
54
|
+
msg_id_A: m1.message.id,
|
|
55
|
+
msg_id_B: m2.message.id,
|
|
56
|
+
seqA: String(getMessageBlockSequence(m1)),
|
|
57
|
+
seqB: String(getMessageBlockSequence(m2))
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
function textContentBlocksEqual(cb1, cb2) {
|
|
61
|
+
return cb1.text === cb2.text;
|
|
62
|
+
}
|
|
63
|
+
function contentBlocksEqual(cb1, cb2) {
|
|
64
|
+
if (cb1.type !== cb2.type) {
|
|
65
|
+
return false;
|
|
66
|
+
}
|
|
67
|
+
if (cb1.type === "text") {
|
|
68
|
+
return textContentBlocksEqual(cb1, cb2);
|
|
69
|
+
}
|
|
70
|
+
cb2 = cb2;
|
|
71
|
+
return cb1.name === cb2.name && isEqual(cb1.input, cb2.input);
|
|
72
|
+
}
|
|
73
|
+
function allContentBlocksEqual(content1, content2) {
|
|
74
|
+
if (content1.length !== content2.length) {
|
|
75
|
+
return false;
|
|
76
|
+
}
|
|
77
|
+
return zip(content1, content2).every(
|
|
78
|
+
([cb1, cb2]) => contentBlocksEqual(cb1, cb2)
|
|
79
|
+
);
|
|
80
|
+
}
|
|
81
|
+
async function shouldUseBinaryFeedback() {
|
|
82
|
+
if (process.env.DISABLE_BINARY_FEEDBACK) {
|
|
83
|
+
logBinaryFeedbackSamplingDecision(false, "disabled_by_env_var");
|
|
84
|
+
return false;
|
|
85
|
+
}
|
|
86
|
+
if (process.env.FORCE_BINARY_FEEDBACK) {
|
|
87
|
+
logBinaryFeedbackSamplingDecision(true, "forced_by_env_var");
|
|
88
|
+
return true;
|
|
89
|
+
}
|
|
90
|
+
if (process.env.USER_TYPE !== "ant") {
|
|
91
|
+
logBinaryFeedbackSamplingDecision(false, "not_ant");
|
|
92
|
+
return false;
|
|
93
|
+
}
|
|
94
|
+
if (process.env.NODE_ENV === "test") {
|
|
95
|
+
logBinaryFeedbackSamplingDecision(false, "test");
|
|
96
|
+
return false;
|
|
97
|
+
}
|
|
98
|
+
const config = await getBinaryFeedbackStatsigConfig();
|
|
99
|
+
if (config.sampleFrequency === 0) {
|
|
100
|
+
logBinaryFeedbackSamplingDecision(false, "top_level_frequency_zero");
|
|
101
|
+
return false;
|
|
102
|
+
}
|
|
103
|
+
if (Math.random() > config.sampleFrequency) {
|
|
104
|
+
logBinaryFeedbackSamplingDecision(false, "top_level_frequency_rng");
|
|
105
|
+
return false;
|
|
106
|
+
}
|
|
107
|
+
logBinaryFeedbackSamplingDecision(true);
|
|
108
|
+
return true;
|
|
109
|
+
}
|
|
110
|
+
function messagePairValidForBinaryFeedback(m1, m2) {
|
|
111
|
+
const logPass = () => logBinaryFeedbackDisplayDecision(true, m1, m2);
|
|
112
|
+
const logFail = (reason) => logBinaryFeedbackDisplayDecision(false, m1, m2, reason);
|
|
113
|
+
const nonThinkingBlocks1 = m1.message.content.filter(
|
|
114
|
+
(b) => b.type !== "thinking" && b.type !== "redacted_thinking"
|
|
115
|
+
);
|
|
116
|
+
const nonThinkingBlocks2 = m2.message.content.filter(
|
|
117
|
+
(b) => b.type !== "thinking" && b.type !== "redacted_thinking"
|
|
118
|
+
);
|
|
119
|
+
const hasToolUse = nonThinkingBlocks1.some((b) => b.type === "tool_use") || nonThinkingBlocks2.some((b) => b.type === "tool_use");
|
|
120
|
+
if (!hasToolUse) {
|
|
121
|
+
if (allContentBlocksEqual(nonThinkingBlocks1, nonThinkingBlocks2)) {
|
|
122
|
+
logFail("contents_identical");
|
|
123
|
+
return false;
|
|
124
|
+
}
|
|
125
|
+
logPass();
|
|
126
|
+
return true;
|
|
127
|
+
}
|
|
128
|
+
if (allContentBlocksEqual(
|
|
129
|
+
nonThinkingBlocks1.filter((b) => b.type === "tool_use"),
|
|
130
|
+
nonThinkingBlocks2.filter((b) => b.type === "tool_use")
|
|
131
|
+
)) {
|
|
132
|
+
logFail("contents_identical");
|
|
133
|
+
return false;
|
|
134
|
+
}
|
|
135
|
+
logPass();
|
|
136
|
+
return true;
|
|
137
|
+
}
|
|
138
|
+
function getBinaryFeedbackResultForChoice(m1, m2, choice) {
|
|
139
|
+
switch (choice) {
|
|
140
|
+
case "prefer-left":
|
|
141
|
+
return { message: m1, shouldSkipPermissionCheck: true };
|
|
142
|
+
case "prefer-right":
|
|
143
|
+
return { message: m2, shouldSkipPermissionCheck: true };
|
|
144
|
+
case "no-preference":
|
|
145
|
+
return {
|
|
146
|
+
message: Math.random() < 0.5 ? m1 : m2,
|
|
147
|
+
shouldSkipPermissionCheck: false
|
|
148
|
+
};
|
|
149
|
+
case "neither":
|
|
150
|
+
return { message: null, shouldSkipPermissionCheck: false };
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
export {
|
|
154
|
+
getBinaryFeedbackResultForChoice,
|
|
155
|
+
logBinaryFeedbackDisplayDecision,
|
|
156
|
+
logBinaryFeedbackEvent,
|
|
157
|
+
logBinaryFeedbackSamplingDecision,
|
|
158
|
+
messagePairValidForBinaryFeedback,
|
|
159
|
+
shouldUseBinaryFeedback
|
|
160
|
+
};
|
|
161
|
+
//# sourceMappingURL=utils.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/binary-feedback/utils.ts"],
|
|
4
|
+
"sourcesContent": ["import { TextBlock, ToolUseBlock } from '@anthropic-ai/sdk/resources/index.mjs'\nimport { AssistantMessage, BinaryFeedbackResult } from '../../query'\nimport { MAIN_QUERY_TEMPERATURE } from '../../services/claude'\nimport { getDynamicConfig, logEvent } from '../../services/statsig'\n\nimport { isEqual, zip } from 'lodash-es'\nimport { getGitState } from '../../utils/git'\n\nexport type BinaryFeedbackChoice =\n | 'prefer-left'\n | 'prefer-right'\n | 'neither'\n | 'no-preference'\n\nexport type BinaryFeedbackChoose = (choice: BinaryFeedbackChoice) => void\n\ntype BinaryFeedbackConfig = {\n sampleFrequency: number\n}\n\nasync function getBinaryFeedbackStatsigConfig(): Promise<BinaryFeedbackConfig> {\n return await getDynamicConfig('tengu-binary-feedback-config', {\n sampleFrequency: 0,\n })\n}\n\nfunction getMessageBlockSequence(m: AssistantMessage) {\n return m.message.content.map(cb => {\n if (cb.type === 'text') return 'text'\n if (cb.type === 'tool_use') return cb.name\n return cb.type // Handle other block types like 'thinking' or 'redacted_thinking'\n })\n}\n\nexport async function logBinaryFeedbackEvent(\n m1: AssistantMessage,\n m2: AssistantMessage,\n choice: BinaryFeedbackChoice,\n): Promise<void> {\n const modelA = m1.message.model\n const modelB = m2.message.model\n const gitState = await getGitState()\n logEvent('tengu_binary_feedback', {\n msg_id_A: m1.message.id,\n msg_id_B: m2.message.id,\n choice: {\n 'prefer-left': m1.message.id,\n 'prefer-right': m2.message.id,\n neither: undefined,\n 'no-preference': undefined,\n }[choice],\n choiceStr: choice,\n gitHead: gitState?.commitHash,\n gitBranch: gitState?.branchName,\n gitRepoRemoteUrl: gitState?.remoteUrl || undefined,\n gitRepoIsHeadOnRemote: gitState?.isHeadOnRemote?.toString(),\n gitRepoIsClean: gitState?.isClean?.toString(),\n modelA,\n modelB,\n temperatureA: String(MAIN_QUERY_TEMPERATURE),\n temperatureB: String(MAIN_QUERY_TEMPERATURE),\n seqA: String(getMessageBlockSequence(m1)),\n seqB: String(getMessageBlockSequence(m2)),\n })\n}\n\nexport async function logBinaryFeedbackSamplingDecision(\n decision: boolean,\n reason?: string,\n): Promise<void> {\n logEvent('tengu_binary_feedback_sampling_decision', {\n decision: decision.toString(),\n reason,\n })\n}\n\nexport async function logBinaryFeedbackDisplayDecision(\n decision: boolean,\n m1: AssistantMessage,\n m2: AssistantMessage,\n reason?: string,\n): Promise<void> {\n logEvent('tengu_binary_feedback_display_decision', {\n decision: decision.toString(),\n reason,\n msg_id_A: m1.message.id,\n msg_id_B: m2.message.id,\n seqA: String(getMessageBlockSequence(m1)),\n seqB: String(getMessageBlockSequence(m2)),\n })\n}\n\nfunction textContentBlocksEqual(cb1: TextBlock, cb2: TextBlock): boolean {\n return cb1.text === cb2.text\n}\n\nfunction contentBlocksEqual(\n cb1: TextBlock | ToolUseBlock,\n cb2: TextBlock | ToolUseBlock,\n): boolean {\n if (cb1.type !== cb2.type) {\n return false\n }\n if (cb1.type === 'text') {\n return textContentBlocksEqual(cb1, cb2 as TextBlock)\n }\n cb2 = cb2 as ToolUseBlock\n return cb1.name === cb2.name && isEqual(cb1.input, cb2.input)\n}\n\nfunction allContentBlocksEqual(\n content1: (TextBlock | ToolUseBlock)[],\n content2: (TextBlock | ToolUseBlock)[],\n): boolean {\n if (content1.length !== content2.length) {\n return false\n }\n return zip(content1, content2).every(([cb1, cb2]) =>\n contentBlocksEqual(cb1!, cb2!),\n )\n}\n\nexport async function shouldUseBinaryFeedback(): Promise<boolean> {\n if (process.env.DISABLE_BINARY_FEEDBACK) {\n logBinaryFeedbackSamplingDecision(false, 'disabled_by_env_var')\n return false\n }\n if (process.env.FORCE_BINARY_FEEDBACK) {\n logBinaryFeedbackSamplingDecision(true, 'forced_by_env_var')\n return true\n }\n if (process.env.USER_TYPE !== 'ant') {\n logBinaryFeedbackSamplingDecision(false, 'not_ant')\n return false\n }\n if (process.env.NODE_ENV === 'test') {\n // Binary feedback breaks a couple tests related to checking for permission,\n // so we have to disable it in tests at the risk of hiding bugs\n logBinaryFeedbackSamplingDecision(false, 'test')\n return false\n }\n\n const config = await getBinaryFeedbackStatsigConfig()\n if (config.sampleFrequency === 0) {\n logBinaryFeedbackSamplingDecision(false, 'top_level_frequency_zero')\n return false\n }\n if (Math.random() > config.sampleFrequency) {\n logBinaryFeedbackSamplingDecision(false, 'top_level_frequency_rng')\n return false\n }\n logBinaryFeedbackSamplingDecision(true)\n return true\n}\n\nexport function messagePairValidForBinaryFeedback(\n m1: AssistantMessage,\n m2: AssistantMessage,\n): boolean {\n const logPass = () => logBinaryFeedbackDisplayDecision(true, m1, m2)\n const logFail = (reason: string) =>\n logBinaryFeedbackDisplayDecision(false, m1, m2, reason)\n\n // Ignore thinking blocks, on the assumption that users don't find them very relevant\n // compared to other content types\n const nonThinkingBlocks1 = m1.message.content.filter(\n b => b.type !== 'thinking' && b.type !== 'redacted_thinking',\n )\n const nonThinkingBlocks2 = m2.message.content.filter(\n b => b.type !== 'thinking' && b.type !== 'redacted_thinking',\n )\n const hasToolUse =\n nonThinkingBlocks1.some(b => b.type === 'tool_use') ||\n nonThinkingBlocks2.some(b => b.type === 'tool_use')\n\n // If they're all text blocks, compare those\n if (!hasToolUse) {\n if (allContentBlocksEqual(nonThinkingBlocks1, nonThinkingBlocks2)) {\n logFail('contents_identical')\n return false\n }\n logPass()\n return true\n }\n\n // If there are tools, they're the most material difference between the messages.\n // Only show binary feedback if there's a tool use difference, ignoring text.\n if (\n allContentBlocksEqual(\n nonThinkingBlocks1.filter(b => b.type === 'tool_use'),\n nonThinkingBlocks2.filter(b => b.type === 'tool_use'),\n )\n ) {\n logFail('contents_identical')\n return false\n }\n\n logPass()\n return true\n}\n\nexport function getBinaryFeedbackResultForChoice(\n m1: AssistantMessage,\n m2: AssistantMessage,\n choice: BinaryFeedbackChoice,\n): BinaryFeedbackResult {\n switch (choice) {\n case 'prefer-left':\n return { message: m1, shouldSkipPermissionCheck: true }\n case 'prefer-right':\n return { message: m2, shouldSkipPermissionCheck: true }\n case 'no-preference':\n return {\n message: Math.random() < 0.5 ? m1 : m2,\n shouldSkipPermissionCheck: false,\n }\n case 'neither':\n return { message: null, shouldSkipPermissionCheck: false }\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import BashToolResultMessage from "../../tools/BashTool/BashToolResultMessage.js";
|
|
3
|
+
import { extractTag } from "../../utils/messages.js";
|
|
4
|
+
function AssistantBashOutputMessage({
|
|
5
|
+
content,
|
|
6
|
+
verbose
|
|
7
|
+
}) {
|
|
8
|
+
const stdout = extractTag(content, "bash-stdout") ?? "";
|
|
9
|
+
const stderr = extractTag(content, "bash-stderr") ?? "";
|
|
10
|
+
const stdoutLines = stdout.split("\n").length;
|
|
11
|
+
const stderrLines = stderr.split("\n").length;
|
|
12
|
+
return /* @__PURE__ */ React.createElement(
|
|
13
|
+
BashToolResultMessage,
|
|
14
|
+
{
|
|
15
|
+
content: { stdout, stdoutLines, stderr, stderrLines },
|
|
16
|
+
verbose: !!verbose
|
|
17
|
+
}
|
|
18
|
+
);
|
|
19
|
+
}
|
|
20
|
+
export {
|
|
21
|
+
AssistantBashOutputMessage
|
|
22
|
+
};
|
|
23
|
+
//# sourceMappingURL=AssistantBashOutputMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantBashOutputMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import * as React from 'react'\nimport BashToolResultMessage from '../../tools/BashTool/BashToolResultMessage'\nimport { extractTag } from '../../utils/messages'\n\nexport function AssistantBashOutputMessage({\n content,\n verbose,\n}: {\n content: string\n verbose?: boolean\n}): React.ReactNode {\n const stdout = extractTag(content, 'bash-stdout') ?? ''\n const stderr = extractTag(content, 'bash-stderr') ?? ''\n const stdoutLines = stdout.split('\\n').length\n const stderrLines = stderr.split('\\n').length\n return (\n <BashToolResultMessage\n content={{ stdout, stdoutLines, stderr, stderrLines }}\n verbose={!!verbose}\n />\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,YAAY,WAAW;AACvB,OAAO,2BAA2B;AAClC,SAAS,kBAAkB;AAEpB,SAAS,2BAA2B;AAAA,EACzC;AAAA,EACA;AACF,GAGoB;AAClB,QAAM,SAAS,WAAW,SAAS,aAAa,KAAK;AACrD,QAAM,SAAS,WAAW,SAAS,aAAa,KAAK;AACrD,QAAM,cAAc,OAAO,MAAM,IAAI,EAAE;AACvC,QAAM,cAAc,OAAO,MAAM,IAAI,EAAE;AACvC,SACE;AAAA,IAAC;AAAA;AAAA,MACC,SAAS,EAAE,QAAQ,aAAa,QAAQ,YAAY;AAAA,MACpD,SAAS,CAAC,CAAC;AAAA;AAAA,EACb;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
import { extractTag } from "../../utils/messages.js";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
import { Box, Text } from "ink";
|
|
5
|
+
function AssistantLocalCommandOutputMessage({
|
|
6
|
+
content
|
|
7
|
+
}) {
|
|
8
|
+
const stdout = extractTag(content, "local-command-stdout");
|
|
9
|
+
const stderr = extractTag(content, "local-command-stderr");
|
|
10
|
+
if (!stdout && !stderr) {
|
|
11
|
+
return [];
|
|
12
|
+
}
|
|
13
|
+
const theme = getTheme();
|
|
14
|
+
let insides = [
|
|
15
|
+
format(stdout?.trim(), theme.text),
|
|
16
|
+
format(stderr?.trim(), theme.error)
|
|
17
|
+
].filter(Boolean);
|
|
18
|
+
if (insides.length === 0) {
|
|
19
|
+
insides = [
|
|
20
|
+
/* @__PURE__ */ React.createElement(React.Fragment, { key: "0" }, /* @__PURE__ */ React.createElement(Text, null, "(No output)"))
|
|
21
|
+
];
|
|
22
|
+
}
|
|
23
|
+
return [
|
|
24
|
+
/* @__PURE__ */ React.createElement(Box, { key: "0", gap: 1 }, /* @__PURE__ */ React.createElement(Box, null, /* @__PURE__ */ React.createElement(Text, { color: theme.secondaryText }, " ", "\u23BF ")), insides.map((_, index) => /* @__PURE__ */ React.createElement(Box, { key: index, flexDirection: "column" }, _)))
|
|
25
|
+
];
|
|
26
|
+
}
|
|
27
|
+
function format(content, color) {
|
|
28
|
+
if (!content) {
|
|
29
|
+
return null;
|
|
30
|
+
}
|
|
31
|
+
return /* @__PURE__ */ React.createElement(Text, { color }, content);
|
|
32
|
+
}
|
|
33
|
+
export {
|
|
34
|
+
AssistantLocalCommandOutputMessage
|
|
35
|
+
};
|
|
36
|
+
//# sourceMappingURL=AssistantLocalCommandOutputMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantLocalCommandOutputMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import * as React from 'react'\nimport { extractTag } from '../../utils/messages'\nimport { getTheme } from '../../utils/theme'\nimport { Box, Text } from 'ink'\n\nexport function AssistantLocalCommandOutputMessage({\n content,\n}: {\n content: string\n}): React.ReactNode[] {\n const stdout = extractTag(content, 'local-command-stdout')\n const stderr = extractTag(content, 'local-command-stderr')\n if (!stdout && !stderr) {\n return []\n }\n const theme = getTheme()\n let insides = [\n format(stdout?.trim(), theme.text),\n format(stderr?.trim(), theme.error),\n ].filter(Boolean)\n\n if (insides.length === 0) {\n insides = [\n <React.Fragment key=\"0\">\n <Text>(No output)</Text>\n </React.Fragment>\n ]\n }\n\n return [\n <Box key=\"0\" gap={1}>\n <Box>\n <Text color={theme.secondaryText}>{' '}\u23BF </Text>\n </Box>\n {insides.map((_, index) => (\n <Box key={index} flexDirection=\"column\">\n {_}\n </Box>\n ))}\n </Box>,\n ]\n}\n\nfunction format(content: string | undefined, color: string): React.ReactNode {\n if (!content) {\n return null\n }\n return <Text color={color}>{content}</Text>\n}\n"],
|
|
5
|
+
"mappings": "AAAA,YAAY,WAAW;AACvB,SAAS,kBAAkB;AAC3B,SAAS,gBAAgB;AACzB,SAAS,KAAK,YAAY;AAEnB,SAAS,mCAAmC;AAAA,EACjD;AACF,GAEsB;AACpB,QAAM,SAAS,WAAW,SAAS,sBAAsB;AACzD,QAAM,SAAS,WAAW,SAAS,sBAAsB;AACzD,MAAI,CAAC,UAAU,CAAC,QAAQ;AACtB,WAAO,CAAC;AAAA,EACV;AACA,QAAM,QAAQ,SAAS;AACvB,MAAI,UAAU;AAAA,IACZ,OAAO,QAAQ,KAAK,GAAG,MAAM,IAAI;AAAA,IACjC,OAAO,QAAQ,KAAK,GAAG,MAAM,KAAK;AAAA,EACpC,EAAE,OAAO,OAAO;AAEhB,MAAI,QAAQ,WAAW,GAAG;AACxB,cAAU;AAAA,MACR,oCAAC,MAAM,UAAN,EAAe,KAAI,OAClB,oCAAC,YAAK,aAAW,CACnB;AAAA,IACF;AAAA,EACF;AAEA,SAAO;AAAA,IACL,oCAAC,OAAI,KAAI,KAAI,KAAK,KAChB,oCAAC,WACC,oCAAC,QAAK,OAAO,MAAM,iBAAgB,MAAK,SAAE,CAC5C,GACC,QAAQ,IAAI,CAAC,GAAG,UACf,oCAAC,OAAI,KAAK,OAAO,eAAc,YAC5B,CACH,CACD,CACH;AAAA,EACF;AACF;AAEA,SAAS,OAAO,SAA6B,OAAgC;AAC3E,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AACA,SAAO,oCAAC,QAAK,SAAe,OAAQ;AACtC;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { Box, Text } from "ink";
|
|
3
|
+
import { getTheme } from "../../utils/theme.js";
|
|
4
|
+
function AssistantRedactedThinkingMessage({
|
|
5
|
+
addMargin = false
|
|
6
|
+
}) {
|
|
7
|
+
return /* @__PURE__ */ React.createElement(Box, { marginTop: addMargin ? 1 : 0 }, /* @__PURE__ */ React.createElement(Text, { color: getTheme().secondaryText, italic: true }, "\u273B Thinking\u2026"));
|
|
8
|
+
}
|
|
9
|
+
export {
|
|
10
|
+
AssistantRedactedThinkingMessage
|
|
11
|
+
};
|
|
12
|
+
//# sourceMappingURL=AssistantRedactedThinkingMessage.js.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/messages/AssistantRedactedThinkingMessage.tsx"],
|
|
4
|
+
"sourcesContent": ["import React from 'react'\nimport { Box, Text } from 'ink'\nimport { getTheme } from '../../utils/theme'\n\ntype Props = {\n addMargin: boolean\n}\n\nexport function AssistantRedactedThinkingMessage({\n addMargin = false,\n}: Props): React.ReactNode {\n return (\n <Box marginTop={addMargin ? 1 : 0}>\n <Text color={getTheme().secondaryText} italic>\n \u273B Thinking\u2026\n </Text>\n </Box>\n )\n}\n"],
|
|
5
|
+
"mappings": "AAAA,OAAO,WAAW;AAClB,SAAS,KAAK,YAAY;AAC1B,SAAS,gBAAgB;AAMlB,SAAS,iCAAiC;AAAA,EAC/C,YAAY;AACd,GAA2B;AACzB,SACE,oCAAC,OAAI,WAAW,YAAY,IAAI,KAC9B,oCAAC,QAAK,OAAO,SAAS,EAAE,eAAe,QAAM,QAAC,uBAE9C,CACF;AAEJ;",
|
|
6
|
+
"names": []
|
|
7
|
+
}
|