@vybestack/llxprt-code 0.4.8 → 0.5.0-nightly.251102.6bb3db7a
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 +5 -3
- package/dist/src/auth/__tests__/oauthManager.safety.test.d.ts +6 -0
- package/dist/src/auth/__tests__/oauthManager.safety.test.js +49 -0
- package/dist/src/auth/__tests__/oauthManager.safety.test.js.map +1 -0
- package/dist/src/auth/oauth-manager.d.ts +11 -0
- package/dist/src/auth/oauth-manager.js +62 -29
- package/dist/src/auth/oauth-manager.js.map +1 -1
- package/dist/src/auth/oauth-manager.spec.js +7 -2
- package/dist/src/auth/oauth-manager.spec.js.map +1 -1
- package/dist/src/config/__tests__/nonInteractiveTools.test.d.ts +6 -0
- package/dist/src/config/__tests__/nonInteractiveTools.test.js +13 -0
- package/dist/src/config/__tests__/nonInteractiveTools.test.js.map +1 -0
- package/dist/src/config/__tests__/profileBootstrap.test.d.ts +6 -0
- package/dist/src/config/__tests__/profileBootstrap.test.js +91 -0
- package/dist/src/config/__tests__/profileBootstrap.test.js.map +1 -0
- package/dist/src/config/config.d.ts +6 -2
- package/dist/src/config/config.js +219 -18
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/config/profileBootstrap.d.ts +64 -0
- package/dist/src/config/profileBootstrap.js +140 -0
- package/dist/src/config/profileBootstrap.js.map +1 -0
- package/dist/src/gemini.js +68 -23
- package/dist/src/gemini.js.map +1 -1
- package/dist/src/gemini.test.js +1 -2
- package/dist/src/gemini.test.js.map +1 -1
- package/dist/src/generated/git-commit.d.ts +1 -1
- package/dist/src/generated/git-commit.js +1 -1
- package/dist/src/integration-tests/base-url-behavior.integration.test.js +110 -450
- package/dist/src/integration-tests/base-url-behavior.integration.test.js.map +1 -1
- package/dist/src/integration-tests/model-params-isolation.integration.test.js +101 -539
- package/dist/src/integration-tests/model-params-isolation.integration.test.js.map +1 -1
- package/dist/src/integration-tests/modelParams.integration.test.js +86 -761
- package/dist/src/integration-tests/modelParams.integration.test.js.map +1 -1
- package/dist/src/integration-tests/provider-multi-runtime.integration.test.d.ts +6 -0
- package/dist/src/integration-tests/provider-multi-runtime.integration.test.js +198 -0
- package/dist/src/integration-tests/provider-multi-runtime.integration.test.js.map +1 -0
- package/dist/src/integration-tests/provider-switching.integration.test.js +97 -151
- package/dist/src/integration-tests/provider-switching.integration.test.js.map +1 -1
- package/dist/src/integration-tests/runtime-isolation.test.d.ts +13 -0
- package/dist/src/integration-tests/runtime-isolation.test.js +170 -0
- package/dist/src/integration-tests/runtime-isolation.test.js.map +1 -0
- package/dist/src/integration-tests/test-utils.js +19 -2
- package/dist/src/integration-tests/test-utils.js.map +1 -1
- package/dist/src/integration-tests/test-utils.test.js +9 -8
- package/dist/src/integration-tests/test-utils.test.js.map +1 -1
- package/dist/src/integration-tests/todo-continuation.integration.test.js +5 -2
- package/dist/src/integration-tests/todo-continuation.integration.test.js.map +1 -1
- package/dist/src/integration-tests/tools-governance.integration.test.d.ts +6 -0
- package/dist/src/integration-tests/tools-governance.integration.test.js +98 -0
- package/dist/src/integration-tests/tools-governance.integration.test.js.map +1 -0
- package/dist/src/nonInteractiveCli.js +36 -11
- package/dist/src/nonInteractiveCli.js.map +1 -1
- package/dist/src/providers/logging/git-stats.test.js +11 -1
- package/dist/src/providers/logging/git-stats.test.js.map +1 -1
- package/dist/src/providers/logging/multi-provider-logging.integration.test.js +1 -2
- package/dist/src/providers/logging/multi-provider-logging.integration.test.js.map +1 -1
- package/dist/src/providers/logging/performance.test.js +1 -1
- package/dist/src/providers/logging/performance.test.js.map +1 -1
- package/dist/src/providers/oauth-provider-registration.d.ts +2 -2
- package/dist/src/providers/oauth-provider-registration.js +25 -9
- package/dist/src/providers/oauth-provider-registration.js.map +1 -1
- package/dist/src/providers/provider-gemini-switching.test.js +67 -89
- package/dist/src/providers/provider-gemini-switching.test.js.map +1 -1
- package/dist/src/providers/provider-switching.integration.test.js +42 -98
- package/dist/src/providers/provider-switching.integration.test.js.map +1 -1
- package/dist/src/providers/providerConfigUtils.d.ts +12 -7
- package/dist/src/providers/providerConfigUtils.js +31 -99
- package/dist/src/providers/providerConfigUtils.js.map +1 -1
- package/dist/src/providers/providerManagerInstance.d.ts +17 -1
- package/dist/src/providers/providerManagerInstance.js +157 -175
- package/dist/src/providers/providerManagerInstance.js.map +1 -1
- package/dist/src/providers/providerManagerInstance.oauthRegistration.test.js +19 -15
- package/dist/src/providers/providerManagerInstance.oauthRegistration.test.js.map +1 -1
- package/dist/src/providers/providerManagerInstance.test.js +2 -5
- package/dist/src/providers/providerManagerInstance.test.js.map +1 -1
- package/dist/src/runtime/__tests__/profileApplication.test.d.ts +5 -0
- package/dist/src/runtime/__tests__/profileApplication.test.js +232 -0
- package/dist/src/runtime/__tests__/profileApplication.test.js.map +1 -0
- package/dist/src/runtime/__tests__/runtimeIsolation.test.d.ts +5 -0
- package/dist/src/runtime/__tests__/runtimeIsolation.test.js +376 -0
- package/dist/src/runtime/__tests__/runtimeIsolation.test.js.map +1 -0
- package/dist/src/runtime/agentRuntimeAdapter.d.ts +249 -0
- package/dist/src/runtime/agentRuntimeAdapter.js +506 -0
- package/dist/src/runtime/agentRuntimeAdapter.js.map +1 -0
- package/dist/src/runtime/agentRuntimeAdapter.spec.d.ts +6 -0
- package/dist/src/runtime/agentRuntimeAdapter.spec.js +866 -0
- package/dist/src/runtime/agentRuntimeAdapter.spec.js.map +1 -0
- package/dist/src/runtime/messages.d.ts +28 -0
- package/dist/src/runtime/messages.js +64 -0
- package/dist/src/runtime/messages.js.map +1 -0
- package/dist/src/runtime/profileApplication.d.ts +33 -0
- package/dist/src/runtime/profileApplication.js +191 -0
- package/dist/src/runtime/profileApplication.js.map +1 -0
- package/dist/src/runtime/providerConfigUtils.test.d.ts +1 -0
- package/dist/src/runtime/providerConfigUtils.test.js +68 -0
- package/dist/src/runtime/providerConfigUtils.test.js.map +1 -0
- package/dist/src/runtime/runtimeContextFactory.d.ts +102 -0
- package/dist/src/runtime/runtimeContextFactory.js +190 -0
- package/dist/src/runtime/runtimeContextFactory.js.map +1 -0
- package/dist/src/runtime/runtimeSettings.d.ts +217 -0
- package/dist/src/runtime/runtimeSettings.js +1094 -0
- package/dist/src/runtime/runtimeSettings.js.map +1 -0
- package/dist/src/runtime/runtimeSettings.test.d.ts +1 -0
- package/dist/src/runtime/runtimeSettings.test.js +320 -0
- package/dist/src/runtime/runtimeSettings.test.js.map +1 -0
- package/dist/src/services/BuiltinCommandLoader.d.ts +13 -4
- package/dist/src/services/BuiltinCommandLoader.js +17 -4
- package/dist/src/services/BuiltinCommandLoader.js.map +1 -1
- package/dist/src/services/McpPromptLoader.js +34 -13
- package/dist/src/services/McpPromptLoader.js.map +1 -1
- package/dist/src/test-utils/mockCommandContext.js +5 -2
- package/dist/src/test-utils/mockCommandContext.js.map +1 -1
- package/dist/src/ui/App.js +29 -49
- package/dist/src/ui/App.js.map +1 -1
- package/dist/src/ui/commands/aboutCommand.js +59 -38
- package/dist/src/ui/commands/aboutCommand.js.map +1 -1
- package/dist/src/ui/commands/authCommand.js +7 -9
- package/dist/src/ui/commands/authCommand.js.map +1 -1
- package/dist/src/ui/commands/baseurlCommand.js +8 -44
- package/dist/src/ui/commands/baseurlCommand.js.map +1 -1
- package/dist/src/ui/commands/chatCommand.js +28 -12
- package/dist/src/ui/commands/chatCommand.js.map +1 -1
- package/dist/src/ui/commands/diagnosticsCommand.d.ts +0 -3
- package/dist/src/ui/commands/diagnosticsCommand.js +45 -191
- package/dist/src/ui/commands/diagnosticsCommand.js.map +1 -1
- package/dist/src/ui/commands/keyCommand.js +9 -58
- package/dist/src/ui/commands/keyCommand.js.map +1 -1
- package/dist/src/ui/commands/keyCommand.test.js +48 -102
- package/dist/src/ui/commands/keyCommand.test.js.map +1 -1
- package/dist/src/ui/commands/keyfileCommand.js +42 -93
- package/dist/src/ui/commands/keyfileCommand.js.map +1 -1
- package/dist/src/ui/commands/logoutCommand.js +2 -2
- package/dist/src/ui/commands/logoutCommand.js.map +1 -1
- package/dist/src/ui/commands/mcpCommand.js +29 -7
- package/dist/src/ui/commands/mcpCommand.js.map +1 -1
- package/dist/src/ui/commands/modelCommand.js +8 -59
- package/dist/src/ui/commands/modelCommand.js.map +1 -1
- package/dist/src/ui/commands/profileCommand.js +151 -267
- package/dist/src/ui/commands/profileCommand.js.map +1 -1
- package/dist/src/ui/commands/profileCommand.test.js +88 -344
- package/dist/src/ui/commands/profileCommand.test.js.map +1 -1
- package/dist/src/ui/commands/providerCommand.js +9 -3
- package/dist/src/ui/commands/providerCommand.js.map +1 -1
- package/dist/src/ui/commands/restoreCommand.js +38 -18
- package/dist/src/ui/commands/restoreCommand.js.map +1 -1
- package/dist/src/ui/commands/schema/argumentResolver.test.d.ts +6 -0
- package/dist/src/ui/commands/schema/argumentResolver.test.js +619 -0
- package/dist/src/ui/commands/schema/argumentResolver.test.js.map +1 -0
- package/dist/src/ui/commands/schema/index.d.ts +15 -0
- package/dist/src/ui/commands/schema/index.js +320 -0
- package/dist/src/ui/commands/schema/index.js.map +1 -0
- package/dist/src/ui/commands/schema/types.d.ts +61 -0
- package/dist/src/ui/commands/schema/types.js +12 -0
- package/dist/src/ui/commands/schema/types.js.map +1 -0
- package/dist/src/ui/commands/setCommand.js +641 -325
- package/dist/src/ui/commands/setCommand.js.map +1 -1
- package/dist/src/ui/commands/setCommand.test.js +92 -388
- package/dist/src/ui/commands/setCommand.test.js.map +1 -1
- package/dist/src/ui/commands/statusCommand.js +2 -2
- package/dist/src/ui/commands/statusCommand.js.map +1 -1
- package/dist/src/ui/commands/subagentCommand.d.ts +16 -0
- package/dist/src/ui/commands/subagentCommand.js +674 -0
- package/dist/src/ui/commands/subagentCommand.js.map +1 -0
- package/dist/src/ui/commands/test/setCommand.mutation.test.d.ts +6 -0
- package/dist/src/ui/commands/test/setCommand.mutation.test.js +132 -0
- package/dist/src/ui/commands/test/setCommand.mutation.test.js.map +1 -0
- package/dist/src/ui/commands/test/setCommand.phase09.test.d.ts +6 -0
- package/dist/src/ui/commands/test/setCommand.phase09.test.js +222 -0
- package/dist/src/ui/commands/test/setCommand.phase09.test.js.map +1 -0
- package/dist/src/ui/commands/test/subagentCommand.schema.test.d.ts +6 -0
- package/dist/src/ui/commands/test/subagentCommand.schema.test.js +125 -0
- package/dist/src/ui/commands/test/subagentCommand.schema.test.js.map +1 -0
- package/dist/src/ui/commands/test/subagentCommand.test.d.ts +1 -0
- package/dist/src/ui/commands/test/subagentCommand.test.js +598 -0
- package/dist/src/ui/commands/test/subagentCommand.test.js.map +1 -0
- package/dist/src/ui/commands/toolformatCommand.js +25 -98
- package/dist/src/ui/commands/toolformatCommand.js.map +1 -1
- package/dist/src/ui/commands/toolformatCommand.test.js +56 -102
- package/dist/src/ui/commands/toolformatCommand.test.js.map +1 -1
- package/dist/src/ui/commands/toolsCommand.js +187 -31
- package/dist/src/ui/commands/toolsCommand.js.map +1 -1
- package/dist/src/ui/commands/types.d.ts +11 -2
- package/dist/src/ui/commands/types.js.map +1 -1
- package/dist/src/ui/components/AuthDialog.js +16 -55
- package/dist/src/ui/components/AuthDialog.js.map +1 -1
- package/dist/src/ui/components/Footer.js +4 -5
- package/dist/src/ui/components/Footer.js.map +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.js +1 -1
- package/dist/src/ui/components/HistoryItemDisplay.js.map +1 -1
- package/dist/src/ui/components/InputPrompt.js +1 -1
- package/dist/src/ui/components/InputPrompt.js.map +1 -1
- package/dist/src/ui/components/StatsDisplay.js +6 -11
- package/dist/src/ui/components/StatsDisplay.js.map +1 -1
- package/dist/src/ui/components/SuggestionsDisplay.d.ts +13 -1
- package/dist/src/ui/components/SuggestionsDisplay.js +22 -3
- package/dist/src/ui/components/SuggestionsDisplay.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.d.ts +1 -0
- package/dist/src/ui/components/messages/ToolGroupMessage.js +14 -14
- package/dist/src/ui/components/messages/ToolGroupMessage.js.map +1 -1
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js +1 -0
- package/dist/src/ui/components/messages/ToolGroupMessage.test.js.map +1 -1
- package/dist/src/ui/containers/SessionController.js +61 -117
- package/dist/src/ui/containers/SessionController.js.map +1 -1
- package/dist/src/ui/contexts/RuntimeContext.d.ts +61 -0
- package/dist/src/ui/contexts/RuntimeContext.js +118 -0
- package/dist/src/ui/contexts/RuntimeContext.js.map +1 -0
- package/dist/src/ui/contexts/TodoProvider.d.ts +1 -0
- package/dist/src/ui/contexts/TodoProvider.js +10 -8
- package/dist/src/ui/contexts/TodoProvider.js.map +1 -1
- package/dist/src/ui/contexts/ToolCallProvider.d.ts +1 -0
- package/dist/src/ui/contexts/ToolCallProvider.js +10 -9
- package/dist/src/ui/contexts/ToolCallProvider.js.map +1 -1
- package/dist/src/ui/hooks/__tests__/useSlashCompletion.set.phase09.test.d.ts +6 -0
- package/dist/src/ui/hooks/__tests__/useSlashCompletion.set.phase09.test.js +39 -0
- package/dist/src/ui/hooks/__tests__/useSlashCompletion.set.phase09.test.js.map +1 -0
- package/dist/src/ui/hooks/atCommandProcessor.js +11 -3
- package/dist/src/ui/hooks/atCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/atCommandProcessor.test.js +3 -1
- package/dist/src/ui/hooks/atCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/shellCommandProcessor.js +4 -1
- package/dist/src/ui/hooks/shellCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/shellCommandProcessor.test.js +1 -0
- package/dist/src/ui/hooks/shellCommandProcessor.test.js.map +1 -1
- package/dist/src/ui/hooks/slashCommandProcessor.js +27 -1
- package/dist/src/ui/hooks/slashCommandProcessor.js.map +1 -1
- package/dist/src/ui/hooks/useAuthCommand.js +11 -3
- package/dist/src/ui/hooks/useAuthCommand.js.map +1 -1
- package/dist/src/ui/hooks/useCommandCompletion.d.ts +1 -0
- package/dist/src/ui/hooks/useCommandCompletion.js +2 -0
- package/dist/src/ui/hooks/useCommandCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.js +37 -11
- package/dist/src/ui/hooks/useGeminiStream.js.map +1 -1
- package/dist/src/ui/hooks/useGeminiStream.subagent.spec.d.ts +6 -0
- package/dist/src/ui/hooks/useGeminiStream.subagent.spec.js +232 -0
- package/dist/src/ui/hooks/useGeminiStream.subagent.spec.js.map +1 -0
- package/dist/src/ui/hooks/useLoadProfileDialog.d.ts +1 -1
- package/dist/src/ui/hooks/useLoadProfileDialog.js +18 -57
- package/dist/src/ui/hooks/useLoadProfileDialog.js.map +1 -1
- package/dist/src/ui/hooks/useOpenAIProviderInfo.d.ts +1 -1
- package/dist/src/ui/hooks/useOpenAIProviderInfo.js +12 -7
- package/dist/src/ui/hooks/useOpenAIProviderInfo.js.map +1 -1
- package/dist/src/ui/hooks/useProviderDialog.d.ts +1 -1
- package/dist/src/ui/hooks/useProviderDialog.js +17 -90
- package/dist/src/ui/hooks/useProviderDialog.js.map +1 -1
- package/dist/src/ui/hooks/useProviderModelDialog.d.ts +2 -2
- package/dist/src/ui/hooks/useProviderModelDialog.js +11 -12
- package/dist/src/ui/hooks/useProviderModelDialog.js.map +1 -1
- package/dist/src/ui/hooks/useReactToolScheduler.d.ts +3 -1
- package/dist/src/ui/hooks/useReactToolScheduler.js +144 -34
- package/dist/src/ui/hooks/useReactToolScheduler.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.d.ts +32 -0
- package/dist/src/ui/hooks/useSlashCompletion.js +154 -77
- package/dist/src/ui/hooks/useSlashCompletion.js.map +1 -1
- package/dist/src/ui/hooks/useSlashCompletion.test.js +39 -14
- package/dist/src/ui/hooks/useSlashCompletion.test.js.map +1 -1
- package/dist/src/ui/hooks/useToolScheduler.test.js +108 -79
- package/dist/src/ui/hooks/useToolScheduler.test.js.map +1 -1
- package/dist/src/ui/types.d.ts +1 -0
- package/dist/src/ui/types.js.map +1 -1
- package/dist/src/utils/sandbox.js +7 -5
- package/dist/src/utils/sandbox.js.map +1 -1
- package/dist/src/validateNonInterActiveAuth.js +4 -2
- package/dist/src/validateNonInterActiveAuth.js.map +1 -1
- package/dist/src/zed-integration/schema.d.ts +30 -30
- package/dist/src/zed-integration/zedIntegration.js +112 -39
- package/dist/src/zed-integration/zedIntegration.js.map +1 -1
- package/dist/tsconfig.build.tsbuildinfo +1 -0
- package/package.json +5 -3
- package/dist/tsconfig.tsbuildinfo +0 -1
|
@@ -4,8 +4,7 @@
|
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
6
|
import { CommandKind } from './types.js';
|
|
7
|
-
import {
|
|
8
|
-
import { SettingScope } from '../../config/settings.js';
|
|
7
|
+
import { getRuntimeApi } from '../contexts/RuntimeContext.js';
|
|
9
8
|
const STRUCTURED_FORMATS = ['openai', 'anthropic', 'deepseek', 'qwen', 'gemma'];
|
|
10
9
|
const TEXT_FORMATS = ['hermes', 'xml', 'llama'];
|
|
11
10
|
const ALL_FORMATS = [...STRUCTURED_FORMATS, ...TEXT_FORMATS];
|
|
@@ -13,88 +12,36 @@ export const toolformatCommand = {
|
|
|
13
12
|
name: 'toolformat',
|
|
14
13
|
description: 'override the auto-detected tool calling/format parser for tools',
|
|
15
14
|
kind: CommandKind.BUILT_IN,
|
|
16
|
-
action: async (
|
|
15
|
+
action: async (_context, args) => {
|
|
17
16
|
const formatName = args?.trim();
|
|
18
|
-
|
|
19
|
-
|
|
17
|
+
let state;
|
|
18
|
+
try {
|
|
19
|
+
const runtime = getRuntimeApi();
|
|
20
|
+
state = await runtime.getActiveToolFormatState();
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
20
23
|
return {
|
|
21
24
|
type: 'message',
|
|
22
25
|
messageType: 'error',
|
|
23
|
-
content:
|
|
26
|
+
content: `Failed to read tool format: ${error instanceof Error ? error.message : String(error)}`,
|
|
24
27
|
};
|
|
25
28
|
}
|
|
26
|
-
const activeProvider = providerManager.getActiveProvider();
|
|
27
|
-
const providerName = activeProvider.name;
|
|
28
|
-
const settings = context.services.settings;
|
|
29
|
-
const config = context.services.config;
|
|
30
|
-
const settingsService = config?.getSettingsService();
|
|
31
29
|
// Show current format
|
|
32
30
|
if (!formatName) {
|
|
33
|
-
const currentFormat = activeProvider.getToolFormat
|
|
34
|
-
? activeProvider.getToolFormat()
|
|
35
|
-
: 'unknown';
|
|
36
|
-
let isAutoDetected = true;
|
|
37
|
-
if (settingsService) {
|
|
38
|
-
try {
|
|
39
|
-
const providerSettings = await settingsService.getSettings(providerName);
|
|
40
|
-
isAutoDetected =
|
|
41
|
-
!providerSettings.toolFormat ||
|
|
42
|
-
providerSettings.toolFormat === 'auto';
|
|
43
|
-
}
|
|
44
|
-
catch {
|
|
45
|
-
// Provider settings don't exist yet, use legacy check
|
|
46
|
-
isAutoDetected = !(settings.merged.providerToolFormatOverrides &&
|
|
47
|
-
settings.merged.providerToolFormatOverrides[providerName]);
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
else {
|
|
51
|
-
// Fallback to legacy settings
|
|
52
|
-
isAutoDetected = !(settings.merged.providerToolFormatOverrides &&
|
|
53
|
-
settings.merged.providerToolFormatOverrides[providerName]);
|
|
54
|
-
}
|
|
55
31
|
return {
|
|
56
32
|
type: 'message',
|
|
57
33
|
messageType: 'info',
|
|
58
|
-
content: `Current tool format: ${currentFormat} (${isAutoDetected ? 'auto-detected' : 'manual override'})\nTo override: /toolformat <format>\nTo return to auto: /toolformat auto\nSupported formats:\n Structured: ${STRUCTURED_FORMATS.join(', ')}\n Text-based: ${TEXT_FORMATS.join(', ')}`,
|
|
34
|
+
content: `Current tool format: ${state.currentFormat ?? 'unknown'} (${state.isAutoDetected ? 'auto-detected' : 'manual override'})\nTo override: /toolformat <format>\nTo return to auto: /toolformat auto\nSupported formats:\n Structured: ${STRUCTURED_FORMATS.join(', ')}\n Text-based: ${TEXT_FORMATS.join(', ')}`,
|
|
59
35
|
};
|
|
60
36
|
}
|
|
61
37
|
if (formatName === 'auto') {
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
toolFormat: 'auto',
|
|
70
|
-
});
|
|
71
|
-
return {
|
|
72
|
-
type: 'message',
|
|
73
|
-
messageType: 'info',
|
|
74
|
-
content: `Tool format override cleared for provider '${providerName}'. Using auto-detection.`,
|
|
75
|
-
};
|
|
76
|
-
}
|
|
77
|
-
catch (error) {
|
|
78
|
-
return {
|
|
79
|
-
type: 'message',
|
|
80
|
-
messageType: 'error',
|
|
81
|
-
content: `Failed to clear tool format override: ${error instanceof Error ? error.message : String(error)}`,
|
|
82
|
-
};
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
else {
|
|
86
|
-
// Fallback to legacy settings
|
|
87
|
-
const currentOverrides = {
|
|
88
|
-
...(settings.merged.providerToolFormatOverrides || {}),
|
|
89
|
-
};
|
|
90
|
-
delete currentOverrides[providerName];
|
|
91
|
-
settings.setValue(SettingScope.User, 'providerToolFormatOverrides', currentOverrides);
|
|
92
|
-
return {
|
|
93
|
-
type: 'message',
|
|
94
|
-
messageType: 'info',
|
|
95
|
-
content: `Tool format override cleared for provider '${providerName}'. Using auto-detection.`,
|
|
96
|
-
};
|
|
97
|
-
}
|
|
38
|
+
const runtime = getRuntimeApi();
|
|
39
|
+
const updated = await runtime.setActiveToolFormatOverride(null);
|
|
40
|
+
return {
|
|
41
|
+
type: 'message',
|
|
42
|
+
messageType: 'info',
|
|
43
|
+
content: `Tool format override cleared for provider '${updated.providerName}'. Using auto-detection.`,
|
|
44
|
+
};
|
|
98
45
|
}
|
|
99
46
|
if (!ALL_FORMATS.includes(formatName)) {
|
|
100
47
|
return {
|
|
@@ -103,35 +50,15 @@ export const toolformatCommand = {
|
|
|
103
50
|
content: `Invalid tool format '${formatName}'.\nSupported formats:\n Structured: ${STRUCTURED_FORMATS.join(', ')}\n Text-based: ${TEXT_FORMATS.join(', ')}`,
|
|
104
51
|
};
|
|
105
52
|
}
|
|
106
|
-
// Set override
|
|
107
53
|
try {
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
return {
|
|
117
|
-
type: 'message',
|
|
118
|
-
messageType: 'info',
|
|
119
|
-
content: `Tool format override set to '${formatName}' for provider '${providerName}'.`,
|
|
120
|
-
};
|
|
121
|
-
}
|
|
122
|
-
else {
|
|
123
|
-
// Fallback to legacy settings
|
|
124
|
-
const currentOverrides = {
|
|
125
|
-
...(settings.merged.providerToolFormatOverrides || {}),
|
|
126
|
-
};
|
|
127
|
-
currentOverrides[providerName] = formatName;
|
|
128
|
-
settings.setValue(SettingScope.User, 'providerToolFormatOverrides', currentOverrides);
|
|
129
|
-
return {
|
|
130
|
-
type: 'message',
|
|
131
|
-
messageType: 'info',
|
|
132
|
-
content: `Tool format override set to '${formatName}' for provider '${providerName}'.`,
|
|
133
|
-
};
|
|
134
|
-
}
|
|
54
|
+
const normalized = formatName;
|
|
55
|
+
const runtime = getRuntimeApi();
|
|
56
|
+
const updated = await runtime.setActiveToolFormatOverride(normalized);
|
|
57
|
+
return {
|
|
58
|
+
type: 'message',
|
|
59
|
+
messageType: 'info',
|
|
60
|
+
content: `Tool format override set to '${formatName}' for provider '${updated.providerName}'.`,
|
|
61
|
+
};
|
|
135
62
|
}
|
|
136
63
|
catch (error) {
|
|
137
64
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toolformatCommand.js","sourceRoot":"","sources":["../../../../src/ui/commands/toolformatCommand.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAOH,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"toolformatCommand.js","sourceRoot":"","sources":["../../../../src/ui/commands/toolformatCommand.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,143 +3,97 @@
|
|
|
3
3
|
* Copyright 2025 Vybestack LLC
|
|
4
4
|
* SPDX-License-Identifier: Apache-2.0
|
|
5
5
|
*/
|
|
6
|
-
import {
|
|
6
|
+
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
7
7
|
import { toolformatCommand } from './toolformatCommand.js';
|
|
8
8
|
import { createMockCommandContext } from '../../test-utils/mockCommandContext.js';
|
|
9
|
-
|
|
10
|
-
vi.
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
getModels: vi.fn().mockResolvedValue([]),
|
|
17
|
-
generateChatCompletion: vi.fn(),
|
|
18
|
-
getServerTools: vi.fn().mockReturnValue([]),
|
|
19
|
-
invokeServerTool: vi.fn().mockResolvedValue({}),
|
|
20
|
-
...extra,
|
|
21
|
-
};
|
|
22
|
-
}
|
|
9
|
+
const mockRuntime = {
|
|
10
|
+
getActiveToolFormatState: vi.fn(),
|
|
11
|
+
setActiveToolFormatOverride: vi.fn(),
|
|
12
|
+
};
|
|
13
|
+
vi.mock('../contexts/RuntimeContext.js', () => ({
|
|
14
|
+
getRuntimeApi: () => mockRuntime,
|
|
15
|
+
}));
|
|
23
16
|
describe('toolformatCommand', () => {
|
|
24
17
|
let mockContext;
|
|
25
|
-
let providerManager;
|
|
26
|
-
let provider;
|
|
27
|
-
let mockSettingsService;
|
|
28
18
|
beforeEach(() => {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
};
|
|
19
|
+
vi.resetAllMocks();
|
|
20
|
+
mockRuntime.getActiveToolFormatState.mockResolvedValue({
|
|
21
|
+
providerName: 'openai',
|
|
22
|
+
currentFormat: 'openai',
|
|
23
|
+
override: null,
|
|
24
|
+
isAutoDetected: true,
|
|
25
|
+
});
|
|
26
|
+
mockRuntime.setActiveToolFormatOverride.mockResolvedValue({
|
|
27
|
+
providerName: 'openai',
|
|
28
|
+
currentFormat: 'openai',
|
|
29
|
+
override: null,
|
|
30
|
+
isAutoDetected: true,
|
|
31
|
+
});
|
|
43
32
|
mockContext = createMockCommandContext();
|
|
44
33
|
mockContext.services.settings.merged.providerToolFormatOverrides = {
|
|
45
34
|
openai: 'xml',
|
|
46
35
|
};
|
|
47
36
|
mockContext.services.settings.setValue = vi.fn();
|
|
48
|
-
mockContext.services.config = {
|
|
49
|
-
getSettingsService: vi.fn().mockReturnValue(mockSettingsService),
|
|
50
|
-
};
|
|
51
37
|
});
|
|
52
|
-
it('shows current format
|
|
38
|
+
it('shows the current format when invoked without arguments', async () => {
|
|
53
39
|
const result = await toolformatCommand.action(mockContext, '');
|
|
54
|
-
expect(result).toBeDefined();
|
|
55
40
|
expect(result?.type).toBe('message');
|
|
56
|
-
if (result
|
|
41
|
+
if (result?.type === 'message') {
|
|
57
42
|
expect(result.content).toContain('Current tool format: openai');
|
|
58
|
-
expect(result.content).toMatch(/auto-detected|manual override/);
|
|
59
43
|
}
|
|
44
|
+
expect(mockRuntime.getActiveToolFormatState).toHaveBeenCalled();
|
|
60
45
|
});
|
|
61
|
-
it('clears
|
|
46
|
+
it('clears overrides when auto is provided', async () => {
|
|
62
47
|
const result = await toolformatCommand.action(mockContext, 'auto');
|
|
48
|
+
expect(mockRuntime.setActiveToolFormatOverride).toHaveBeenCalledWith(null);
|
|
63
49
|
expect(result?.type).toBe('message');
|
|
64
|
-
if (result
|
|
65
|
-
expect(result.
|
|
50
|
+
if (result?.type === 'message') {
|
|
51
|
+
expect(result.messageType).toBe('info');
|
|
52
|
+
expect(result.content).toContain('override cleared');
|
|
66
53
|
}
|
|
67
|
-
expect(provider.setToolFormatOverride).toHaveBeenCalledWith(null);
|
|
68
|
-
// Should use SettingsService, not legacy settings
|
|
69
|
-
expect(mockSettingsService.updateSettings).toHaveBeenCalledWith('openai', { toolFormat: 'auto' });
|
|
70
54
|
});
|
|
71
|
-
it('
|
|
72
|
-
const result = await toolformatCommand.action(mockContext, '
|
|
55
|
+
it('rejects invalid formats', async () => {
|
|
56
|
+
const result = await toolformatCommand.action(mockContext, 'invalid');
|
|
73
57
|
expect(result?.type).toBe('message');
|
|
74
|
-
if (result
|
|
58
|
+
if (result?.type === 'message') {
|
|
75
59
|
expect(result.messageType).toBe('error');
|
|
76
60
|
expect(result.content).toContain('Invalid tool format');
|
|
77
61
|
}
|
|
78
62
|
});
|
|
79
|
-
it('
|
|
63
|
+
it('persists valid overrides through SettingsService', async () => {
|
|
64
|
+
mockRuntime.setActiveToolFormatOverride.mockResolvedValue({
|
|
65
|
+
providerName: 'openai',
|
|
66
|
+
currentFormat: 'hermes',
|
|
67
|
+
override: 'hermes',
|
|
68
|
+
isAutoDetected: false,
|
|
69
|
+
});
|
|
80
70
|
const result = await toolformatCommand.action(mockContext, 'hermes');
|
|
81
|
-
expect(
|
|
82
|
-
// Should use SettingsService, not legacy settings
|
|
83
|
-
expect(mockSettingsService.updateSettings).toHaveBeenCalledWith('openai', { toolFormat: 'hermes' });
|
|
71
|
+
expect(mockRuntime.setActiveToolFormatOverride).toHaveBeenCalledWith('hermes');
|
|
84
72
|
expect(result?.type).toBe('message');
|
|
85
|
-
if (result
|
|
73
|
+
if (result?.type === 'message') {
|
|
86
74
|
expect(result.messageType).toBe('info');
|
|
87
75
|
expect(result.content).toContain("override set to 'hermes'");
|
|
88
76
|
}
|
|
89
77
|
});
|
|
90
|
-
it('
|
|
91
|
-
|
|
78
|
+
it('works when settings service is unavailable', async () => {
|
|
79
|
+
mockContext.services.config = {
|
|
80
|
+
getSettingsService: vi.fn().mockReturnValue(null),
|
|
81
|
+
};
|
|
92
82
|
const result = await toolformatCommand.action(mockContext, 'hermes');
|
|
83
|
+
expect(mockRuntime.setActiveToolFormatOverride).toHaveBeenCalledWith('hermes');
|
|
93
84
|
expect(result?.type).toBe('message');
|
|
94
|
-
if (result
|
|
95
|
-
expect(result.messageType).toBe('
|
|
96
|
-
expect(result.content).toContain('No active provider');
|
|
85
|
+
if (result?.type === 'message') {
|
|
86
|
+
expect(result.messageType).toBe('info');
|
|
97
87
|
}
|
|
98
88
|
});
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
}
|
|
108
|
-
});
|
|
109
|
-
it('uses SettingsService when available for clearing format', async () => {
|
|
110
|
-
const result = await toolformatCommand.action(mockContext, 'auto');
|
|
111
|
-
expect(mockSettingsService.updateSettings).toHaveBeenCalledWith('openai', { toolFormat: 'auto' });
|
|
112
|
-
expect(result?.type).toBe('message');
|
|
113
|
-
if (result && result.type === 'message') {
|
|
114
|
-
expect(result.content).toMatch(/override cleared|auto-detection/);
|
|
115
|
-
}
|
|
116
|
-
});
|
|
117
|
-
it('falls back to legacy settings when SettingsService is not available', async () => {
|
|
118
|
-
// Remove SettingsService
|
|
119
|
-
mockContext.services.config = {
|
|
120
|
-
getSettingsService: vi.fn().mockReturnValue(null),
|
|
121
|
-
};
|
|
122
|
-
const result = await toolformatCommand.action(mockContext, 'hermes');
|
|
123
|
-
expect(mockContext.services.settings.setValue).toHaveBeenCalledWith('User', 'providerToolFormatOverrides', { openai: 'hermes' });
|
|
124
|
-
expect(result?.type).toBe('message');
|
|
125
|
-
if (result && result.type === 'message') {
|
|
126
|
-
expect(result.messageType).toBe('info');
|
|
127
|
-
expect(result.content).toContain("override set to 'hermes'");
|
|
128
|
-
}
|
|
129
|
-
});
|
|
130
|
-
it('handles SettingsService errors gracefully', async () => {
|
|
131
|
-
// Make SettingsService throw an error
|
|
132
|
-
mockSettingsService.updateSettings = vi
|
|
133
|
-
.fn()
|
|
134
|
-
.mockRejectedValue(new Error('Settings update failed'));
|
|
135
|
-
const result = await toolformatCommand.action(mockContext, 'xml');
|
|
136
|
-
expect(result?.type).toBe('message');
|
|
137
|
-
if (result && result.type === 'message') {
|
|
138
|
-
expect(result.messageType).toBe('error');
|
|
139
|
-
expect(result.content).toContain('Failed to set tool format override');
|
|
140
|
-
expect(result.content).toContain('Settings update failed');
|
|
141
|
-
}
|
|
142
|
-
});
|
|
89
|
+
it('surfaces runtime errors when override update fails', async () => {
|
|
90
|
+
mockRuntime.setActiveToolFormatOverride.mockRejectedValue(new Error('failure'));
|
|
91
|
+
const result = await toolformatCommand.action(mockContext, 'xml');
|
|
92
|
+
expect(result?.type).toBe('message');
|
|
93
|
+
if (result?.type === 'message') {
|
|
94
|
+
expect(result.messageType).toBe('error');
|
|
95
|
+
expect(result.content).toContain('failure');
|
|
96
|
+
}
|
|
143
97
|
});
|
|
144
98
|
});
|
|
145
99
|
//# sourceMappingURL=toolformatCommand.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toolformatCommand.test.js","sourceRoot":"","sources":["../../../../src/ui/commands/toolformatCommand.test.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"toolformatCommand.test.js","sourceRoot":"","sources":["../../../../src/ui/commands/toolformatCommand.test.ts"],"names":[],"mappings":"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"}
|