@machina.ai/cell-cli 1.4.0-rc2 → 1.6.1-rc1
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/dist/package.json +12 -8
- package/dist/src/commands/extensions/disable.d.ts +2 -3
- package/dist/src/commands/extensions/disable.js +20 -6
- package/dist/src/commands/extensions/disable.js.map +1 -1
- package/dist/src/commands/extensions/enable.d.ts +2 -3
- package/dist/src/commands/extensions/enable.js +20 -9
- package/dist/src/commands/extensions/enable.js.map +1 -1
- package/dist/src/commands/extensions/install.d.ts +2 -0
- package/dist/src/commands/extensions/install.js +20 -4
- package/dist/src/commands/extensions/install.js.map +1 -1
- package/dist/src/commands/extensions/install.test.js +80 -3
- package/dist/src/commands/extensions/install.test.js.map +1 -1
- package/dist/src/commands/extensions/link.js +1 -1
- package/dist/src/commands/extensions/link.js.map +1 -1
- package/dist/src/commands/extensions/uninstall.js +1 -1
- package/dist/src/commands/extensions/uninstall.js.map +1 -1
- package/dist/src/commands/extensions/update.js +42 -11
- package/dist/src/commands/extensions/update.js.map +1 -1
- package/dist/src/config/config.d.ts +2 -1
- package/dist/src/config/config.js +33 -16
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/extension.d.ts +10 -14
- package/dist/src/config/extension.js +160 -145
- package/dist/src/config/extension.js.map +1 -1
- package/dist/src/config/extensions/extensionEnablement.d.ts +44 -0
- package/dist/src/config/extensions/extensionEnablement.js +161 -0
- package/dist/src/config/extensions/extensionEnablement.js.map +1 -0
- package/dist/src/config/extensions/extensionEnablement.test.js +261 -0
- package/dist/src/config/extensions/extensionEnablement.test.js.map +1 -0
- package/dist/src/config/extensions/github.d.ts +29 -0
- package/dist/src/config/extensions/github.js +306 -0
- package/dist/src/config/extensions/github.js.map +1 -0
- package/dist/src/config/extensions/github.test.d.ts +6 -0
- package/dist/src/config/extensions/github.test.js +267 -0
- package/dist/src/config/extensions/github.test.js.map +1 -0
- package/dist/src/config/extensions/update.d.ts +20 -0
- package/dist/src/config/extensions/update.js +94 -0
- package/dist/src/config/extensions/update.js.map +1 -0
- package/dist/src/config/extensions/update.test.d.ts +6 -0
- package/dist/src/config/extensions/update.test.js +324 -0
- package/dist/src/config/extensions/update.test.js.map +1 -0
- package/dist/src/config/extensions/variableSchema.d.ts +8 -0
- package/dist/src/config/extensions/variableSchema.js +4 -0
- package/dist/src/config/extensions/variableSchema.js.map +1 -1
- package/dist/src/config/keyBindings.d.ts +4 -1
- package/dist/src/config/keyBindings.js +8 -0
- package/dist/src/config/keyBindings.js.map +1 -1
- package/dist/src/config/settings.d.ts +3 -0
- package/dist/src/config/settings.js +58 -18
- package/dist/src/config/settings.js.map +1 -1
- package/dist/src/config/settingsSchema.d.ts +121 -12
- package/dist/src/config/settingsSchema.js +112 -9
- package/dist/src/config/settingsSchema.js.map +1 -1
- package/dist/src/config/settingsSchema.test.js +68 -55
- package/dist/src/config/settingsSchema.test.js.map +1 -1
- package/dist/src/config/trustedFolders.d.ts +1 -1
- package/dist/src/config/trustedFolders.js +9 -4
- package/dist/src/config/trustedFolders.js.map +1 -1
- package/dist/src/config/trustedFolders.test.js +41 -25
- package/dist/src/config/trustedFolders.test.js.map +1 -1
- package/dist/src/core/auth.d.ts +13 -0
- package/dist/src/core/auth.js +27 -0
- package/dist/src/core/auth.js.map +1 -0
- package/dist/src/core/initializer.d.ts +21 -0
- package/dist/src/core/initializer.js +33 -0
- package/dist/src/core/initializer.js.map +1 -0
- package/dist/src/core/theme.d.ts +12 -0
- package/dist/src/core/theme.js +20 -0
- package/dist/src/core/theme.js.map +1 -0
- package/dist/src/gemini.d.ts +2 -1
- package/dist/src/gemini.js +110 -69
- package/dist/src/gemini.js.map +1 -1
- package/dist/src/gemini.test.js +124 -14
- package/dist/src/gemini.test.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/generated/git-commit.js.map +1 -1
- package/dist/src/nonInteractiveCli.js +87 -71
- package/dist/src/nonInteractiveCli.js.map +1 -1
- package/dist/src/services/BuiltinCommandLoader.test.js +16 -17
- package/dist/src/services/BuiltinCommandLoader.test.js.map +1 -1
- package/dist/src/services/FeedbackService.d.ts +21 -0
- package/dist/src/services/FeedbackService.js +124 -0
- package/dist/src/services/FeedbackService.js.map +1 -0
- package/dist/src/services/McpPromptLoader.js +43 -8
- package/dist/src/services/McpPromptLoader.js.map +1 -1
- package/dist/src/services/McpPromptLoader.test.js +228 -1
- package/dist/src/services/McpPromptLoader.test.js.map +1 -1
- package/dist/src/services/prompt-processors/shellProcessor.js +8 -1
- package/dist/src/services/prompt-processors/shellProcessor.js.map +1 -1
- package/dist/src/test-utils/createExtension.d.ts +15 -0
- package/dist/src/test-utils/createExtension.js +25 -0
- package/dist/src/test-utils/createExtension.js.map +1 -0
- package/dist/src/test-utils/mockCommandContext.js +2 -0
- package/dist/src/test-utils/mockCommandContext.js.map +1 -1
- package/dist/src/ui/App.d.ts +1 -10
- package/dist/src/ui/App.js +17 -729
- package/dist/src/ui/App.js.map +1 -1
- package/dist/src/ui/AppContainer.d.ts +17 -0
- package/dist/src/ui/AppContainer.js +905 -0
- package/dist/src/ui/AppContainer.js.map +1 -0
- package/dist/src/ui/AppContainer.test.d.ts +6 -0
- package/dist/src/ui/AppContainer.test.js +422 -0
- package/dist/src/ui/AppContainer.test.js.map +1 -0
- package/dist/src/ui/IdeIntegrationNudge.js +2 -1
- package/dist/src/ui/IdeIntegrationNudge.js.map +1 -1
- package/dist/src/ui/auth/AuthDialog.d.ts +18 -0
- package/dist/src/ui/auth/AuthDialog.js +81 -0
- package/dist/src/ui/auth/AuthDialog.js.map +1 -0
- package/dist/src/ui/auth/AuthDialog.test.d.ts +6 -0
- package/dist/src/ui/auth/AuthDialog.test.js +176 -0
- package/dist/src/ui/auth/AuthDialog.test.js.map +1 -0
- package/dist/src/ui/{components → auth}/AuthInProgress.js +2 -2
- package/dist/src/ui/auth/AuthInProgress.js.map +1 -0
- package/dist/src/ui/auth/useAuth.d.ts +15 -0
- package/dist/src/ui/auth/useAuth.js +73 -0
- package/dist/src/ui/auth/useAuth.js.map +1 -0
- package/dist/src/ui/commands/chatCommand.d.ts +2 -0
- package/dist/src/ui/commands/chatCommand.js +82 -3
- package/dist/src/ui/commands/chatCommand.js.map +1 -1
- package/dist/src/ui/commands/corgiCommand.js +1 -0
- package/dist/src/ui/commands/corgiCommand.js.map +1 -1
- package/dist/src/ui/commands/extensionsCommand.js +86 -16
- package/dist/src/ui/commands/extensionsCommand.js.map +1 -1
- package/dist/src/ui/commands/ideCommand.js +2 -2
- package/dist/src/ui/commands/ideCommand.js.map +1 -1
- package/dist/src/ui/commands/mcpCommand.js +1 -1
- package/dist/src/ui/commands/mcpCommand.js.map +1 -1
- package/dist/src/ui/commands/types.d.ts +5 -1
- package/dist/src/ui/commands/types.js +0 -1
- package/dist/src/ui/commands/types.js.map +1 -1
- package/dist/src/ui/components/AboutBox.js +2 -2
- package/dist/src/ui/components/AboutBox.js.map +1 -1
- package/dist/src/ui/components/AnsiOutput.d.ts +13 -0
- package/dist/src/ui/components/AnsiOutput.js +12 -0
- package/dist/src/ui/components/AnsiOutput.js.map +1 -0
- package/dist/src/ui/components/AnsiOutput.test.d.ts +6 -0
- package/dist/src/ui/components/AnsiOutput.test.js +97 -0
- package/dist/src/ui/components/AnsiOutput.test.js.map +1 -0
- package/dist/src/ui/components/AppHeader.d.ts +10 -0
- package/dist/src/ui/components/AppHeader.js +22 -0
- package/dist/src/ui/components/AppHeader.js.map +1 -0
- package/dist/src/ui/components/AsciiArt.d.ts +3 -3
- package/dist/src/ui/components/AsciiArt.js +3 -3
- package/dist/src/ui/components/AutoAcceptIndicator.js +4 -4
- package/dist/src/ui/components/AutoAcceptIndicator.js.map +1 -1
- package/dist/src/ui/components/Composer.d.ts +6 -0
- package/dist/src/ui/components/Composer.js +74 -0
- package/dist/src/ui/components/Composer.js.map +1 -0
- package/dist/src/ui/components/Composer.test.d.ts +6 -0
- package/dist/src/ui/components/Composer.test.js +340 -0
- package/dist/src/ui/components/Composer.test.js.map +1 -0
- package/dist/src/ui/components/ConfigInitDisplay.d.ts +6 -0
- package/dist/src/ui/components/ConfigInitDisplay.js +38 -0
- package/dist/src/ui/components/ConfigInitDisplay.js.map +1 -0
- package/dist/src/ui/components/ConsoleSummaryDisplay.js +2 -2
- package/dist/src/ui/components/ConsoleSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/ContextSummaryDisplay.js +3 -3
- package/dist/src/ui/components/ContextSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/ContextUsageDisplay.js +2 -2
- package/dist/src/ui/components/ContextUsageDisplay.js.map +1 -1
- package/dist/src/ui/components/DebugProfiler.js +2 -2
- package/dist/src/ui/components/DebugProfiler.js.map +1 -1
- package/dist/src/ui/components/DetailedMessagesDisplay.js +7 -7
- package/dist/src/ui/components/DetailedMessagesDisplay.js.map +1 -1
- package/dist/src/ui/components/DialogManager.d.ts +6 -0
- package/dist/src/ui/components/DialogManager.js +85 -0
- package/dist/src/ui/components/DialogManager.js.map +1 -0
- package/dist/src/ui/components/EditorSettingsDialog.js +5 -5
- package/dist/src/ui/components/EditorSettingsDialog.js.map +1 -1
- package/dist/src/ui/components/FolderTrustDialog.js +16 -8
- package/dist/src/ui/components/FolderTrustDialog.js.map +1 -1
- package/dist/src/ui/components/FolderTrustDialog.test.js +18 -8
- package/dist/src/ui/components/FolderTrustDialog.test.js.map +1 -1
- package/dist/src/ui/components/Footer.d.ts +1 -2
- package/dist/src/ui/components/Footer.js +6 -2
- package/dist/src/ui/components/Footer.js.map +1 -1
- package/dist/src/ui/components/GeminiRespondingSpinner.d.ts +5 -0
- package/dist/src/ui/components/GeminiRespondingSpinner.js +7 -2
- package/dist/src/ui/components/GeminiRespondingSpinner.js.map +1 -1
- package/dist/src/ui/components/Header.js +2 -2
- package/dist/src/ui/components/Header.js.map +1 -1
- package/dist/src/ui/components/Help.d.ts +1 -1
- package/dist/src/ui/components/Help.js +9 -6
- package/dist/src/ui/components/Help.js.map +1 -1
- package/dist/src/ui/components/Help.test.d.ts +6 -0
- package/dist/src/ui/components/Help.test.js +57 -0
- package/dist/src/ui/components/Help.test.js.map +1 -0
- package/dist/src/ui/components/HistoryItemDisplay.d.ts +2 -2
- package/dist/src/ui/components/HistoryItemDisplay.js +2 -1
- package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
- package/dist/src/ui/components/InputPrompt.d.ts +3 -0
- package/dist/src/ui/components/InputPrompt.js +122 -22
- package/dist/src/ui/components/InputPrompt.js.map +1 -1
- package/dist/src/ui/components/LoadingIndicator.js +2 -2
- package/dist/src/ui/components/LoadingIndicator.js.map +1 -1
- package/dist/src/ui/components/LoopDetectionConfirmation.d.ts +13 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.js +35 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.js.map +1 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.test.d.ts +6 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.test.js +25 -0
- package/dist/src/ui/components/LoopDetectionConfirmation.test.js.map +1 -0
- package/dist/src/ui/components/MainContent.d.ts +6 -0
- package/dist/src/ui/components/MainContent.js +23 -0
- package/dist/src/ui/components/MainContent.js.map +1 -0
- package/dist/src/ui/components/MemoryUsageDisplay.js +6 -4
- package/dist/src/ui/components/MemoryUsageDisplay.js.map +1 -1
- package/dist/src/ui/components/ModelStatsDisplay.js +7 -7
- package/dist/src/ui/components/ModelStatsDisplay.js.map +1 -1
- package/dist/src/ui/components/Notifications.d.ts +6 -0
- package/dist/src/ui/components/Notifications.js +23 -0
- package/dist/src/ui/components/Notifications.js.map +1 -0
- package/dist/src/ui/components/PrepareLabel.d.ts +5 -5
- package/dist/src/ui/components/PrepareLabel.js +67 -11
- package/dist/src/ui/components/PrepareLabel.js.map +1 -1
- package/dist/src/ui/components/PrepareLabel.test.d.ts +6 -0
- package/dist/src/ui/components/PrepareLabel.test.js +71 -0
- package/dist/src/ui/components/PrepareLabel.test.js.map +1 -0
- package/dist/src/ui/components/ProQuotaDialog.d.ts +2 -2
- package/dist/src/ui/components/ProQuotaDialog.js +3 -3
- package/dist/src/ui/components/ProQuotaDialog.js.map +1 -1
- package/dist/src/ui/components/ProQuotaDialog.test.js +3 -3
- package/dist/src/ui/components/ProQuotaDialog.test.js.map +1 -1
- package/dist/src/ui/components/QuittingDisplay.d.ts +6 -0
- package/dist/src/ui/components/QuittingDisplay.js +20 -0
- package/dist/src/ui/components/QuittingDisplay.js.map +1 -0
- package/dist/src/ui/components/RatingWidget.d.ts +14 -0
- package/dist/src/ui/components/RatingWidget.js +56 -0
- package/dist/src/ui/components/RatingWidget.js.map +1 -0
- package/dist/src/ui/components/SessionSummaryDisplay.d.ts +4 -0
- package/dist/src/ui/components/SessionSummaryDisplay.js +1 -1
- package/dist/src/ui/components/SessionSummaryDisplay.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.d.ts +2 -1
- package/dist/src/ui/components/SettingsDialog.js +93 -22
- package/dist/src/ui/components/SettingsDialog.js.map +1 -1
- package/dist/src/ui/components/SettingsDialog.test.js +435 -79
- package/dist/src/ui/components/SettingsDialog.test.js.map +1 -1
- package/dist/src/ui/components/ShellConfirmationDialog.js +2 -2
- package/dist/src/ui/components/ShellConfirmationDialog.js.map +1 -1
- package/dist/src/ui/components/ShellInputPrompt.d.ts +11 -0
- package/dist/src/ui/components/ShellInputPrompt.js +36 -0
- package/dist/src/ui/components/ShellInputPrompt.js.map +1 -0
- package/dist/src/ui/components/ShellModeIndicator.js +2 -2
- package/dist/src/ui/components/ShellModeIndicator.js.map +1 -1
- package/dist/src/ui/components/ShowMoreLines.js +2 -2
- package/dist/src/ui/components/ShowMoreLines.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.d.ts +4 -0
- package/dist/src/ui/components/StatsDisplay.js +10 -7
- package/dist/src/ui/components/StatsDisplay.js.map +1 -1
- package/dist/src/ui/components/SuggestionsDisplay.d.ts +7 -2
- package/dist/src/ui/components/SuggestionsDisplay.js +17 -17
- package/dist/src/ui/components/SuggestionsDisplay.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.js +12 -29
- package/dist/src/ui/components/ThemeDialog.js.map +1 -1
- package/dist/src/ui/components/ThemeDialog.test.d.ts +6 -0
- package/dist/src/ui/components/ThemeDialog.test.js +75 -0
- package/dist/src/ui/components/ThemeDialog.test.js.map +1 -0
- package/dist/src/ui/components/Tips.js +2 -2
- package/dist/src/ui/components/Tips.js.map +1 -1
- package/dist/src/ui/components/ToolStatsDisplay.js +4 -4
- package/dist/src/ui/components/ToolStatsDisplay.js.map +1 -1
- package/dist/src/ui/components/UpdateNotification.js +2 -2
- package/dist/src/ui/components/UpdateNotification.js.map +1 -1
- package/dist/src/ui/components/WorkspaceMigrationDialog.js +4 -4
- package/dist/src/ui/components/WorkspaceMigrationDialog.js.map +1 -1
- package/dist/src/ui/components/messages/CompressionMessage.d.ts +1 -2
- package/dist/src/ui/components/messages/CompressionMessage.js +37 -8
- package/dist/src/ui/components/messages/CompressionMessage.js.map +1 -1
- package/dist/src/ui/components/messages/CompressionMessage.test.d.ts +6 -0
- package/dist/src/ui/components/messages/CompressionMessage.test.js +160 -0
- package/dist/src/ui/components/messages/CompressionMessage.test.js.map +1 -0
- package/dist/src/ui/components/messages/DiffRenderer.d.ts +2 -1
- package/dist/src/ui/components/messages/DiffRenderer.js +14 -22
- package/dist/src/ui/components/messages/DiffRenderer.js.map +1 -1
- package/dist/src/ui/components/messages/ErrorMessage.js +2 -2
- package/dist/src/ui/components/messages/ErrorMessage.js.map +1 -1
- package/dist/src/ui/components/messages/GeminiMessage.js +2 -2
- package/dist/src/ui/components/messages/GeminiMessage.js.map +1 -1
- package/dist/src/ui/components/messages/InfoMessage.js +2 -2
- package/dist/src/ui/components/messages/InfoMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js +31 -19
- package/dist/src/ui/components/messages/ToolConfirmationMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +3 -2
- package/dist/src/ui/components/messages/ToolGroupMessage.js +17 -9
- package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js +17 -15
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.d.ts +4 -0
- package/dist/src/ui/components/messages/ToolMessage.js +24 -10
- package/dist/src/ui/components/messages/ToolMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolMessage.test.js +33 -1
- package/dist/src/ui/components/messages/ToolMessage.test.js.map +1 -1
- package/dist/src/ui/components/messages/UserMessage.js +3 -3
- package/dist/src/ui/components/messages/UserMessage.js.map +1 -1
- package/dist/src/ui/components/messages/UserShellMessage.js +2 -2
- package/dist/src/ui/components/messages/UserShellMessage.js.map +1 -1
- package/dist/src/ui/components/shared/EnumSelector.d.ts +18 -0
- package/dist/src/ui/components/shared/EnumSelector.js +44 -0
- package/dist/src/ui/components/shared/EnumSelector.js.map +1 -0
- package/dist/src/ui/components/shared/EnumSelector.test.d.ts +6 -0
- package/dist/src/ui/components/shared/EnumSelector.test.js +70 -0
- package/dist/src/ui/components/shared/EnumSelector.test.js.map +1 -0
- package/dist/src/ui/components/shared/MaxSizedBox.js +2 -2
- package/dist/src/ui/components/shared/MaxSizedBox.js.map +1 -1
- package/dist/src/ui/components/shared/RadioButtonSelect.js +12 -12
- package/dist/src/ui/components/shared/RadioButtonSelect.js.map +1 -1
- package/dist/src/ui/components/shared/ScopeSelector.d.ts +19 -0
- package/dist/src/ui/components/shared/ScopeSelector.js +11 -0
- package/dist/src/ui/components/shared/ScopeSelector.js.map +1 -0
- package/dist/src/ui/components/shared/text-buffer.d.ts +19 -2
- package/dist/src/ui/components/shared/text-buffer.js +191 -133
- package/dist/src/ui/components/shared/text-buffer.js.map +1 -1
- package/dist/src/ui/components/views/ExtensionsList.d.ts +6 -0
- package/dist/src/ui/components/views/ExtensionsList.js +47 -0
- package/dist/src/ui/components/views/ExtensionsList.js.map +1 -0
- package/dist/src/ui/components/views/ExtensionsList.test.d.ts +6 -0
- package/dist/src/ui/components/views/ExtensionsList.test.js +97 -0
- package/dist/src/ui/components/views/ExtensionsList.test.js.map +1 -0
- package/dist/src/ui/constants.d.ts +1 -0
- package/dist/src/ui/constants.js +1 -0
- package/dist/src/ui/constants.js.map +1 -1
- package/dist/src/ui/contexts/AppContext.d.ts +11 -0
- package/dist/src/ui/contexts/AppContext.js +15 -0
- package/dist/src/ui/contexts/AppContext.js.map +1 -0
- package/dist/src/ui/contexts/ConfigContext.d.ts +9 -0
- package/dist/src/ui/contexts/ConfigContext.js +16 -0
- package/dist/src/ui/contexts/ConfigContext.js.map +1 -0
- package/dist/src/ui/contexts/KeypressContext.d.ts +3 -0
- package/dist/src/ui/contexts/KeypressContext.js +51 -2
- package/dist/src/ui/contexts/KeypressContext.js.map +1 -1
- package/dist/src/ui/contexts/KeypressContext.test.js +173 -1
- package/dist/src/ui/contexts/KeypressContext.test.js.map +1 -1
- package/dist/src/ui/contexts/UIActionsContext.d.ts +36 -0
- package/dist/src/ui/contexts/UIActionsContext.js +20 -0
- package/dist/src/ui/contexts/UIActionsContext.js.map +1 -0
- package/dist/src/ui/contexts/UIStateContext.d.ts +103 -0
- package/dist/src/ui/contexts/UIStateContext.js +15 -0
- package/dist/src/ui/contexts/UIStateContext.js.map +1 -0
- package/dist/src/ui/hooks/atCommandProcessor.test.js +7 -5
- package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/keyToAnsi.d.ts +15 -0
- package/dist/src/ui/hooks/keyToAnsi.js +67 -0
- package/dist/src/ui/hooks/keyToAnsi.js.map +1 -0
- package/dist/src/ui/hooks/shellCommandProcessor.d.ts +2 -1
- package/dist/src/ui/hooks/shellCommandProcessor.js +60 -15
- package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/shellCommandProcessor.test.js +196 -17
- package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.d.ts +16 -2
- package/dist/src/ui/hooks/slashCommandProcessor.js +28 -70
- package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/useAutoAcceptIndicator.d.ts +3 -2
- package/dist/src/ui/hooks/useAutoAcceptIndicator.js +9 -5
- package/dist/src/ui/hooks/useAutoAcceptIndicator.js.map +1 -1
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js +69 -0
- package/dist/src/ui/hooks/useAutoAcceptIndicator.test.js.map +1 -1
- package/dist/src/ui/hooks/useExtensionUpdates.d.ts +12 -0
- package/dist/src/ui/hooks/useExtensionUpdates.js +64 -0
- package/dist/src/ui/hooks/useExtensionUpdates.js.map +1 -0
- package/dist/src/ui/hooks/useExtensionUpdates.test.d.ts +6 -0
- package/dist/src/ui/hooks/useExtensionUpdates.test.js +162 -0
- package/dist/src/ui/hooks/useExtensionUpdates.test.js.map +1 -0
- package/dist/src/ui/hooks/useFolderTrust.d.ts +1 -1
- package/dist/src/ui/hooks/useFolderTrust.js +12 -13
- package/dist/src/ui/hooks/useFolderTrust.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.d.ts +11 -1
- package/dist/src/ui/hooks/useGeminiStream.js +124 -59
- package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
- package/dist/src/ui/hooks/useGitBranchName.js +15 -18
- package/dist/src/ui/hooks/useGitBranchName.js.map +1 -1
- package/dist/src/ui/hooks/useGitBranchName.test.js +49 -53
- package/dist/src/ui/hooks/useGitBranchName.test.js.map +1 -1
- package/dist/src/ui/hooks/useIdeTrustListener.js +2 -2
- package/dist/src/ui/hooks/useIdeTrustListener.js.map +1 -1
- package/dist/src/ui/hooks/useMessageQueue.d.ts +2 -1
- package/dist/src/ui/hooks/useMessageQueue.js +5 -3
- package/dist/src/ui/hooks/useMessageQueue.js.map +1 -1
- package/dist/src/ui/hooks/useMessageQueue.test.js +9 -0
- package/dist/src/ui/hooks/useMessageQueue.test.js.map +1 -1
- package/dist/src/ui/hooks/useQuotaAndFallback.d.ts +21 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.js +122 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.js.map +1 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.test.d.ts +6 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.test.js +267 -0
- package/dist/src/ui/hooks/useQuotaAndFallback.test.js.map +1 -0
- package/dist/src/ui/hooks/useReactToolScheduler.d.ts +3 -2
- package/dist/src/ui/hooks/useReactToolScheduler.js +23 -17
- package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
- package/dist/src/ui/hooks/useReverseSearchCompletion.d.ts +1 -1
- package/dist/src/ui/hooks/useReverseSearchCompletion.js +67 -20
- package/dist/src/ui/hooks/useReverseSearchCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.d.ts +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.js +16 -3
- package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.test.js +169 -270
- package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
- package/dist/src/ui/hooks/useThemeCommand.d.ts +1 -1
- package/dist/src/ui/hooks/useThemeCommand.js +3 -14
- package/dist/src/ui/hooks/useThemeCommand.js.map +1 -1
- package/dist/src/ui/hooks/useToolScheduler.test.js +12 -5
- package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
- package/dist/src/ui/keyMatchers.test.js +8 -0
- package/dist/src/ui/keyMatchers.test.js.map +1 -1
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.js +8 -8
- package/dist/src/ui/privacy/CloudFreePrivacyNotice.js.map +1 -1
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js +2 -2
- package/dist/src/ui/privacy/CloudPaidPrivacyNotice.js.map +1 -1
- package/dist/src/ui/privacy/GeminiPrivacyNotice.js +2 -2
- package/dist/src/ui/privacy/GeminiPrivacyNotice.js.map +1 -1
- package/dist/src/ui/state/extensions.d.ts +15 -0
- package/dist/src/ui/state/extensions.js +17 -0
- package/dist/src/ui/state/extensions.js.map +1 -0
- package/dist/src/ui/themes/ayu.js +1 -1
- package/dist/src/ui/themes/dracula.js +2 -2
- package/dist/src/ui/themes/github-dark.js +1 -1
- package/dist/src/ui/themes/theme.js +17 -17
- package/dist/src/ui/themes/theme.js.map +1 -1
- package/dist/src/ui/types.d.ts +29 -3
- package/dist/src/ui/types.js +11 -0
- package/dist/src/ui/types.js.map +1 -1
- package/dist/src/ui/utils/CodeColorizer.js +3 -2
- package/dist/src/ui/utils/CodeColorizer.js.map +1 -1
- package/dist/src/ui/utils/InlineMarkdownRenderer.js +7 -7
- package/dist/src/ui/utils/InlineMarkdownRenderer.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.js +10 -10
- package/dist/src/ui/utils/MarkdownDisplay.js.map +1 -1
- package/dist/src/ui/utils/MarkdownDisplay.test.js +6 -2
- package/dist/src/ui/utils/MarkdownDisplay.test.js.map +1 -1
- package/dist/src/ui/utils/TableRenderer.js +4 -4
- package/dist/src/ui/utils/TableRenderer.js.map +1 -1
- package/dist/src/ui/utils/clipboardUtils.js +5 -6
- package/dist/src/ui/utils/clipboardUtils.js.map +1 -1
- package/dist/src/ui/utils/displayUtils.js +4 -4
- package/dist/src/ui/utils/displayUtils.js.map +1 -1
- package/dist/src/ui/utils/highlight.d.ts +1 -1
- package/dist/src/ui/utils/highlight.js +15 -6
- package/dist/src/ui/utils/highlight.js.map +1 -1
- package/dist/src/ui/utils/highlight.test.js +56 -29
- package/dist/src/ui/utils/highlight.test.js.map +1 -1
- package/dist/src/ui/utils/kittyProtocolDetector.js +39 -29
- package/dist/src/ui/utils/kittyProtocolDetector.js.map +1 -1
- package/dist/src/ui/utils/textUtils.d.ts +9 -0
- package/dist/src/ui/utils/textUtils.js +52 -3
- package/dist/src/ui/utils/textUtils.js.map +1 -1
- package/dist/src/utils/commands.d.ts +20 -0
- package/dist/src/utils/commands.js +53 -0
- package/dist/src/utils/commands.js.map +1 -0
- package/dist/src/utils/commands.test.d.ts +6 -0
- package/dist/src/utils/commands.test.js +115 -0
- package/dist/src/utils/commands.test.js.map +1 -0
- package/dist/src/utils/commentJson.d.ts +9 -0
- package/dist/src/utils/commentJson.js +48 -0
- package/dist/src/utils/commentJson.js.map +1 -0
- package/dist/src/utils/commentJson.test.d.ts +6 -0
- package/dist/src/utils/commentJson.test.js +146 -0
- package/dist/src/utils/commentJson.test.js.map +1 -0
- package/dist/src/utils/errors.d.ts +21 -0
- package/dist/src/utils/errors.js +93 -0
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/errors.test.d.ts +6 -0
- package/dist/src/utils/errors.test.js +303 -0
- package/dist/src/utils/errors.test.js.map +1 -0
- package/dist/src/utils/processUtils.d.ts +13 -0
- package/dist/src/utils/processUtils.js +18 -0
- package/dist/src/utils/processUtils.js.map +1 -0
- package/dist/src/utils/processUtils.test.d.ts +6 -0
- package/dist/src/utils/processUtils.test.js +20 -0
- package/dist/src/utils/processUtils.test.js.map +1 -0
- package/dist/src/utils/sandbox.d.ts +1 -1
- package/dist/src/utils/sandbox.js +19 -8
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/utils/settingsUtils.d.ts +16 -6
- package/dist/src/utils/settingsUtils.js +35 -25
- package/dist/src/utils/settingsUtils.js.map +1 -1
- package/dist/src/utils/settingsUtils.test.js +455 -158
- package/dist/src/utils/settingsUtils.test.js.map +1 -1
- package/dist/src/zed-integration/schema.d.ts +596 -596
- package/dist/src/zed-integration/zedIntegration.js +10 -7
- package/dist/src/zed-integration/zedIntegration.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +13 -9
- package/dist/src/ui/components/AuthDialog.d.ts +0 -16
- package/dist/src/ui/components/AuthDialog.js +0 -62
- package/dist/src/ui/components/AuthDialog.js.map +0 -1
- package/dist/src/ui/components/AuthDialog.test.js +0 -175
- package/dist/src/ui/components/AuthDialog.test.js.map +0 -1
- package/dist/src/ui/components/AuthInProgress.js.map +0 -1
- package/dist/src/ui/hooks/useAuthCommand.d.ts +0 -15
- package/dist/src/ui/hooks/useAuthCommand.js +0 -68
- package/dist/src/ui/hooks/useAuthCommand.js.map +0 -1
- /package/dist/src/{ui/components/AuthDialog.test.d.ts → config/extensions/extensionEnablement.test.d.ts} +0 -0
- /package/dist/src/ui/{components → auth}/AuthInProgress.d.ts +0 -0
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2025 Google LLC
|
|
4
|
+
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
+
*/
|
|
6
|
+
import { vi } from 'vitest';
|
|
7
|
+
import * as fs from 'node:fs';
|
|
8
|
+
import * as os from 'node:os';
|
|
9
|
+
import * as path from 'node:path';
|
|
10
|
+
import { EXTENSIONS_CONFIG_FILENAME, annotateActiveExtensions, loadExtension, } from '../../config/extension.js';
|
|
11
|
+
import { createExtension } from '../../test-utils/createExtension.js';
|
|
12
|
+
import { useExtensionUpdates } from './useExtensionUpdates.js';
|
|
13
|
+
import { CELL_DIR } from '@google/gemini-cli-core';
|
|
14
|
+
import { isWorkspaceTrusted } from '../../config/trustedFolders.js';
|
|
15
|
+
import { renderHook, waitFor } from '@testing-library/react';
|
|
16
|
+
import { MessageType } from '../types.js';
|
|
17
|
+
const mockGit = {
|
|
18
|
+
clone: vi.fn(),
|
|
19
|
+
getRemotes: vi.fn(),
|
|
20
|
+
fetch: vi.fn(),
|
|
21
|
+
checkout: vi.fn(),
|
|
22
|
+
listRemote: vi.fn(),
|
|
23
|
+
revparse: vi.fn(),
|
|
24
|
+
// Not a part of the actual API, but we need to use this to do the correct
|
|
25
|
+
// file system interactions.
|
|
26
|
+
path: vi.fn(),
|
|
27
|
+
};
|
|
28
|
+
vi.mock('simple-git', () => ({
|
|
29
|
+
simpleGit: vi.fn((path) => {
|
|
30
|
+
mockGit.path.mockReturnValue(path);
|
|
31
|
+
return mockGit;
|
|
32
|
+
}),
|
|
33
|
+
}));
|
|
34
|
+
vi.mock('os', async (importOriginal) => {
|
|
35
|
+
const mockedOs = await importOriginal();
|
|
36
|
+
return {
|
|
37
|
+
...mockedOs,
|
|
38
|
+
homedir: vi.fn(),
|
|
39
|
+
};
|
|
40
|
+
});
|
|
41
|
+
vi.mock('../../config/trustedFolders.js', async (importOriginal) => {
|
|
42
|
+
const actual = await importOriginal();
|
|
43
|
+
return {
|
|
44
|
+
...actual,
|
|
45
|
+
isWorkspaceTrusted: vi.fn(),
|
|
46
|
+
};
|
|
47
|
+
});
|
|
48
|
+
const mockLogExtensionInstallEvent = vi.hoisted(() => vi.fn());
|
|
49
|
+
const mockLogExtensionUninstall = vi.hoisted(() => vi.fn());
|
|
50
|
+
vi.mock('@google/gemini-cli-core', async (importOriginal) => {
|
|
51
|
+
const actual = await importOriginal();
|
|
52
|
+
return {
|
|
53
|
+
...actual,
|
|
54
|
+
logExtensionInstallEvent: mockLogExtensionInstallEvent,
|
|
55
|
+
logExtensionUninstall: mockLogExtensionUninstall,
|
|
56
|
+
ExtensionInstallEvent: vi.fn(),
|
|
57
|
+
ExtensionUninstallEvent: vi.fn(),
|
|
58
|
+
};
|
|
59
|
+
});
|
|
60
|
+
vi.mock('child_process', async (importOriginal) => {
|
|
61
|
+
const actual = await importOriginal();
|
|
62
|
+
return {
|
|
63
|
+
...actual,
|
|
64
|
+
execSync: vi.fn(),
|
|
65
|
+
};
|
|
66
|
+
});
|
|
67
|
+
const mockQuestion = vi.hoisted(() => vi.fn());
|
|
68
|
+
const mockClose = vi.hoisted(() => vi.fn());
|
|
69
|
+
vi.mock('node:readline', () => ({
|
|
70
|
+
createInterface: vi.fn(() => ({
|
|
71
|
+
question: mockQuestion,
|
|
72
|
+
close: mockClose,
|
|
73
|
+
})),
|
|
74
|
+
}));
|
|
75
|
+
describe('useExtensionUpdates', () => {
|
|
76
|
+
let tempHomeDir;
|
|
77
|
+
let userExtensionsDir;
|
|
78
|
+
beforeEach(() => {
|
|
79
|
+
tempHomeDir = fs.mkdtempSync(path.join(os.tmpdir(), 'cell-cli-test-home-'));
|
|
80
|
+
vi.mocked(os.homedir).mockReturnValue(tempHomeDir);
|
|
81
|
+
userExtensionsDir = path.join(tempHomeDir, CELL_DIR, 'extensions');
|
|
82
|
+
fs.mkdirSync(userExtensionsDir, { recursive: true });
|
|
83
|
+
Object.values(mockGit).forEach((fn) => fn.mockReset());
|
|
84
|
+
});
|
|
85
|
+
afterEach(() => {
|
|
86
|
+
fs.rmSync(tempHomeDir, { recursive: true, force: true });
|
|
87
|
+
});
|
|
88
|
+
it('should check for updates and log a message if an update is available', async () => {
|
|
89
|
+
const extensions = [
|
|
90
|
+
{
|
|
91
|
+
name: 'test-extension',
|
|
92
|
+
type: 'git',
|
|
93
|
+
version: '1.0.0',
|
|
94
|
+
path: '/some/path',
|
|
95
|
+
isActive: true,
|
|
96
|
+
installMetadata: {
|
|
97
|
+
type: 'git',
|
|
98
|
+
source: 'https://some/repo',
|
|
99
|
+
autoUpdate: false,
|
|
100
|
+
},
|
|
101
|
+
},
|
|
102
|
+
];
|
|
103
|
+
const addItem = vi.fn();
|
|
104
|
+
const cwd = '/test/cwd';
|
|
105
|
+
mockGit.getRemotes.mockResolvedValue([
|
|
106
|
+
{
|
|
107
|
+
name: 'origin',
|
|
108
|
+
refs: {
|
|
109
|
+
fetch: 'https://github.com/google/gemini-cli.git',
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
]);
|
|
113
|
+
mockGit.revparse.mockResolvedValue('local-hash');
|
|
114
|
+
mockGit.listRemote.mockResolvedValue('remote-hash\tHEAD');
|
|
115
|
+
renderHook(() => useExtensionUpdates(extensions, addItem, cwd));
|
|
116
|
+
await waitFor(() => {
|
|
117
|
+
expect(addItem).toHaveBeenCalledWith({
|
|
118
|
+
type: MessageType.INFO,
|
|
119
|
+
text: 'Extension test-extension has an update available, run "/extensions update test-extension" to install it.',
|
|
120
|
+
}, expect.any(Number));
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
it('should check for updates and automatically update if autoUpdate is true', async () => {
|
|
124
|
+
const extensionDir = createExtension({
|
|
125
|
+
extensionsDir: userExtensionsDir,
|
|
126
|
+
name: 'test-extension',
|
|
127
|
+
version: '1.0.0',
|
|
128
|
+
installMetadata: {
|
|
129
|
+
source: 'https://some.git/repo',
|
|
130
|
+
type: 'git',
|
|
131
|
+
autoUpdate: true,
|
|
132
|
+
},
|
|
133
|
+
});
|
|
134
|
+
const extension = annotateActiveExtensions([loadExtension({ extensionDir, workspaceDir: tempHomeDir })], [], tempHomeDir)[0];
|
|
135
|
+
const addItem = vi.fn();
|
|
136
|
+
mockGit.getRemotes.mockResolvedValue([
|
|
137
|
+
{
|
|
138
|
+
name: 'origin',
|
|
139
|
+
refs: {
|
|
140
|
+
fetch: 'https://github.com/google/gemini-cli.git',
|
|
141
|
+
},
|
|
142
|
+
},
|
|
143
|
+
]);
|
|
144
|
+
mockGit.revparse.mockResolvedValue('local-hash');
|
|
145
|
+
mockGit.listRemote.mockResolvedValue('remote-hash\tHEAD');
|
|
146
|
+
mockGit.clone.mockImplementation(async (_, destination) => {
|
|
147
|
+
fs.mkdirSync(path.join(mockGit.path(), destination), {
|
|
148
|
+
recursive: true,
|
|
149
|
+
});
|
|
150
|
+
fs.writeFileSync(path.join(mockGit.path(), destination, EXTENSIONS_CONFIG_FILENAME), JSON.stringify({ name: 'test-extension', version: '1.1.0' }));
|
|
151
|
+
});
|
|
152
|
+
vi.mocked(isWorkspaceTrusted).mockReturnValue(true);
|
|
153
|
+
renderHook(() => useExtensionUpdates([extension], addItem, tempHomeDir));
|
|
154
|
+
await waitFor(() => {
|
|
155
|
+
expect(addItem).toHaveBeenCalledWith({
|
|
156
|
+
type: MessageType.INFO,
|
|
157
|
+
text: 'Extension "test-extension" successfully updated: 1.0.0 → 1.1.0.',
|
|
158
|
+
}, expect.any(Number));
|
|
159
|
+
}, { timeout: 2000 });
|
|
160
|
+
});
|
|
161
|
+
});
|
|
162
|
+
//# sourceMappingURL=useExtensionUpdates.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useExtensionUpdates.test.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useExtensionUpdates.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
*/
|
|
6
6
|
import type { LoadedSettings } from '../../config/settings.js';
|
|
7
7
|
import { FolderTrustChoice } from '../components/FolderTrustDialog.js';
|
|
8
|
-
export declare const useFolderTrust: (settings: LoadedSettings, onTrustChange: (isTrusted: boolean | undefined) => void) => {
|
|
8
|
+
export declare const useFolderTrust: (settings: LoadedSettings, onTrustChange: (isTrusted: boolean | undefined) => void, refreshStatic: () => void) => {
|
|
9
9
|
isTrusted: boolean | undefined;
|
|
10
10
|
isFolderTrustDialogOpen: boolean;
|
|
11
11
|
handleFolderTrustSelect: (choice: FolderTrustChoice) => void;
|
|
@@ -7,23 +7,22 @@ import { useState, useCallback, useEffect } from 'react';
|
|
|
7
7
|
import { FolderTrustChoice } from '../components/FolderTrustDialog.js';
|
|
8
8
|
import { loadTrustedFolders, TrustLevel, isWorkspaceTrusted, } from '../../config/trustedFolders.js';
|
|
9
9
|
import * as process from 'node:process';
|
|
10
|
-
export const useFolderTrust = (settings, onTrustChange) => {
|
|
10
|
+
export const useFolderTrust = (settings, onTrustChange, refreshStatic) => {
|
|
11
11
|
const [isTrusted, setIsTrusted] = useState(undefined);
|
|
12
12
|
const [isFolderTrustDialogOpen, setIsFolderTrustDialogOpen] = useState(false);
|
|
13
13
|
const [isRestarting, setIsRestarting] = useState(false);
|
|
14
14
|
const folderTrust = settings.merged.security?.folderTrust?.enabled;
|
|
15
15
|
useEffect(() => {
|
|
16
|
-
const trusted = isWorkspaceTrusted(
|
|
17
|
-
security: {
|
|
18
|
-
folderTrust: {
|
|
19
|
-
enabled: folderTrust,
|
|
20
|
-
},
|
|
21
|
-
},
|
|
22
|
-
});
|
|
16
|
+
const trusted = isWorkspaceTrusted(settings.merged);
|
|
23
17
|
setIsTrusted(trusted);
|
|
24
18
|
setIsFolderTrustDialogOpen(trusted === undefined);
|
|
25
19
|
onTrustChange(trusted);
|
|
26
|
-
}, [onTrustChange,
|
|
20
|
+
}, [folderTrust, onTrustChange, settings.merged]);
|
|
21
|
+
useEffect(() => {
|
|
22
|
+
// When the folder trust dialog is about to open/close, we need to force a refresh
|
|
23
|
+
// of the static content to ensure the Tips are hidden/shown correctly.
|
|
24
|
+
refreshStatic();
|
|
25
|
+
}, [isFolderTrustDialogOpen, refreshStatic]);
|
|
27
26
|
const handleFolderTrustSelect = useCallback((choice) => {
|
|
28
27
|
const trustedFolders = loadTrustedFolders();
|
|
29
28
|
const cwd = process.cwd();
|
|
@@ -43,11 +42,11 @@ export const useFolderTrust = (settings, onTrustChange) => {
|
|
|
43
42
|
return;
|
|
44
43
|
}
|
|
45
44
|
trustedFolders.setValue(cwd, trustLevel);
|
|
46
|
-
const
|
|
45
|
+
const currentIsTrusted = trustLevel === TrustLevel.TRUST_FOLDER ||
|
|
47
46
|
trustLevel === TrustLevel.TRUST_PARENT;
|
|
48
|
-
setIsTrusted(
|
|
49
|
-
onTrustChange(
|
|
50
|
-
const needsRestart = wasTrusted !==
|
|
47
|
+
setIsTrusted(currentIsTrusted);
|
|
48
|
+
onTrustChange(currentIsTrusted);
|
|
49
|
+
const needsRestart = wasTrusted !== currentIsTrusted;
|
|
51
50
|
if (needsRestart) {
|
|
52
51
|
setIsRestarting(true);
|
|
53
52
|
setIsFolderTrustDialogOpen(true);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useFolderTrust.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useFolderTrust.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EACL,kBAAkB,EAClB,UAAU,EACV,kBAAkB,GACnB,MAAM,gCAAgC,CAAC;AACxC,OAAO,KAAK,OAAO,MAAM,cAAc,CAAC;AAExC,MAAM,CAAC,MAAM,cAAc,GAAG,CAC5B,QAAwB,EACxB,aAAuD,EACvD,EAAE;IACF,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAsB,SAAS,CAAC,CAAC;IAC3E,MAAM,CAAC,uBAAuB,EAAE,0BAA0B,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9E,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAExD,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,CAAC;IAEnE,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,OAAO,GAAG,kBAAkB,CAAC
|
|
1
|
+
{"version":3,"file":"useFolderTrust.js","sourceRoot":"","sources":["../../../../src/ui/hooks/useFolderTrust.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,QAAQ,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EACL,kBAAkB,EAClB,UAAU,EACV,kBAAkB,GACnB,MAAM,gCAAgC,CAAC;AACxC,OAAO,KAAK,OAAO,MAAM,cAAc,CAAC;AAExC,MAAM,CAAC,MAAM,cAAc,GAAG,CAC5B,QAAwB,EACxB,aAAuD,EACvD,aAAyB,EACzB,EAAE;IACF,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAsB,SAAS,CAAC,CAAC;IAC3E,MAAM,CAAC,uBAAuB,EAAE,0BAA0B,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC9E,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAExD,MAAM,WAAW,GAAG,QAAQ,CAAC,MAAM,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,CAAC;IAEnE,SAAS,CAAC,GAAG,EAAE;QACb,MAAM,OAAO,GAAG,kBAAkB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACpD,YAAY,CAAC,OAAO,CAAC,CAAC;QACtB,0BAA0B,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC;QAClD,aAAa,CAAC,OAAO,CAAC,CAAC;IACzB,CAAC,EAAE,CAAC,WAAW,EAAE,aAAa,EAAE,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;IAElD,SAAS,CAAC,GAAG,EAAE;QACb,kFAAkF;QAClF,uEAAuE;QACvE,aAAa,EAAE,CAAC;IAClB,CAAC,EAAE,CAAC,uBAAuB,EAAE,aAAa,CAAC,CAAC,CAAC;IAE7C,MAAM,uBAAuB,GAAG,WAAW,CACzC,CAAC,MAAyB,EAAE,EAAE;QAC5B,MAAM,cAAc,GAAG,kBAAkB,EAAE,CAAC;QAC5C,MAAM,GAAG,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC;QAC1B,IAAI,UAAsB,CAAC;QAE3B,MAAM,UAAU,GAAG,SAAS,IAAI,IAAI,CAAC;QAErC,QAAQ,MAAM,EAAE,CAAC;YACf,KAAK,iBAAiB,CAAC,YAAY;gBACjC,UAAU,GAAG,UAAU,CAAC,YAAY,CAAC;gBACrC,MAAM;YACR,KAAK,iBAAiB,CAAC,YAAY;gBACjC,UAAU,GAAG,UAAU,CAAC,YAAY,CAAC;gBACrC,MAAM;YACR,KAAK,iBAAiB,CAAC,YAAY;gBACjC,UAAU,GAAG,UAAU,CAAC,YAAY,CAAC;gBACrC,MAAM;YACR;gBACE,OAAO;QACX,CAAC;QAED,cAAc,CAAC,QAAQ,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;QACzC,MAAM,gBAAgB,GACpB,UAAU,KAAK,UAAU,CAAC,YAAY;YACtC,UAAU,KAAK,UAAU,CAAC,YAAY,CAAC;QACzC,YAAY,CAAC,gBAAgB,CAAC,CAAC;QAC/B,aAAa,CAAC,gBAAgB,CAAC,CAAC;QAEhC,MAAM,YAAY,GAAG,UAAU,KAAK,gBAAgB,CAAC;QACrD,IAAI,YAAY,EAAE,CAAC;YACjB,eAAe,CAAC,IAAI,CAAC,CAAC;YACtB,0BAA0B,CAAC,IAAI,CAAC,CAAC;QACnC,CAAC;aAAM,CAAC;YACN,0BAA0B,CAAC,KAAK,CAAC,CAAC;QACpC,CAAC;IACH,CAAC,EACD,CAAC,aAAa,EAAE,SAAS,CAAC,CAC3B,CAAC;IAEF,OAAO;QACL,SAAS;QACT,uBAAuB;QACvB,uBAAuB;QACvB,YAAY;KACb,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -4,16 +4,18 @@
|
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
6
|
import type { Config, EditorType, GeminiClient, ThoughtSummary } from '@google/gemini-cli-core';
|
|
7
|
+
import { ApprovalMode } from '@google/gemini-cli-core';
|
|
7
8
|
import { type PartListUnion } from '@google/genai';
|
|
8
9
|
import type { HistoryItem, HistoryItemWithoutId, SlashCommandProcessorResult } from '../types.js';
|
|
9
10
|
import { StreamingState } from '../types.js';
|
|
10
11
|
import type { UseHistoryManagerReturn } from './useHistoryManager.js';
|
|
12
|
+
import { type TrackedToolCall } from './useReactToolScheduler.js';
|
|
11
13
|
import type { LoadedSettings } from '../../config/settings.js';
|
|
12
14
|
/**
|
|
13
15
|
* Manages the Gemini stream, including user input, command processing,
|
|
14
16
|
* API interaction, and tool call lifecycle.
|
|
15
17
|
*/
|
|
16
|
-
export declare const useGeminiStream: (geminiClient: GeminiClient, history: HistoryItem[], addItem: UseHistoryManagerReturn["addItem"], config: Config, settings: LoadedSettings, onDebugMessage: (message: string) => void, handleSlashCommand: (cmd: PartListUnion) => Promise<SlashCommandProcessorResult | false>, shellModeActive: boolean, getPreferredEditor: () => EditorType | undefined, onAuthError: () => void, performMemoryRefresh: () => Promise<void>, modelSwitchedFromQuotaError: boolean, setModelSwitchedFromQuotaError: React.Dispatch<React.SetStateAction<boolean>>, onEditorClose: () => void, onCancelSubmit: () => void) => {
|
|
18
|
+
export declare const useGeminiStream: (geminiClient: GeminiClient, history: HistoryItem[], addItem: UseHistoryManagerReturn["addItem"], config: Config, settings: LoadedSettings, onDebugMessage: (message: string) => void, handleSlashCommand: (cmd: PartListUnion) => Promise<SlashCommandProcessorResult | false>, shellModeActive: boolean, getPreferredEditor: () => EditorType | undefined, onAuthError: (error: string) => void, performMemoryRefresh: () => Promise<void>, modelSwitchedFromQuotaError: boolean, setModelSwitchedFromQuotaError: React.Dispatch<React.SetStateAction<boolean>>, onEditorClose: () => void, onCancelSubmit: () => void, setShellInputFocused: (value: boolean) => void, terminalWidth: number, terminalHeight: number, isShellFocused?: boolean) => {
|
|
17
19
|
streamingState: StreamingState;
|
|
18
20
|
submitQuery: (query: PartListUnion, options?: {
|
|
19
21
|
isContinuation: boolean;
|
|
@@ -22,4 +24,12 @@ export declare const useGeminiStream: (geminiClient: GeminiClient, history: Hist
|
|
|
22
24
|
pendingHistoryItems: HistoryItemWithoutId[];
|
|
23
25
|
thought: ThoughtSummary | null;
|
|
24
26
|
cancelOngoingRequest: () => void;
|
|
27
|
+
pendingToolCalls: TrackedToolCall[];
|
|
28
|
+
handleApprovalModeChange: (newApprovalMode: ApprovalMode) => Promise<void>;
|
|
29
|
+
activePtyId: number | undefined;
|
|
30
|
+
loopDetectionConfirmationRequest: {
|
|
31
|
+
onComplete: (result: {
|
|
32
|
+
userSelection: "disable" | "keep";
|
|
33
|
+
}) => void;
|
|
34
|
+
} | null;
|
|
25
35
|
};
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
6
|
import { useState, useRef, useCallback, useEffect, useMemo } from 'react';
|
|
7
|
-
import { GeminiEventType as ServerGeminiEventType, getErrorMessage, isNodeError, MessageSenderType, logUserPrompt, GitService, UnauthorizedError, UserPromptEvent, DEFAULT_GEMINI_FLASH_MODEL, logConversationFinishedEvent, ConversationFinishedEvent, ApprovalMode, parseAndFormatApiError,
|
|
7
|
+
import { GeminiEventType as ServerGeminiEventType, getErrorMessage, isNodeError, MessageSenderType, logUserPrompt, GitService, UnauthorizedError, UserPromptEvent, DEFAULT_GEMINI_FLASH_MODEL, logConversationFinishedEvent, ConversationFinishedEvent, ApprovalMode, parseAndFormatApiError, ToolConfirmationOutcome, promptIdContext, } from '@google/gemini-cli-core';
|
|
8
8
|
import { FinishReason } from '@google/genai';
|
|
9
9
|
import { StreamingState, MessageType, ToolCallStatus } from '../types.js';
|
|
10
10
|
import { isAtCommand, isSlashCommand } from '../utils/commandUtils.js';
|
|
@@ -13,9 +13,9 @@ import { handleAtCommand } from './atCommandProcessor.js';
|
|
|
13
13
|
import { findLastSafeSplitPoint } from '../utils/markdownUtilities.js';
|
|
14
14
|
import { useStateAndRef } from './useStateAndRef.js';
|
|
15
15
|
import { useLogger } from './useLogger.js';
|
|
16
|
+
import { useReactToolScheduler, mapToDisplay as mapTrackedToolCallsToDisplay, } from './useReactToolScheduler.js';
|
|
16
17
|
import { promises as fs } from 'node:fs';
|
|
17
18
|
import path from 'node:path';
|
|
18
|
-
import { useReactToolScheduler, mapToDisplay as mapTrackedToolCallsToDisplay, } from './useReactToolScheduler.js';
|
|
19
19
|
import { useSessionStats } from '../contexts/SessionContext.js';
|
|
20
20
|
import { useKeypress } from './useKeypress.js';
|
|
21
21
|
var StreamProcessingStatus;
|
|
@@ -24,19 +24,19 @@ var StreamProcessingStatus;
|
|
|
24
24
|
StreamProcessingStatus[StreamProcessingStatus["UserCancelled"] = 1] = "UserCancelled";
|
|
25
25
|
StreamProcessingStatus[StreamProcessingStatus["Error"] = 2] = "Error";
|
|
26
26
|
})(StreamProcessingStatus || (StreamProcessingStatus = {}));
|
|
27
|
-
|
|
27
|
+
const EDIT_TOOL_NAMES = new Set(['replace', 'write_file']);
|
|
28
|
+
function showCitations(settings) {
|
|
28
29
|
const enabled = settings?.merged?.ui?.showCitations;
|
|
29
30
|
if (enabled !== undefined) {
|
|
30
31
|
return enabled;
|
|
31
32
|
}
|
|
32
|
-
|
|
33
|
-
return (server && server.userTier !== UserTierId.FREE) ?? false;
|
|
33
|
+
return true;
|
|
34
34
|
}
|
|
35
35
|
/**
|
|
36
36
|
* Manages the Gemini stream, including user input, command processing,
|
|
37
37
|
* API interaction, and tool call lifecycle.
|
|
38
38
|
*/
|
|
39
|
-
export const useGeminiStream = (geminiClient, history, addItem, config, settings, onDebugMessage, handleSlashCommand, shellModeActive, getPreferredEditor, onAuthError, performMemoryRefresh, modelSwitchedFromQuotaError, setModelSwitchedFromQuotaError, onEditorClose, onCancelSubmit) => {
|
|
39
|
+
export const useGeminiStream = (geminiClient, history, addItem, config, settings, onDebugMessage, handleSlashCommand, shellModeActive, getPreferredEditor, onAuthError, performMemoryRefresh, modelSwitchedFromQuotaError, setModelSwitchedFromQuotaError, onEditorClose, onCancelSubmit, setShellInputFocused, terminalWidth, terminalHeight, isShellFocused) => {
|
|
40
40
|
const [initError, setInitError] = useState(null);
|
|
41
41
|
const abortControllerRef = useRef(null);
|
|
42
42
|
const turnCancelledRef = useRef(false);
|
|
@@ -61,15 +61,29 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
61
61
|
// Handle tool response submission immediately when tools complete
|
|
62
62
|
await handleCompletedTools(completedToolCallsFromScheduler);
|
|
63
63
|
}
|
|
64
|
-
}, config,
|
|
64
|
+
}, config, getPreferredEditor, onEditorClose);
|
|
65
65
|
const pendingToolCallGroupDisplay = useMemo(() => toolCalls.length ? mapTrackedToolCallsToDisplay(toolCalls) : undefined, [toolCalls]);
|
|
66
|
+
const activeToolPtyId = useMemo(() => {
|
|
67
|
+
const executingShellTool = toolCalls?.find((tc) => tc.status === 'executing' && tc.request.name === 'run_shell_command');
|
|
68
|
+
if (executingShellTool) {
|
|
69
|
+
return executingShellTool.pid;
|
|
70
|
+
}
|
|
71
|
+
return undefined;
|
|
72
|
+
}, [toolCalls]);
|
|
66
73
|
const loopDetectedRef = useRef(false);
|
|
74
|
+
const [loopDetectionConfirmationRequest, setLoopDetectionConfirmationRequest,] = useState(null);
|
|
67
75
|
const onExec = useCallback(async (done) => {
|
|
68
76
|
setIsResponding(true);
|
|
69
77
|
await done;
|
|
70
78
|
setIsResponding(false);
|
|
71
79
|
}, []);
|
|
72
|
-
const { handleShellCommand } = useShellCommandProcessor(addItem, setPendingHistoryItem, onExec, onDebugMessage, config, geminiClient);
|
|
80
|
+
const { handleShellCommand, activeShellPtyId } = useShellCommandProcessor(addItem, setPendingHistoryItem, onExec, onDebugMessage, config, geminiClient, setShellInputFocused, terminalWidth, terminalHeight);
|
|
81
|
+
const activePtyId = activeShellPtyId || activeToolPtyId;
|
|
82
|
+
useEffect(() => {
|
|
83
|
+
if (!activePtyId) {
|
|
84
|
+
setShellInputFocused(false);
|
|
85
|
+
}
|
|
86
|
+
}, [activePtyId, setShellInputFocused]);
|
|
73
87
|
const streamingState = useMemo(() => {
|
|
74
88
|
if (toolCalls.some((tc) => tc.status === 'awaiting_approval')) {
|
|
75
89
|
return StreamingState.WaitingForConfirmation;
|
|
@@ -116,15 +130,17 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
116
130
|
setPendingHistoryItem(null);
|
|
117
131
|
onCancelSubmit();
|
|
118
132
|
setIsResponding(false);
|
|
133
|
+
setShellInputFocused(false);
|
|
119
134
|
}, [
|
|
120
135
|
streamingState,
|
|
121
136
|
addItem,
|
|
122
137
|
setPendingHistoryItem,
|
|
123
138
|
onCancelSubmit,
|
|
124
139
|
pendingHistoryItemRef,
|
|
140
|
+
setShellInputFocused,
|
|
125
141
|
]);
|
|
126
142
|
useKeypress((key) => {
|
|
127
|
-
if (key.name === 'escape') {
|
|
143
|
+
if (key.name === 'escape' && !isShellFocused) {
|
|
128
144
|
cancelOngoingRequest();
|
|
129
145
|
}
|
|
130
146
|
}, { isActive: streamingState === StreamingState.Responding });
|
|
@@ -303,7 +319,7 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
303
319
|
setThought(null); // Reset thought when there's an error
|
|
304
320
|
}, [addItem, pendingHistoryItemRef, setPendingHistoryItem, config, setThought]);
|
|
305
321
|
const handleCitationEvent = useCallback((text, userMessageTimestamp) => {
|
|
306
|
-
if (!showCitations(settings
|
|
322
|
+
if (!showCitations(settings)) {
|
|
307
323
|
return;
|
|
308
324
|
}
|
|
309
325
|
if (pendingHistoryItemRef.current) {
|
|
@@ -311,7 +327,7 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
311
327
|
setPendingHistoryItem(null);
|
|
312
328
|
}
|
|
313
329
|
addItem({ type: MessageType.INFO, text }, userMessageTimestamp);
|
|
314
|
-
}, [addItem, pendingHistoryItemRef, setPendingHistoryItem, settings
|
|
330
|
+
}, [addItem, pendingHistoryItemRef, setPendingHistoryItem, settings]);
|
|
315
331
|
const handleFinishedEvent = useCallback((event, userMessageTimestamp) => {
|
|
316
332
|
const finishReason = event.value.reason;
|
|
317
333
|
if (!finishReason) {
|
|
@@ -340,24 +356,46 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
340
356
|
}, userMessageTimestamp);
|
|
341
357
|
}
|
|
342
358
|
}, [addItem]);
|
|
343
|
-
const handleChatCompressionEvent = useCallback((eventValue) =>
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
359
|
+
const handleChatCompressionEvent = useCallback((eventValue, userMessageTimestamp) => {
|
|
360
|
+
if (pendingHistoryItemRef.current) {
|
|
361
|
+
addItem(pendingHistoryItemRef.current, userMessageTimestamp);
|
|
362
|
+
setPendingHistoryItem(null);
|
|
363
|
+
}
|
|
364
|
+
return addItem({
|
|
365
|
+
type: 'info',
|
|
366
|
+
text: `IMPORTANT: This conversation approached the input token limit for ${config.getModel()}. ` +
|
|
367
|
+
`A compressed context will be sent for future messages (compressed from: ` +
|
|
368
|
+
`${eventValue?.originalTokenCount ?? 'unknown'} to ` +
|
|
369
|
+
`${eventValue?.newTokenCount ?? 'unknown'} tokens).`,
|
|
370
|
+
}, Date.now());
|
|
371
|
+
}, [addItem, config, pendingHistoryItemRef, setPendingHistoryItem]);
|
|
350
372
|
const handleMaxSessionTurnsEvent = useCallback(() => addItem({
|
|
351
373
|
type: 'info',
|
|
352
374
|
text: `The session has reached the maximum number of turns: ${config.getMaxSessionTurns()}. ` +
|
|
353
375
|
`Please update this limit in your setting.json file.`,
|
|
354
376
|
}, Date.now()), [addItem, config]);
|
|
377
|
+
const handleLoopDetectionConfirmation = useCallback((result) => {
|
|
378
|
+
setLoopDetectionConfirmationRequest(null);
|
|
379
|
+
if (result.userSelection === 'disable') {
|
|
380
|
+
config.getGeminiClient().getLoopDetectionService().disableForSession();
|
|
381
|
+
addItem({
|
|
382
|
+
type: 'info',
|
|
383
|
+
text: `Loop detection has been disabled for this session. Please try your request again.`,
|
|
384
|
+
}, Date.now());
|
|
385
|
+
}
|
|
386
|
+
else {
|
|
387
|
+
addItem({
|
|
388
|
+
type: 'info',
|
|
389
|
+
text: `A potential loop was detected. This can happen due to repetitive tool calls or other model behavior. The request has been halted.`,
|
|
390
|
+
}, Date.now());
|
|
391
|
+
}
|
|
392
|
+
}, [config, addItem]);
|
|
355
393
|
const handleLoopDetectedEvent = useCallback(() => {
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
}
|
|
360
|
-
}, [
|
|
394
|
+
// Show the confirmation dialog to choose whether to disable loop detection
|
|
395
|
+
setLoopDetectionConfirmationRequest({
|
|
396
|
+
onComplete: handleLoopDetectionConfirmation,
|
|
397
|
+
});
|
|
398
|
+
}, [handleLoopDetectionConfirmation]);
|
|
361
399
|
const processGeminiStreamEvents = useCallback(async (stream, userMessageTimestamp, signal) => {
|
|
362
400
|
let geminiMessageBuffer = '';
|
|
363
401
|
const toolCallRequests = [];
|
|
@@ -379,7 +417,7 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
379
417
|
handleErrorEvent(event.value, userMessageTimestamp);
|
|
380
418
|
break;
|
|
381
419
|
case ServerGeminiEventType.ChatCompressed:
|
|
382
|
-
handleChatCompressionEvent(event.value);
|
|
420
|
+
handleChatCompressionEvent(event.value, userMessageTimestamp);
|
|
383
421
|
break;
|
|
384
422
|
case ServerGeminiEventType.ToolCallConfirmation:
|
|
385
423
|
case ServerGeminiEventType.ToolCallResponse:
|
|
@@ -440,45 +478,47 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
440
478
|
if (!prompt_id) {
|
|
441
479
|
prompt_id = config.getSessionId() + '########' + getPromptCount();
|
|
442
480
|
}
|
|
443
|
-
|
|
444
|
-
|
|
445
|
-
|
|
446
|
-
}
|
|
447
|
-
if (!options?.isContinuation) {
|
|
448
|
-
startNewPrompt();
|
|
449
|
-
setThought(null); // Reset thought when starting a new prompt
|
|
450
|
-
}
|
|
451
|
-
setIsResponding(true);
|
|
452
|
-
setInitError(null);
|
|
453
|
-
try {
|
|
454
|
-
const stream = geminiClient.sendMessageStream(queryToSend, abortSignal, prompt_id);
|
|
455
|
-
const processingStatus = await processGeminiStreamEvents(stream, userMessageTimestamp, abortSignal);
|
|
456
|
-
if (processingStatus === StreamProcessingStatus.UserCancelled) {
|
|
481
|
+
return promptIdContext.run(prompt_id, async () => {
|
|
482
|
+
const { queryToSend, shouldProceed } = await prepareQueryForGemini(query, userMessageTimestamp, abortSignal, prompt_id);
|
|
483
|
+
if (!shouldProceed || queryToSend === null) {
|
|
457
484
|
return;
|
|
458
485
|
}
|
|
459
|
-
if (
|
|
460
|
-
|
|
461
|
-
|
|
486
|
+
if (!options?.isContinuation) {
|
|
487
|
+
startNewPrompt();
|
|
488
|
+
setThought(null); // Reset thought when starting a new prompt
|
|
462
489
|
}
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
490
|
+
setIsResponding(true);
|
|
491
|
+
setInitError(null);
|
|
492
|
+
try {
|
|
493
|
+
const stream = geminiClient.sendMessageStream(queryToSend, abortSignal, prompt_id);
|
|
494
|
+
const processingStatus = await processGeminiStreamEvents(stream, userMessageTimestamp, abortSignal);
|
|
495
|
+
if (processingStatus === StreamProcessingStatus.UserCancelled) {
|
|
496
|
+
return;
|
|
497
|
+
}
|
|
498
|
+
if (pendingHistoryItemRef.current) {
|
|
499
|
+
addItem(pendingHistoryItemRef.current, userMessageTimestamp);
|
|
500
|
+
setPendingHistoryItem(null);
|
|
501
|
+
}
|
|
502
|
+
if (loopDetectedRef.current) {
|
|
503
|
+
loopDetectedRef.current = false;
|
|
504
|
+
handleLoopDetectedEvent();
|
|
505
|
+
}
|
|
466
506
|
}
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
507
|
+
catch (error) {
|
|
508
|
+
if (error instanceof UnauthorizedError) {
|
|
509
|
+
onAuthError('Session expired or is unauthorized.');
|
|
510
|
+
}
|
|
511
|
+
else if (!isNodeError(error) || error.name !== 'AbortError') {
|
|
512
|
+
addItem({
|
|
513
|
+
type: MessageType.ERROR,
|
|
514
|
+
text: parseAndFormatApiError(getErrorMessage(error) || 'Unknown error', config.getContentGeneratorConfig()?.authType, undefined, config.getModel(), DEFAULT_GEMINI_FLASH_MODEL),
|
|
515
|
+
}, userMessageTimestamp);
|
|
516
|
+
}
|
|
471
517
|
}
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
type: MessageType.ERROR,
|
|
475
|
-
text: parseAndFormatApiError(getErrorMessage(error) || 'Unknown error', config.getContentGeneratorConfig()?.authType, undefined, config.getModel(), DEFAULT_GEMINI_FLASH_MODEL),
|
|
476
|
-
}, userMessageTimestamp);
|
|
518
|
+
finally {
|
|
519
|
+
setIsResponding(false);
|
|
477
520
|
}
|
|
478
|
-
}
|
|
479
|
-
finally {
|
|
480
|
-
setIsResponding(false);
|
|
481
|
-
}
|
|
521
|
+
});
|
|
482
522
|
}, [
|
|
483
523
|
streamingState,
|
|
484
524
|
setModelSwitchedFromQuotaError,
|
|
@@ -495,6 +535,28 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
495
535
|
getPromptCount,
|
|
496
536
|
handleLoopDetectedEvent,
|
|
497
537
|
]);
|
|
538
|
+
const handleApprovalModeChange = useCallback(async (newApprovalMode) => {
|
|
539
|
+
// Auto-approve pending tool calls when switching to auto-approval modes
|
|
540
|
+
if (newApprovalMode === ApprovalMode.YOLO ||
|
|
541
|
+
newApprovalMode === ApprovalMode.AUTO_EDIT) {
|
|
542
|
+
let awaitingApprovalCalls = toolCalls.filter((call) => call.status === 'awaiting_approval');
|
|
543
|
+
// For AUTO_EDIT mode, only approve edit tools (replace, write_file)
|
|
544
|
+
if (newApprovalMode === ApprovalMode.AUTO_EDIT) {
|
|
545
|
+
awaitingApprovalCalls = awaitingApprovalCalls.filter((call) => EDIT_TOOL_NAMES.has(call.request.name));
|
|
546
|
+
}
|
|
547
|
+
// Process pending tool calls sequentially to reduce UI chaos
|
|
548
|
+
for (const call of awaitingApprovalCalls) {
|
|
549
|
+
if (call.confirmationDetails?.onConfirm) {
|
|
550
|
+
try {
|
|
551
|
+
await call.confirmationDetails.onConfirm(ToolConfirmationOutcome.ProceedOnce);
|
|
552
|
+
}
|
|
553
|
+
catch (error) {
|
|
554
|
+
console.error(`Failed to auto-approve tool call ${call.request.callId}:`, error);
|
|
555
|
+
}
|
|
556
|
+
}
|
|
557
|
+
}
|
|
558
|
+
}
|
|
559
|
+
}, [toolCalls]);
|
|
498
560
|
const handleCompletedTools = useCallback(async (completedToolCallsFromScheduler) => {
|
|
499
561
|
if (isResponding) {
|
|
500
562
|
return;
|
|
@@ -572,8 +634,7 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
572
634
|
if (!config.getCheckpointingEnabled()) {
|
|
573
635
|
return;
|
|
574
636
|
}
|
|
575
|
-
const restorableToolCalls = toolCalls.filter((toolCall) => (toolCall.request.name
|
|
576
|
-
toolCall.request.name === 'write_file') &&
|
|
637
|
+
const restorableToolCalls = toolCalls.filter((toolCall) => EDIT_TOOL_NAMES.has(toolCall.request.name) &&
|
|
577
638
|
toolCall.status === 'awaiting_approval');
|
|
578
639
|
if (restorableToolCalls.length > 0) {
|
|
579
640
|
const checkpointDir = storage.getProjectTempCheckpointsDir();
|
|
@@ -657,6 +718,10 @@ export const useGeminiStream = (geminiClient, history, addItem, config, settings
|
|
|
657
718
|
pendingHistoryItems,
|
|
658
719
|
thought,
|
|
659
720
|
cancelOngoingRequest,
|
|
721
|
+
pendingToolCalls: toolCalls,
|
|
722
|
+
handleApprovalModeChange,
|
|
723
|
+
activePtyId,
|
|
724
|
+
loopDetectionConfirmationRequest,
|
|
660
725
|
};
|
|
661
726
|
};
|
|
662
727
|
//# sourceMappingURL=useGeminiStream.js.map
|