fss-link 1.0.49 → 1.0.51
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/index.js +0 -0
- package/dist/package.json +2 -2
- package/dist/src/config/auth.js +8 -5
- package/dist/src/config/auth.js.map +1 -1
- package/dist/src/config/database.d.ts +103 -11
- package/dist/src/config/database.js +301 -59
- package/dist/src/config/database.js.map +1 -1
- package/dist/src/config/databaseBackup.d.ts +114 -0
- package/dist/src/config/databaseBackup.js +334 -0
- package/dist/src/config/databaseBackup.js.map +1 -0
- package/dist/src/config/databaseMigrations.d.ts +63 -0
- package/dist/src/config/databaseMigrations.js +379 -0
- package/dist/src/config/databaseMigrations.js.map +1 -0
- package/dist/src/config/databasePool.d.ts +70 -0
- package/dist/src/config/databasePool.js +193 -0
- package/dist/src/config/databasePool.js.map +1 -0
- package/dist/src/config/queryOptimizer.d.ts +127 -0
- package/dist/src/config/queryOptimizer.js +309 -0
- package/dist/src/config/queryOptimizer.js.map +1 -0
- package/dist/src/utils/sandbox.js +2 -8
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/validateNonInterActiveAuth.js +3 -7
- package/dist/src/validateNonInterActiveAuth.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +2 -2
- package/dist/commands/mcp/add.test.ts +0 -122
- package/dist/commands/mcp/add.ts +0 -222
- package/dist/commands/mcp/list.test.ts +0 -154
- package/dist/commands/mcp/list.ts +0 -139
- package/dist/commands/mcp/remove.test.ts +0 -69
- package/dist/commands/mcp/remove.ts +0 -60
- package/dist/commands/mcp.test.ts +0 -55
- package/dist/commands/mcp.ts +0 -27
- package/dist/config/apiValidation.test.ts +0 -118
- package/dist/config/auth.test.ts +0 -79
- package/dist/config/auth.ts +0 -100
- package/dist/config/config.integration.test.ts +0 -407
- package/dist/config/config.test.ts +0 -1952
- package/dist/config/config.ts +0 -690
- package/dist/config/database.test.ts +0 -96
- package/dist/config/database.ts +0 -824
- package/dist/config/extension.test.ts +0 -236
- package/dist/config/extension.ts +0 -180
- package/dist/config/keyBindings.test.ts +0 -62
- package/dist/config/keyBindings.ts +0 -184
- package/dist/config/modelManager.ts +0 -326
- package/dist/config/providerManager.ts +0 -244
- package/dist/config/providerPersistence.test.ts +0 -377
- package/dist/config/providerPersistence.ts +0 -105
- package/dist/config/sandboxConfig.ts +0 -107
- package/dist/config/settings.test.ts +0 -1424
- package/dist/config/settings.ts +0 -517
- package/dist/config/settingsSchema.test.ts +0 -252
- package/dist/config/settingsSchema.ts +0 -728
- package/dist/config/trustedFolders.test.ts +0 -208
- package/dist/config/trustedFolders.ts +0 -167
- package/dist/gemini.test.tsx +0 -252
- package/dist/gemini.tsx +0 -357
- package/dist/generated/git-commit.ts +0 -10
- package/dist/index.ts +0 -21
- package/dist/nonInteractiveCli.test.ts +0 -276
- package/dist/nonInteractiveCli.ts +0 -143
- package/dist/patches/is-in-ci.ts +0 -17
- package/dist/services/BuiltinCommandLoader.test.ts +0 -127
- package/dist/services/BuiltinCommandLoader.ts +0 -95
- package/dist/services/CommandService.test.ts +0 -352
- package/dist/services/CommandService.ts +0 -103
- package/dist/services/FileCommandLoader.test.ts +0 -1002
- package/dist/services/FileCommandLoader.ts +0 -289
- package/dist/services/McpPromptLoader.ts +0 -231
- package/dist/services/SearchEngineConfigProvider.ts +0 -100
- package/dist/services/prompt-processors/argumentProcessor.test.ts +0 -41
- package/dist/services/prompt-processors/argumentProcessor.ts +0 -23
- package/dist/services/prompt-processors/shellProcessor.test.ts +0 -709
- package/dist/services/prompt-processors/shellProcessor.ts +0 -248
- package/dist/services/prompt-processors/types.ts +0 -44
- package/dist/services/types.ts +0 -24
- package/dist/src/config/apiValidation.test.d.ts +0 -6
- package/dist/src/config/apiValidation.test.js +0 -99
- package/dist/src/config/apiValidation.test.js.map +0 -1
- package/dist/src/config/database.test.d.ts +0 -6
- package/dist/src/config/database.test.js +0 -80
- package/dist/src/config/database.test.js.map +0 -1
- package/dist/src/config/providerManager.d.ts +0 -74
- package/dist/src/config/providerManager.js +0 -203
- package/dist/src/config/providerManager.js.map +0 -1
- package/dist/src/config/providerPersistence.test.d.ts +0 -6
- package/dist/src/config/providerPersistence.test.js +0 -283
- package/dist/src/config/providerPersistence.test.js.map +0 -1
- package/dist/src/ui/components/GeminiKeyDialog.d.ts +0 -11
- package/dist/src/ui/components/GeminiKeyDialog.js +0 -156
- package/dist/src/ui/components/GeminiKeyDialog.js.map +0 -1
- package/dist/src/ui/components/OpenAIEndpointDialog.d.ts +0 -19
- package/dist/src/ui/components/OpenAIEndpointDialog.js +0 -163
- package/dist/src/ui/components/OpenAIEndpointDialog.js.map +0 -1
- package/dist/test-setup.ts +0 -12
- package/dist/test-utils/customMatchers.ts +0 -65
- package/dist/test-utils/mockCommandContext.test.ts +0 -62
- package/dist/test-utils/mockCommandContext.ts +0 -105
- package/dist/test-utils/render.tsx +0 -18
- package/dist/ui/App.test.tsx +0 -2181
- package/dist/ui/App.tsx +0 -1344
- package/dist/ui/IdeIntegrationNudge.tsx +0 -98
- package/dist/ui/__snapshots__/App.test.tsx.snap +0 -124
- package/dist/ui/colors.ts +0 -56
- package/dist/ui/commands/aboutCommand.test.ts +0 -153
- package/dist/ui/commands/aboutCommand.ts +0 -49
- package/dist/ui/commands/authCommand.test.ts +0 -36
- package/dist/ui/commands/authCommand.ts +0 -17
- package/dist/ui/commands/bugCommand.test.ts +0 -114
- package/dist/ui/commands/bugCommand.ts +0 -92
- package/dist/ui/commands/chatCommand.test.ts +0 -414
- package/dist/ui/commands/chatCommand.ts +0 -280
- package/dist/ui/commands/clearCommand.test.ts +0 -100
- package/dist/ui/commands/clearCommand.ts +0 -29
- package/dist/ui/commands/compressCommand.test.ts +0 -129
- package/dist/ui/commands/compressCommand.ts +0 -78
- package/dist/ui/commands/contextCommand.ts +0 -132
- package/dist/ui/commands/copyCommand.test.ts +0 -296
- package/dist/ui/commands/copyCommand.ts +0 -67
- package/dist/ui/commands/corgiCommand.test.ts +0 -34
- package/dist/ui/commands/corgiCommand.ts +0 -16
- package/dist/ui/commands/directoryCommand.test.tsx +0 -185
- package/dist/ui/commands/directoryCommand.tsx +0 -179
- package/dist/ui/commands/docsCommand.test.ts +0 -99
- package/dist/ui/commands/docsCommand.ts +0 -42
- package/dist/ui/commands/editorCommand.test.ts +0 -30
- package/dist/ui/commands/editorCommand.ts +0 -21
- package/dist/ui/commands/extensionsCommand.test.ts +0 -67
- package/dist/ui/commands/extensionsCommand.ts +0 -46
- package/dist/ui/commands/helpCommand.test.ts +0 -52
- package/dist/ui/commands/helpCommand.ts +0 -23
- package/dist/ui/commands/ideCommand.test.ts +0 -255
- package/dist/ui/commands/ideCommand.ts +0 -283
- package/dist/ui/commands/initCommand.test.ts +0 -127
- package/dist/ui/commands/initCommand.ts +0 -117
- package/dist/ui/commands/mcpCommand.test.ts +0 -1057
- package/dist/ui/commands/mcpCommand.ts +0 -531
- package/dist/ui/commands/memoryCommand.test.ts +0 -344
- package/dist/ui/commands/memoryCommand.ts +0 -305
- package/dist/ui/commands/privacyCommand.test.ts +0 -38
- package/dist/ui/commands/privacyCommand.ts +0 -17
- package/dist/ui/commands/quitCommand.test.ts +0 -55
- package/dist/ui/commands/quitCommand.ts +0 -36
- package/dist/ui/commands/restoreCommand.test.ts +0 -250
- package/dist/ui/commands/restoreCommand.ts +0 -157
- package/dist/ui/commands/searchEngineSetupCommand.ts +0 -18
- package/dist/ui/commands/settingsCommand.test.ts +0 -36
- package/dist/ui/commands/settingsCommand.ts +0 -17
- package/dist/ui/commands/setupGithubCommand.test.ts +0 -238
- package/dist/ui/commands/setupGithubCommand.ts +0 -212
- package/dist/ui/commands/speakCommand.ts +0 -175
- package/dist/ui/commands/statsCommand.test.ts +0 -78
- package/dist/ui/commands/statsCommand.ts +0 -70
- package/dist/ui/commands/terminalSetupCommand.test.ts +0 -85
- package/dist/ui/commands/terminalSetupCommand.ts +0 -45
- package/dist/ui/commands/themeCommand.test.ts +0 -38
- package/dist/ui/commands/themeCommand.ts +0 -17
- package/dist/ui/commands/toolsCommand.test.ts +0 -105
- package/dist/ui/commands/toolsCommand.ts +0 -71
- package/dist/ui/commands/ttsCommand.ts +0 -143
- package/dist/ui/commands/types.ts +0 -204
- package/dist/ui/commands/vimCommand.ts +0 -25
- package/dist/ui/commands/voiceCommand.ts +0 -125
- package/dist/ui/components/AboutBox.tsx +0 -133
- package/dist/ui/components/AsciiArt.ts +0 -54
- package/dist/ui/components/AuthDialog.test.tsx +0 -334
- package/dist/ui/components/AuthDialog.tsx +0 -289
- package/dist/ui/components/AuthInProgress.tsx +0 -62
- package/dist/ui/components/AutoAcceptIndicator.tsx +0 -47
- package/dist/ui/components/ConsoleSummaryDisplay.tsx +0 -35
- package/dist/ui/components/ContextSummaryDisplay.test.tsx +0 -85
- package/dist/ui/components/ContextSummaryDisplay.tsx +0 -120
- package/dist/ui/components/ContextUsageDisplay.tsx +0 -77
- package/dist/ui/components/DebugProfiler.tsx +0 -36
- package/dist/ui/components/DetailedMessagesDisplay.tsx +0 -82
- package/dist/ui/components/EditorSettingsDialog.tsx +0 -172
- package/dist/ui/components/FolderTrustDialog.test.tsx +0 -36
- package/dist/ui/components/FolderTrustDialog.tsx +0 -74
- package/dist/ui/components/Footer.test.tsx +0 -159
- package/dist/ui/components/Footer.tsx +0 -158
- package/dist/ui/components/GeminiKeyDialog.tsx +0 -252
- package/dist/ui/components/GeminiRespondingSpinner.tsx +0 -34
- package/dist/ui/components/Header.test.tsx +0 -44
- package/dist/ui/components/Header.tsx +0 -70
- package/dist/ui/components/Help.tsx +0 -174
- package/dist/ui/components/HistoryItemDisplay.test.tsx +0 -125
- package/dist/ui/components/HistoryItemDisplay.tsx +0 -98
- package/dist/ui/components/InputPrompt.test.tsx +0 -1467
- package/dist/ui/components/InputPrompt.tsx +0 -641
- package/dist/ui/components/LMStudioModelPrompt.tsx +0 -215
- package/dist/ui/components/LoadingIndicator.test.tsx +0 -296
- package/dist/ui/components/LoadingIndicator.tsx +0 -82
- package/dist/ui/components/MemoryUsageDisplay.tsx +0 -36
- package/dist/ui/components/ModelStatsDisplay.test.tsx +0 -252
- package/dist/ui/components/ModelStatsDisplay.tsx +0 -197
- package/dist/ui/components/OllamaModelPrompt.tsx +0 -206
- package/dist/ui/components/OpenAIEndpointDialog.tsx +0 -261
- package/dist/ui/components/OpenAIKeyPrompt.test.tsx +0 -64
- package/dist/ui/components/OpenAIKeyPrompt.tsx +0 -197
- package/dist/ui/components/PrepareLabel.tsx +0 -48
- package/dist/ui/components/SearchEngineConfigDialog.tsx +0 -280
- package/dist/ui/components/SessionSummaryDisplay.test.tsx +0 -75
- package/dist/ui/components/SessionSummaryDisplay.tsx +0 -18
- package/dist/ui/components/SettingsDialog.test.tsx +0 -865
- package/dist/ui/components/SettingsDialog.tsx +0 -753
- package/dist/ui/components/ShellConfirmationDialog.test.tsx +0 -53
- package/dist/ui/components/ShellConfirmationDialog.tsx +0 -103
- package/dist/ui/components/ShellModeIndicator.tsx +0 -18
- package/dist/ui/components/ShowMoreLines.tsx +0 -40
- package/dist/ui/components/StatsDisplay.test.tsx +0 -401
- package/dist/ui/components/StatsDisplay.tsx +0 -273
- package/dist/ui/components/SuggestionsDisplay.tsx +0 -102
- package/dist/ui/components/ThemeDialog.tsx +0 -310
- package/dist/ui/components/Tips.tsx +0 -45
- package/dist/ui/components/TodoDisplay.test.tsx +0 -97
- package/dist/ui/components/TodoDisplay.tsx +0 -72
- package/dist/ui/components/ToolStatsDisplay.test.tsx +0 -180
- package/dist/ui/components/ToolStatsDisplay.tsx +0 -208
- package/dist/ui/components/UpdateNotification.tsx +0 -23
- package/dist/ui/components/WelcomeBackDialog.tsx +0 -290
- package/dist/ui/components/__snapshots__/IDEContextDetailDisplay.test.tsx.snap +0 -24
- package/dist/ui/components/__snapshots__/ModelStatsDisplay.test.tsx.snap +0 -121
- package/dist/ui/components/__snapshots__/SessionSummaryDisplay.test.tsx.snap +0 -30
- package/dist/ui/components/__snapshots__/ShellConfirmationDialog.test.tsx.snap +0 -21
- package/dist/ui/components/__snapshots__/StatsDisplay.test.tsx.snap +0 -264
- package/dist/ui/components/__snapshots__/ToolStatsDisplay.test.tsx.snap +0 -91
- package/dist/ui/components/messages/CompressionMessage.tsx +0 -49
- package/dist/ui/components/messages/DiffRenderer.test.tsx +0 -365
- package/dist/ui/components/messages/DiffRenderer.tsx +0 -358
- package/dist/ui/components/messages/ErrorMessage.tsx +0 -31
- package/dist/ui/components/messages/GeminiMessage.tsx +0 -43
- package/dist/ui/components/messages/GeminiMessageContent.tsx +0 -43
- package/dist/ui/components/messages/InfoMessage.tsx +0 -32
- package/dist/ui/components/messages/ToolConfirmationMessage.test.tsx +0 -58
- package/dist/ui/components/messages/ToolConfirmationMessage.tsx +0 -297
- package/dist/ui/components/messages/ToolGroupMessage.tsx +0 -126
- package/dist/ui/components/messages/ToolMessage.test.tsx +0 -183
- package/dist/ui/components/messages/ToolMessage.tsx +0 -296
- package/dist/ui/components/messages/UserMessage.tsx +0 -43
- package/dist/ui/components/messages/UserShellMessage.tsx +0 -25
- package/dist/ui/components/shared/MaxSizedBox.test.tsx +0 -425
- package/dist/ui/components/shared/MaxSizedBox.tsx +0 -624
- package/dist/ui/components/shared/RadioButtonSelect.test.tsx +0 -181
- package/dist/ui/components/shared/RadioButtonSelect.tsx +0 -234
- package/dist/ui/components/shared/__snapshots__/RadioButtonSelect.test.tsx.snap +0 -47
- package/dist/ui/components/shared/text-buffer.test.ts +0 -1728
- package/dist/ui/components/shared/text-buffer.ts +0 -2227
- package/dist/ui/components/shared/vim-buffer-actions.test.ts +0 -1119
- package/dist/ui/components/shared/vim-buffer-actions.ts +0 -814
- package/dist/ui/constants.ts +0 -17
- package/dist/ui/contexts/KeypressContext.test.tsx +0 -391
- package/dist/ui/contexts/KeypressContext.tsx +0 -440
- package/dist/ui/contexts/OverflowContext.tsx +0 -87
- package/dist/ui/contexts/SessionContext.test.tsx +0 -132
- package/dist/ui/contexts/SessionContext.tsx +0 -143
- package/dist/ui/contexts/SettingsContext.tsx +0 -20
- package/dist/ui/contexts/StreamingContext.tsx +0 -22
- package/dist/ui/contexts/VimModeContext.tsx +0 -79
- package/dist/ui/editors/editorSettingsManager.ts +0 -66
- package/dist/ui/hooks/atCommandProcessor.test.ts +0 -1102
- package/dist/ui/hooks/atCommandProcessor.ts +0 -485
- package/dist/ui/hooks/shellCommandProcessor.test.ts +0 -481
- package/dist/ui/hooks/shellCommandProcessor.ts +0 -314
- package/dist/ui/hooks/slashCommandProcessor.test.ts +0 -1044
- package/dist/ui/hooks/slashCommandProcessor.ts +0 -595
- package/dist/ui/hooks/useAtCompletion.test.ts +0 -497
- package/dist/ui/hooks/useAtCompletion.ts +0 -244
- package/dist/ui/hooks/useAuthCommand.ts +0 -129
- package/dist/ui/hooks/useAutoAcceptIndicator.test.ts +0 -300
- package/dist/ui/hooks/useAutoAcceptIndicator.ts +0 -52
- package/dist/ui/hooks/useBracketedPaste.ts +0 -37
- package/dist/ui/hooks/useCommandCompletion.test.ts +0 -518
- package/dist/ui/hooks/useCommandCompletion.tsx +0 -238
- package/dist/ui/hooks/useCompletion.ts +0 -128
- package/dist/ui/hooks/useConsoleMessages.test.ts +0 -147
- package/dist/ui/hooks/useConsoleMessages.ts +0 -110
- package/dist/ui/hooks/useEditorSettings.test.ts +0 -283
- package/dist/ui/hooks/useEditorSettings.ts +0 -75
- package/dist/ui/hooks/useFocus.test.ts +0 -119
- package/dist/ui/hooks/useFocus.ts +0 -48
- package/dist/ui/hooks/useFolderTrust.test.ts +0 -159
- package/dist/ui/hooks/useFolderTrust.ts +0 -72
- package/dist/ui/hooks/useGeminiStream.test.tsx +0 -1998
- package/dist/ui/hooks/useGeminiStream.ts +0 -1017
- package/dist/ui/hooks/useGitBranchName.test.ts +0 -280
- package/dist/ui/hooks/useGitBranchName.ts +0 -79
- package/dist/ui/hooks/useHistoryManager.test.ts +0 -202
- package/dist/ui/hooks/useHistoryManager.ts +0 -111
- package/dist/ui/hooks/useInputHistory.test.ts +0 -261
- package/dist/ui/hooks/useInputHistory.ts +0 -111
- package/dist/ui/hooks/useKeypress.test.ts +0 -280
- package/dist/ui/hooks/useKeypress.ts +0 -39
- package/dist/ui/hooks/useKittyKeyboardProtocol.ts +0 -31
- package/dist/ui/hooks/useLoadingIndicator.test.ts +0 -139
- package/dist/ui/hooks/useLoadingIndicator.ts +0 -57
- package/dist/ui/hooks/useLogger.ts +0 -32
- package/dist/ui/hooks/useMessageQueue.test.ts +0 -226
- package/dist/ui/hooks/useMessageQueue.ts +0 -69
- package/dist/ui/hooks/usePhraseCycler.test.ts +0 -145
- package/dist/ui/hooks/usePhraseCycler.ts +0 -198
- package/dist/ui/hooks/usePrivacySettings.test.ts +0 -242
- package/dist/ui/hooks/usePrivacySettings.ts +0 -150
- package/dist/ui/hooks/useReactToolScheduler.ts +0 -309
- package/dist/ui/hooks/useRefreshMemoryCommand.ts +0 -7
- package/dist/ui/hooks/useReverseSearchCompletion.test.tsx +0 -260
- package/dist/ui/hooks/useReverseSearchCompletion.tsx +0 -95
- package/dist/ui/hooks/useSettingsCommand.ts +0 -25
- package/dist/ui/hooks/useShellHistory.test.ts +0 -219
- package/dist/ui/hooks/useShellHistory.ts +0 -133
- package/dist/ui/hooks/useShowMemoryCommand.ts +0 -75
- package/dist/ui/hooks/useSlashCompletion.test.ts +0 -434
- package/dist/ui/hooks/useSlashCompletion.ts +0 -187
- package/dist/ui/hooks/useStateAndRef.ts +0 -36
- package/dist/ui/hooks/useTerminalSize.ts +0 -32
- package/dist/ui/hooks/useThemeCommand.ts +0 -110
- package/dist/ui/hooks/useTimer.test.ts +0 -120
- package/dist/ui/hooks/useTimer.ts +0 -65
- package/dist/ui/hooks/useToolScheduler.test.ts +0 -1123
- package/dist/ui/hooks/useWelcomeBack.ts +0 -253
- package/dist/ui/hooks/vim.test.ts +0 -1691
- package/dist/ui/hooks/vim.ts +0 -784
- package/dist/ui/keyMatchers.test.ts +0 -337
- package/dist/ui/keyMatchers.ts +0 -105
- package/dist/ui/privacy/CloudFreePrivacyNotice.tsx +0 -117
- package/dist/ui/privacy/CloudPaidPrivacyNotice.tsx +0 -59
- package/dist/ui/privacy/GeminiPrivacyNotice.tsx +0 -62
- package/dist/ui/privacy/PrivacyNotice.tsx +0 -42
- package/dist/ui/semantic-colors.ts +0 -26
- package/dist/ui/themes/ansi-light.ts +0 -150
- package/dist/ui/themes/ansi.ts +0 -159
- package/dist/ui/themes/atom-one-dark.ts +0 -147
- package/dist/ui/themes/ayu-light.ts +0 -139
- package/dist/ui/themes/ayu.ts +0 -113
- package/dist/ui/themes/color-utils.test.ts +0 -221
- package/dist/ui/themes/color-utils.ts +0 -231
- package/dist/ui/themes/default-light.ts +0 -108
- package/dist/ui/themes/default.ts +0 -151
- package/dist/ui/themes/dracula.ts +0 -124
- package/dist/ui/themes/fss-code-dark.ts +0 -156
- package/dist/ui/themes/fss-dark.ts +0 -113
- package/dist/ui/themes/fss-light.ts +0 -139
- package/dist/ui/themes/github-dark.ts +0 -147
- package/dist/ui/themes/github-light.ts +0 -149
- package/dist/ui/themes/googlecode.ts +0 -146
- package/dist/ui/themes/no-color.ts +0 -125
- package/dist/ui/themes/qwen-dark.ts +0 -118
- package/dist/ui/themes/qwen-light.ts +0 -144
- package/dist/ui/themes/semantic-tokens.ts +0 -127
- package/dist/ui/themes/shades-of-purple.ts +0 -352
- package/dist/ui/themes/theme-manager.test.ts +0 -99
- package/dist/ui/themes/theme-manager.ts +0 -257
- package/dist/ui/themes/theme.test.ts +0 -97
- package/dist/ui/themes/theme.ts +0 -451
- package/dist/ui/themes/xcode.ts +0 -154
- package/dist/ui/types.ts +0 -255
- package/dist/ui/utils/CodeColorizer.tsx +0 -217
- package/dist/ui/utils/ConsolePatcher.ts +0 -71
- package/dist/ui/utils/InlineMarkdownRenderer.tsx +0 -173
- package/dist/ui/utils/MarkdownDisplay.test.tsx +0 -244
- package/dist/ui/utils/MarkdownDisplay.tsx +0 -415
- package/dist/ui/utils/TableRenderer.tsx +0 -159
- package/dist/ui/utils/__snapshots__/MarkdownDisplay.test.tsx.snap +0 -93
- package/dist/ui/utils/clipboardUtils.test.ts +0 -76
- package/dist/ui/utils/clipboardUtils.ts +0 -149
- package/dist/ui/utils/commandUtils.test.ts +0 -384
- package/dist/ui/utils/commandUtils.ts +0 -106
- package/dist/ui/utils/computeStats.test.ts +0 -292
- package/dist/ui/utils/computeStats.ts +0 -86
- package/dist/ui/utils/displayUtils.test.ts +0 -58
- package/dist/ui/utils/displayUtils.ts +0 -32
- package/dist/ui/utils/formatters.test.ts +0 -72
- package/dist/ui/utils/formatters.ts +0 -63
- package/dist/ui/utils/isNarrowWidth.ts +0 -9
- package/dist/ui/utils/kittyProtocolDetector.ts +0 -105
- package/dist/ui/utils/markdownUtilities.test.ts +0 -50
- package/dist/ui/utils/markdownUtilities.ts +0 -125
- package/dist/ui/utils/platformConstants.ts +0 -52
- package/dist/ui/utils/terminalSetup.ts +0 -342
- package/dist/ui/utils/textUtils.ts +0 -40
- package/dist/ui/utils/updateCheck.test.ts +0 -163
- package/dist/ui/utils/updateCheck.ts +0 -100
- package/dist/utils/checks.ts +0 -28
- package/dist/utils/cleanup.test.ts +0 -68
- package/dist/utils/cleanup.ts +0 -36
- package/dist/utils/dialogScopeUtils.ts +0 -64
- package/dist/utils/events.ts +0 -14
- package/dist/utils/gitUtils.test.ts +0 -149
- package/dist/utils/gitUtils.ts +0 -116
- package/dist/utils/handleAutoUpdate.test.ts +0 -272
- package/dist/utils/handleAutoUpdate.ts +0 -145
- package/dist/utils/installationInfo.test.ts +0 -315
- package/dist/utils/installationInfo.ts +0 -176
- package/dist/utils/package.ts +0 -38
- package/dist/utils/readStdin.ts +0 -51
- package/dist/utils/resolvePath.ts +0 -21
- package/dist/utils/sandbox-macos-permissive-closed.sb +0 -32
- package/dist/utils/sandbox-macos-permissive-open.sb +0 -25
- package/dist/utils/sandbox-macos-permissive-proxied.sb +0 -37
- package/dist/utils/sandbox-macos-restrictive-closed.sb +0 -93
- package/dist/utils/sandbox-macos-restrictive-open.sb +0 -96
- package/dist/utils/sandbox-macos-restrictive-proxied.sb +0 -98
- package/dist/utils/sandbox.ts +0 -962
- package/dist/utils/settingsUtils.test.ts +0 -797
- package/dist/utils/settingsUtils.ts +0 -489
- package/dist/utils/spawnWrapper.ts +0 -9
- package/dist/utils/startupWarnings.test.ts +0 -83
- package/dist/utils/startupWarnings.ts +0 -40
- package/dist/utils/updateEventEmitter.ts +0 -13
- package/dist/utils/userStartupWarnings.test.ts +0 -87
- package/dist/utils/userStartupWarnings.ts +0 -69
- package/dist/utils/version.ts +0 -12
- package/dist/validateNonInterActiveAuth.test.ts +0 -260
- package/dist/validateNonInterActiveAuth.ts +0 -51
- package/dist/vitest.config.ts +0 -37
- package/dist/zed-integration/acp.ts +0 -366
- package/dist/zed-integration/fileSystemService.ts +0 -47
- package/dist/zed-integration/schema.ts +0 -466
- package/dist/zed-integration/zedIntegration.ts +0 -944
|
@@ -1,485 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
import * as fs from 'fs/promises';
|
|
8
|
-
import * as path from 'path';
|
|
9
|
-
import { PartListUnion, PartUnion } from '@google/genai';
|
|
10
|
-
import {
|
|
11
|
-
AnyToolInvocation,
|
|
12
|
-
Config,
|
|
13
|
-
getErrorMessage,
|
|
14
|
-
isNodeError,
|
|
15
|
-
unescapePath,
|
|
16
|
-
} from 'fss-link-core';
|
|
17
|
-
import {
|
|
18
|
-
HistoryItem,
|
|
19
|
-
IndividualToolCallDisplay,
|
|
20
|
-
ToolCallStatus,
|
|
21
|
-
} from '../types.js';
|
|
22
|
-
import { UseHistoryManagerReturn } from './useHistoryManager.js';
|
|
23
|
-
|
|
24
|
-
interface HandleAtCommandParams {
|
|
25
|
-
query: string;
|
|
26
|
-
config: Config;
|
|
27
|
-
addItem: UseHistoryManagerReturn['addItem'];
|
|
28
|
-
onDebugMessage: (message: string) => void;
|
|
29
|
-
messageId: number;
|
|
30
|
-
signal: AbortSignal;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
interface HandleAtCommandResult {
|
|
34
|
-
processedQuery: PartListUnion | null;
|
|
35
|
-
shouldProceed: boolean;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
interface AtCommandPart {
|
|
39
|
-
type: 'text' | 'atPath';
|
|
40
|
-
content: string;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Parses a query string to find all '@<path>' commands and text segments.
|
|
45
|
-
* Handles \ escaped spaces within paths.
|
|
46
|
-
*/
|
|
47
|
-
function parseAllAtCommands(query: string): AtCommandPart[] {
|
|
48
|
-
const parts: AtCommandPart[] = [];
|
|
49
|
-
let currentIndex = 0;
|
|
50
|
-
|
|
51
|
-
while (currentIndex < query.length) {
|
|
52
|
-
let atIndex = -1;
|
|
53
|
-
let nextSearchIndex = currentIndex;
|
|
54
|
-
// Find next unescaped '@'
|
|
55
|
-
while (nextSearchIndex < query.length) {
|
|
56
|
-
if (
|
|
57
|
-
query[nextSearchIndex] === '@' &&
|
|
58
|
-
(nextSearchIndex === 0 || query[nextSearchIndex - 1] !== '\\')
|
|
59
|
-
) {
|
|
60
|
-
atIndex = nextSearchIndex;
|
|
61
|
-
break;
|
|
62
|
-
}
|
|
63
|
-
nextSearchIndex++;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (atIndex === -1) {
|
|
67
|
-
// No more @
|
|
68
|
-
if (currentIndex < query.length) {
|
|
69
|
-
parts.push({ type: 'text', content: query.substring(currentIndex) });
|
|
70
|
-
}
|
|
71
|
-
break;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
// Add text before @
|
|
75
|
-
if (atIndex > currentIndex) {
|
|
76
|
-
parts.push({
|
|
77
|
-
type: 'text',
|
|
78
|
-
content: query.substring(currentIndex, atIndex),
|
|
79
|
-
});
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
// Parse @path
|
|
83
|
-
let pathEndIndex = atIndex + 1;
|
|
84
|
-
let inEscape = false;
|
|
85
|
-
while (pathEndIndex < query.length) {
|
|
86
|
-
const char = query[pathEndIndex];
|
|
87
|
-
if (inEscape) {
|
|
88
|
-
inEscape = false;
|
|
89
|
-
} else if (char === '\\') {
|
|
90
|
-
inEscape = true;
|
|
91
|
-
} else if (/[,\s;!?()[\]{}]/.test(char)) {
|
|
92
|
-
// Path ends at first whitespace or punctuation not escaped
|
|
93
|
-
break;
|
|
94
|
-
} else if (char === '.') {
|
|
95
|
-
// For . we need to be more careful - only terminate if followed by whitespace or end of string
|
|
96
|
-
// This allows file extensions like .txt, .js but terminates at sentence endings like "file.txt. Next sentence"
|
|
97
|
-
const nextChar =
|
|
98
|
-
pathEndIndex + 1 < query.length ? query[pathEndIndex + 1] : '';
|
|
99
|
-
if (nextChar === '' || /\s/.test(nextChar)) {
|
|
100
|
-
break;
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
pathEndIndex++;
|
|
104
|
-
}
|
|
105
|
-
const rawAtPath = query.substring(atIndex, pathEndIndex);
|
|
106
|
-
// unescapePath expects the @ symbol to be present, and will handle it.
|
|
107
|
-
const atPath = unescapePath(rawAtPath);
|
|
108
|
-
parts.push({ type: 'atPath', content: atPath });
|
|
109
|
-
currentIndex = pathEndIndex;
|
|
110
|
-
}
|
|
111
|
-
// Filter out empty text parts that might result from consecutive @paths or leading/trailing spaces
|
|
112
|
-
return parts.filter(
|
|
113
|
-
(part) => !(part.type === 'text' && part.content.trim() === ''),
|
|
114
|
-
);
|
|
115
|
-
}
|
|
116
|
-
|
|
117
|
-
/**
|
|
118
|
-
* Processes user input potentially containing one or more '@<path>' commands.
|
|
119
|
-
* If found, it attempts to read the specified files/directories using the
|
|
120
|
-
* 'read_many_files' tool. The user query is modified to include resolved paths,
|
|
121
|
-
* and the content of the files is appended in a structured block.
|
|
122
|
-
*
|
|
123
|
-
* @returns An object indicating whether the main hook should proceed with an
|
|
124
|
-
* LLM call and the processed query parts (including file content).
|
|
125
|
-
*/
|
|
126
|
-
export async function handleAtCommand({
|
|
127
|
-
query,
|
|
128
|
-
config,
|
|
129
|
-
addItem,
|
|
130
|
-
onDebugMessage,
|
|
131
|
-
messageId: userMessageTimestamp,
|
|
132
|
-
signal,
|
|
133
|
-
}: HandleAtCommandParams): Promise<HandleAtCommandResult> {
|
|
134
|
-
const commandParts = parseAllAtCommands(query);
|
|
135
|
-
const atPathCommandParts = commandParts.filter(
|
|
136
|
-
(part) => part.type === 'atPath',
|
|
137
|
-
);
|
|
138
|
-
|
|
139
|
-
if (atPathCommandParts.length === 0) {
|
|
140
|
-
return { processedQuery: [{ text: query }], shouldProceed: true };
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
// Get centralized file discovery service
|
|
144
|
-
const fileDiscovery = config.getFileService();
|
|
145
|
-
|
|
146
|
-
const respectFileIgnore = config.getFileFilteringOptions();
|
|
147
|
-
|
|
148
|
-
const pathSpecsToRead: string[] = [];
|
|
149
|
-
const atPathToResolvedSpecMap = new Map<string, string>();
|
|
150
|
-
const contentLabelsForDisplay: string[] = [];
|
|
151
|
-
const ignoredByReason: Record<string, string[]> = {
|
|
152
|
-
git: [],
|
|
153
|
-
gemini: [],
|
|
154
|
-
both: [],
|
|
155
|
-
};
|
|
156
|
-
|
|
157
|
-
const toolRegistry = config.getToolRegistry();
|
|
158
|
-
const readManyFilesTool = toolRegistry.getTool('read_many_files');
|
|
159
|
-
const globTool = toolRegistry.getTool('glob');
|
|
160
|
-
|
|
161
|
-
if (!readManyFilesTool) {
|
|
162
|
-
addItem(
|
|
163
|
-
{ type: 'error', text: 'Error: read_many_files tool not found.' },
|
|
164
|
-
userMessageTimestamp,
|
|
165
|
-
);
|
|
166
|
-
return { processedQuery: null, shouldProceed: false };
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
for (const atPathPart of atPathCommandParts) {
|
|
170
|
-
const originalAtPath = atPathPart.content; // e.g., "@file.txt" or "@"
|
|
171
|
-
|
|
172
|
-
if (originalAtPath === '@') {
|
|
173
|
-
onDebugMessage(
|
|
174
|
-
'Lone @ detected, will be treated as text in the modified query.',
|
|
175
|
-
);
|
|
176
|
-
continue;
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
const pathName = originalAtPath.substring(1);
|
|
180
|
-
if (!pathName) {
|
|
181
|
-
// This case should ideally not be hit if parseAllAtCommands ensures content after @
|
|
182
|
-
// but as a safeguard:
|
|
183
|
-
addItem(
|
|
184
|
-
{
|
|
185
|
-
type: 'error',
|
|
186
|
-
text: `Error: Invalid @ command '${originalAtPath}'. No path specified.`,
|
|
187
|
-
},
|
|
188
|
-
userMessageTimestamp,
|
|
189
|
-
);
|
|
190
|
-
// Decide if this is a fatal error for the whole command or just skip this @ part
|
|
191
|
-
// For now, let's be strict and fail the command if one @path is malformed.
|
|
192
|
-
return { processedQuery: null, shouldProceed: false };
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
// Check if path should be ignored based on filtering options
|
|
196
|
-
|
|
197
|
-
const workspaceContext = config.getWorkspaceContext();
|
|
198
|
-
if (!workspaceContext.isPathWithinWorkspace(pathName)) {
|
|
199
|
-
onDebugMessage(
|
|
200
|
-
`Path ${pathName} is not in the workspace and will be skipped.`,
|
|
201
|
-
);
|
|
202
|
-
continue;
|
|
203
|
-
}
|
|
204
|
-
|
|
205
|
-
const gitIgnored =
|
|
206
|
-
respectFileIgnore.respectGitIgnore &&
|
|
207
|
-
fileDiscovery.shouldIgnoreFile(pathName, {
|
|
208
|
-
respectGitIgnore: true,
|
|
209
|
-
respectFssLinkIgnore: false,
|
|
210
|
-
});
|
|
211
|
-
const geminiIgnored =
|
|
212
|
-
respectFileIgnore.respectFssLinkIgnore &&
|
|
213
|
-
fileDiscovery.shouldIgnoreFile(pathName, {
|
|
214
|
-
respectGitIgnore: false,
|
|
215
|
-
respectFssLinkIgnore: true,
|
|
216
|
-
});
|
|
217
|
-
|
|
218
|
-
if (gitIgnored || geminiIgnored) {
|
|
219
|
-
const reason =
|
|
220
|
-
gitIgnored && geminiIgnored ? 'both' : gitIgnored ? 'git' : 'gemini';
|
|
221
|
-
ignoredByReason[reason].push(pathName);
|
|
222
|
-
const reasonText =
|
|
223
|
-
reason === 'both'
|
|
224
|
-
? 'ignored by both git and fss-link'
|
|
225
|
-
: reason === 'git'
|
|
226
|
-
? 'git-ignored'
|
|
227
|
-
: 'fss-link-ignored';
|
|
228
|
-
onDebugMessage(`Path ${pathName} is ${reasonText} and will be skipped.`);
|
|
229
|
-
continue;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
for (const dir of config.getWorkspaceContext().getDirectories()) {
|
|
233
|
-
let currentPathSpec = pathName;
|
|
234
|
-
let resolvedSuccessfully = false;
|
|
235
|
-
try {
|
|
236
|
-
const absolutePath = path.resolve(dir, pathName);
|
|
237
|
-
const stats = await fs.stat(absolutePath);
|
|
238
|
-
if (stats.isDirectory()) {
|
|
239
|
-
currentPathSpec =
|
|
240
|
-
pathName + (pathName.endsWith(path.sep) ? `**` : `/**`);
|
|
241
|
-
onDebugMessage(
|
|
242
|
-
`Path ${pathName} resolved to directory, using glob: ${currentPathSpec}`,
|
|
243
|
-
);
|
|
244
|
-
} else {
|
|
245
|
-
onDebugMessage(`Path ${pathName} resolved to file: ${absolutePath}`);
|
|
246
|
-
}
|
|
247
|
-
resolvedSuccessfully = true;
|
|
248
|
-
} catch (error) {
|
|
249
|
-
if (isNodeError(error) && error.code === 'ENOENT') {
|
|
250
|
-
if (config.getEnableRecursiveFileSearch() && globTool) {
|
|
251
|
-
onDebugMessage(
|
|
252
|
-
`Path ${pathName} not found directly, attempting glob search.`,
|
|
253
|
-
);
|
|
254
|
-
try {
|
|
255
|
-
const globResult = await globTool.buildAndExecute(
|
|
256
|
-
{
|
|
257
|
-
pattern: `**/*${pathName}*`,
|
|
258
|
-
path: dir,
|
|
259
|
-
},
|
|
260
|
-
signal,
|
|
261
|
-
);
|
|
262
|
-
if (
|
|
263
|
-
globResult.llmContent &&
|
|
264
|
-
typeof globResult.llmContent === 'string' &&
|
|
265
|
-
!globResult.llmContent.startsWith('No files found') &&
|
|
266
|
-
!globResult.llmContent.startsWith('Error:')
|
|
267
|
-
) {
|
|
268
|
-
const lines = globResult.llmContent.split('\n');
|
|
269
|
-
if (lines.length > 1 && lines[1]) {
|
|
270
|
-
const firstMatchAbsolute = lines[1].trim();
|
|
271
|
-
currentPathSpec = path.relative(dir, firstMatchAbsolute);
|
|
272
|
-
onDebugMessage(
|
|
273
|
-
`Glob search for ${pathName} found ${firstMatchAbsolute}, using relative path: ${currentPathSpec}`,
|
|
274
|
-
);
|
|
275
|
-
resolvedSuccessfully = true;
|
|
276
|
-
} else {
|
|
277
|
-
onDebugMessage(
|
|
278
|
-
`Glob search for '**/*${pathName}*' did not return a usable path. Path ${pathName} will be skipped.`,
|
|
279
|
-
);
|
|
280
|
-
}
|
|
281
|
-
} else {
|
|
282
|
-
onDebugMessage(
|
|
283
|
-
`Glob search for '**/*${pathName}*' found no files or an error. Path ${pathName} will be skipped.`,
|
|
284
|
-
);
|
|
285
|
-
}
|
|
286
|
-
} catch (globError) {
|
|
287
|
-
console.error(
|
|
288
|
-
`Error during glob search for ${pathName}: ${getErrorMessage(globError)}`,
|
|
289
|
-
);
|
|
290
|
-
onDebugMessage(
|
|
291
|
-
`Error during glob search for ${pathName}. Path ${pathName} will be skipped.`,
|
|
292
|
-
);
|
|
293
|
-
}
|
|
294
|
-
} else {
|
|
295
|
-
onDebugMessage(
|
|
296
|
-
`Glob tool not found. Path ${pathName} will be skipped.`,
|
|
297
|
-
);
|
|
298
|
-
}
|
|
299
|
-
} else {
|
|
300
|
-
console.error(
|
|
301
|
-
`Error stating path ${pathName}: ${getErrorMessage(error)}`,
|
|
302
|
-
);
|
|
303
|
-
onDebugMessage(
|
|
304
|
-
`Error stating path ${pathName}. Path ${pathName} will be skipped.`,
|
|
305
|
-
);
|
|
306
|
-
}
|
|
307
|
-
}
|
|
308
|
-
if (resolvedSuccessfully) {
|
|
309
|
-
pathSpecsToRead.push(currentPathSpec);
|
|
310
|
-
atPathToResolvedSpecMap.set(originalAtPath, currentPathSpec);
|
|
311
|
-
contentLabelsForDisplay.push(pathName);
|
|
312
|
-
break;
|
|
313
|
-
}
|
|
314
|
-
}
|
|
315
|
-
}
|
|
316
|
-
|
|
317
|
-
// Construct the initial part of the query for the LLM
|
|
318
|
-
let initialQueryText = '';
|
|
319
|
-
for (let i = 0; i < commandParts.length; i++) {
|
|
320
|
-
const part = commandParts[i];
|
|
321
|
-
if (part.type === 'text') {
|
|
322
|
-
initialQueryText += part.content;
|
|
323
|
-
} else {
|
|
324
|
-
// type === 'atPath'
|
|
325
|
-
const resolvedSpec = atPathToResolvedSpecMap.get(part.content);
|
|
326
|
-
if (
|
|
327
|
-
i > 0 &&
|
|
328
|
-
initialQueryText.length > 0 &&
|
|
329
|
-
!initialQueryText.endsWith(' ')
|
|
330
|
-
) {
|
|
331
|
-
// Add space if previous part was text and didn't end with space, or if previous was @path
|
|
332
|
-
const prevPart = commandParts[i - 1];
|
|
333
|
-
if (
|
|
334
|
-
prevPart.type === 'text' ||
|
|
335
|
-
(prevPart.type === 'atPath' &&
|
|
336
|
-
atPathToResolvedSpecMap.has(prevPart.content))
|
|
337
|
-
) {
|
|
338
|
-
initialQueryText += ' ';
|
|
339
|
-
}
|
|
340
|
-
}
|
|
341
|
-
if (resolvedSpec) {
|
|
342
|
-
initialQueryText += `@${resolvedSpec}`;
|
|
343
|
-
} else {
|
|
344
|
-
// If not resolved for reading (e.g. lone @ or invalid path that was skipped),
|
|
345
|
-
// add the original @-string back, ensuring spacing if it's not the first element.
|
|
346
|
-
if (
|
|
347
|
-
i > 0 &&
|
|
348
|
-
initialQueryText.length > 0 &&
|
|
349
|
-
!initialQueryText.endsWith(' ') &&
|
|
350
|
-
!part.content.startsWith(' ')
|
|
351
|
-
) {
|
|
352
|
-
initialQueryText += ' ';
|
|
353
|
-
}
|
|
354
|
-
initialQueryText += part.content;
|
|
355
|
-
}
|
|
356
|
-
}
|
|
357
|
-
}
|
|
358
|
-
initialQueryText = initialQueryText.trim();
|
|
359
|
-
|
|
360
|
-
// Inform user about ignored paths
|
|
361
|
-
const totalIgnored =
|
|
362
|
-
ignoredByReason['git'].length +
|
|
363
|
-
ignoredByReason['gemini'].length +
|
|
364
|
-
ignoredByReason['both'].length;
|
|
365
|
-
|
|
366
|
-
if (totalIgnored > 0) {
|
|
367
|
-
const messages = [];
|
|
368
|
-
if (ignoredByReason['git'].length) {
|
|
369
|
-
messages.push(`Git-ignored: ${ignoredByReason['git'].join(', ')}`);
|
|
370
|
-
}
|
|
371
|
-
if (ignoredByReason['gemini'].length) {
|
|
372
|
-
messages.push(`Fss-Link-ignored: ${ignoredByReason['gemini'].join(', ')}`);
|
|
373
|
-
}
|
|
374
|
-
if (ignoredByReason['both'].length) {
|
|
375
|
-
messages.push(`Ignored by both: ${ignoredByReason['both'].join(', ')}`);
|
|
376
|
-
}
|
|
377
|
-
|
|
378
|
-
const message = `Ignored ${totalIgnored} files:\n${messages.join('\n')}`;
|
|
379
|
-
console.log(message);
|
|
380
|
-
onDebugMessage(message);
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
// Fallback for lone "@" or completely invalid @-commands resulting in empty initialQueryText
|
|
384
|
-
if (pathSpecsToRead.length === 0) {
|
|
385
|
-
onDebugMessage('No valid file paths found in @ commands to read.');
|
|
386
|
-
if (initialQueryText === '@' && query.trim() === '@') {
|
|
387
|
-
// If the only thing was a lone @, pass original query (which might have spaces)
|
|
388
|
-
return { processedQuery: [{ text: query }], shouldProceed: true };
|
|
389
|
-
} else if (!initialQueryText && query) {
|
|
390
|
-
// If all @-commands were invalid and no surrounding text, pass original query
|
|
391
|
-
return { processedQuery: [{ text: query }], shouldProceed: true };
|
|
392
|
-
}
|
|
393
|
-
// Otherwise, proceed with the (potentially modified) query text that doesn't involve file reading
|
|
394
|
-
return {
|
|
395
|
-
processedQuery: [{ text: initialQueryText || query }],
|
|
396
|
-
shouldProceed: true,
|
|
397
|
-
};
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
const processedQueryParts: PartUnion[] = [{ text: initialQueryText }];
|
|
401
|
-
|
|
402
|
-
const toolArgs = {
|
|
403
|
-
paths: pathSpecsToRead,
|
|
404
|
-
file_filtering_options: {
|
|
405
|
-
respect_git_ignore: respectFileIgnore.respectGitIgnore,
|
|
406
|
-
respect_gemini_ignore: respectFileIgnore.respectFssLinkIgnore,
|
|
407
|
-
},
|
|
408
|
-
// Use configuration setting
|
|
409
|
-
};
|
|
410
|
-
let toolCallDisplay: IndividualToolCallDisplay;
|
|
411
|
-
|
|
412
|
-
let invocation: AnyToolInvocation | undefined = undefined;
|
|
413
|
-
try {
|
|
414
|
-
invocation = readManyFilesTool.build(toolArgs);
|
|
415
|
-
const result = await invocation.execute(signal);
|
|
416
|
-
toolCallDisplay = {
|
|
417
|
-
callId: `client-read-${userMessageTimestamp}`,
|
|
418
|
-
name: readManyFilesTool.displayName,
|
|
419
|
-
description: invocation.getDescription(),
|
|
420
|
-
status: ToolCallStatus.Success,
|
|
421
|
-
resultDisplay:
|
|
422
|
-
result.returnDisplay ||
|
|
423
|
-
`Successfully read: ${contentLabelsForDisplay.join(', ')}`,
|
|
424
|
-
confirmationDetails: undefined,
|
|
425
|
-
};
|
|
426
|
-
|
|
427
|
-
if (Array.isArray(result.llmContent)) {
|
|
428
|
-
const fileContentRegex = /^--- (.*?) ---\n\n([\s\S]*?)\n\n$/;
|
|
429
|
-
processedQueryParts.push({
|
|
430
|
-
text: '\n--- Content from referenced files ---',
|
|
431
|
-
});
|
|
432
|
-
for (const part of result.llmContent) {
|
|
433
|
-
if (typeof part === 'string') {
|
|
434
|
-
const match = fileContentRegex.exec(part);
|
|
435
|
-
if (match) {
|
|
436
|
-
const filePathSpecInContent = match[1]; // This is a resolved pathSpec
|
|
437
|
-
const fileActualContent = match[2].trim();
|
|
438
|
-
processedQueryParts.push({
|
|
439
|
-
text: `\nContent from @${filePathSpecInContent}:\n`,
|
|
440
|
-
});
|
|
441
|
-
processedQueryParts.push({ text: fileActualContent });
|
|
442
|
-
} else {
|
|
443
|
-
processedQueryParts.push({ text: part });
|
|
444
|
-
}
|
|
445
|
-
} else {
|
|
446
|
-
// part is a Part object.
|
|
447
|
-
processedQueryParts.push(part);
|
|
448
|
-
}
|
|
449
|
-
}
|
|
450
|
-
processedQueryParts.push({ text: '\n--- End of content ---' });
|
|
451
|
-
} else {
|
|
452
|
-
onDebugMessage(
|
|
453
|
-
'read_many_files tool returned no content or empty content.',
|
|
454
|
-
);
|
|
455
|
-
}
|
|
456
|
-
|
|
457
|
-
addItem(
|
|
458
|
-
{ type: 'tool_group', tools: [toolCallDisplay] } as Omit<
|
|
459
|
-
HistoryItem,
|
|
460
|
-
'id'
|
|
461
|
-
>,
|
|
462
|
-
userMessageTimestamp,
|
|
463
|
-
);
|
|
464
|
-
return { processedQuery: processedQueryParts, shouldProceed: true };
|
|
465
|
-
} catch (error: unknown) {
|
|
466
|
-
toolCallDisplay = {
|
|
467
|
-
callId: `client-read-${userMessageTimestamp}`,
|
|
468
|
-
name: readManyFilesTool.displayName,
|
|
469
|
-
description:
|
|
470
|
-
invocation?.getDescription() ??
|
|
471
|
-
'Error attempting to execute tool to read files',
|
|
472
|
-
status: ToolCallStatus.Error,
|
|
473
|
-
resultDisplay: `Error reading files (${contentLabelsForDisplay.join(', ')}): ${getErrorMessage(error)}`,
|
|
474
|
-
confirmationDetails: undefined,
|
|
475
|
-
};
|
|
476
|
-
addItem(
|
|
477
|
-
{ type: 'tool_group', tools: [toolCallDisplay] } as Omit<
|
|
478
|
-
HistoryItem,
|
|
479
|
-
'id'
|
|
480
|
-
>,
|
|
481
|
-
userMessageTimestamp,
|
|
482
|
-
);
|
|
483
|
-
return { processedQuery: null, shouldProceed: false };
|
|
484
|
-
}
|
|
485
|
-
}
|