@qduc/term2 0.1.4 → 0.1.6
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/agent.d.ts.map +1 -1
- package/dist/agent.js +4 -24
- package/dist/agent.js.map +1 -1
- package/dist/app.d.ts.map +1 -1
- package/dist/app.js +12 -33
- package/dist/app.js.map +1 -1
- package/dist/app.parseInput.test.js +4 -4
- package/dist/app.parseInput.test.js.map +1 -1
- package/dist/cli.js +44 -29
- package/dist/cli.js.map +1 -1
- package/dist/components/ApprovalPrompt.d.ts.map +1 -1
- package/dist/components/ApprovalPrompt.js +14 -11
- package/dist/components/ApprovalPrompt.js.map +1 -1
- package/dist/components/Banner.d.ts.map +1 -1
- package/dist/components/Banner.js +4 -12
- package/dist/components/Banner.js.map +1 -1
- package/dist/components/BottomArea.d.ts +2 -0
- package/dist/components/BottomArea.d.ts.map +1 -1
- package/dist/components/BottomArea.js +6 -9
- package/dist/components/BottomArea.js.map +1 -1
- package/dist/components/BottomArea.test.js +4 -6
- package/dist/components/BottomArea.test.js.map +1 -1
- package/dist/components/ChatMessage.d.ts.map +1 -1
- package/dist/components/ChatMessage.js.map +1 -1
- package/dist/components/CommandMessage.d.ts.map +1 -1
- package/dist/components/CommandMessage.js +19 -30
- package/dist/components/CommandMessage.js.map +1 -1
- package/dist/components/CommandMessage.test.js +2 -2
- package/dist/components/CommandMessage.test.js.map +1 -1
- package/dist/components/ErrorBoundary.d.ts.map +1 -1
- package/dist/components/ErrorBoundary.js +3 -9
- package/dist/components/ErrorBoundary.js.map +1 -1
- package/dist/components/ErrorBoundary.test.js +2 -2
- package/dist/components/ErrorBoundary.test.js.map +1 -1
- package/dist/components/Input/PopupManager.d.ts.map +1 -1
- package/dist/components/Input/PopupManager.js.map +1 -1
- package/dist/components/InputBox.d.ts.map +1 -1
- package/dist/components/InputBox.js +15 -33
- package/dist/components/InputBox.js.map +1 -1
- package/dist/components/InputBox.menu-logic.test.js +6 -7
- package/dist/components/InputBox.menu-logic.test.js.map +1 -1
- package/dist/components/InputBox.test.js +7 -9
- package/dist/components/InputBox.test.js.map +1 -1
- package/dist/components/LiveResponse.d.ts.map +1 -1
- package/dist/components/LiveResponse.js.map +1 -1
- package/dist/components/MarkdownRenderer.d.ts.map +1 -1
- package/dist/components/MarkdownRenderer.js +12 -12
- package/dist/components/MarkdownRenderer.js.map +1 -1
- package/dist/components/MessageList.d.ts.map +1 -1
- package/dist/components/MessageList.js.map +1 -1
- package/dist/components/MessageList.test.js +1 -1
- package/dist/components/MessageList.test.js.map +1 -1
- package/dist/components/ModelSelectionMenu.d.ts.map +1 -1
- package/dist/components/ModelSelectionMenu.js +35 -31
- package/dist/components/ModelSelectionMenu.js.map +1 -1
- package/dist/components/ModelSelectionMenu.test.js +9 -9
- package/dist/components/ModelSelectionMenu.test.js.map +1 -1
- package/dist/components/PathSelectionMenu.d.ts.map +1 -1
- package/dist/components/PathSelectionMenu.js +1 -1
- package/dist/components/PathSelectionMenu.js.map +1 -1
- package/dist/components/SettingsSelectionMenu.d.ts.map +1 -1
- package/dist/components/SettingsSelectionMenu.js +1 -1
- package/dist/components/SettingsSelectionMenu.js.map +1 -1
- package/dist/components/SettingsSelectionMenu.test.js +4 -4
- package/dist/components/SettingsSelectionMenu.test.js.map +1 -1
- package/dist/components/SettingsValueSelectionMenu.d.ts.map +1 -1
- package/dist/components/SettingsValueSelectionMenu.js +5 -6
- package/dist/components/SettingsValueSelectionMenu.js.map +1 -1
- package/dist/components/SettingsValueSelectionMenu.test.js +5 -5
- package/dist/components/SettingsValueSelectionMenu.test.js.map +1 -1
- package/dist/components/SlashCommandMenu.d.ts.map +1 -1
- package/dist/components/SlashCommandMenu.js +1 -1
- package/dist/components/SlashCommandMenu.js.map +1 -1
- package/dist/components/StatusBar.d.ts +2 -0
- package/dist/components/StatusBar.d.ts.map +1 -1
- package/dist/components/StatusBar.js +45 -41
- package/dist/components/StatusBar.js.map +1 -1
- package/dist/components/StatusBar.test.d.ts +2 -0
- package/dist/components/StatusBar.test.d.ts.map +1 -0
- package/dist/components/StatusBar.test.js +19 -0
- package/dist/components/StatusBar.test.js.map +1 -0
- package/dist/context/InputContext.d.ts.map +1 -1
- package/dist/context/InputContext.js.map +1 -1
- package/dist/context/InputContext.stability.test.js +1 -1
- package/dist/context/InputContext.stability.test.js.map +1 -1
- package/dist/context/InputContext.test.js +15 -15
- package/dist/context/InputContext.test.js.map +1 -1
- package/dist/hooks/use-conversation.d.ts +5 -13
- package/dist/hooks/use-conversation.d.ts.map +1 -1
- package/dist/hooks/use-conversation.js +40 -148
- package/dist/hooks/use-conversation.js.map +1 -1
- package/dist/hooks/use-input-history.d.ts.map +1 -1
- package/dist/hooks/use-input-history.js +1 -3
- package/dist/hooks/use-input-history.js.map +1 -1
- package/dist/hooks/use-model-selection.d.ts.map +1 -1
- package/dist/hooks/use-model-selection.js +9 -35
- package/dist/hooks/use-model-selection.js.map +1 -1
- package/dist/hooks/use-path-completion.d.ts.map +1 -1
- package/dist/hooks/use-path-completion.js +6 -6
- package/dist/hooks/use-path-completion.js.map +1 -1
- package/dist/hooks/use-setting.d.ts.map +1 -1
- package/dist/hooks/use-setting.js +3 -6
- package/dist/hooks/use-setting.js.map +1 -1
- package/dist/hooks/use-settings-completion.d.ts.map +1 -1
- package/dist/hooks/use-settings-completion.js +10 -12
- package/dist/hooks/use-settings-completion.js.map +1 -1
- package/dist/hooks/use-settings-completion.test.js +46 -46
- package/dist/hooks/use-settings-completion.test.js.map +1 -1
- package/dist/hooks/use-settings-value-completion.d.ts.map +1 -1
- package/dist/hooks/use-settings-value-completion.js +13 -43
- package/dist/hooks/use-settings-value-completion.js.map +1 -1
- package/dist/hooks/use-settings-value-completion.test.js +12 -18
- package/dist/hooks/use-settings-value-completion.test.js.map +1 -1
- package/dist/hooks/use-slash-commands.d.ts +1 -1
- package/dist/hooks/use-slash-commands.d.ts.map +1 -1
- package/dist/hooks/use-slash-commands.js +6 -11
- package/dist/hooks/use-slash-commands.js.map +1 -1
- package/dist/hooks/use-slash-commands.test.js +24 -24
- package/dist/hooks/use-slash-commands.test.js.map +1 -1
- package/dist/lib/editor-impl.d.ts.map +1 -1
- package/dist/lib/editor-impl.js +6 -16
- package/dist/lib/editor-impl.js.map +1 -1
- package/dist/lib/editor-impl.test.js.map +1 -1
- package/dist/lib/mentor-client.d.ts +41 -0
- package/dist/lib/mentor-client.d.ts.map +1 -0
- package/dist/lib/mentor-client.js +146 -0
- package/dist/lib/mentor-client.js.map +1 -0
- package/dist/lib/mentor-client.test.d.ts +2 -0
- package/dist/lib/mentor-client.test.d.ts.map +1 -0
- package/dist/lib/mentor-client.test.js +440 -0
- package/dist/lib/mentor-client.test.js.map +1 -0
- package/dist/lib/openai-agent-client.chat.test.js +33 -8
- package/dist/lib/openai-agent-client.chat.test.js.map +1 -1
- package/dist/lib/openai-agent-client.d.ts.map +1 -1
- package/dist/lib/openai-agent-client.flex-tier.test.js +5 -5
- package/dist/lib/openai-agent-client.flex-tier.test.js.map +1 -1
- package/dist/lib/openai-agent-client.js +99 -88
- package/dist/lib/openai-agent-client.js.map +1 -1
- package/dist/lib/openai-agent-client.public-methods.test.js +186 -12
- package/dist/lib/openai-agent-client.public-methods.test.js.map +1 -1
- package/dist/lib/openai-agent-client.test.js +17 -17
- package/dist/lib/openai-agent-client.test.js.map +1 -1
- package/dist/lib/retry-strategy.d.ts +43 -0
- package/dist/lib/retry-strategy.d.ts.map +1 -0
- package/dist/lib/retry-strategy.js +93 -0
- package/dist/lib/retry-strategy.js.map +1 -0
- package/dist/lib/retry-strategy.test.d.ts +2 -0
- package/dist/lib/retry-strategy.test.d.ts.map +1 -0
- package/dist/lib/retry-strategy.test.js +200 -0
- package/dist/lib/retry-strategy.test.js.map +1 -0
- package/dist/lib/tool-invoke.d.ts.map +1 -1
- package/dist/lib/tool-invoke.js.map +1 -1
- package/dist/lib/tool-invoke.test.js.map +1 -1
- package/dist/no-singleton-imports.test.js +1 -1
- package/dist/no-singleton-imports.test.js.map +1 -1
- package/dist/non-interactive.d.ts +20 -0
- package/dist/non-interactive.d.ts.map +1 -0
- package/dist/non-interactive.js +86 -0
- package/dist/non-interactive.js.map +1 -0
- package/dist/non-interactive.test.d.ts +2 -0
- package/dist/non-interactive.test.d.ts.map +1 -0
- package/dist/non-interactive.test.js +213 -0
- package/dist/non-interactive.test.js.map +1 -0
- package/dist/prompts/anthropic.md +11 -11
- package/dist/prompts/codex.md +63 -63
- package/dist/prompts/gpt-5.md +95 -95
- package/dist/prompts/mentor-addon.md +6 -5
- package/dist/prompts/prompt-selector.d.ts +8 -0
- package/dist/prompts/prompt-selector.d.ts.map +1 -0
- package/dist/prompts/prompt-selector.js +21 -0
- package/dist/prompts/prompt-selector.js.map +1 -0
- package/dist/prompts/prompt-selector.test.d.ts +2 -0
- package/dist/prompts/prompt-selector.test.d.ts.map +1 -0
- package/dist/prompts/prompt-selector.test.js +21 -0
- package/dist/prompts/prompt-selector.test.js.map +1 -0
- package/dist/prompts/prompt-selector.test.ts +32 -0
- package/dist/prompts/prompt-selector.ts +30 -0
- package/dist/prompts/simple.md +58 -58
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js.map +1 -1
- package/dist/providers/openai-compatible/api.d.ts.map +1 -1
- package/dist/providers/openai-compatible/api.js.map +1 -1
- package/dist/providers/openai-compatible/model.d.ts.map +1 -1
- package/dist/providers/openai-compatible/model.js +19 -53
- package/dist/providers/openai-compatible/model.js.map +1 -1
- package/dist/providers/openai-compatible/provider.d.ts.map +1 -1
- package/dist/providers/openai-compatible/provider.js.map +1 -1
- package/dist/providers/openai-compatible/reasoning-content.test.js +2 -2
- package/dist/providers/openai-compatible/reasoning-content.test.js.map +1 -1
- package/dist/providers/openai-compatible/utils.d.ts.map +1 -1
- package/dist/providers/openai-compatible/utils.js.map +1 -1
- package/dist/providers/openai-compatible.provider.d.ts.map +1 -1
- package/dist/providers/openai-compatible.provider.js +5 -1
- package/dist/providers/openai-compatible.provider.js.map +1 -1
- package/dist/providers/openai.provider.js +4 -0
- package/dist/providers/openai.provider.js.map +1 -1
- package/dist/providers/openrouter/api.d.ts.map +1 -1
- package/dist/providers/openrouter/api.js +5 -13
- package/dist/providers/openrouter/api.js.map +1 -1
- package/dist/providers/openrouter/converters.d.ts.map +1 -1
- package/dist/providers/openrouter/converters.js +9 -28
- package/dist/providers/openrouter/converters.js.map +1 -1
- package/dist/providers/openrouter/converters.test.js +7 -11
- package/dist/providers/openrouter/converters.test.js.map +1 -1
- package/dist/providers/openrouter/index.d.ts.map +1 -1
- package/dist/providers/openrouter/index.js.map +1 -1
- package/dist/providers/openrouter/model.d.ts.map +1 -1
- package/dist/providers/openrouter/model.js +19 -55
- package/dist/providers/openrouter/model.js.map +1 -1
- package/dist/providers/openrouter/provider.d.ts.map +1 -1
- package/dist/providers/openrouter/provider.js.map +1 -1
- package/dist/providers/openrouter/reasoning-content.test.js +1 -1
- package/dist/providers/openrouter/reasoning-content.test.js.map +1 -1
- package/dist/providers/openrouter/utils.d.ts.map +1 -1
- package/dist/providers/openrouter/utils.js +2 -3
- package/dist/providers/openrouter/utils.js.map +1 -1
- package/dist/providers/openrouter.api.retry.test.js.map +1 -1
- package/dist/providers/openrouter.provider.createRunner.test.js +1 -1
- package/dist/providers/openrouter.provider.createRunner.test.js.map +1 -1
- package/dist/providers/openrouter.provider.js +6 -4
- package/dist/providers/openrouter.provider.js.map +1 -1
- package/dist/providers/openrouter.test.js +13 -17
- package/dist/providers/openrouter.test.js.map +1 -1
- package/dist/providers/registry.d.ts +5 -0
- package/dist/providers/registry.d.ts.map +1 -1
- package/dist/providers/registry.js.map +1 -1
- package/dist/providers/registry.test.js +11 -11
- package/dist/providers/registry.test.js.map +1 -1
- package/dist/providers/web-search/index.d.ts +1 -1
- package/dist/providers/web-search/index.d.ts.map +1 -1
- package/dist/providers/web-search/index.js.map +1 -1
- package/dist/providers/web-search/registry.d.ts.map +1 -1
- package/dist/providers/web-search/registry.js.map +1 -1
- package/dist/providers/web-search/registry.test.js +14 -14
- package/dist/providers/web-search/registry.test.js.map +1 -1
- package/dist/providers/web-search/tavily.provider.d.ts.map +1 -1
- package/dist/providers/web-search/tavily.provider.js +4 -4
- package/dist/providers/web-search/tavily.provider.js.map +1 -1
- package/dist/providers/web-search/tavily.provider.test.js +7 -7
- package/dist/providers/web-search/tavily.provider.test.js.map +1 -1
- package/dist/providers/web-search/types.d.ts.map +1 -1
- package/dist/scripts/extract-provider-traffic.d.ts +3 -0
- package/dist/scripts/extract-provider-traffic.d.ts.map +1 -0
- package/dist/scripts/extract-provider-traffic.js +32 -0
- package/dist/scripts/extract-provider-traffic.js.map +1 -0
- package/dist/services/approval-state.d.ts +24 -0
- package/dist/services/approval-state.d.ts.map +1 -0
- package/dist/services/approval-state.js +41 -0
- package/dist/services/approval-state.js.map +1 -0
- package/dist/services/approval-state.test.d.ts +2 -0
- package/dist/services/approval-state.test.d.ts.map +1 -0
- package/dist/services/approval-state.test.js +59 -0
- package/dist/services/approval-state.test.js.map +1 -0
- package/dist/services/command-message-streaming.d.ts +12 -0
- package/dist/services/command-message-streaming.d.ts.map +1 -0
- package/dist/services/command-message-streaming.js +68 -0
- package/dist/services/command-message-streaming.js.map +1 -0
- package/dist/services/command-message-streaming.test.d.ts +2 -0
- package/dist/services/command-message-streaming.test.d.ts.map +1 -0
- package/dist/services/command-message-streaming.test.js +78 -0
- package/dist/services/command-message-streaming.test.js.map +1 -0
- package/dist/services/conversation-events.d.ts +5 -13
- package/dist/services/conversation-events.d.ts.map +1 -1
- package/dist/services/conversation-integration.test.d.ts +2 -0
- package/dist/services/conversation-integration.test.d.ts.map +1 -0
- package/dist/services/conversation-integration.test.js +155 -0
- package/dist/services/conversation-integration.test.js.map +1 -0
- package/dist/services/conversation-result-builder.d.ts +41 -0
- package/dist/services/conversation-result-builder.d.ts.map +1 -0
- package/dist/services/conversation-result-builder.js +110 -0
- package/dist/services/conversation-result-builder.js.map +1 -0
- package/dist/services/conversation-result-builder.test.d.ts +2 -0
- package/dist/services/conversation-result-builder.test.d.ts.map +1 -0
- package/dist/services/conversation-result-builder.test.js +76 -0
- package/dist/services/conversation-result-builder.test.js.map +1 -0
- package/dist/services/conversation-service.d.ts +1 -1
- package/dist/services/conversation-service.d.ts.map +1 -1
- package/dist/services/conversation-service.js.map +1 -1
- package/dist/services/conversation-session-reasoning.test.js +3 -3
- package/dist/services/conversation-session-reasoning.test.js.map +1 -1
- package/dist/services/conversation-session.d.ts +7 -17
- package/dist/services/conversation-session.d.ts.map +1 -1
- package/dist/services/conversation-session.js +290 -278
- package/dist/services/conversation-session.js.map +1 -1
- package/dist/services/conversation-session.usage.test.d.ts +2 -0
- package/dist/services/conversation-session.usage.test.d.ts.map +1 -0
- package/dist/services/conversation-session.usage.test.js +59 -0
- package/dist/services/conversation-session.usage.test.js.map +1 -0
- package/dist/services/conversation-store.d.ts.map +1 -1
- package/dist/services/conversation-store.js +3 -9
- package/dist/services/conversation-store.js.map +1 -1
- package/dist/services/conversation-store.test.js +17 -14
- package/dist/services/conversation-store.test.js.map +1 -1
- package/dist/services/execution-context.d.ts.map +1 -1
- package/dist/services/execution-context.js.map +1 -1
- package/dist/services/execution-context.test.js +7 -7
- package/dist/services/execution-context.test.js.map +1 -1
- package/dist/services/file-service.d.ts.map +1 -1
- package/dist/services/file-service.js +5 -9
- package/dist/services/file-service.js.map +1 -1
- package/dist/services/history-service.d.ts.map +1 -1
- package/dist/services/history-service.js +3 -7
- package/dist/services/history-service.js.map +1 -1
- package/dist/services/logging-contract.d.ts +74 -0
- package/dist/services/logging-contract.d.ts.map +1 -0
- package/dist/services/logging-contract.js +157 -0
- package/dist/services/logging-contract.js.map +1 -0
- package/dist/services/logging-contract.test.d.ts +2 -0
- package/dist/services/logging-contract.test.d.ts.map +1 -0
- package/dist/services/logging-contract.test.js +66 -0
- package/dist/services/logging-contract.test.js.map +1 -0
- package/dist/services/logging-service.d.ts +5 -0
- package/dist/services/logging-service.d.ts.map +1 -1
- package/dist/services/logging-service.js +93 -21
- package/dist/services/logging-service.js.map +1 -1
- package/dist/services/model-service.d.ts.map +1 -1
- package/dist/services/model-service.js +2 -2
- package/dist/services/model-service.js.map +1 -1
- package/dist/services/model-service.test.js +6 -6
- package/dist/services/model-service.test.js.map +1 -1
- package/dist/services/service-interfaces.d.ts.map +1 -1
- package/dist/services/settings-env.d.ts +9 -0
- package/dist/services/settings-env.d.ts.map +1 -0
- package/dist/services/settings-env.js +75 -0
- package/dist/services/settings-env.js.map +1 -0
- package/dist/services/settings-env.test.d.ts +2 -0
- package/dist/services/settings-env.test.d.ts.map +1 -0
- package/dist/services/settings-env.test.js +32 -0
- package/dist/services/settings-env.test.js.map +1 -0
- package/dist/services/settings-merger.d.ts +26 -0
- package/dist/services/settings-merger.d.ts.map +1 -0
- package/dist/services/settings-merger.js +122 -0
- package/dist/services/settings-merger.js.map +1 -0
- package/dist/services/settings-merger.test.d.ts +2 -0
- package/dist/services/settings-merger.test.d.ts.map +1 -0
- package/dist/services/settings-merger.test.js +26 -0
- package/dist/services/settings-merger.test.js.map +1 -0
- package/dist/services/settings-persistence.d.ts +32 -0
- package/dist/services/settings-persistence.d.ts.map +1 -0
- package/dist/services/settings-persistence.js +134 -0
- package/dist/services/settings-persistence.js.map +1 -0
- package/dist/services/settings-persistence.test.d.ts +2 -0
- package/dist/services/settings-persistence.test.d.ts.map +1 -0
- package/dist/services/settings-persistence.test.js +51 -0
- package/dist/services/settings-persistence.test.js.map +1 -0
- package/dist/services/settings-schema.d.ts +320 -0
- package/dist/services/settings-schema.d.ts.map +1 -0
- package/dist/services/settings-schema.js +272 -0
- package/dist/services/settings-schema.js.map +1 -0
- package/dist/services/settings-service.d.ts +4 -248
- package/dist/services/settings-service.d.ts.map +1 -1
- package/dist/services/settings-service.js +45 -641
- package/dist/services/settings-service.js.map +1 -1
- package/dist/services/settings-service.mock.d.ts.map +1 -1
- package/dist/services/settings-service.mock.js.map +1 -1
- package/dist/services/singleton-deprecation.test.js +2 -2
- package/dist/services/singleton-deprecation.test.js.map +1 -1
- package/dist/services/ssh-service.d.ts.map +1 -1
- package/dist/services/ssh-service.js +8 -7
- package/dist/services/ssh-service.js.map +1 -1
- package/dist/services/ssh-service.test.js +15 -13
- package/dist/services/ssh-service.test.js.map +1 -1
- package/dist/services/stream-event-parsing.d.ts +4 -0
- package/dist/services/stream-event-parsing.d.ts.map +1 -0
- package/dist/services/stream-event-parsing.js +76 -0
- package/dist/services/stream-event-parsing.js.map +1 -0
- package/dist/services/stream-event-parsing.test.d.ts +2 -0
- package/dist/services/stream-event-parsing.test.d.ts.map +1 -0
- package/dist/services/stream-event-parsing.test.js +59 -0
- package/dist/services/stream-event-parsing.test.js.map +1 -0
- package/dist/services/stream-event-processor.d.ts +32 -0
- package/dist/services/stream-event-processor.d.ts.map +1 -0
- package/dist/services/stream-event-processor.js +344 -0
- package/dist/services/stream-event-processor.js.map +1 -0
- package/dist/services/stream-event-processor.test.d.ts +2 -0
- package/dist/services/stream-event-processor.test.d.ts.map +1 -0
- package/dist/services/stream-event-processor.test.js +117 -0
- package/dist/services/stream-event-processor.test.js.map +1 -0
- package/dist/tools/apply-patch.d.ts.map +1 -1
- package/dist/tools/apply-patch.js +45 -35
- package/dist/tools/apply-patch.js.map +1 -1
- package/dist/tools/apply-patch.test.js +23 -0
- package/dist/tools/apply-patch.test.js.map +1 -1
- package/dist/tools/ask-mentor.d.ts.map +1 -1
- package/dist/tools/ask-mentor.js +5 -15
- package/dist/tools/ask-mentor.js.map +1 -1
- package/dist/tools/ask-mentor.test.js +1 -1
- package/dist/tools/ask-mentor.test.js.map +1 -1
- package/dist/tools/create-file.d.ts.map +1 -1
- package/dist/tools/create-file.js +2 -2
- package/dist/tools/create-file.js.map +1 -1
- package/dist/tools/create-file.test.js.map +1 -1
- package/dist/tools/edit-healing.d.ts.map +1 -1
- package/dist/tools/edit-healing.js +5 -4
- package/dist/tools/edit-healing.js.map +1 -1
- package/dist/tools/edit-healing.test.js.map +1 -1
- package/dist/tools/find-files.d.ts +1 -0
- package/dist/tools/find-files.d.ts.map +1 -1
- package/dist/tools/find-files.js +93 -24
- package/dist/tools/find-files.js.map +1 -1
- package/dist/tools/find-files.test.js +46 -2
- package/dist/tools/find-files.test.js.map +1 -1
- package/dist/tools/format-helpers.d.ts.map +1 -1
- package/dist/tools/format-helpers.js +2 -6
- package/dist/tools/format-helpers.js.map +1 -1
- package/dist/tools/grep.d.ts +1 -1
- package/dist/tools/grep.d.ts.map +1 -1
- package/dist/tools/grep.js +6 -21
- package/dist/tools/grep.js.map +1 -1
- package/dist/tools/read-file.d.ts.map +1 -1
- package/dist/tools/read-file.js +3 -7
- package/dist/tools/read-file.js.map +1 -1
- package/dist/tools/read-file.test.js.map +1 -1
- package/dist/tools/search-replace.d.ts.map +1 -1
- package/dist/tools/search-replace.js +14 -31
- package/dist/tools/search-replace.js.map +1 -1
- package/dist/tools/search-replace.test.js.map +1 -1
- package/dist/tools/search.d.ts +1 -1
- package/dist/tools/search.d.ts.map +1 -1
- package/dist/tools/search.js +6 -16
- package/dist/tools/search.js.map +1 -1
- package/dist/tools/shell.d.ts +1 -1
- package/dist/tools/shell.d.ts.map +1 -1
- package/dist/tools/shell.js +25 -51
- package/dist/tools/shell.js.map +1 -1
- package/dist/tools/shell.test.d.ts +2 -0
- package/dist/tools/shell.test.d.ts.map +1 -0
- package/dist/tools/shell.test.js +70 -0
- package/dist/tools/shell.test.js.map +1 -0
- package/dist/tools/tool-names.d.ts +3 -0
- package/dist/tools/tool-names.d.ts.map +1 -0
- package/dist/tools/tool-names.js +3 -0
- package/dist/tools/tool-names.js.map +1 -0
- package/dist/tools/tool-names.test.d.ts +2 -0
- package/dist/tools/tool-names.test.d.ts.map +1 -0
- package/dist/tools/tool-names.test.js +7 -0
- package/dist/tools/tool-names.test.js.map +1 -0
- package/dist/tools/types.d.ts.map +1 -1
- package/dist/tools/utils.d.ts.map +1 -1
- package/dist/tools/utils.js +3 -8
- package/dist/tools/utils.js.map +1 -1
- package/dist/tools/web-fetch.d.ts +4 -4
- package/dist/tools/web-fetch.d.ts.map +1 -1
- package/dist/tools/web-fetch.js +32 -249
- package/dist/tools/web-fetch.js.map +1 -1
- package/dist/tools/web-fetch.test.js +3 -3
- package/dist/tools/web-fetch.test.js.map +1 -1
- package/dist/tools/web-search.d.ts.map +1 -1
- package/dist/tools/web-search.js +6 -10
- package/dist/tools/web-search.js.map +1 -1
- package/dist/tools/web-search.test.js +12 -14
- package/dist/tools/web-search.test.js.map +1 -1
- package/dist/types/messages.d.ts +29 -0
- package/dist/types/messages.d.ts.map +1 -0
- package/dist/types/messages.js +2 -0
- package/dist/types/messages.js.map +1 -0
- package/dist/utils/command-logger.d.ts.map +1 -1
- package/dist/utils/command-logger.js.map +1 -1
- package/dist/utils/command-safety/constants.d.ts.map +1 -1
- package/dist/utils/command-safety/constants.js +1 -9
- package/dist/utils/command-safety/constants.js.map +1 -1
- package/dist/utils/command-safety/find-helpers.d.ts.map +1 -1
- package/dist/utils/command-safety/find-helpers.js +4 -9
- package/dist/utils/command-safety/find-helpers.js.map +1 -1
- package/dist/utils/command-safety/handlers/find-handler.d.ts.map +1 -1
- package/dist/utils/command-safety/handlers/find-handler.js +3 -10
- package/dist/utils/command-safety/handlers/find-handler.js.map +1 -1
- package/dist/utils/command-safety/handlers/git-handler.d.ts.map +1 -1
- package/dist/utils/command-safety/handlers/git-handler.js +2 -4
- package/dist/utils/command-safety/handlers/git-handler.js.map +1 -1
- package/dist/utils/command-safety/handlers/index.d.ts +1 -1
- package/dist/utils/command-safety/handlers/index.d.ts.map +1 -1
- package/dist/utils/command-safety/handlers/index.js.map +1 -1
- package/dist/utils/command-safety/handlers/sed-handler.d.ts.map +1 -1
- package/dist/utils/command-safety/handlers/sed-handler.js.map +1 -1
- package/dist/utils/command-safety/handlers/types.d.ts.map +1 -1
- package/dist/utils/command-safety/index.d.ts.map +1 -1
- package/dist/utils/command-safety/index.js +4 -10
- package/dist/utils/command-safety/index.js.map +1 -1
- package/dist/utils/command-safety/path-analysis.d.ts.map +1 -1
- package/dist/utils/command-safety/path-analysis.js +9 -20
- package/dist/utils/command-safety/path-analysis.js.map +1 -1
- package/dist/utils/command-safety/utils.d.ts.map +1 -1
- package/dist/utils/command-safety/utils.js +1 -3
- package/dist/utils/command-safety/utils.js.map +1 -1
- package/dist/utils/command-safety.find.test.js +44 -87
- package/dist/utils/command-safety.find.test.js.map +1 -1
- package/dist/utils/command-safety.path.test.js +32 -67
- package/dist/utils/command-safety.path.test.js.map +1 -1
- package/dist/utils/conversation-event-handler.d.ts +4 -16
- package/dist/utils/conversation-event-handler.d.ts.map +1 -1
- package/dist/utils/conversation-event-handler.js +4 -8
- package/dist/utils/conversation-event-handler.js.map +1 -1
- package/dist/utils/conversation-event-handler.test.js +16 -18
- package/dist/utils/conversation-event-handler.test.js.map +1 -1
- package/dist/utils/conversation-utils.d.ts.map +1 -1
- package/dist/utils/conversation-utils.js +5 -8
- package/dist/utils/conversation-utils.js.map +1 -1
- package/dist/utils/conversation-utils.test.js +45 -44
- package/dist/utils/conversation-utils.test.js.map +1 -1
- package/dist/utils/diff.d.ts.map +1 -1
- package/dist/utils/diff.js +2 -4
- package/dist/utils/diff.js.map +1 -1
- package/dist/utils/diff.test.js +12 -12
- package/dist/utils/diff.test.js.map +1 -1
- package/dist/utils/error-helpers.d.ts.map +1 -1
- package/dist/utils/error-helpers.js +2 -6
- package/dist/utils/error-helpers.js.map +1 -1
- package/dist/utils/error-helpers.test.js +32 -32
- package/dist/utils/error-helpers.test.js.map +1 -1
- package/dist/utils/execute-shell.d.ts.map +1 -1
- package/dist/utils/execute-shell.js.map +1 -1
- package/dist/utils/execute-shell.test.js.map +1 -1
- package/dist/utils/extract-command-messages.d.ts.map +1 -1
- package/dist/utils/extract-command-messages.js +16 -21
- package/dist/utils/extract-command-messages.js.map +1 -1
- package/dist/utils/ink-render-options.d.ts.map +1 -1
- package/dist/utils/ink-render-options.js.map +1 -1
- package/dist/utils/log-viewer-filters.d.ts +29 -0
- package/dist/utils/log-viewer-filters.d.ts.map +1 -0
- package/dist/utils/log-viewer-filters.js +49 -0
- package/dist/utils/log-viewer-filters.js.map +1 -0
- package/dist/utils/log-viewer-filters.test.d.ts +2 -0
- package/dist/utils/log-viewer-filters.test.d.ts.map +1 -0
- package/dist/utils/log-viewer-filters.test.js +48 -0
- package/dist/utils/log-viewer-filters.test.js.map +1 -0
- package/dist/utils/message-buffer.d.ts.map +1 -1
- package/dist/utils/message-buffer.js.map +1 -1
- package/dist/utils/message-buffer.test.js +4 -4
- package/dist/utils/message-buffer.test.js.map +1 -1
- package/dist/utils/output-trim.d.ts.map +1 -1
- package/dist/utils/output-trim.js.map +1 -1
- package/dist/utils/provider-credentials.d.ts.map +1 -1
- package/dist/utils/provider-credentials.js +1 -1
- package/dist/utils/provider-credentials.js.map +1 -1
- package/dist/utils/provider-traffic-extractor.d.ts +18 -0
- package/dist/utils/provider-traffic-extractor.d.ts.map +1 -0
- package/dist/utils/provider-traffic-extractor.js +121 -0
- package/dist/utils/provider-traffic-extractor.js.map +1 -0
- package/dist/utils/provider-traffic-extractor.test.d.ts +2 -0
- package/dist/utils/provider-traffic-extractor.test.d.ts.map +1 -0
- package/dist/utils/provider-traffic-extractor.test.js +84 -0
- package/dist/utils/provider-traffic-extractor.test.js.map +1 -0
- package/dist/utils/settings-command.d.ts.map +1 -1
- package/dist/utils/settings-command.js +5 -12
- package/dist/utils/settings-command.js.map +1 -1
- package/dist/utils/ssh-config-parser.d.ts.map +1 -1
- package/dist/utils/ssh-config-parser.js.map +1 -1
- package/dist/utils/ssh-config-parser.test.js.map +1 -1
- package/dist/utils/streaming-session-factory.d.ts +33 -0
- package/dist/utils/streaming-session-factory.d.ts.map +1 -0
- package/dist/utils/streaming-session-factory.js +75 -0
- package/dist/utils/streaming-session-factory.js.map +1 -0
- package/dist/utils/streaming-session-factory.test.d.ts +2 -0
- package/dist/utils/streaming-session-factory.test.d.ts.map +1 -0
- package/dist/utils/streaming-session-factory.test.js +74 -0
- package/dist/utils/streaming-session-factory.test.js.map +1 -0
- package/dist/utils/streaming-updater.d.ts.map +1 -1
- package/dist/utils/streaming-updater.js.map +1 -1
- package/dist/utils/throttle.d.ts.map +1 -1
- package/dist/utils/throttle.js.map +1 -1
- package/dist/utils/token-usage.d.ts +16 -0
- package/dist/utils/token-usage.d.ts.map +1 -0
- package/dist/utils/token-usage.js +109 -0
- package/dist/utils/token-usage.js.map +1 -0
- package/dist/utils/token-usage.test.d.ts +2 -0
- package/dist/utils/token-usage.test.d.ts.map +1 -0
- package/dist/utils/token-usage.test.js +38 -0
- package/dist/utils/token-usage.test.js.map +1 -0
- package/dist/utils/trim-tool-output.d.ts +2 -0
- package/dist/utils/trim-tool-output.d.ts.map +1 -0
- package/dist/utils/trim-tool-output.js +52 -0
- package/dist/utils/trim-tool-output.js.map +1 -0
- package/package.json +117 -110
- package/{README.md → readme.md} +208 -136
|
@@ -0,0 +1,344 @@
|
|
|
1
|
+
import { extractCommandMessages } from '../utils/extract-command-messages.js';
|
|
2
|
+
import { extractUsage } from '../utils/token-usage.js';
|
|
3
|
+
export class StreamEventProcessor {
|
|
4
|
+
logger;
|
|
5
|
+
sessionId;
|
|
6
|
+
toolCallArgumentsById = new Map();
|
|
7
|
+
textDeltaCount = 0;
|
|
8
|
+
reasoningDeltaCount = 0;
|
|
9
|
+
lastEventType = null;
|
|
10
|
+
eventTypeCount = 0;
|
|
11
|
+
constructor({ logger, sessionId }) {
|
|
12
|
+
this.logger = logger;
|
|
13
|
+
this.sessionId = sessionId;
|
|
14
|
+
}
|
|
15
|
+
reset() {
|
|
16
|
+
this.toolCallArgumentsById.clear();
|
|
17
|
+
this.textDeltaCount = 0;
|
|
18
|
+
this.reasoningDeltaCount = 0;
|
|
19
|
+
this.lastEventType = null;
|
|
20
|
+
this.eventTypeCount = 0;
|
|
21
|
+
}
|
|
22
|
+
getToolCallArgumentsSnapshot() {
|
|
23
|
+
return new Map(this.toolCallArgumentsById);
|
|
24
|
+
}
|
|
25
|
+
restoreToolCallArguments(snapshot) {
|
|
26
|
+
this.toolCallArgumentsById.clear();
|
|
27
|
+
if (!snapshot?.size) {
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
for (const [key, value] of snapshot.entries()) {
|
|
31
|
+
this.toolCallArgumentsById.set(key, value);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
async *streamEvents(stream, acc, { preserveExistingToolArgs }) {
|
|
35
|
+
const toolCallArgumentsById = this.toolCallArgumentsById;
|
|
36
|
+
if (!preserveExistingToolArgs) {
|
|
37
|
+
toolCallArgumentsById.clear();
|
|
38
|
+
}
|
|
39
|
+
this.textDeltaCount = 0;
|
|
40
|
+
this.reasoningDeltaCount = 0;
|
|
41
|
+
const emitText = (delta) => {
|
|
42
|
+
if (!delta) {
|
|
43
|
+
return null;
|
|
44
|
+
}
|
|
45
|
+
acc.finalOutput += delta;
|
|
46
|
+
this.textDeltaCount++;
|
|
47
|
+
return {
|
|
48
|
+
type: 'text_delta',
|
|
49
|
+
delta,
|
|
50
|
+
fullText: acc.finalOutput,
|
|
51
|
+
};
|
|
52
|
+
};
|
|
53
|
+
const emitReasoning = (delta) => {
|
|
54
|
+
if (!delta || delta.replaceAll('\n', '') === '') {
|
|
55
|
+
return null;
|
|
56
|
+
}
|
|
57
|
+
acc.reasoningOutput += delta;
|
|
58
|
+
this.reasoningDeltaCount++;
|
|
59
|
+
return {
|
|
60
|
+
type: 'reasoning_delta',
|
|
61
|
+
delta,
|
|
62
|
+
fullText: acc.reasoningOutput,
|
|
63
|
+
};
|
|
64
|
+
};
|
|
65
|
+
for await (const event of stream) {
|
|
66
|
+
// Extract usage if present in any of the common locations
|
|
67
|
+
const usage = extractUsage(event);
|
|
68
|
+
if (usage) {
|
|
69
|
+
acc.latestUsage = usage;
|
|
70
|
+
this.logger.debug('Usage extracted from stream event', {
|
|
71
|
+
sessionId: this.sessionId,
|
|
72
|
+
source: 'stream_event',
|
|
73
|
+
eventType: event?.type ?? event?.data?.type ?? 'unknown',
|
|
74
|
+
usage,
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
// Log event type with deduplication for ordering understanding
|
|
78
|
+
const delta1 = this.#extractTextDelta(event);
|
|
79
|
+
if (delta1) {
|
|
80
|
+
const e = emitText(delta1);
|
|
81
|
+
if (e)
|
|
82
|
+
yield e;
|
|
83
|
+
}
|
|
84
|
+
if (event?.data) {
|
|
85
|
+
const delta2 = this.#extractTextDelta(event.data);
|
|
86
|
+
if (delta2) {
|
|
87
|
+
const e = emitText(delta2);
|
|
88
|
+
if (e)
|
|
89
|
+
yield e;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
// Handle reasoning items
|
|
93
|
+
const reasoningDelta = (() => {
|
|
94
|
+
// OpenAI style
|
|
95
|
+
const data = event?.data;
|
|
96
|
+
if (data && typeof data === 'object' && data.type === 'model') {
|
|
97
|
+
const eventDetail = data.event;
|
|
98
|
+
if (eventDetail &&
|
|
99
|
+
typeof eventDetail === 'object' &&
|
|
100
|
+
eventDetail.type === 'response.reasoning_summary_text.delta') {
|
|
101
|
+
return eventDetail.delta ?? '';
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
// OpenRouter style
|
|
105
|
+
const choices = event?.data?.event?.choices;
|
|
106
|
+
if (!choices)
|
|
107
|
+
return '';
|
|
108
|
+
if (Array.isArray(choices)) {
|
|
109
|
+
return choices[0]?.delta?.reasoning ?? choices[0]?.delta?.reasoning_content ?? '';
|
|
110
|
+
}
|
|
111
|
+
if (typeof choices === 'object') {
|
|
112
|
+
const byZero = choices['0'];
|
|
113
|
+
const first = byZero ?? choices[Object.keys(choices)[0]];
|
|
114
|
+
return first?.delta?.reasoning ?? first?.delta?.reasoning_content ?? '';
|
|
115
|
+
}
|
|
116
|
+
return '';
|
|
117
|
+
})();
|
|
118
|
+
if (reasoningDelta) {
|
|
119
|
+
const e = emitReasoning(reasoningDelta);
|
|
120
|
+
if (e)
|
|
121
|
+
yield e;
|
|
122
|
+
}
|
|
123
|
+
const maybeEmitCommandMessagesFromItems = (items) => {
|
|
124
|
+
this.#attachCachedArguments(items, toolCallArgumentsById);
|
|
125
|
+
const commandMessages = extractCommandMessages(items);
|
|
126
|
+
const out = [];
|
|
127
|
+
for (const cmdMsg of commandMessages) {
|
|
128
|
+
if (acc.emittedCommandIds.has(cmdMsg.id)) {
|
|
129
|
+
continue;
|
|
130
|
+
}
|
|
131
|
+
if (cmdMsg.isApprovalRejection) {
|
|
132
|
+
continue;
|
|
133
|
+
}
|
|
134
|
+
acc.emittedCommandIds.add(cmdMsg.id);
|
|
135
|
+
out.push({ type: 'command_message', message: cmdMsg });
|
|
136
|
+
}
|
|
137
|
+
return out;
|
|
138
|
+
};
|
|
139
|
+
if (event?.type === 'run_item_stream_event') {
|
|
140
|
+
this.#captureToolCallArguments(event.item, toolCallArgumentsById);
|
|
141
|
+
// Emit tool_started event when a function_call is detected
|
|
142
|
+
const rawItem = event.item?.rawItem ?? event.item;
|
|
143
|
+
if (rawItem?.type === 'function_call') {
|
|
144
|
+
const callId = rawItem.callId ?? rawItem.call_id ?? rawItem.tool_call_id ?? rawItem.toolCallId ?? rawItem.id;
|
|
145
|
+
if (callId) {
|
|
146
|
+
const toolName = rawItem.name ?? event.item?.name;
|
|
147
|
+
const args = rawItem.arguments ?? rawItem.args ?? event.item?.arguments ?? event.item?.args;
|
|
148
|
+
// Providers sometimes surface arguments as a JSON string.
|
|
149
|
+
// Normalize here so downstream UI (pending/running display)
|
|
150
|
+
// can reliably render parameters.
|
|
151
|
+
const normalizedArgs = (() => {
|
|
152
|
+
if (typeof args !== 'string') {
|
|
153
|
+
return args;
|
|
154
|
+
}
|
|
155
|
+
const trimmed = args.trim();
|
|
156
|
+
if (!trimmed) {
|
|
157
|
+
return args;
|
|
158
|
+
}
|
|
159
|
+
try {
|
|
160
|
+
return JSON.parse(trimmed);
|
|
161
|
+
}
|
|
162
|
+
catch {
|
|
163
|
+
return args;
|
|
164
|
+
}
|
|
165
|
+
})();
|
|
166
|
+
yield {
|
|
167
|
+
type: 'tool_started',
|
|
168
|
+
toolCallId: callId,
|
|
169
|
+
toolName: toolName ?? 'unknown',
|
|
170
|
+
arguments: normalizedArgs,
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
for (const e of maybeEmitCommandMessagesFromItems([event.item])) {
|
|
175
|
+
yield e;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
else if (event?.type === 'tool_call_output_item' || event?.rawItem?.type === 'function_call_output') {
|
|
179
|
+
this.#captureToolCallArguments(event, toolCallArgumentsById);
|
|
180
|
+
for (const e of maybeEmitCommandMessagesFromItems([event])) {
|
|
181
|
+
yield e;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
const completedResult = await stream.completed;
|
|
186
|
+
const rawResponses = Array.isArray(stream?.rawResponses) ? stream.rawResponses : [];
|
|
187
|
+
let usageFromRawResponses;
|
|
188
|
+
for (let i = rawResponses.length - 1; i >= 0; i--) {
|
|
189
|
+
const candidate = extractUsage(rawResponses[i]);
|
|
190
|
+
if (candidate) {
|
|
191
|
+
usageFromRawResponses = candidate;
|
|
192
|
+
break;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
const finalUsage = extractUsage(completedResult) || extractUsage(stream) || usageFromRawResponses;
|
|
196
|
+
if (finalUsage) {
|
|
197
|
+
acc.latestUsage = finalUsage;
|
|
198
|
+
const usageSource = extractUsage(completedResult)
|
|
199
|
+
? 'completed_result'
|
|
200
|
+
: extractUsage(stream)
|
|
201
|
+
? 'stream_object'
|
|
202
|
+
: 'stream_raw_responses';
|
|
203
|
+
this.logger.debug('Usage extracted from stream completion', {
|
|
204
|
+
sessionId: this.sessionId,
|
|
205
|
+
source: 'stream_completed',
|
|
206
|
+
usageSource,
|
|
207
|
+
usage: finalUsage,
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
else {
|
|
211
|
+
const completedResultRecord = completedResult && typeof completedResult === 'object' && !Array.isArray(completedResult)
|
|
212
|
+
? completedResult
|
|
213
|
+
: undefined;
|
|
214
|
+
const streamRecord = stream && typeof stream === 'object' && !Array.isArray(stream)
|
|
215
|
+
? stream
|
|
216
|
+
: undefined;
|
|
217
|
+
this.logger.debug('No usage found in stream completion', {
|
|
218
|
+
sessionId: this.sessionId,
|
|
219
|
+
source: 'stream_completed',
|
|
220
|
+
completedResultType: completedResult === null ? 'null' : Array.isArray(completedResult) ? 'array' : typeof completedResult,
|
|
221
|
+
completedResultKeys: completedResultRecord ? Object.keys(completedResultRecord) : [],
|
|
222
|
+
streamKeys: streamRecord ? Object.keys(streamRecord) : [],
|
|
223
|
+
completedResultHasUsagePath: {
|
|
224
|
+
usage: Boolean(completedResultRecord?.usage),
|
|
225
|
+
usageMetadata: Boolean(completedResultRecord?.usageMetadata),
|
|
226
|
+
usage_metadata: Boolean(completedResultRecord?.usage_metadata),
|
|
227
|
+
responseUsage: Boolean(completedResultRecord?.response?.usage),
|
|
228
|
+
},
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
this.flushStreamEventLog();
|
|
232
|
+
}
|
|
233
|
+
flushStreamEventLog() {
|
|
234
|
+
if (this.lastEventType !== null && this.eventTypeCount > 1) {
|
|
235
|
+
this.logger.debug('Stream event summary', {
|
|
236
|
+
eventType: this.lastEventType,
|
|
237
|
+
count: this.eventTypeCount,
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
this.lastEventType = null;
|
|
241
|
+
this.eventTypeCount = 0;
|
|
242
|
+
}
|
|
243
|
+
#captureToolCallArguments(item, toolCallArgumentsById) {
|
|
244
|
+
const rawItem = item?.rawItem ?? item;
|
|
245
|
+
if (!rawItem) {
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
if (rawItem?.type !== 'function_call') {
|
|
249
|
+
return;
|
|
250
|
+
}
|
|
251
|
+
const callId = rawItem.callId ?? rawItem.call_id ?? rawItem.tool_call_id ?? rawItem.toolCallId ?? rawItem.id;
|
|
252
|
+
if (!callId) {
|
|
253
|
+
return;
|
|
254
|
+
}
|
|
255
|
+
const args = rawItem.arguments ?? rawItem.args ?? item?.arguments ?? item?.args;
|
|
256
|
+
if (!args) {
|
|
257
|
+
return;
|
|
258
|
+
}
|
|
259
|
+
toolCallArgumentsById.set(callId, args);
|
|
260
|
+
}
|
|
261
|
+
#attachCachedArguments(items = [], toolCallArgumentsById) {
|
|
262
|
+
if (!items?.length) {
|
|
263
|
+
return;
|
|
264
|
+
}
|
|
265
|
+
for (const item of items) {
|
|
266
|
+
if (!item) {
|
|
267
|
+
continue;
|
|
268
|
+
}
|
|
269
|
+
if (item.arguments || item.args || item?.rawItem?.arguments || item?.rawItem?.args) {
|
|
270
|
+
continue;
|
|
271
|
+
}
|
|
272
|
+
const rawItem = item?.rawItem ?? item;
|
|
273
|
+
const callId = rawItem?.callId ??
|
|
274
|
+
rawItem?.call_id ??
|
|
275
|
+
rawItem?.tool_call_id ??
|
|
276
|
+
rawItem?.toolCallId ??
|
|
277
|
+
rawItem?.id ??
|
|
278
|
+
item?.callId ??
|
|
279
|
+
item?.call_id ??
|
|
280
|
+
item?.tool_call_id ??
|
|
281
|
+
item?.toolCallId ??
|
|
282
|
+
item?.id;
|
|
283
|
+
if (!callId) {
|
|
284
|
+
continue;
|
|
285
|
+
}
|
|
286
|
+
const args = toolCallArgumentsById.get(callId);
|
|
287
|
+
if (!args) {
|
|
288
|
+
continue;
|
|
289
|
+
}
|
|
290
|
+
item.arguments = args;
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
#extractTextDelta(payload) {
|
|
294
|
+
if (payload === null || payload === undefined) {
|
|
295
|
+
return null;
|
|
296
|
+
}
|
|
297
|
+
if (typeof payload === 'string') {
|
|
298
|
+
return payload || null;
|
|
299
|
+
}
|
|
300
|
+
if (typeof payload !== 'object') {
|
|
301
|
+
return null;
|
|
302
|
+
}
|
|
303
|
+
const type = typeof payload.type === 'string' ? payload.type : '';
|
|
304
|
+
const looksLikeOutput = typeof type === 'string' && type.includes('output_text');
|
|
305
|
+
const hasOutputProperties = Boolean(payload.delta ?? payload.output_text ?? payload.text ?? payload.content);
|
|
306
|
+
if (!looksLikeOutput && !hasOutputProperties) {
|
|
307
|
+
return null;
|
|
308
|
+
}
|
|
309
|
+
const deltaCandidate = payload.delta ?? payload.output_text ?? payload.text ?? payload.content;
|
|
310
|
+
const text = this.#coerceToText(deltaCandidate);
|
|
311
|
+
return text || null;
|
|
312
|
+
}
|
|
313
|
+
#coerceToText(value) {
|
|
314
|
+
if (value === null || value === undefined) {
|
|
315
|
+
return '';
|
|
316
|
+
}
|
|
317
|
+
if (typeof value === 'string') {
|
|
318
|
+
return value;
|
|
319
|
+
}
|
|
320
|
+
if (typeof value === 'number' || typeof value === 'boolean') {
|
|
321
|
+
return String(value);
|
|
322
|
+
}
|
|
323
|
+
if (Array.isArray(value)) {
|
|
324
|
+
return value
|
|
325
|
+
.map((entry) => this.#coerceToText(entry))
|
|
326
|
+
.filter(Boolean)
|
|
327
|
+
.join('');
|
|
328
|
+
}
|
|
329
|
+
if (typeof value === 'object') {
|
|
330
|
+
const record = value;
|
|
331
|
+
const candidates = ['text', 'value', 'content', 'delta'];
|
|
332
|
+
for (const field of candidates) {
|
|
333
|
+
if (field in record) {
|
|
334
|
+
const text = this.#coerceToText(record[field]);
|
|
335
|
+
if (text) {
|
|
336
|
+
return text;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
}
|
|
341
|
+
return '';
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
//# sourceMappingURL=stream-event-processor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-event-processor.js","sourceRoot":"","sources":["../../source/services/stream-event-processor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-event-processor.test.d.ts","sourceRoot":"","sources":["../../source/services/stream-event-processor.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import test from 'ava';
|
|
2
|
+
import { StreamEventProcessor } from './stream-event-processor.js';
|
|
3
|
+
const mockLogger = {
|
|
4
|
+
info: () => { },
|
|
5
|
+
warn: () => { },
|
|
6
|
+
error: () => { },
|
|
7
|
+
debug: () => { },
|
|
8
|
+
security: () => { },
|
|
9
|
+
setCorrelationId: () => { },
|
|
10
|
+
getCorrelationId: () => undefined,
|
|
11
|
+
clearCorrelationId: () => { },
|
|
12
|
+
};
|
|
13
|
+
class MockStream {
|
|
14
|
+
constructor(events, completed = undefined) {
|
|
15
|
+
this.events = events;
|
|
16
|
+
this.completed = Promise.resolve(completed);
|
|
17
|
+
this.lastResponseId = 'resp_test';
|
|
18
|
+
this.interruptions = [];
|
|
19
|
+
this.state = {};
|
|
20
|
+
this.newItems = [];
|
|
21
|
+
this.history = [];
|
|
22
|
+
this.finalOutput = '';
|
|
23
|
+
}
|
|
24
|
+
events;
|
|
25
|
+
completed;
|
|
26
|
+
lastResponseId;
|
|
27
|
+
interruptions;
|
|
28
|
+
state;
|
|
29
|
+
newItems;
|
|
30
|
+
history;
|
|
31
|
+
finalOutput;
|
|
32
|
+
async *[Symbol.asyncIterator]() {
|
|
33
|
+
for (const event of this.events) {
|
|
34
|
+
yield event;
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
test('StreamEventProcessor streams text and reasoning deltas with fullText', async (t) => {
|
|
39
|
+
const stream = new MockStream([
|
|
40
|
+
{ type: 'response.output_text.delta', delta: 'Hello' },
|
|
41
|
+
{
|
|
42
|
+
data: {
|
|
43
|
+
type: 'model',
|
|
44
|
+
event: {
|
|
45
|
+
choices: [
|
|
46
|
+
{
|
|
47
|
+
delta: {
|
|
48
|
+
reasoning_content: 'think',
|
|
49
|
+
},
|
|
50
|
+
},
|
|
51
|
+
],
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
]);
|
|
56
|
+
const processor = new StreamEventProcessor({ logger: mockLogger, sessionId: 's1' });
|
|
57
|
+
const acc = {
|
|
58
|
+
finalOutput: '',
|
|
59
|
+
reasoningOutput: '',
|
|
60
|
+
emittedCommandIds: new Set(),
|
|
61
|
+
latestUsage: undefined,
|
|
62
|
+
};
|
|
63
|
+
const emitted = [];
|
|
64
|
+
for await (const event of processor.streamEvents(stream, acc, { preserveExistingToolArgs: false })) {
|
|
65
|
+
emitted.push(event);
|
|
66
|
+
}
|
|
67
|
+
t.is(emitted[0].type, 'text_delta');
|
|
68
|
+
t.is(emitted[0].delta, 'Hello');
|
|
69
|
+
t.is(emitted[0].fullText, 'Hello');
|
|
70
|
+
t.is(emitted[1].type, 'reasoning_delta');
|
|
71
|
+
t.is(emitted[1].delta, 'think');
|
|
72
|
+
t.is(emitted[1].fullText, 'think');
|
|
73
|
+
});
|
|
74
|
+
test('StreamEventProcessor emits tool_started and command_message with cached args', async (t) => {
|
|
75
|
+
const stream = new MockStream([
|
|
76
|
+
{
|
|
77
|
+
type: 'run_item_stream_event',
|
|
78
|
+
item: {
|
|
79
|
+
rawItem: {
|
|
80
|
+
type: 'function_call',
|
|
81
|
+
callId: 'call-1',
|
|
82
|
+
name: 'shell',
|
|
83
|
+
arguments: JSON.stringify({ command: 'echo hi' }),
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
{
|
|
88
|
+
type: 'tool_call_output_item',
|
|
89
|
+
rawItem: {
|
|
90
|
+
type: 'function_call_output',
|
|
91
|
+
callId: 'call-1',
|
|
92
|
+
name: 'shell',
|
|
93
|
+
output: 'exit 0\nhi',
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
]);
|
|
97
|
+
const processor = new StreamEventProcessor({ logger: mockLogger, sessionId: 's1' });
|
|
98
|
+
const acc = {
|
|
99
|
+
finalOutput: '',
|
|
100
|
+
reasoningOutput: '',
|
|
101
|
+
emittedCommandIds: new Set(),
|
|
102
|
+
latestUsage: undefined,
|
|
103
|
+
};
|
|
104
|
+
const emitted = [];
|
|
105
|
+
for await (const event of processor.streamEvents(stream, acc, { preserveExistingToolArgs: false })) {
|
|
106
|
+
emitted.push(event);
|
|
107
|
+
}
|
|
108
|
+
const toolStarted = emitted.find((event) => event.type === 'tool_started');
|
|
109
|
+
const commandMessage = emitted.find((event) => event.type === 'command_message');
|
|
110
|
+
t.truthy(toolStarted);
|
|
111
|
+
t.is(toolStarted.toolCallId, 'call-1');
|
|
112
|
+
t.is(toolStarted.toolName, 'shell');
|
|
113
|
+
t.deepEqual(toolStarted.arguments, { command: 'echo hi' });
|
|
114
|
+
t.truthy(commandMessage);
|
|
115
|
+
t.is(commandMessage.message.command, 'echo hi');
|
|
116
|
+
});
|
|
117
|
+
//# sourceMappingURL=stream-event-processor.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-event-processor.test.js","sourceRoot":"","sources":["../../source/services/stream-event-processor.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"apply-patch.d.ts","sourceRoot":"","sources":["../../source/tools/apply-patch.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"apply-patch.d.ts","sourceRoot":"","sources":["../../source/tools/apply-patch.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAKxB,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjE,OAAO,KAAK,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAE3F,OAAO,EAAE,gBAAgB,EAAE,MAAM,kCAAkC,CAAC;AAEpE;;GAEG;AACH,qBAAa,oBAAqB,SAAQ,KAAK;IACT,QAAQ,EAAE,MAAM;gBAAxC,OAAO,EAAE,MAAM,EAAS,QAAQ,EAAE,MAAM;CAIrD;AAED,QAAA,MAAM,0BAA0B;;;;;;;iBAI9B,CAAC;AAEH,MAAM,MAAM,oBAAoB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,0BAA0B,CAAC,CAAC;AAE9E,eAAO,MAAM,8BAA8B,GACzC,MAAM,GAAG,EACT,OAAO,MAAM,EACb,wBAAwB,GAAG,CAAC,MAAM,EAAE,OAAO,CAAC,KAC3C,cAAc,EA4ChB,CAAC;AAEF,wBAAgB,8BAA8B,CAAC,IAAI,EAAE;IACnD,cAAc,EAAE,eAAe,CAAC;IAChC,eAAe,EAAE,gBAAgB,CAAC;IAClC,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;CACrC,GAAG,cAAc,CAAC,oBAAoB,CAAC,CAkXvC"}
|
|
@@ -3,7 +3,7 @@ import { readFile, writeFile, mkdir } from 'fs/promises';
|
|
|
3
3
|
import path from 'path';
|
|
4
4
|
import { applyDiff } from '@openai/agents';
|
|
5
5
|
import { resolveWorkspacePath } from './utils.js';
|
|
6
|
-
import { getOutputText, safeJsonParse, normalizeToolArguments, createBaseMessage
|
|
6
|
+
import { getOutputText, safeJsonParse, normalizeToolArguments, createBaseMessage } from './format-helpers.js';
|
|
7
7
|
/**
|
|
8
8
|
* Error thrown when patch validation fails (malformed diff)
|
|
9
9
|
*/
|
|
@@ -18,9 +18,7 @@ export class PatchValidationError extends Error {
|
|
|
18
18
|
const applyPatchParametersSchema = z.object({
|
|
19
19
|
type: z.enum(['create_file', 'update_file']),
|
|
20
20
|
path: z.string().min(1, 'File path cannot be empty'),
|
|
21
|
-
diff: z
|
|
22
|
-
.string()
|
|
23
|
-
.describe('Unified diff content for create/update operations'),
|
|
21
|
+
diff: z.string().describe('Unified diff content for create/update operations'),
|
|
24
22
|
});
|
|
25
23
|
export const formatApplyPatchCommandMessage = (item, index, _toolCallArgumentsById) => {
|
|
26
24
|
const parsedOutput = safeJsonParse(getOutputText(item));
|
|
@@ -112,6 +110,25 @@ export function createApplyPatchToolDefinition(deps) {
|
|
|
112
110
|
try {
|
|
113
111
|
const editMode = settingsService.get('app.editMode');
|
|
114
112
|
const { type, path: filePath, diff } = params;
|
|
113
|
+
const workspaceRoot = executionContext?.getCwd() || process.cwd();
|
|
114
|
+
const sshService = executionContext?.getSSHService();
|
|
115
|
+
const isRemote = executionContext?.isRemote() && !!sshService;
|
|
116
|
+
// Resolve and ensure target within workspace before any validation.
|
|
117
|
+
// This prevents validation from running against a mismatched cwd.
|
|
118
|
+
let targetPath;
|
|
119
|
+
try {
|
|
120
|
+
targetPath = resolveWorkspacePath(filePath, workspaceRoot);
|
|
121
|
+
}
|
|
122
|
+
catch (e) {
|
|
123
|
+
// Outside workspace => require approval
|
|
124
|
+
loggingService.security('apply_patch needsApproval: outside workspace', {
|
|
125
|
+
editMode,
|
|
126
|
+
type,
|
|
127
|
+
path: filePath,
|
|
128
|
+
error: e?.message || String(e),
|
|
129
|
+
});
|
|
130
|
+
return true;
|
|
131
|
+
}
|
|
115
132
|
// Validate diff syntax by attempting a dry-run (before approval)
|
|
116
133
|
if (type === 'create_file' || type === 'update_file') {
|
|
117
134
|
try {
|
|
@@ -120,9 +137,10 @@ export function createApplyPatchToolDefinition(deps) {
|
|
|
120
137
|
applyDiff('', diff);
|
|
121
138
|
}
|
|
122
139
|
else {
|
|
123
|
-
// Dry-run: read existing file and test diff application
|
|
124
|
-
|
|
125
|
-
|
|
140
|
+
// Dry-run: read existing file and test diff application.
|
|
141
|
+
// Read failures are environment/file-state issues, not
|
|
142
|
+
// deterministic patch syntax failures.
|
|
143
|
+
const original = isRemote && sshService ? await sshService.readFile(targetPath) : await readFile(targetPath, 'utf8');
|
|
126
144
|
applyDiff(original, diff);
|
|
127
145
|
}
|
|
128
146
|
loggingService.info('apply_patch validation passed', {
|
|
@@ -131,8 +149,22 @@ export function createApplyPatchToolDefinition(deps) {
|
|
|
131
149
|
});
|
|
132
150
|
}
|
|
133
151
|
catch (diffError) {
|
|
134
|
-
//
|
|
135
|
-
//
|
|
152
|
+
// Keep fast UX for deterministic patch-format errors, but
|
|
153
|
+
// require approval for environment/file-state failures.
|
|
154
|
+
const fileAccessFailure = typeof diffError?.code === 'string' ||
|
|
155
|
+
['enoent', 'not found', 'no such file', 'permission denied', 'eacces', 'eperm', 'is a directory'].some((token) => String(diffError?.message || '')
|
|
156
|
+
.toLowerCase()
|
|
157
|
+
.includes(token));
|
|
158
|
+
if (fileAccessFailure) {
|
|
159
|
+
loggingService.warn('apply_patch prevalidation could not confirm patch due to file/context issue', {
|
|
160
|
+
type,
|
|
161
|
+
path: filePath,
|
|
162
|
+
error: diffError?.message || String(diffError),
|
|
163
|
+
});
|
|
164
|
+
return true;
|
|
165
|
+
}
|
|
166
|
+
// Diff-format validation failed - auto-approve and let execute
|
|
167
|
+
// return a structured error without bothering the user.
|
|
136
168
|
loggingService.error('apply_patch validation failed - will fail in execute', {
|
|
137
169
|
type,
|
|
138
170
|
path: filePath,
|
|
@@ -151,27 +183,9 @@ export function createApplyPatchToolDefinition(deps) {
|
|
|
151
183
|
// });
|
|
152
184
|
// return true;
|
|
153
185
|
// }
|
|
154
|
-
// Resolve and ensure target within workspace
|
|
155
|
-
const workspaceRoot = executionContext?.getCwd() || process.cwd();
|
|
156
|
-
let targetPath;
|
|
157
|
-
try {
|
|
158
|
-
targetPath = resolveWorkspacePath(filePath, workspaceRoot);
|
|
159
|
-
}
|
|
160
|
-
catch (e) {
|
|
161
|
-
// Outside workspace => require approval
|
|
162
|
-
loggingService.security('apply_patch needsApproval: outside workspace', {
|
|
163
|
-
editMode,
|
|
164
|
-
type,
|
|
165
|
-
path: filePath,
|
|
166
|
-
error: e?.message || String(e),
|
|
167
|
-
});
|
|
168
|
-
return true;
|
|
169
|
-
}
|
|
170
186
|
const insideCwd = targetPath.startsWith(workspaceRoot + path.sep);
|
|
171
187
|
// In edit mode, auto-approve create/update within cwd
|
|
172
|
-
if (editMode &&
|
|
173
|
-
insideCwd &&
|
|
174
|
-
(type === 'create_file' || type === 'update_file')) {
|
|
188
|
+
if (editMode && insideCwd && (type === 'create_file' || type === 'update_file')) {
|
|
175
189
|
loggingService.security('apply_patch needsApproval: auto-approved in edit mode', {
|
|
176
190
|
editMode,
|
|
177
191
|
type,
|
|
@@ -244,15 +258,13 @@ export function createApplyPatchToolDefinition(deps) {
|
|
|
244
258
|
loggingService.error('Patch validation failed in execute', {
|
|
245
259
|
type,
|
|
246
260
|
path: filePath,
|
|
247
|
-
error: validationError?.message ||
|
|
248
|
-
String(validationError),
|
|
261
|
+
error: validationError?.message || String(validationError),
|
|
249
262
|
});
|
|
250
263
|
return JSON.stringify({
|
|
251
264
|
output: [
|
|
252
265
|
{
|
|
253
266
|
success: false,
|
|
254
|
-
error: `Invalid patch: ${validationError?.message ||
|
|
255
|
-
String(validationError)}. Please check the file path and diff format.`,
|
|
267
|
+
error: `Invalid patch: ${validationError?.message || String(validationError)}. Please check the file path and diff format.`,
|
|
256
268
|
},
|
|
257
269
|
],
|
|
258
270
|
});
|
|
@@ -378,9 +390,7 @@ export function createApplyPatchToolDefinition(deps) {
|
|
|
378
390
|
loggingService.error('File operation failed', {
|
|
379
391
|
type: params.type,
|
|
380
392
|
path: params.path,
|
|
381
|
-
error: error instanceof Error
|
|
382
|
-
? error.message
|
|
383
|
-
: String(error),
|
|
393
|
+
error: error instanceof Error ? error.message : String(error),
|
|
384
394
|
});
|
|
385
395
|
}
|
|
386
396
|
return JSON.stringify({
|