catui-agent 1.0.0-beta.0
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/LICENSE +674 -0
- package/README.md +267 -0
- package/dist/build-meta.json +6 -0
- package/dist/builtin-extensions.d.ts +47 -0
- package/dist/builtin-extensions.js +1 -0
- package/dist/catui-defaults.d.ts +555 -0
- package/dist/catui-defaults.js +22 -0
- package/dist/cli/args.d.ts +70 -0
- package/dist/cli/args.js +158 -0
- package/dist/cli/config-selector.d.ts +10 -0
- package/dist/cli/config-selector.js +1 -0
- package/dist/cli/file-processor.d.ts +11 -0
- package/dist/cli/file-processor.js +6 -0
- package/dist/cli/list-models.d.ts +12 -0
- package/dist/cli/list-models.js +2 -0
- package/dist/cli/session-picker.d.ts +5 -0
- package/dist/cli/session-picker.js +1 -0
- package/dist/cli.d.ts +2 -0
- package/dist/cli.js +2 -0
- package/dist/config.d.ts +103 -0
- package/dist/config.js +1 -0
- package/dist/core/agent-dir/agent-dir-context.d.ts +60 -0
- package/dist/core/agent-dir/agent-dir-context.js +1 -0
- package/dist/core/agent-dir/agent-metadata.d.ts +48 -0
- package/dist/core/agent-dir/agent-metadata.js +1 -0
- package/dist/core/agent-dir/migration-tool.d.ts +40 -0
- package/dist/core/agent-dir/migration-tool.js +7 -0
- package/dist/core/export-html/AGENT.md +12 -0
- package/dist/core/export-html/ansi-to-html.d.ts +9 -0
- package/dist/core/export-html/ansi-to-html.js +2 -0
- package/dist/core/export-html/index.d.ts +39 -0
- package/dist/core/export-html/index.js +2 -0
- package/dist/core/export-html/template.css +971 -0
- package/dist/core/export-html/template.html +54 -0
- package/dist/core/export-html/template.js +66 -0
- package/dist/core/export-html/tool-renderer.d.ts +28 -0
- package/dist/core/export-html/tool-renderer.js +1 -0
- package/dist/core/export-html/vendor/highlight.min.js +4 -0
- package/dist/core/export-html/vendor/marked.min.js +56 -0
- package/dist/core/extensions-host/index.d.ts +13 -0
- package/dist/core/extensions-host/index.js +1 -0
- package/dist/core/extensions-host/loader.d.ts +21 -0
- package/dist/core/extensions-host/loader.js +1 -0
- package/dist/core/extensions-host/runner.d.ts +233 -0
- package/dist/core/extensions-host/runner.js +3 -0
- package/dist/core/extensions-host/types.d.ts +1079 -0
- package/dist/core/extensions-host/types.js +1 -0
- package/dist/core/extensions-host/wrapper.d.ts +29 -0
- package/dist/core/extensions-host/wrapper.js +2 -0
- package/dist/core/index.d.ts +17 -0
- package/dist/core/index.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop-continuations.d.ts +17 -0
- package/dist/core/lib/agent-core/src/agent-loop-continuations.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop-stream-events.d.ts +19 -0
- package/dist/core/lib/agent-core/src/agent-loop-stream-events.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-results.d.ts +10 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-results.js +3 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-summaries.d.ts +22 -0
- package/dist/core/lib/agent-core/src/agent-loop-tool-summaries.js +1 -0
- package/dist/core/lib/agent-core/src/agent-loop.d.ts +26 -0
- package/dist/core/lib/agent-core/src/agent-loop.js +4 -0
- package/dist/core/lib/agent-core/src/agent-run-result.d.ts +9 -0
- package/dist/core/lib/agent-core/src/agent-run-result.js +1 -0
- package/dist/core/lib/agent-core/src/agent.d.ts +215 -0
- package/dist/core/lib/agent-core/src/agent.js +1 -0
- package/dist/core/lib/agent-core/src/errors.d.ts +62 -0
- package/dist/core/lib/agent-core/src/errors.js +1 -0
- package/dist/core/lib/agent-core/src/index.d.ts +14 -0
- package/dist/core/lib/agent-core/src/index.js +1 -0
- package/dist/core/lib/agent-core/src/proxy.d.ts +91 -0
- package/dist/core/lib/agent-core/src/proxy.js +2 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-agent-loop.d.ts +15 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-agent-loop.js +2 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-streaming-tool-executor.d.ts +33 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-streaming-tool-executor.js +1 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-tool-orchestration.d.ts +35 -0
- package/dist/core/lib/agent-core/src/structured-adaptive-tool-orchestration.js +3 -0
- package/dist/core/lib/agent-core/src/types.d.ts +417 -0
- package/dist/core/lib/agent-core/src/types.js +1 -0
- package/dist/core/lib/ai/src/api-registry.d.ts +27 -0
- package/dist/core/lib/ai/src/api-registry.js +1 -0
- package/dist/core/lib/ai/src/config-path.d.ts +1 -0
- package/dist/core/lib/ai/src/config-path.js +1 -0
- package/dist/core/lib/ai/src/debug-logger.d.ts +94 -0
- package/dist/core/lib/ai/src/debug-logger.js +4 -0
- package/dist/core/lib/ai/src/env-api-keys.d.ts +8 -0
- package/dist/core/lib/ai/src/env-api-keys.js +1 -0
- package/dist/core/lib/ai/src/env.d.ts +7 -0
- package/dist/core/lib/ai/src/env.js +1 -0
- package/dist/core/lib/ai/src/events.d.ts +8 -0
- package/dist/core/lib/ai/src/events.js +1 -0
- package/dist/core/lib/ai/src/index.d.ts +27 -0
- package/dist/core/lib/ai/src/index.js +1 -0
- package/dist/core/lib/ai/src/json.d.ts +7 -0
- package/dist/core/lib/ai/src/json.js +1 -0
- package/dist/core/lib/ai/src/models.d.ts +31 -0
- package/dist/core/lib/ai/src/models.generated.d.ts +15315 -0
- package/dist/core/lib/ai/src/models.generated.js +1 -0
- package/dist/core/lib/ai/src/models.js +1 -0
- package/dist/core/lib/ai/src/overflow.d.ts +7 -0
- package/dist/core/lib/ai/src/overflow.js +1 -0
- package/dist/core/lib/ai/src/providers/amazon-bedrock.d.ts +20 -0
- package/dist/core/lib/ai/src/providers/amazon-bedrock.js +1 -0
- package/dist/core/lib/ai/src/providers/anthropic.d.ts +38 -0
- package/dist/core/lib/ai/src/providers/anthropic.js +2 -0
- package/dist/core/lib/ai/src/providers/azure-openai-responses.d.ts +21 -0
- package/dist/core/lib/ai/src/providers/azure-openai-responses.js +1 -0
- package/dist/core/lib/ai/src/providers/github-copilot-headers.d.ts +13 -0
- package/dist/core/lib/ai/src/providers/github-copilot-headers.js +1 -0
- package/dist/core/lib/ai/src/providers/google-gemini-cli.d.ts +79 -0
- package/dist/core/lib/ai/src/providers/google-gemini-cli.js +2 -0
- package/dist/core/lib/ai/src/providers/google-shared.d.ts +70 -0
- package/dist/core/lib/ai/src/providers/google-shared.js +2 -0
- package/dist/core/lib/ai/src/providers/google-vertex.d.ts +20 -0
- package/dist/core/lib/ai/src/providers/google-vertex.js +1 -0
- package/dist/core/lib/ai/src/providers/google.d.ts +18 -0
- package/dist/core/lib/ai/src/providers/google.js +1 -0
- package/dist/core/lib/ai/src/providers/openai-codex-responses.d.ts +8 -0
- package/dist/core/lib/ai/src/providers/openai-codex-responses.js +7 -0
- package/dist/core/lib/ai/src/providers/openai-completions.d.ts +20 -0
- package/dist/core/lib/ai/src/providers/openai-completions.js +6 -0
- package/dist/core/lib/ai/src/providers/openai-responses-shared.d.ts +22 -0
- package/dist/core/lib/ai/src/providers/openai-responses-shared.js +10 -0
- package/dist/core/lib/ai/src/providers/openai-responses.d.ts +19 -0
- package/dist/core/lib/ai/src/providers/openai-responses.js +1 -0
- package/dist/core/lib/ai/src/providers/register-builtins.d.ts +8 -0
- package/dist/core/lib/ai/src/providers/register-builtins.js +1 -0
- package/dist/core/lib/ai/src/providers/simple-options.d.ts +13 -0
- package/dist/core/lib/ai/src/providers/simple-options.js +1 -0
- package/dist/core/lib/ai/src/providers/transform-messages.d.ts +13 -0
- package/dist/core/lib/ai/src/providers/transform-messages.js +1 -0
- package/dist/core/lib/ai/src/registry.d.ts +8 -0
- package/dist/core/lib/ai/src/registry.js +1 -0
- package/dist/core/lib/ai/src/schema.d.ts +10 -0
- package/dist/core/lib/ai/src/schema.js +1 -0
- package/dist/core/lib/ai/src/stream.d.ts +33 -0
- package/dist/core/lib/ai/src/stream.js +1 -0
- package/dist/core/lib/ai/src/types.d.ts +331 -0
- package/dist/core/lib/ai/src/types.js +0 -0
- package/dist/core/lib/ai/src/utils/event-stream-types.d.ts +12 -0
- package/dist/core/lib/ai/src/utils/event-stream-types.js +0 -0
- package/dist/core/lib/ai/src/utils/event-stream.d.ts +31 -0
- package/dist/core/lib/ai/src/utils/event-stream.js +1 -0
- package/dist/core/lib/ai/src/utils/http-proxy.d.ts +13 -0
- package/dist/core/lib/ai/src/utils/http-proxy.js +1 -0
- package/dist/core/lib/ai/src/utils/json-parse.d.ts +14 -0
- package/dist/core/lib/ai/src/utils/json-parse.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/anthropic.d.ts +22 -0
- package/dist/core/lib/ai/src/utils/oauth/anthropic.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/decode-credential.d.ts +12 -0
- package/dist/core/lib/ai/src/utils/oauth/decode-credential.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/github-copilot.d.ts +35 -0
- package/dist/core/lib/ai/src/utils/oauth/github-copilot.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/google-antigravity.d.ts +31 -0
- package/dist/core/lib/ai/src/utils/oauth/google-antigravity.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/google-gemini-cli.d.ts +31 -0
- package/dist/core/lib/ai/src/utils/oauth/google-gemini-cli.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/index.d.ts +60 -0
- package/dist/core/lib/ai/src/utils/oauth/index.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/openai-codex.d.ts +39 -0
- package/dist/core/lib/ai/src/utils/oauth/openai-codex.js +11 -0
- package/dist/core/lib/ai/src/utils/oauth/pkce.d.ts +18 -0
- package/dist/core/lib/ai/src/utils/oauth/pkce.js +1 -0
- package/dist/core/lib/ai/src/utils/oauth/types.d.ts +52 -0
- package/dist/core/lib/ai/src/utils/oauth/types.js +0 -0
- package/dist/core/lib/ai/src/utils/overflow.d.ts +57 -0
- package/dist/core/lib/ai/src/utils/overflow.js +1 -0
- package/dist/core/lib/ai/src/utils/sanitize-unicode.d.ts +16 -0
- package/dist/core/lib/ai/src/utils/sanitize-unicode.js +1 -0
- package/dist/core/lib/ai/src/utils/typebox-helpers.d.ts +22 -0
- package/dist/core/lib/ai/src/utils/typebox-helpers.js +1 -0
- package/dist/core/lib/ai/src/utils/validation.d.ts +23 -0
- package/dist/core/lib/ai/src/utils/validation.js +6 -0
- package/dist/core/lib/tui/src/autocomplete.d.ts +62 -0
- package/dist/core/lib/tui/src/autocomplete.js +2 -0
- package/dist/core/lib/tui/src/components/box.d.ts +27 -0
- package/dist/core/lib/tui/src/components/box.js +1 -0
- package/dist/core/lib/tui/src/components/cached-container.d.ts +42 -0
- package/dist/core/lib/tui/src/components/cached-container.js +1 -0
- package/dist/core/lib/tui/src/components/cancellable-loader.d.ts +27 -0
- package/dist/core/lib/tui/src/components/cancellable-loader.js +1 -0
- package/dist/core/lib/tui/src/components/editor.d.ts +222 -0
- package/dist/core/lib/tui/src/components/editor.js +21 -0
- package/dist/core/lib/tui/src/components/image.d.ts +33 -0
- package/dist/core/lib/tui/src/components/image.js +1 -0
- package/dist/core/lib/tui/src/components/input.d.ts +42 -0
- package/dist/core/lib/tui/src/components/input.js +2 -0
- package/dist/core/lib/tui/src/components/loader.d.ts +26 -0
- package/dist/core/lib/tui/src/components/loader.js +1 -0
- package/dist/core/lib/tui/src/components/markdown.d.ts +100 -0
- package/dist/core/lib/tui/src/components/markdown.js +7 -0
- package/dist/core/lib/tui/src/components/select-list.d.ts +37 -0
- package/dist/core/lib/tui/src/components/select-list.js +1 -0
- package/dist/core/lib/tui/src/components/settings-list.d.ts +55 -0
- package/dist/core/lib/tui/src/components/settings-list.js +1 -0
- package/dist/core/lib/tui/src/components/spacer.d.ts +17 -0
- package/dist/core/lib/tui/src/components/spacer.js +1 -0
- package/dist/core/lib/tui/src/components/text.d.ts +24 -0
- package/dist/core/lib/tui/src/components/text.js +1 -0
- package/dist/core/lib/tui/src/components/truncated-text.d.ts +18 -0
- package/dist/core/lib/tui/src/components/truncated-text.js +2 -0
- package/dist/core/lib/tui/src/editor-component.d.ts +51 -0
- package/dist/core/lib/tui/src/editor-component.js +0 -0
- package/dist/core/lib/tui/src/fuzzy.d.ts +32 -0
- package/dist/core/lib/tui/src/fuzzy.js +1 -0
- package/dist/core/lib/tui/src/index.d.ts +29 -0
- package/dist/core/lib/tui/src/index.js +1 -0
- package/dist/core/lib/tui/src/keybindings.d.ts +44 -0
- package/dist/core/lib/tui/src/keybindings.js +1 -0
- package/dist/core/lib/tui/src/keys.d.ts +149 -0
- package/dist/core/lib/tui/src/keys.js +5 -0
- package/dist/core/lib/tui/src/kill-ring.d.ts +33 -0
- package/dist/core/lib/tui/src/kill-ring.js +1 -0
- package/dist/core/lib/tui/src/stdin-buffer.d.ts +38 -0
- package/dist/core/lib/tui/src/stdin-buffer.js +1 -0
- package/dist/core/lib/tui/src/terminal-image.d.ts +73 -0
- package/dist/core/lib/tui/src/terminal-image.js +1 -0
- package/dist/core/lib/tui/src/terminal.d.ts +86 -0
- package/dist/core/lib/tui/src/terminal.js +1 -0
- package/dist/core/lib/tui/src/tui.d.ts +220 -0
- package/dist/core/lib/tui/src/tui.js +12 -0
- package/dist/core/lib/tui/src/undo-stack.d.ts +22 -0
- package/dist/core/lib/tui/src/undo-stack.js +1 -0
- package/dist/core/lib/tui/src/utils.d.ts +83 -0
- package/dist/core/lib/tui/src/utils.js +2 -0
- package/dist/core/mcp/figma-auth.d.ts +21 -0
- package/dist/core/mcp/figma-auth.js +22 -0
- package/dist/core/mcp/index.d.ts +11 -0
- package/dist/core/mcp/index.js +1 -0
- package/dist/core/mcp/mcp-adapter.d.ts +21 -0
- package/dist/core/mcp/mcp-adapter.js +3 -0
- package/dist/core/mcp/mcp-client.d.ts +91 -0
- package/dist/core/mcp/mcp-client.js +6 -0
- package/dist/core/mcp/mcp-config.d.ts +55 -0
- package/dist/core/mcp/mcp-config.js +1 -0
- package/dist/core/mcp/mcp-guidance.d.ts +52 -0
- package/dist/core/mcp/mcp-guidance.js +54 -0
- package/dist/core/mcp/mcp-manager.d.ts +51 -0
- package/dist/core/mcp/mcp-manager.js +1 -0
- package/dist/core/mcp/mcp-types.d.ts +62 -0
- package/dist/core/mcp/mcp-types.js +0 -0
- package/dist/core/messages.d.ts +77 -0
- package/dist/core/messages.js +17 -0
- package/dist/core/model/custom-providers.d.ts +34 -0
- package/dist/core/model/custom-providers.js +1 -0
- package/dist/core/model/discovery-cache.d.ts +65 -0
- package/dist/core/model/discovery-cache.js +1 -0
- package/dist/core/model/discovery-cache.test.d.ts +7 -0
- package/dist/core/model/discovery-cache.test.js +1 -0
- package/dist/core/model/discovery.d.ts +79 -0
- package/dist/core/model/discovery.js +1 -0
- package/dist/core/model/discovery.test.d.ts +7 -0
- package/dist/core/model/discovery.test.js +1 -0
- package/dist/core/model/index.d.ts +10 -0
- package/dist/core/model/index.js +1 -0
- package/dist/core/model/known-models.d.ts +65 -0
- package/dist/core/model/known-models.generated.d.ts +2 -0
- package/dist/core/model/known-models.generated.js +1 -0
- package/dist/core/model/known-models.js +1 -0
- package/dist/core/model/switcher.d.ts +80 -0
- package/dist/core/model/switcher.js +1 -0
- package/dist/core/model-registry.d.ts +186 -0
- package/dist/core/model-registry.js +9 -0
- package/dist/core/model-resolver.d.ts +106 -0
- package/dist/core/model-resolver.js +1 -0
- package/dist/core/package-manager.d.ts +156 -0
- package/dist/core/package-manager.js +3 -0
- package/dist/core/persona/persona-manager.d.ts +35 -0
- package/dist/core/persona/persona-manager.js +5 -0
- package/dist/core/platform/abort-slot.d.ts +26 -0
- package/dist/core/platform/abort-slot.js +1 -0
- package/dist/core/platform/config/auth-storage.d.ts +126 -0
- package/dist/core/platform/config/auth-storage.js +1 -0
- package/dist/core/platform/config/defaults.d.ts +8 -0
- package/dist/core/platform/config/defaults.js +1 -0
- package/dist/core/platform/config/diagnostics.d.ts +20 -0
- package/dist/core/platform/config/diagnostics.js +0 -0
- package/dist/core/platform/config/resolve-config-value.d.ts +12 -0
- package/dist/core/platform/config/resolve-config-value.js +1 -0
- package/dist/core/platform/config/resource-loader.d.ts +188 -0
- package/dist/core/platform/config/resource-loader.js +2 -0
- package/dist/core/platform/config/settings-manager.d.ts +314 -0
- package/dist/core/platform/config/settings-manager.js +1 -0
- package/dist/core/platform/exec/bash-executor.d.ts +41 -0
- package/dist/core/platform/exec/bash-executor.js +1 -0
- package/dist/core/platform/exec/exec.d.ts +25 -0
- package/dist/core/platform/exec/exec.js +1 -0
- package/dist/core/platform/i18n/index.d.ts +26 -0
- package/dist/core/platform/i18n/index.js +1 -0
- package/dist/core/platform/i18n/messages.d.ts +56 -0
- package/dist/core/platform/i18n/messages.js +1 -0
- package/dist/core/platform/i18n/messages.zh.d.ts +56 -0
- package/dist/core/platform/i18n/messages.zh.js +1 -0
- package/dist/core/platform/i18n/slash-commands.d.ts +53 -0
- package/dist/core/platform/i18n/slash-commands.js +1 -0
- package/dist/core/platform/i18n/slash-commands.zh.d.ts +53 -0
- package/dist/core/platform/i18n/slash-commands.zh.js +1 -0
- package/dist/core/platform/i18n/themes.d.ts +11 -0
- package/dist/core/platform/i18n/themes.js +1 -0
- package/dist/core/platform/i18n/themes.zh.d.ts +11 -0
- package/dist/core/platform/i18n/themes.zh.js +1 -0
- package/dist/core/platform/keybindings.d.ts +61 -0
- package/dist/core/platform/keybindings.js +1 -0
- package/dist/core/platform/listeners.d.ts +21 -0
- package/dist/core/platform/listeners.js +1 -0
- package/dist/core/platform/telemetry/batching-dispatcher.d.ts +41 -0
- package/dist/core/platform/telemetry/batching-dispatcher.js +1 -0
- package/dist/core/platform/telemetry/build-meta.d.ts +12 -0
- package/dist/core/platform/telemetry/build-meta.js +1 -0
- package/dist/core/platform/telemetry/caller-context.d.ts +32 -0
- package/dist/core/platform/telemetry/caller-context.js +1 -0
- package/dist/core/platform/telemetry/credentials.d.ts +27 -0
- package/dist/core/platform/telemetry/credentials.js +1 -0
- package/dist/core/platform/telemetry/ext-events.d.ts +89 -0
- package/dist/core/platform/telemetry/ext-events.js +1 -0
- package/dist/core/platform/telemetry/index.d.ts +13 -0
- package/dist/core/platform/telemetry/index.js +1 -0
- package/dist/core/platform/telemetry/insforge-base.d.ts +37 -0
- package/dist/core/platform/telemetry/insforge-base.js +1 -0
- package/dist/core/platform/telemetry/types.d.ts +33 -0
- package/dist/core/platform/telemetry/types.js +0 -0
- package/dist/core/platform/timings.d.ts +2 -0
- package/dist/core/platform/timings.js +3 -0
- package/dist/core/platform/utils/logger.d.ts +75 -0
- package/dist/core/platform/utils/logger.js +1 -0
- package/dist/core/platform/utils/shell.d.ts +25 -0
- package/dist/core/platform/utils/shell.js +9 -0
- package/dist/core/platform/utils/sleep.d.ts +7 -0
- package/dist/core/platform/utils/sleep.js +1 -0
- package/dist/core/platform/utils/tools-manager.d.ts +19 -0
- package/dist/core/platform/utils/tools-manager.js +1 -0
- package/dist/core/prompt/prompt-templates.d.ts +49 -0
- package/dist/core/prompt/prompt-templates.js +2 -0
- package/dist/core/prompt/system-prompt.d.ts +24 -0
- package/dist/core/prompt/system-prompt.js +139 -0
- package/dist/core/runtime/agent-session.d.ts +676 -0
- package/dist/core/runtime/agent-session.js +15 -0
- package/dist/core/runtime/bash-runner.d.ts +56 -0
- package/dist/core/runtime/bash-runner.js +2 -0
- package/dist/core/runtime/catui-agent.d.ts +182 -0
- package/dist/core/runtime/catui-agent.js +1 -0
- package/dist/core/runtime/compaction-controller.d.ts +43 -0
- package/dist/core/runtime/compaction-controller.js +1 -0
- package/dist/core/runtime/default-tools.d.ts +9 -0
- package/dist/core/runtime/default-tools.js +1 -0
- package/dist/core/runtime/event-bridge.d.ts +21 -0
- package/dist/core/runtime/event-bridge.js +1 -0
- package/dist/core/runtime/event-bus.d.ts +8 -0
- package/dist/core/runtime/event-bus.js +1 -0
- package/dist/core/runtime/export-bridge.d.ts +23 -0
- package/dist/core/runtime/export-bridge.js +1 -0
- package/dist/core/runtime/extension-core-bindings.d.ts +46 -0
- package/dist/core/runtime/extension-core-bindings.js +3 -0
- package/dist/core/runtime/model-controller.d.ts +84 -0
- package/dist/core/runtime/model-controller.js +1 -0
- package/dist/core/runtime/model-cycle.d.ts +20 -0
- package/dist/core/runtime/model-cycle.js +1 -0
- package/dist/core/runtime/prompt-assembly.d.ts +20 -0
- package/dist/core/runtime/prompt-assembly.js +3 -0
- package/dist/core/runtime/retry-coordinator.d.ts +84 -0
- package/dist/core/runtime/retry-coordinator.js +1 -0
- package/dist/core/runtime/sdk.d.ts +163 -0
- package/dist/core/runtime/sdk.js +1 -0
- package/dist/core/runtime/session-context.d.ts +155 -0
- package/dist/core/runtime/session-context.js +0 -0
- package/dist/core/runtime/session-lifecycle-controller.d.ts +42 -0
- package/dist/core/runtime/session-lifecycle-controller.js +1 -0
- package/dist/core/runtime/session-tree-controller.d.ts +40 -0
- package/dist/core/runtime/session-tree-controller.js +1 -0
- package/dist/core/runtime/slash-command-catalog.d.ts +27 -0
- package/dist/core/runtime/slash-command-catalog.js +1 -0
- package/dist/core/runtime/thinking-levels.d.ts +31 -0
- package/dist/core/runtime/thinking-levels.js +1 -0
- package/dist/core/runtime/tool-runtime-controller.d.ts +35 -0
- package/dist/core/runtime/tool-runtime-controller.js +1 -0
- package/dist/core/runtime/turn-context.d.ts +52 -0
- package/dist/core/runtime/turn-context.js +1 -0
- package/dist/core/session/compaction/branch-summarization.d.ts +85 -0
- package/dist/core/session/compaction/branch-summarization.js +38 -0
- package/dist/core/session/compaction/compaction.d.ts +120 -0
- package/dist/core/session/compaction/compaction.js +104 -0
- package/dist/core/session/compaction/index.d.ts +9 -0
- package/dist/core/session/compaction/index.js +1 -0
- package/dist/core/session/compaction/utils.d.ts +37 -0
- package/dist/core/session/compaction/utils.js +17 -0
- package/dist/core/session/session-manager.d.ts +359 -0
- package/dist/core/session/session-manager.js +14 -0
- package/dist/core/skills.d.ts +57 -0
- package/dist/core/skills.js +4 -0
- package/dist/core/slash-commands.d.ts +36 -0
- package/dist/core/slash-commands.js +1 -0
- package/dist/core/soul-integration.d.ts +77 -0
- package/dist/core/soul-integration.js +1 -0
- package/dist/core/soul-options-contract.d.ts +10 -0
- package/dist/core/soul-options-contract.js +0 -0
- package/dist/core/sub-agent/agent-definition-loader.d.ts +96 -0
- package/dist/core/sub-agent/agent-definition-loader.js +2 -0
- package/dist/core/sub-agent/agent-definition.d.ts +162 -0
- package/dist/core/sub-agent/agent-definition.js +6 -0
- package/dist/core/sub-agent/agent-handoff-safety.d.ts +39 -0
- package/dist/core/sub-agent/agent-handoff-safety.js +1 -0
- package/dist/core/sub-agent/agent-input-output.d.ts +143 -0
- package/dist/core/sub-agent/agent-input-output.js +1 -0
- package/dist/core/sub-agent/agent-output-persistence.d.ts +43 -0
- package/dist/core/sub-agent/agent-output-persistence.js +3 -0
- package/dist/core/sub-agent/agent-prompt-builder.d.ts +37 -0
- package/dist/core/sub-agent/agent-prompt-builder.js +2 -0
- package/dist/core/sub-agent/agent-registry.d.ts +145 -0
- package/dist/core/sub-agent/agent-registry.js +1 -0
- package/dist/core/sub-agent/agent-result-extractor.d.ts +28 -0
- package/dist/core/sub-agent/agent-result-extractor.js +3 -0
- package/dist/core/sub-agent/agent-telemetry.d.ts +71 -0
- package/dist/core/sub-agent/agent-telemetry.js +1 -0
- package/dist/core/sub-agent/agent-tool-filter.d.ts +89 -0
- package/dist/core/sub-agent/agent-tool-filter.js +2 -0
- package/dist/core/sub-agent/agent-tool.d.ts +69 -0
- package/dist/core/sub-agent/agent-tool.js +11 -0
- package/dist/core/sub-agent/index.d.ts +26 -0
- package/dist/core/sub-agent/index.js +1 -0
- package/dist/core/sub-agent/send-message-tool.d.ts +33 -0
- package/dist/core/sub-agent/send-message-tool.js +2 -0
- package/dist/core/sub-agent/sub-agent-backend.d.ts +26 -0
- package/dist/core/sub-agent/sub-agent-backend.js +7 -0
- package/dist/core/sub-agent/sub-agent-runtime.d.ts +34 -0
- package/dist/core/sub-agent/sub-agent-runtime.js +1 -0
- package/dist/core/sub-agent/sub-agent-types.d.ts +138 -0
- package/dist/core/sub-agent/sub-agent-types.js +0 -0
- package/dist/core/sub-agent/subprocess-backend.d.ts +35 -0
- package/dist/core/sub-agent/subprocess-backend.js +1 -0
- package/dist/core/sub-agent/subprocess-worker.d.ts +12 -0
- package/dist/core/sub-agent/subprocess-worker.js +1 -0
- package/dist/core/theme-contract.d.ts +32 -0
- package/dist/core/theme-contract.js +0 -0
- package/dist/core/tools/bash.d.ts +73 -0
- package/dist/core/tools/bash.js +21 -0
- package/dist/core/tools/edit-diff.d.ts +58 -0
- package/dist/core/tools/edit-diff.js +16 -0
- package/dist/core/tools/edit.d.ts +46 -0
- package/dist/core/tools/edit.js +1 -0
- package/dist/core/tools/file-state-cache.d.ts +30 -0
- package/dist/core/tools/file-state-cache.js +1 -0
- package/dist/core/tools/find.d.ts +46 -0
- package/dist/core/tools/find.js +8 -0
- package/dist/core/tools/grep.d.ts +58 -0
- package/dist/core/tools/grep.js +13 -0
- package/dist/core/tools/index.d.ts +116 -0
- package/dist/core/tools/index.js +1 -0
- package/dist/core/tools/input-validation.d.ts +13 -0
- package/dist/core/tools/input-validation.js +1 -0
- package/dist/core/tools/ls.d.ts +45 -0
- package/dist/core/tools/ls.js +4 -0
- package/dist/core/tools/orchestrator.d.ts +76 -0
- package/dist/core/tools/orchestrator.js +1 -0
- package/dist/core/tools/path-utils.d.ts +7 -0
- package/dist/core/tools/path-utils.js +1 -0
- package/dist/core/tools/pdf-extract.d.ts +11 -0
- package/dist/core/tools/pdf-extract.js +1 -0
- package/dist/core/tools/read.d.ts +46 -0
- package/dist/core/tools/read.js +11 -0
- package/dist/core/tools/source.d.ts +78 -0
- package/dist/core/tools/source.js +1 -0
- package/dist/core/tools/time.d.ts +19 -0
- package/dist/core/tools/time.js +2 -0
- package/dist/core/tools/truncate.d.ts +66 -0
- package/dist/core/tools/truncate.js +5 -0
- package/dist/core/tools/write-guard.d.ts +2 -0
- package/dist/core/tools/write-guard.js +1 -0
- package/dist/core/tools/write.d.ts +36 -0
- package/dist/core/tools/write.js +1 -0
- package/dist/core/workspace/index.d.ts +8 -0
- package/dist/core/workspace/index.js +1 -0
- package/dist/core/workspace/worktree-manager.d.ts +73 -0
- package/dist/core/workspace/worktree-manager.js +3 -0
- package/dist/extensions/builtin/AGENT.md +115 -0
- package/dist/extensions/builtin/ask-user-question/ask-user-question-tool.d.ts +9 -0
- package/dist/extensions/builtin/ask-user-question/ask-user-question-tool.js +4 -0
- package/dist/extensions/builtin/ask-user-question/index.d.ts +8 -0
- package/dist/extensions/builtin/ask-user-question/index.js +1 -0
- package/dist/extensions/builtin/ask-user-question/prompt.d.ts +14 -0
- package/dist/extensions/builtin/ask-user-question/prompt.js +30 -0
- package/dist/extensions/builtin/ask-user-question/types.d.ts +69 -0
- package/dist/extensions/builtin/ask-user-question/types.js +1 -0
- package/dist/extensions/builtin/browser/AGENT.md +17 -0
- package/dist/extensions/builtin/browser/agent-workspace/agent_helpers.py +12 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/amazon/product-search.md +198 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/archive-org/scraping.md +341 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/arxiv/scraping.md +311 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/arxiv-bulk/scraping.md +333 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/atlas/overview.md +70 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/booking-com/scraping.md +578 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/capterra/scraping.md +440 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/centilebrain/generate-estimates.md +110 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/coingecko/scraping.md +325 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/coinmarketcap/scraping.md +463 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/coursera/scraping.md +360 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/craigslist/scraping.md +390 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/crossref/scraping.md +568 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/dev-to/scraping.md +323 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/duckduckgo/scraping.md +349 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/ebay/scraping.md +435 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/etsy/scraping.md +506 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/eventbrite/scraping.md +363 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/expedia/automation.md +168 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/facebook/groups.md +236 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/facebook/pages.md +295 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/framer/editor.md +108 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/fred/scraping.md +493 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/g2/scraping.md +580 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/genius/scraping.md +511 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/github/repo-actions.md +65 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/github/scraping.md +184 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/glassdoor/scraping.md +543 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/gmail/compose.md +122 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/goodreads/scraping.md +461 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/gutenberg/scraping.md +383 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/hackernews/scraping.md +243 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/howlongtobeat/scraping.md +473 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/imdb/scraping.md +271 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/itch-io/scraping.md +436 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/job-boards/indeed-glassdoor.md +1021 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/letterboxd/scraping.md +349 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/linkedin/invitation-manager.md +109 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/loom/folder-enumeration.md +170 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/macrotrends/scraping.md +537 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/medium/article-hydration.md +120 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/medium/scraping.md +414 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/metacritic/scraping.md +477 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/musicbrainz/scraping.md +478 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/nasa/scraping.md +339 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/news-aggregation/multi-source.md +205 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/open-library/scraping.md +472 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/openalex/scraping.md +470 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/openstreetmap/scraping.md +490 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/package-registries/npm-pypi.md +478 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/polymarket/scraping.md +234 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/producthunt/scraping.md +307 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/pubmed/scraping.md +421 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/quora/scraping.md +364 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/rawg/scraping.md +352 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/reddit/scraping.md +124 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/rest-countries/scraping.md +233 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/sec-edgar/scraping.md +361 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/README.md +36 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/embedded-apps.md +72 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/knowledge-base.md +109 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/shopify-admin/polaris-inputs.md +137 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/soundcloud/scraping.md +362 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/spotify/scraping.md +339 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/stackoverflow/scraping.md +435 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/steam/scraping.md +575 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/substack/scraping.md +338 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/thetechgeeks/pricing.md +52 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/tiktok/upload.md +107 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/tradingview/scraping.md +309 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/trello/boards-and-lists.md +88 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/trustpilot/scraping.md +375 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/walmart/scraping.md +444 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/wayback-machine/scraping.md +306 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/weather/scraping.md +398 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/wellfound/scraping.md +596 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/world-bank/scraping.md +356 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/xiaohongshu/scraping.md +84 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/youtube/scraping.md +418 -0
- package/dist/extensions/builtin/browser/agent-workspace/domain-skills/zillow/scraping.md +433 -0
- package/dist/extensions/builtin/browser/browser.md +73 -0
- package/dist/extensions/builtin/browser/index.d.ts +8 -0
- package/dist/extensions/builtin/browser/index.js +15 -0
- package/dist/extensions/builtin/browser/install.md +142 -0
- package/dist/extensions/builtin/browser/interaction-skills/connection.md +48 -0
- package/dist/extensions/builtin/browser/interaction-skills/cookies.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/cross-origin-iframes.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/dialogs.md +64 -0
- package/dist/extensions/builtin/browser/interaction-skills/downloads.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/drag-and-drop.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/dropdowns.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/iframes.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/network-requests.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/print-as-pdf.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/profile-sync.md +90 -0
- package/dist/extensions/builtin/browser/interaction-skills/screenshots.md +17 -0
- package/dist/extensions/builtin/browser/interaction-skills/scrolling.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/shadow-dom.md +3 -0
- package/dist/extensions/builtin/browser/interaction-skills/tabs.md +69 -0
- package/dist/extensions/builtin/browser/interaction-skills/uploads.md +1 -0
- package/dist/extensions/builtin/browser/interaction-skills/viewport.md +3 -0
- package/dist/extensions/builtin/browser/src/browser_harness/AGENT.md +15 -0
- package/dist/extensions/builtin/browser/src/browser_harness/__init__.py +8 -0
- package/dist/extensions/builtin/browser/src/browser_harness/_ipc.py +90 -0
- package/dist/extensions/builtin/browser/src/browser_harness/admin.py +722 -0
- package/dist/extensions/builtin/browser/src/browser_harness/daemon.py +328 -0
- package/dist/extensions/builtin/browser/src/browser_harness/helpers.py +396 -0
- package/dist/extensions/builtin/browser/src/browser_harness/run.py +103 -0
- package/dist/extensions/builtin/btw/index.d.ts +8 -0
- package/dist/extensions/builtin/btw/index.js +15 -0
- package/dist/extensions/builtin/debug/collectors.d.ts +96 -0
- package/dist/extensions/builtin/debug/collectors.js +7 -0
- package/dist/extensions/builtin/debug/index.d.ts +8 -0
- package/dist/extensions/builtin/debug/index.js +49 -0
- package/dist/extensions/builtin/diagnostics/diagnostic-buffer.d.ts +19 -0
- package/dist/extensions/builtin/diagnostics/diagnostic-buffer.js +1 -0
- package/dist/extensions/builtin/diagnostics/index.d.ts +8 -0
- package/dist/extensions/builtin/diagnostics/index.js +1 -0
- package/dist/extensions/builtin/diagnostics/redaction.d.ts +8 -0
- package/dist/extensions/builtin/diagnostics/redaction.js +1 -0
- package/dist/extensions/builtin/diagnostics/reporter.d.ts +17 -0
- package/dist/extensions/builtin/diagnostics/reporter.js +1 -0
- package/dist/extensions/builtin/diagnostics/types.d.ts +62 -0
- package/dist/extensions/builtin/diagnostics/types.js +1 -0
- package/dist/extensions/builtin/discipline/index.d.ts +8 -0
- package/dist/extensions/builtin/discipline/index.js +7 -0
- package/dist/extensions/builtin/discipline/skills/brainstorming/SKILL.md +33 -0
- package/dist/extensions/builtin/discipline/skills/executing-plans/SKILL.md +25 -0
- package/dist/extensions/builtin/discipline/skills/finishing-development-branch/SKILL.md +25 -0
- package/dist/extensions/builtin/discipline/skills/receiving-code-review/SKILL.md +22 -0
- package/dist/extensions/builtin/discipline/skills/requesting-code-review/SKILL.md +31 -0
- package/dist/extensions/builtin/discipline/skills/systematic-debugging/SKILL.md +28 -0
- package/dist/extensions/builtin/discipline/skills/test-driven-development/SKILL.md +32 -0
- package/dist/extensions/builtin/discipline/skills/using-git-worktrees/SKILL.md +25 -0
- package/dist/extensions/builtin/discipline/skills/verification-before-completion/SKILL.md +27 -0
- package/dist/extensions/builtin/discipline/skills/writing-plans/SKILL.md +26 -0
- package/dist/extensions/builtin/goal/README.md +67 -0
- package/dist/extensions/builtin/goal/goal-command.d.ts +13 -0
- package/dist/extensions/builtin/goal/goal-command.js +9 -0
- package/dist/extensions/builtin/goal/goal-controller.d.ts +143 -0
- package/dist/extensions/builtin/goal/goal-controller.js +1 -0
- package/dist/extensions/builtin/goal/goal-format.d.ts +52 -0
- package/dist/extensions/builtin/goal/goal-format.js +1 -0
- package/dist/extensions/builtin/goal/goal-parser.d.ts +27 -0
- package/dist/extensions/builtin/goal/goal-parser.js +2 -0
- package/dist/extensions/builtin/goal/goal-prompts.d.ts +15 -0
- package/dist/extensions/builtin/goal/goal-prompts.js +5 -0
- package/dist/extensions/builtin/goal/goal-store.d.ts +28 -0
- package/dist/extensions/builtin/goal/goal-store.js +1 -0
- package/dist/extensions/builtin/goal/goal-tools.d.ts +26 -0
- package/dist/extensions/builtin/goal/goal-tools.js +3 -0
- package/dist/extensions/builtin/goal/goal-types.d.ts +87 -0
- package/dist/extensions/builtin/goal/goal-types.js +1 -0
- package/dist/extensions/builtin/goal/index.d.ts +8 -0
- package/dist/extensions/builtin/goal/index.js +10 -0
- package/dist/extensions/builtin/grub/README.md +112 -0
- package/dist/extensions/builtin/grub/grub-controller.d.ts +67 -0
- package/dist/extensions/builtin/grub/grub-controller.js +1 -0
- package/dist/extensions/builtin/grub/grub-decision.d.ts +8 -0
- package/dist/extensions/builtin/grub/grub-decision.js +1 -0
- package/dist/extensions/builtin/grub/grub-feature-list.d.ts +54 -0
- package/dist/extensions/builtin/grub/grub-feature-list.js +2 -0
- package/dist/extensions/builtin/grub/grub-format.d.ts +13 -0
- package/dist/extensions/builtin/grub/grub-format.js +4 -0
- package/dist/extensions/builtin/grub/grub-harness.d.ts +9 -0
- package/dist/extensions/builtin/grub/grub-harness.js +3 -0
- package/dist/extensions/builtin/grub/grub-i18n.d.ts +166 -0
- package/dist/extensions/builtin/grub/grub-i18n.js +1 -0
- package/dist/extensions/builtin/grub/grub-parser.d.ts +24 -0
- package/dist/extensions/builtin/grub/grub-parser.js +2 -0
- package/dist/extensions/builtin/grub/grub-persistence.d.ts +17 -0
- package/dist/extensions/builtin/grub/grub-persistence.js +2 -0
- package/dist/extensions/builtin/grub/grub-prompts.d.ts +12 -0
- package/dist/extensions/builtin/grub/grub-prompts.js +97 -0
- package/dist/extensions/builtin/grub/grub-turn.d.ts +16 -0
- package/dist/extensions/builtin/grub/grub-turn.js +1 -0
- package/dist/extensions/builtin/grub/grub-types.d.ts +110 -0
- package/dist/extensions/builtin/grub/grub-types.js +1 -0
- package/dist/extensions/builtin/grub/index.d.ts +8 -0
- package/dist/extensions/builtin/grub/index.js +6 -0
- package/dist/extensions/builtin/idle-think/curiosity.d.ts +46 -0
- package/dist/extensions/builtin/idle-think/curiosity.js +2 -0
- package/dist/extensions/builtin/idle-think/idle-think-runtime.d.ts +46 -0
- package/dist/extensions/builtin/idle-think/idle-think-runtime.js +1 -0
- package/dist/extensions/builtin/idle-think/index.d.ts +15 -0
- package/dist/extensions/builtin/idle-think/index.js +1 -0
- package/dist/extensions/builtin/idle-think/insights.d.ts +27 -0
- package/dist/extensions/builtin/idle-think/insights.js +5 -0
- package/dist/extensions/builtin/idle-think/thinker.d.ts +26 -0
- package/dist/extensions/builtin/idle-think/thinker.js +9 -0
- package/dist/extensions/builtin/insights/html-report.d.ts +21 -0
- package/dist/extensions/builtin/insights/html-report.js +463 -0
- package/dist/extensions/builtin/insights/index.d.ts +24 -0
- package/dist/extensions/builtin/insights/index.js +2 -0
- package/dist/extensions/builtin/insights/insights-engine.d.ts +18 -0
- package/dist/extensions/builtin/insights/insights-engine.js +39 -0
- package/dist/extensions/builtin/insights/prompts.d.ts +17 -0
- package/dist/extensions/builtin/insights/prompts.js +180 -0
- package/dist/extensions/builtin/insights/session-scanner.d.ts +27 -0
- package/dist/extensions/builtin/insights/session-scanner.js +19 -0
- package/dist/extensions/builtin/insights/stats.d.ts +13 -0
- package/dist/extensions/builtin/insights/stats.js +1 -0
- package/dist/extensions/builtin/insights/types.d.ts +199 -0
- package/dist/extensions/builtin/insights/types.js +0 -0
- package/dist/extensions/builtin/link-world/agent-workspace/README.md +16 -0
- package/dist/extensions/builtin/link-world/index.d.ts +8 -0
- package/dist/extensions/builtin/link-world/index.js +19 -0
- package/dist/extensions/builtin/link-world/internet-search/internet-search.md +65 -0
- package/dist/extensions/builtin/link-world/link-world-agent.md +82 -0
- package/dist/extensions/builtin/link-world/linkworld.md +313 -0
- package/dist/extensions/builtin/link-world/network-routing/network-routing.md +67 -0
- package/dist/extensions/builtin/loop/README.md +92 -0
- package/dist/extensions/builtin/loop/cron/cron-parser.d.ts +56 -0
- package/dist/extensions/builtin/loop/cron/cron-parser.js +1 -0
- package/dist/extensions/builtin/loop/cron/cron-scheduler.d.ts +85 -0
- package/dist/extensions/builtin/loop/cron/cron-scheduler.js +10 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks-lock.d.ts +42 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks-lock.js +1 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks.d.ts +200 -0
- package/dist/extensions/builtin/loop/cron/cron-tasks.js +2 -0
- package/dist/extensions/builtin/loop/cron/index.d.ts +18 -0
- package/dist/extensions/builtin/loop/cron/index.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-create-tool.d.ts +35 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-create-tool.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-delete-tool.d.ts +29 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-delete-tool.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-list-tool.d.ts +25 -0
- package/dist/extensions/builtin/loop/cron-tools/cron-list-tool.js +2 -0
- package/dist/extensions/builtin/loop/cron-tools/index.d.ts +16 -0
- package/dist/extensions/builtin/loop/cron-tools/index.js +1 -0
- package/dist/extensions/builtin/loop/cron-tools/prompt.d.ts +35 -0
- package/dist/extensions/builtin/loop/cron-tools/prompt.js +38 -0
- package/dist/extensions/builtin/loop/index.d.ts +19 -0
- package/dist/extensions/builtin/loop/index.js +2 -0
- package/dist/extensions/builtin/loop/loop-skill.d.ts +18 -0
- package/dist/extensions/builtin/loop/loop-skill.js +58 -0
- package/dist/extensions/builtin/lsp/index.d.ts +8 -0
- package/dist/extensions/builtin/lsp/index.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-client.d.ts +22 -0
- package/dist/extensions/builtin/lsp/lsp-client.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-config.d.ts +8 -0
- package/dist/extensions/builtin/lsp/lsp-config.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-formatters.d.ts +15 -0
- package/dist/extensions/builtin/lsp/lsp-formatters.js +18 -0
- package/dist/extensions/builtin/lsp/lsp-server-instance.d.ts +24 -0
- package/dist/extensions/builtin/lsp/lsp-server-instance.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-server-manager.d.ts +21 -0
- package/dist/extensions/builtin/lsp/lsp-server-manager.js +1 -0
- package/dist/extensions/builtin/lsp/lsp-tool.d.ts +33 -0
- package/dist/extensions/builtin/lsp/lsp-tool.js +2 -0
- package/dist/extensions/builtin/lsp/types.d.ts +31 -0
- package/dist/extensions/builtin/lsp/types.js +1 -0
- package/dist/extensions/builtin/mcp/figma-design.md +68 -0
- package/dist/extensions/builtin/mcp/index.d.ts +14 -0
- package/dist/extensions/builtin/mcp/index.js +25 -0
- package/dist/extensions/builtin/mcp/mcp-management.md +85 -0
- package/dist/extensions/builtin/plan/clear-context-state.d.ts +8 -0
- package/dist/extensions/builtin/plan/clear-context-state.js +1 -0
- package/dist/extensions/builtin/plan/enter-plan-mode-tool.d.ts +11 -0
- package/dist/extensions/builtin/plan/enter-plan-mode-tool.js +2 -0
- package/dist/extensions/builtin/plan/exit-plan-mode-tool.d.ts +18 -0
- package/dist/extensions/builtin/plan/exit-plan-mode-tool.js +13 -0
- package/dist/extensions/builtin/plan/index.d.ts +8 -0
- package/dist/extensions/builtin/plan/index.js +24 -0
- package/dist/extensions/builtin/plan/plan-agents.d.ts +23 -0
- package/dist/extensions/builtin/plan/plan-agents.js +43 -0
- package/dist/extensions/builtin/plan/plan-file-manager.d.ts +26 -0
- package/dist/extensions/builtin/plan/plan-file-manager.js +1 -0
- package/dist/extensions/builtin/plan/plan-permissions.d.ts +15 -0
- package/dist/extensions/builtin/plan/plan-permissions.js +12 -0
- package/dist/extensions/builtin/plan/plan-validation.d.ts +18 -0
- package/dist/extensions/builtin/plan/plan-validation.js +5 -0
- package/dist/extensions/builtin/plan/plan-workflow-prompt.d.ts +18 -0
- package/dist/extensions/builtin/plan/plan-workflow-prompt.js +102 -0
- package/dist/extensions/builtin/plan/teammate-approval.d.ts +49 -0
- package/dist/extensions/builtin/plan/teammate-approval.js +3 -0
- package/dist/extensions/builtin/plan/types.d.ts +133 -0
- package/dist/extensions/builtin/plan/types.js +1 -0
- package/dist/extensions/builtin/presence/index.d.ts +40 -0
- package/dist/extensions/builtin/presence/index.js +15 -0
- package/dist/extensions/builtin/presence/presence-memory.d.ts +47 -0
- package/dist/extensions/builtin/presence/presence-memory.js +1 -0
- package/dist/extensions/builtin/recap/AGENT.md +15 -0
- package/dist/extensions/builtin/recap/index.d.ts +8 -0
- package/dist/extensions/builtin/recap/index.js +1 -0
- package/dist/extensions/builtin/recap/recap-budget.d.ts +24 -0
- package/dist/extensions/builtin/recap/recap-budget.js +1 -0
- package/dist/extensions/builtin/recap/recap-extractor.d.ts +34 -0
- package/dist/extensions/builtin/recap/recap-extractor.js +3 -0
- package/dist/extensions/builtin/recap/recap-renderer.d.ts +19 -0
- package/dist/extensions/builtin/recap/recap-renderer.js +2 -0
- package/dist/extensions/builtin/recap/recap-synthesizer.d.ts +51 -0
- package/dist/extensions/builtin/recap/recap-synthesizer.js +19 -0
- package/dist/extensions/builtin/recap/recap-types.d.ts +40 -0
- package/dist/extensions/builtin/recap/recap-types.js +1 -0
- package/dist/extensions/builtin/sal/README.md +72 -0
- package/dist/extensions/builtin/sal/anchors.d.ts +46 -0
- package/dist/extensions/builtin/sal/anchors.js +1 -0
- package/dist/extensions/builtin/sal/eval/index.d.ts +18 -0
- package/dist/extensions/builtin/sal/eval/index.js +1 -0
- package/dist/extensions/builtin/sal/eval/insforge-sink.d.ts +30 -0
- package/dist/extensions/builtin/sal/eval/insforge-sink.js +1 -0
- package/dist/extensions/builtin/sal/eval/jsonl-sink.d.ts +27 -0
- package/dist/extensions/builtin/sal/eval/jsonl-sink.js +3 -0
- package/dist/extensions/builtin/sal/eval/noop-sink.d.ts +8 -0
- package/dist/extensions/builtin/sal/eval/noop-sink.js +1 -0
- package/dist/extensions/builtin/sal/eval/types.d.ts +60 -0
- package/dist/extensions/builtin/sal/eval/types.js +1 -0
- package/dist/extensions/builtin/sal/index.d.ts +12 -0
- package/dist/extensions/builtin/sal/index.js +7 -0
- package/dist/extensions/builtin/sal/sal-config.d.ts +46 -0
- package/dist/extensions/builtin/sal/sal-config.js +1 -0
- package/dist/extensions/builtin/sal/sal-context.d.ts +11 -0
- package/dist/extensions/builtin/sal/sal-context.js +2 -0
- package/dist/extensions/builtin/sal/sal-runtime.d.ts +72 -0
- package/dist/extensions/builtin/sal/sal-runtime.js +0 -0
- package/dist/extensions/builtin/sal/sal-trace.d.ts +11 -0
- package/dist/extensions/builtin/sal/sal-trace.js +1 -0
- package/dist/extensions/builtin/sal/terrain.d.ts +73 -0
- package/dist/extensions/builtin/sal/terrain.js +3 -0
- package/dist/extensions/builtin/sal/weights.d.ts +28 -0
- package/dist/extensions/builtin/sal/weights.js +1 -0
- package/dist/extensions/builtin/security-audit/README.md +289 -0
- package/dist/extensions/builtin/security-audit/engine/detector.d.ts +44 -0
- package/dist/extensions/builtin/security-audit/engine/detector.js +1 -0
- package/dist/extensions/builtin/security-audit/engine/interceptor.d.ts +61 -0
- package/dist/extensions/builtin/security-audit/engine/interceptor.js +27 -0
- package/dist/extensions/builtin/security-audit/engine/logger.d.ts +65 -0
- package/dist/extensions/builtin/security-audit/engine/logger.js +65 -0
- package/dist/extensions/builtin/security-audit/index.d.ts +13 -0
- package/dist/extensions/builtin/security-audit/index.js +49 -0
- package/dist/extensions/builtin/security-audit/interface.d.ts +167 -0
- package/dist/extensions/builtin/security-audit/interface.js +1 -0
- package/dist/extensions/builtin/soul/index.d.ts +13 -0
- package/dist/extensions/builtin/soul/index.js +1 -0
- package/dist/extensions/builtin/subagent/index.d.ts +8 -0
- package/dist/extensions/builtin/subagent/index.js +8 -0
- package/dist/extensions/builtin/subagent/subagent-parser.d.ts +30 -0
- package/dist/extensions/builtin/subagent/subagent-parser.js +15 -0
- package/dist/extensions/builtin/subagent/subagent-runner.d.ts +49 -0
- package/dist/extensions/builtin/subagent/subagent-runner.js +8 -0
- package/dist/extensions/builtin/subagent/subagent-types.d.ts +57 -0
- package/dist/extensions/builtin/subagent/subagent-types.js +0 -0
- package/dist/extensions/builtin/task/index.d.ts +8 -0
- package/dist/extensions/builtin/task/index.js +1 -0
- package/dist/extensions/builtin/task/task-store.d.ts +42 -0
- package/dist/extensions/builtin/task/task-store.js +1 -0
- package/dist/extensions/builtin/task/task-tools/task-create-tool.d.ts +37 -0
- package/dist/extensions/builtin/task/task-tools/task-create-tool.js +40 -0
- package/dist/extensions/builtin/task/task-tools/task-get-tool.d.ts +31 -0
- package/dist/extensions/builtin/task/task-tools/task-get-tool.js +23 -0
- package/dist/extensions/builtin/task/task-tools/task-list-tool.d.ts +27 -0
- package/dist/extensions/builtin/task/task-tools/task-list-tool.js +22 -0
- package/dist/extensions/builtin/task/task-tools/task-output-tool.d.ts +32 -0
- package/dist/extensions/builtin/task/task-tools/task-output-tool.js +10 -0
- package/dist/extensions/builtin/task/task-tools/task-stop-tool.d.ts +31 -0
- package/dist/extensions/builtin/task/task-tools/task-stop-tool.js +5 -0
- package/dist/extensions/builtin/task/task-tools/task-update-tool.d.ts +47 -0
- package/dist/extensions/builtin/task/task-tools/task-update-tool.js +77 -0
- package/dist/extensions/builtin/task/task-tools/tool-search-tool.d.ts +34 -0
- package/dist/extensions/builtin/task/task-tools/tool-search-tool.js +14 -0
- package/dist/extensions/builtin/task/task-types.d.ts +30 -0
- package/dist/extensions/builtin/task/task-types.js +1 -0
- package/dist/extensions/builtin/teach/README.md +197 -0
- package/dist/extensions/builtin/teach/index.d.ts +12 -0
- package/dist/extensions/builtin/teach/index.js +6 -0
- package/dist/extensions/builtin/teach/references/analogy-library.md +153 -0
- package/dist/extensions/builtin/teach/references/learning-paths.md +214 -0
- package/dist/extensions/builtin/teach/references/source-verification.md +268 -0
- package/dist/extensions/builtin/teach/references/teaching-template.md +237 -0
- package/dist/extensions/builtin/teach/teach-format.d.ts +35 -0
- package/dist/extensions/builtin/teach/teach-format.js +6 -0
- package/dist/extensions/builtin/teach/teach-i18n.d.ts +47 -0
- package/dist/extensions/builtin/teach/teach-i18n.js +1 -0
- package/dist/extensions/builtin/teach/teach-persistence.d.ts +36 -0
- package/dist/extensions/builtin/teach/teach-persistence.js +35 -0
- package/dist/extensions/builtin/teach/teach-prompts.d.ts +52 -0
- package/dist/extensions/builtin/teach/teach-prompts.js +35 -0
- package/dist/extensions/builtin/teach/teach-runtime.d.ts +93 -0
- package/dist/extensions/builtin/teach/teach-runtime.js +9 -0
- package/dist/extensions/builtin/teach/teach-types.d.ts +81 -0
- package/dist/extensions/builtin/teach/teach-types.js +0 -0
- package/dist/extensions/builtin/team/AGENT.md +112 -0
- package/dist/extensions/builtin/team/TESTING.md +299 -0
- package/dist/extensions/builtin/team/index.d.ts +26 -0
- package/dist/extensions/builtin/team/index.js +11 -0
- package/dist/extensions/builtin/team/team-dashboard.d.ts +13 -0
- package/dist/extensions/builtin/team/team-dashboard.js +1 -0
- package/dist/extensions/builtin/team/team-harness.d.ts +35 -0
- package/dist/extensions/builtin/team/team-harness.js +18 -0
- package/dist/extensions/builtin/team/team-mailbox.d.ts +50 -0
- package/dist/extensions/builtin/team/team-mailbox.js +4 -0
- package/dist/extensions/builtin/team/team-orchestrator.d.ts +39 -0
- package/dist/extensions/builtin/team/team-orchestrator.js +5 -0
- package/dist/extensions/builtin/team/team-parser.d.ts +84 -0
- package/dist/extensions/builtin/team/team-parser.js +38 -0
- package/dist/extensions/builtin/team/team-permissions.d.ts +63 -0
- package/dist/extensions/builtin/team/team-permissions.js +1 -0
- package/dist/extensions/builtin/team/team-presets.d.ts +45 -0
- package/dist/extensions/builtin/team/team-presets.js +2 -0
- package/dist/extensions/builtin/team/team-psyche.d.ts +14 -0
- package/dist/extensions/builtin/team/team-psyche.js +5 -0
- package/dist/extensions/builtin/team/team-runtime-helpers.d.ts +48 -0
- package/dist/extensions/builtin/team/team-runtime-helpers.js +2 -0
- package/dist/extensions/builtin/team/team-runtime.d.ts +91 -0
- package/dist/extensions/builtin/team/team-runtime.js +3 -0
- package/dist/extensions/builtin/team/team-state-store.d.ts +29 -0
- package/dist/extensions/builtin/team/team-state-store.js +2 -0
- package/dist/extensions/builtin/team/team-task-store.d.ts +35 -0
- package/dist/extensions/builtin/team/team-task-store.js +2 -0
- package/dist/extensions/builtin/team/team-transcript.d.ts +31 -0
- package/dist/extensions/builtin/team/team-transcript.js +2 -0
- package/dist/extensions/builtin/team/team-types.d.ts +250 -0
- package/dist/extensions/builtin/team/team-types.js +0 -0
- package/dist/extensions/builtin/team/team-ui.d.ts +50 -0
- package/dist/extensions/builtin/team/team-ui.js +2 -0
- package/dist/extensions/builtin/token-save/README.md +56 -0
- package/dist/extensions/builtin/token-save/config.d.ts +8 -0
- package/dist/extensions/builtin/token-save/config.js +1 -0
- package/dist/extensions/builtin/token-save/filters.d.ts +14 -0
- package/dist/extensions/builtin/token-save/filters.js +24 -0
- package/dist/extensions/builtin/token-save/index.d.ts +8 -0
- package/dist/extensions/builtin/token-save/index.js +4 -0
- package/dist/extensions/builtin/token-save/lexer.d.ts +11 -0
- package/dist/extensions/builtin/token-save/lexer.js +1 -0
- package/dist/extensions/builtin/token-save/recovery.d.ts +1 -0
- package/dist/extensions/builtin/token-save/recovery.js +1 -0
- package/dist/extensions/builtin/token-save/rewrite.d.ts +19 -0
- package/dist/extensions/builtin/token-save/rewrite.js +1 -0
- package/dist/extensions/builtin/token-save/runner.d.ts +14 -0
- package/dist/extensions/builtin/token-save/runner.js +3 -0
- package/dist/extensions/builtin/token-save/stream.d.ts +20 -0
- package/dist/extensions/builtin/token-save/stream.js +1 -0
- package/dist/extensions/builtin/token-save/toml-dsl.d.ts +25 -0
- package/dist/extensions/builtin/token-save/toml-dsl.js +3 -0
- package/dist/extensions/builtin/token-save/tracking.d.ts +24 -0
- package/dist/extensions/builtin/token-save/tracking.js +8 -0
- package/dist/extensions/optional/AGENT.md +11 -0
- package/dist/extensions/optional/export-html/index.d.ts +41 -0
- package/dist/extensions/optional/export-html/index.js +2 -0
- package/dist/extensions/optional/simplify/index.d.ts +35 -0
- package/dist/extensions/optional/simplify/index.js +77 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.js +1 -0
- package/dist/main.d.ts +7 -0
- package/dist/main.js +41 -0
- package/dist/migrations.d.ts +30 -0
- package/dist/migrations.js +4 -0
- package/dist/models.d.ts +7 -0
- package/dist/models.js +1 -0
- package/dist/modes/acp/acp-mode.d.ts +30 -0
- package/dist/modes/acp/acp-mode.js +25 -0
- package/dist/modes/index.d.ts +14 -0
- package/dist/modes/index.js +1 -0
- package/dist/modes/interactive/agent-loop-status.d.ts +8 -0
- package/dist/modes/interactive/agent-loop-status.js +1 -0
- package/dist/modes/interactive/components/apikey-input.d.ts +10 -0
- package/dist/modes/interactive/components/apikey-input.js +3 -0
- package/dist/modes/interactive/components/armin.d.ts +39 -0
- package/dist/modes/interactive/components/armin.js +1 -0
- package/dist/modes/interactive/components/assistant-message.d.ts +21 -0
- package/dist/modes/interactive/components/assistant-message.js +1 -0
- package/dist/modes/interactive/components/attachments-bar.d.ts +37 -0
- package/dist/modes/interactive/components/attachments-bar.js +1 -0
- package/dist/modes/interactive/components/bash-execution.d.ts +40 -0
- package/dist/modes/interactive/components/bash-execution.js +13 -0
- package/dist/modes/interactive/components/bordered-loader.d.ts +21 -0
- package/dist/modes/interactive/components/bordered-loader.js +1 -0
- package/dist/modes/interactive/components/branch-summary-message.d.ts +21 -0
- package/dist/modes/interactive/components/branch-summary-message.js +3 -0
- package/dist/modes/interactive/components/buddy/pet-sprites.d.ts +31 -0
- package/dist/modes/interactive/components/buddy/pet-sprites.js +1 -0
- package/dist/modes/interactive/components/catui-loader.d.ts +55 -0
- package/dist/modes/interactive/components/catui-loader.js +1 -0
- package/dist/modes/interactive/components/compaction-summary-message.d.ts +21 -0
- package/dist/modes/interactive/components/compaction-summary-message.js +3 -0
- package/dist/modes/interactive/components/config-selector.d.ts +76 -0
- package/dist/modes/interactive/components/config-selector.js +1 -0
- package/dist/modes/interactive/components/countdown-timer.d.ts +19 -0
- package/dist/modes/interactive/components/countdown-timer.js +1 -0
- package/dist/modes/interactive/components/custom-editor.d.ts +37 -0
- package/dist/modes/interactive/components/custom-editor.js +1 -0
- package/dist/modes/interactive/components/custom-message.d.ts +26 -0
- package/dist/modes/interactive/components/custom-message.js +2 -0
- package/dist/modes/interactive/components/daxnuts.d.ts +28 -0
- package/dist/modes/interactive/components/daxnuts.js +1 -0
- package/dist/modes/interactive/components/diff.d.ts +17 -0
- package/dist/modes/interactive/components/diff.js +3 -0
- package/dist/modes/interactive/components/dynamic-border.d.ts +20 -0
- package/dist/modes/interactive/components/dynamic-border.js +1 -0
- package/dist/modes/interactive/components/editor-buddy-layout.d.ts +17 -0
- package/dist/modes/interactive/components/editor-buddy-layout.js +1 -0
- package/dist/modes/interactive/components/extension-editor.d.ts +25 -0
- package/dist/modes/interactive/components/extension-editor.js +1 -0
- package/dist/modes/interactive/components/extension-input.d.ts +29 -0
- package/dist/modes/interactive/components/extension-input.js +2 -0
- package/dist/modes/interactive/components/extension-selector.d.ts +32 -0
- package/dist/modes/interactive/components/extension-selector.js +2 -0
- package/dist/modes/interactive/components/footer.d.ts +34 -0
- package/dist/modes/interactive/components/footer.js +1 -0
- package/dist/modes/interactive/components/index.d.ts +44 -0
- package/dist/modes/interactive/components/index.js +1 -0
- package/dist/modes/interactive/components/keybinding-hints.d.ts +46 -0
- package/dist/modes/interactive/components/keybinding-hints.js +1 -0
- package/dist/modes/interactive/components/login-dialog.d.ts +47 -0
- package/dist/modes/interactive/components/login-dialog.js +1 -0
- package/dist/modes/interactive/components/memory-stats.d.ts +14 -0
- package/dist/modes/interactive/components/memory-stats.js +2 -0
- package/dist/modes/interactive/components/model-selector.d.ts +59 -0
- package/dist/modes/interactive/components/model-selector.js +2 -0
- package/dist/modes/interactive/components/notification-queue.d.ts +49 -0
- package/dist/modes/interactive/components/notification-queue.js +1 -0
- package/dist/modes/interactive/components/oauth-selector.d.ts +30 -0
- package/dist/modes/interactive/components/oauth-selector.js +1 -0
- package/dist/modes/interactive/components/persona-selector.d.ts +24 -0
- package/dist/modes/interactive/components/persona-selector.js +1 -0
- package/dist/modes/interactive/components/plan-progress-panel.d.ts +24 -0
- package/dist/modes/interactive/components/plan-progress-panel.js +1 -0
- package/dist/modes/interactive/components/provider-selector.d.ts +25 -0
- package/dist/modes/interactive/components/provider-selector.js +1 -0
- package/dist/modes/interactive/components/raw-text.d.ts +19 -0
- package/dist/modes/interactive/components/raw-text.js +3 -0
- package/dist/modes/interactive/components/scoped-models-selector.d.ts +54 -0
- package/dist/modes/interactive/components/scoped-models-selector.js +1 -0
- package/dist/modes/interactive/components/session-selector-search.d.ts +28 -0
- package/dist/modes/interactive/components/session-selector-search.js +1 -0
- package/dist/modes/interactive/components/session-selector.d.ts +100 -0
- package/dist/modes/interactive/components/session-selector.js +2 -0
- package/dist/modes/interactive/components/settings-selector.d.ts +77 -0
- package/dist/modes/interactive/components/settings-selector.js +1 -0
- package/dist/modes/interactive/components/show-images-selector.d.ts +15 -0
- package/dist/modes/interactive/components/show-images-selector.js +1 -0
- package/dist/modes/interactive/components/skill-invocation-message.d.ts +22 -0
- package/dist/modes/interactive/components/skill-invocation-message.js +3 -0
- package/dist/modes/interactive/components/soul-stats.d.ts +15 -0
- package/dist/modes/interactive/components/soul-stats.js +2 -0
- package/dist/modes/interactive/components/sub-agent-panel.d.ts +24 -0
- package/dist/modes/interactive/components/sub-agent-panel.js +1 -0
- package/dist/modes/interactive/components/task-status-panel.d.ts +36 -0
- package/dist/modes/interactive/components/task-status-panel.js +1 -0
- package/dist/modes/interactive/components/theme-selector.d.ts +16 -0
- package/dist/modes/interactive/components/theme-selector.js +1 -0
- package/dist/modes/interactive/components/thinking-selector.d.ts +16 -0
- package/dist/modes/interactive/components/thinking-selector.js +1 -0
- package/dist/modes/interactive/components/tool-execution.d.ts +80 -0
- package/dist/modes/interactive/components/tool-execution.js +58 -0
- package/dist/modes/interactive/components/tree-selector.d.ts +73 -0
- package/dist/modes/interactive/components/tree-selector.js +1 -0
- package/dist/modes/interactive/components/user-message-selector.d.ts +35 -0
- package/dist/modes/interactive/components/user-message-selector.js +1 -0
- package/dist/modes/interactive/components/user-message.d.ts +13 -0
- package/dist/modes/interactive/components/user-message.js +1 -0
- package/dist/modes/interactive/components/visual-truncate.d.ts +29 -0
- package/dist/modes/interactive/components/visual-truncate.js +1 -0
- package/dist/modes/interactive/controllers/auth-provider-config-controller.d.ts +64 -0
- package/dist/modes/interactive/controllers/auth-provider-config-controller.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/custom-overlay-host.d.ts +38 -0
- package/dist/modes/interactive/controllers/extension-ui/custom-overlay-host.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/editor-component-adapter.d.ts +37 -0
- package/dist/modes/interactive/controllers/extension-ui/editor-component-adapter.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/persistent-surface-registry.d.ts +53 -0
- package/dist/modes/interactive/controllers/extension-ui/persistent-surface-registry.js +1 -0
- package/dist/modes/interactive/controllers/extension-ui/prompt-host.d.ts +52 -0
- package/dist/modes/interactive/controllers/extension-ui/prompt-host.js +2 -0
- package/dist/modes/interactive/controllers/image-pipeline-controller.d.ts +106 -0
- package/dist/modes/interactive/controllers/image-pipeline-controller.js +1 -0
- package/dist/modes/interactive/controllers/input-submit-controller.d.ts +80 -0
- package/dist/modes/interactive/controllers/input-submit-controller.js +2 -0
- package/dist/modes/interactive/controllers/interrupt-controller.d.ts +75 -0
- package/dist/modes/interactive/controllers/interrupt-controller.js +1 -0
- package/dist/modes/interactive/controllers/model-overlay-controller.d.ts +127 -0
- package/dist/modes/interactive/controllers/model-overlay-controller.js +3 -0
- package/dist/modes/interactive/controllers/self-update-controller.d.ts +71 -0
- package/dist/modes/interactive/controllers/self-update-controller.js +24 -0
- package/dist/modes/interactive/controllers/settings-overlay-controller.d.ts +56 -0
- package/dist/modes/interactive/controllers/settings-overlay-controller.js +2 -0
- package/dist/modes/interactive/controllers/slash-dispatcher-controller.d.ts +74 -0
- package/dist/modes/interactive/controllers/slash-dispatcher-controller.js +1 -0
- package/dist/modes/interactive/controllers/stream-render-controller.d.ts +110 -0
- package/dist/modes/interactive/controllers/stream-render-controller.js +2 -0
- package/dist/modes/interactive/controllers/tree-overlay-controller.d.ts +55 -0
- package/dist/modes/interactive/controllers/tree-overlay-controller.js +1 -0
- package/dist/modes/interactive/footer-data-provider.d.ts +32 -0
- package/dist/modes/interactive/footer-data-provider.js +1 -0
- package/dist/modes/interactive/interactive-mode.d.ts +303 -0
- package/dist/modes/interactive/interactive-mode.js +119 -0
- package/dist/modes/interactive/services/tips.d.ts +20 -0
- package/dist/modes/interactive/services/tips.js +1 -0
- package/dist/modes/interactive/slash-command-arguments.d.ts +28 -0
- package/dist/modes/interactive/slash-command-arguments.js +1 -0
- package/dist/modes/interactive/state/interactive-state.d.ts +74 -0
- package/dist/modes/interactive/state/interactive-state.js +1 -0
- package/dist/modes/interactive/theme/dark.json +85 -0
- package/dist/modes/interactive/theme/light.json +84 -0
- package/dist/modes/interactive/theme/theme-schema.json +335 -0
- package/dist/modes/interactive/theme/theme.d.ts +81 -0
- package/dist/modes/interactive/theme/theme.js +16 -0
- package/dist/modes/interactive/theme/warm.json +81 -0
- package/dist/modes/print-mode.d.ts +38 -0
- package/dist/modes/print-mode.js +2 -0
- package/dist/modes/rpc/rpc-client.d.ts +221 -0
- package/dist/modes/rpc/rpc-client.js +2 -0
- package/dist/modes/rpc/rpc-mode.d.ts +14 -0
- package/dist/modes/rpc/rpc-mode.js +1 -0
- package/dist/modes/rpc/rpc-types.d.ts +449 -0
- package/dist/modes/rpc/rpc-types.js +0 -0
- package/dist/modes/utils/agent-loop-result-format.d.ts +10 -0
- package/dist/modes/utils/agent-loop-result-format.js +1 -0
- package/dist/modes/utils/clipboard-image.d.ts +10 -0
- package/dist/modes/utils/clipboard-image.js +1 -0
- package/dist/modes/utils/clipboard-native.d.ts +11 -0
- package/dist/modes/utils/clipboard-native.js +1 -0
- package/dist/modes/utils/clipboard.d.ts +1 -0
- package/dist/modes/utils/clipboard.js +1 -0
- package/dist/modes/utils/image-convert.d.ts +8 -0
- package/dist/modes/utils/image-convert.js +1 -0
- package/dist/modes/utils/image-resize.d.ts +41 -0
- package/dist/modes/utils/image-resize.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-continuations.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-stream-events.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-tool-results.js +3 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop-tool-summaries.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-loop.js +4 -0
- package/dist/node_modules/@catui/agent-core/dist/agent-run-result.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/agent.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/errors.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/index.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/proxy.js +2 -0
- package/dist/node_modules/@catui/agent-core/dist/structured-adaptive-agent-loop.js +2 -0
- package/dist/node_modules/@catui/agent-core/dist/structured-adaptive-streaming-tool-executor.js +1 -0
- package/dist/node_modules/@catui/agent-core/dist/structured-adaptive-tool-orchestration.js +3 -0
- package/dist/node_modules/@catui/agent-core/dist/types.js +1 -0
- package/dist/node_modules/@catui/agent-core/package.json +28 -0
- package/dist/node_modules/@catui/ai/dist/api-registry.js +1 -0
- package/dist/node_modules/@catui/ai/dist/cli.js +21 -0
- package/dist/node_modules/@catui/ai/dist/config-path.js +1 -0
- package/dist/node_modules/@catui/ai/dist/debug-logger.js +4 -0
- package/dist/node_modules/@catui/ai/dist/env-api-keys.js +1 -0
- package/dist/node_modules/@catui/ai/dist/env.js +1 -0
- package/dist/node_modules/@catui/ai/dist/events.js +1 -0
- package/dist/node_modules/@catui/ai/dist/index.js +1 -0
- package/dist/node_modules/@catui/ai/dist/json.js +1 -0
- package/dist/node_modules/@catui/ai/dist/models.generated.js +1 -0
- package/dist/node_modules/@catui/ai/dist/models.js +1 -0
- package/dist/node_modules/@catui/ai/dist/overflow.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/amazon-bedrock.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/anthropic.js +2 -0
- package/dist/node_modules/@catui/ai/dist/providers/azure-openai-responses.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/github-copilot-headers.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/google-gemini-cli.js +2 -0
- package/dist/node_modules/@catui/ai/dist/providers/google-shared.js +2 -0
- package/dist/node_modules/@catui/ai/dist/providers/google-vertex.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/google.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-codex-responses.js +7 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-completions.js +6 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-responses-shared.js +10 -0
- package/dist/node_modules/@catui/ai/dist/providers/openai-responses.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/register-builtins.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/simple-options.js +1 -0
- package/dist/node_modules/@catui/ai/dist/providers/transform-messages.js +1 -0
- package/dist/node_modules/@catui/ai/dist/registry.js +1 -0
- package/dist/node_modules/@catui/ai/dist/schema.js +1 -0
- package/dist/node_modules/@catui/ai/dist/stream.js +1 -0
- package/dist/node_modules/@catui/ai/dist/types.js +0 -0
- package/dist/node_modules/@catui/ai/dist/utils/event-stream-types.js +0 -0
- package/dist/node_modules/@catui/ai/dist/utils/event-stream.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/http-proxy.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/json-parse.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/anthropic.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/decode-credential.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/github-copilot.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/google-antigravity.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/google-gemini-cli.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/index.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/openai-codex.js +11 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/pkce.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/oauth/types.js +0 -0
- package/dist/node_modules/@catui/ai/dist/utils/overflow.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/sanitize-unicode.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/typebox-helpers.js +1 -0
- package/dist/node_modules/@catui/ai/dist/utils/validation.js +6 -0
- package/dist/node_modules/@catui/ai/package.json +106 -0
- package/dist/node_modules/@catui/tui/dist/autocomplete.js +2 -0
- package/dist/node_modules/@catui/tui/dist/components/box.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/cached-container.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/cancellable-loader.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/editor.js +21 -0
- package/dist/node_modules/@catui/tui/dist/components/image.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/input.js +2 -0
- package/dist/node_modules/@catui/tui/dist/components/loader.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/markdown.js +7 -0
- package/dist/node_modules/@catui/tui/dist/components/select-list.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/settings-list.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/spacer.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/text.js +1 -0
- package/dist/node_modules/@catui/tui/dist/components/truncated-text.js +2 -0
- package/dist/node_modules/@catui/tui/dist/editor-component.js +0 -0
- package/dist/node_modules/@catui/tui/dist/fuzzy.js +1 -0
- package/dist/node_modules/@catui/tui/dist/index.js +1 -0
- package/dist/node_modules/@catui/tui/dist/keybindings.js +1 -0
- package/dist/node_modules/@catui/tui/dist/keys.js +5 -0
- package/dist/node_modules/@catui/tui/dist/kill-ring.js +1 -0
- package/dist/node_modules/@catui/tui/dist/stdin-buffer.js +1 -0
- package/dist/node_modules/@catui/tui/dist/terminal-image.js +1 -0
- package/dist/node_modules/@catui/tui/dist/terminal.js +1 -0
- package/dist/node_modules/@catui/tui/dist/tui.js +12 -0
- package/dist/node_modules/@catui/tui/dist/undo-stack.js +1 -0
- package/dist/node_modules/@catui/tui/dist/utils.js +2 -0
- package/dist/node_modules/@catui/tui/package.json +37 -0
- package/dist/packages/mem-core/src/store.d.ts +21 -0
- package/dist/packages/mem-core/src/store.js +1 -0
- package/dist/packages/mem-core/src/types.d.ts +329 -0
- package/dist/packages/mem-core/src/types.js +0 -0
- package/dist/packages/protocol/src/commands.d.ts +33 -0
- package/dist/packages/protocol/src/commands.js +0 -0
- package/dist/packages/protocol/src/flags.d.ts +20 -0
- package/dist/packages/protocol/src/flags.js +0 -0
- package/dist/packages/protocol/src/hooks.d.ts +17 -0
- package/dist/packages/protocol/src/hooks.js +0 -0
- package/dist/packages/protocol/src/index.d.ts +15 -0
- package/dist/packages/protocol/src/index.js +1 -0
- package/dist/packages/protocol/src/lifecycle.d.ts +61 -0
- package/dist/packages/protocol/src/lifecycle.js +0 -0
- package/dist/packages/protocol/src/tools.d.ts +77 -0
- package/dist/packages/protocol/src/tools.js +0 -0
- package/dist/packages/soul-core/src/config.d.ts +20 -0
- package/dist/packages/soul-core/src/config.js +1 -0
- package/dist/packages/soul-core/src/diagnostics.d.ts +23 -0
- package/dist/packages/soul-core/src/diagnostics.js +1 -0
- package/dist/packages/soul-core/src/evolution.d.ts +75 -0
- package/dist/packages/soul-core/src/evolution.js +1 -0
- package/dist/packages/soul-core/src/index.d.ts +13 -0
- package/dist/packages/soul-core/src/index.js +1 -0
- package/dist/packages/soul-core/src/injection.d.ts +35 -0
- package/dist/packages/soul-core/src/injection.js +8 -0
- package/dist/packages/soul-core/src/manager.d.ts +101 -0
- package/dist/packages/soul-core/src/manager.js +1 -0
- package/dist/packages/soul-core/src/store.d.ts +62 -0
- package/dist/packages/soul-core/src/store.js +1 -0
- package/dist/packages/soul-core/src/types.d.ts +317 -0
- package/dist/packages/soul-core/src/types.js +0 -0
- package/dist/public-config.d.ts +12 -0
- package/dist/public-config.js +1 -0
- package/dist/runtime.d.ts +9 -0
- package/dist/runtime.js +1 -0
- package/dist/session-compaction.d.ts +7 -0
- package/dist/session-compaction.js +1 -0
- package/dist/session.d.ts +7 -0
- package/dist/session.js +1 -0
- package/dist/skills.d.ts +7 -0
- package/dist/skills.js +1 -0
- package/dist/tools.d.ts +7 -0
- package/dist/tools.js +1 -0
- package/dist/utils/changelog.d.ts +20 -0
- package/dist/utils/changelog.js +4 -0
- package/dist/utils/diagnostics.d.ts +37 -0
- package/dist/utils/diagnostics.js +1 -0
- package/dist/utils/frontmatter.d.ts +7 -0
- package/dist/utils/frontmatter.js +4 -0
- package/dist/utils/git.d.ts +25 -0
- package/dist/utils/git.js +1 -0
- package/dist/utils/mime.d.ts +1 -0
- package/dist/utils/mime.js +1 -0
- package/dist/utils/photon.d.ts +6 -0
- package/dist/utils/photon.js +1 -0
- package/dist/utils/startup-profiler.d.ts +87 -0
- package/dist/utils/startup-profiler.js +2 -0
- package/docs/codex-goal-command-impl.md +1055 -0
- package/docs/codex-goal-vs-grub.md +500 -0
- package/docs/custom-provider.md +27 -0
- package/docs/extensions.md +27 -0
- package/docs/keybindings.md +27 -0
- package/docs/loop /351/207/215/346/236/204/345/256/214/346/210/220/346/200/273/347/273/223.md" +251 -0
- package/docs/loop /351/207/215/346/236/204/345/256/214/346/210/220/346/212/245/345/221/212.md" +123 -0
- package/docs/loop /351/207/215/346/236/204/346/226/271/346/241/210.md" +1222 -0
- package/docs/loop /351/207/215/346/236/204/346/226/271/346/241/210/345/256/236/347/216/260/346/212/245/345/221/212.md" +158 -0
- package/docs/loop /351/207/215/346/236/204/346/226/271/346/241/210/345/257/271/346/257/224/345/210/206/346/236/220.md" +128 -0
- package/docs/loop /351/207/215/346/236/204/350/256/241/345/210/222.md" +321 -0
- package/docs/loop-usage-examples.md +215 -0
- package/docs/models.md +27 -0
- package/docs/packages.md +27 -0
- package/docs/pi-design-philosophy.md +457 -0
- package/docs/planmode.md +1987 -0
- package/docs/prompt-templates.md +27 -0
- package/docs/providers.md +27 -0
- package/docs/sdk.md +27 -0
- package/docs/skills.md +27 -0
- package/docs/themes.md +27 -0
- package/docs/tui.md +27 -0
- package/package.json +191 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var r=Object.defineProperty;var t=(o,e)=>r(o,"name",{value:e,configurable:!0});function l(o){return o.toolName==="bash"}t(l,"isBashToolResult");function u(o){return o.toolName==="read"}t(u,"isReadToolResult");function i(o){return o.toolName==="edit"}t(i,"isEditToolResult");function s(o){return o.toolName==="write"}t(s,"isWriteToolResult");function a(o){return o.toolName==="grep"}t(a,"isGrepToolResult");function p(o){return o.toolName==="find"}t(p,"isFindToolResult");function f(o){return o.toolName==="ls"}t(f,"isLsToolResult");function T(o,e){return e.toolName===o}t(T,"isToolCallEventType");export{l as isBashToolResult,i as isEditToolResult,p as isFindToolResult,a as isGrepToolResult,f as isLsToolResult,u as isReadToolResult,T as isToolCallEventType,s as isWriteToolResult};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: wrapRegisteredTool()
|
|
3
|
+
* [FROM]: Depends on agent-core, extensions/runner, extensions/types
|
|
4
|
+
* [TO]: Consumed by core/extensions-host/index.ts
|
|
5
|
+
* [HERE]: core/extensions-host/wrapper.ts - wraps RegisteredTool into AgentTool
|
|
6
|
+
*/
|
|
7
|
+
import type { AgentTool } from "@catui/agent-core";
|
|
8
|
+
import type { ExtensionRunner } from "./runner.js";
|
|
9
|
+
import type { RegisteredTool } from "./types.js";
|
|
10
|
+
/**
|
|
11
|
+
* Wrap a RegisteredTool into an AgentTool.
|
|
12
|
+
* Uses the runner's createContext() for consistent context across tools and event handlers.
|
|
13
|
+
*/
|
|
14
|
+
export declare function wrapRegisteredTool(registeredTool: RegisteredTool, runner: ExtensionRunner): AgentTool;
|
|
15
|
+
/**
|
|
16
|
+
* Wrap all registered tools into AgentTools.
|
|
17
|
+
* Uses the runner's createContext() for consistent context across tools and event handlers.
|
|
18
|
+
*/
|
|
19
|
+
export declare function wrapRegisteredTools(registeredTools: RegisteredTool[], runner: ExtensionRunner): AgentTool[];
|
|
20
|
+
/**
|
|
21
|
+
* Wrap a tool with extension callbacks for interception.
|
|
22
|
+
* - Emits tool_call event before execution (can block)
|
|
23
|
+
* - Emits tool_result event after execution (can modify result)
|
|
24
|
+
*/
|
|
25
|
+
export declare function wrapToolWithExtensions<T>(tool: AgentTool<any, T>, runner: ExtensionRunner): AgentTool<any, T>;
|
|
26
|
+
/**
|
|
27
|
+
* Wrap all tools with extension callbacks.
|
|
28
|
+
*/
|
|
29
|
+
export declare function wrapToolsWithExtensions<T>(tools: AgentTool<any, T>[], runner: ExtensionRunner): AgentTool<any, T>[];
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var f=Object.defineProperty;var i=(r,n)=>f(r,"name",{value:n,configurable:!0});function m(r,n){const{definition:e}=r;return{name:e.name,label:e.label,description:e.description,parameters:e.parameters,aliases:e.aliases,isConcurrencySafe:e.isConcurrencySafe,interruptBehavior:e.interruptBehavior,validateInput:e.validateInput,maxResultSizeChars:e.maxResultSizeChars,execute:i((s,l,c,a)=>e.execute(s,l,c,a,n.createContext()),"execute")}}i(m,"wrapRegisteredTool");function w(r,n){return r.map(e=>m(e,n))}i(w,"wrapRegisteredTools");function x(r,n){return{...r,execute:i(async(e,s,l,c)=>{let a=s;if(n.hasHandlers("tool_call"))try{const t=await n.emitToolCall({type:"tool_call",toolName:r.name,toolCallId:e,input:a});if(t?.block){const o=t.reason||"Tool execution was blocked by an extension";throw new Error(o)}t?.input&&(a=t.input)}catch(t){throw t instanceof Error?t:new Error(`Extension failed, blocking execution: ${String(t)}`)}try{const t=await r.execute(e,a,l,c);if(n.hasHandlers("tool_result")){const o=await n.emitToolResult({type:"tool_result",toolName:r.name,toolCallId:e,input:a,content:t.content,details:t.details,isError:!1});if(o)return{content:o.content??t.content,details:o.details??t.details}}return t}catch(t){if(n.hasHandlers("tool_result")){const o=await n.emitToolResult({type:"tool_result",toolName:r.name,toolCallId:e,input:a,content:[{type:"text",text:t instanceof Error?t.message:String(t)}],details:void 0,isError:!0});if(o?.content){const p=o.content.filter(u=>u.type==="text").map(u=>u.text).join(`
|
|
2
|
+
`);throw new Error(p||(t instanceof Error?t.message:String(t)))}}throw t}},"execute")}}i(x,"wrapToolWithExtensions");function h(r,n){return r.map(e=>x(e,n))}i(h,"wrapToolsWithExtensions");export{m as wrapRegisteredTool,w as wrapRegisteredTools,x as wrapToolWithExtensions,h as wrapToolsWithExtensions};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Barrel exports for core API surface
|
|
3
|
+
* [FROM]: Depends on runtime/, tools/, extensions/, session/, model/, config/
|
|
4
|
+
* [TO]: Consumed by index.ts (package root barrel)
|
|
5
|
+
* [HERE]: Public entry point for core functionality; consumed by modes and SDK
|
|
6
|
+
*/
|
|
7
|
+
export { AgentSession, type AgentSessionConfig, type AgentSessionEvent, type AgentSessionEventListener, type ModelCycleResult, type PromptOptions, type SessionStats, } from "./runtime/agent-session.js";
|
|
8
|
+
export { type BashExecutorOptions, type BashResult, executeBash, executeBashWithOperations, } from "./platform/exec/bash-executor.js";
|
|
9
|
+
export type { CompactionResult } from "./session/compaction/index.js";
|
|
10
|
+
export { createEventBus, type EventBus, type EventBusController, } from "./runtime/event-bus.js";
|
|
11
|
+
export { CatuiAgent, quickAgent, type CatuiAgentOptions, } from "./runtime/catui-agent.js";
|
|
12
|
+
export { type SDKLogger, silentLogger, defaultLogger, } from "./runtime/sdk.js";
|
|
13
|
+
export { type AgentEndEvent, type AgentStartEvent, type AgentToolResult, type AgentToolUpdateCallback, type BeforeAgentStartEvent, type ContextEvent, discoverAndLoadExtensions, type ExecOptions, type ExecResult, type Extension, type ExtensionAPI, type ExtensionCommandContext, type ExtensionContext, type ExtensionError, type ExtensionEvent, type ExtensionFactory, type ExtensionFlag, type ExtensionHandler, ExtensionRunner, type ExtensionShortcut, type ExtensionUIContext, type LoadExtensionsResult, type MessageRenderer, type RegisteredCommand, type SessionBeforeCompactEvent, type SessionBeforeForkEvent, type SessionBeforeSwitchEvent, type SessionBeforeTreeEvent, type SessionCompactEvent, type SessionForkEvent, type SessionShutdownEvent, type SessionStartEvent, type SessionSwitchEvent, type SessionTreeEvent, type ToolCallEvent, type ToolDefinition, type ToolRenderResultOptions, type ToolResultEvent, type TurnEndEvent, type TurnStartEvent, wrapToolsWithExtensions, } from "./extensions-host/index.js";
|
|
14
|
+
export { MCPManager } from "./mcp/mcp-manager.js";
|
|
15
|
+
export { getDebugLogger, createDebugLogger, debug, type DebugLogLevel, } from "./lib/ai/dist/debug-logger.js";
|
|
16
|
+
export type { MCPServerConfig, MCPTool, MCPToolResult, } from "./mcp/mcp-types.js";
|
|
17
|
+
export { loadMCPConfig, saveMCPConfig, addMCPServer, removeMCPServer, getMCPServer, listMCPServers, listEnabledMCPServers, } from "./mcp/mcp-config.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{AgentSession as o}from"./runtime/agent-session.js";import{executeBash as n,executeBashWithOperations as g}from"./platform/exec/bash-executor.js";import{createEventBus as a}from"./runtime/event-bus.js";import{CatuiAgent as x,quickAgent as f}from"./runtime/catui-agent.js";import{silentLogger as C,defaultLogger as m}from"./runtime/sdk.js";import{discoverAndLoadExtensions as d,ExtensionRunner as v,wrapToolsWithExtensions as M}from"./extensions-host/index.js";import{MCPManager as l}from"./mcp/mcp-manager.js";import{getDebugLogger as S,createDebugLogger as E,debug as L}from"./lib/ai/dist/debug-logger.js";import{loadMCPConfig as h,saveMCPConfig as A,addMCPServer as B,removeMCPServer as D,getMCPServer as W,listMCPServers as k,listEnabledMCPServers as q}from"./mcp/mcp-config.js";export{o as AgentSession,x as CatuiAgent,v as ExtensionRunner,l as MCPManager,B as addMCPServer,E as createDebugLogger,a as createEventBus,L as debug,m as defaultLogger,d as discoverAndLoadExtensions,n as executeBash,g as executeBashWithOperations,S as getDebugLogger,W as getMCPServer,q as listEnabledMCPServers,k as listMCPServers,h as loadMCPConfig,f as quickAgent,D as removeMCPServer,A as saveMCPConfig,C as silentLogger,M as wrapToolsWithExtensions};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides output-token recovery and token-budget continuation helpers for agent loops.
|
|
3
|
+
* [FROM]: Depends on @catui/ai message types and AgentLoopConfig budget settings.
|
|
4
|
+
* [TO]: Consumed by standard and structured-adaptive agent loops.
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/agent-loop-continuations.ts within agent-core; shared loop continuation policy.
|
|
6
|
+
*/
|
|
7
|
+
import type { AssistantMessage, UserMessage } from "@catui/ai/types";
|
|
8
|
+
import type { AgentLoopConfig } from "./types.js";
|
|
9
|
+
export declare const DEFAULT_OUTPUT_TOKEN_BUDGET_THRESHOLD_PCT = 0.9;
|
|
10
|
+
export declare const DEFAULT_OUTPUT_TOKEN_BUDGET_CONTINUATIONS = 3;
|
|
11
|
+
export declare function computeRecoveryMaxTokens(config: AgentLoopConfig, message: AssistantMessage): number | undefined;
|
|
12
|
+
export declare function createOutputTokenRecoveryMessage(attempt: number): UserMessage;
|
|
13
|
+
export declare function createTokenBudgetContinuation(config: AgentLoopConfig, outputTokens: number, continuationCount: number): {
|
|
14
|
+
message: UserMessage;
|
|
15
|
+
outputTokens: number;
|
|
16
|
+
targetTokens: number;
|
|
17
|
+
} | undefined;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var c=Object.defineProperty;var s=(t,e)=>c(t,"name",{value:e,configurable:!0});const x=.9,p=3;function M(t,e){const a=Math.max(1,Math.floor(t.model.maxTokens||1)),o=t.maxTokens!==void 0?Math.max(1,Math.floor(t.maxTokens)):void 0,n=Math.max(1,Math.floor(e.usage.output||1)),u=o??n,i=Math.max(u+1,Math.ceil(Math.max(u,n)*1.5));return Math.min(a,i)}s(M,"computeRecoveryMaxTokens");function l(t){return{role:"user",content:[{type:"text",text:`Continue the previous response from exactly where it stopped. This is automatic output-token recovery attempt ${t}.`}],timestamp:Date.now()}}s(l,"createOutputTokenRecoveryMessage");function f(t,e,a){const o=t.outputTokenBudget;if(!o)return;const n=Math.max(1,Math.floor(o.targetTokens)),u=d(o.thresholdPct??.9,0,1);if(Math.max(0,Math.floor(o.maxContinuations??3))<=a)return;const r=Math.max(0,Math.floor(e)),T=Math.ceil(n*u);return r>=T?void 0:{message:{role:"user",content:[{type:"text",text:`Continue because the output token budget is underused (${r}/${n} tokens). Add the missing useful detail directly; do not recap or apologize.`}],timestamp:Date.now()},outputTokens:r,targetTokens:n}}s(f,"createTokenBudgetContinuation");function d(t,e,a){return Number.isFinite(t)?Math.min(a,Math.max(e,t)):e}s(d,"clamp");export{p as DEFAULT_OUTPUT_TOKEN_BUDGET_CONTINUATIONS,x as DEFAULT_OUTPUT_TOKEN_BUDGET_THRESHOLD_PCT,M as computeRecoveryMaxTokens,l as createOutputTokenRecoveryMessage,f as createTokenBudgetContinuation};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides waitForAbortableOperation(), waitForAssistantStream(), waitForAssistantStreamEvent()
|
|
3
|
+
* [FROM]: Depends on @catui/ai AssistantMessageEvent/AssistantMessageEventStream contracts.
|
|
4
|
+
* [TO]: Consumed by standard and structured-adaptive agent loops.
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/agent-loop-stream-events.ts within agent-core; shared abortable operation and assistant-stream iterator utilities.
|
|
6
|
+
*/
|
|
7
|
+
import type { AssistantMessageEvent } from "@catui/ai/types";
|
|
8
|
+
import type { AssistantMessageEventStream } from "@catui/ai/events";
|
|
9
|
+
export type AssistantStreamNext = IteratorResult<AssistantMessageEvent> | "aborted";
|
|
10
|
+
export type AssistantStreamStart = AssistantMessageEventStream | "aborted";
|
|
11
|
+
export type AbortableOperationResult<T> = {
|
|
12
|
+
type: "resolved";
|
|
13
|
+
value: T;
|
|
14
|
+
} | {
|
|
15
|
+
type: "aborted";
|
|
16
|
+
};
|
|
17
|
+
export declare function waitForAbortableOperation<T>(valueOrPromise: T | Promise<T>, signal?: AbortSignal): Promise<AbortableOperationResult<T>>;
|
|
18
|
+
export declare function waitForAssistantStream(streamOrPromise: AssistantMessageEventStream | Promise<AssistantMessageEventStream>, signal?: AbortSignal): Promise<AssistantStreamStart>;
|
|
19
|
+
export declare function waitForAssistantStreamEvent(iterator: AsyncIterator<AssistantMessageEvent>, signal?: AbortSignal): Promise<AssistantStreamNext>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var s=Object.defineProperty;var r=(o,e)=>s(o,"name",{value:e,configurable:!0});function u(o,e){return e?.aborted?Promise.resolve({type:"aborted"}):new Promise((t,b)=>{const n=r(()=>{e?.removeEventListener("abort",i)},"cleanup"),i=r(()=>{n(),t({type:"aborted"})},"onAbort");e?.addEventListener("abort",i,{once:!0}),Promise.resolve(o).then(a=>{n(),t({type:"resolved",value:a})},a=>{n(),b(a)})})}r(u,"waitForAbortableOperation");function c(o,e){return u(o,e).then(t=>t.type==="aborted"?"aborted":t.value)}r(c,"waitForAssistantStream");function p(o,e){return e?.aborted?Promise.resolve("aborted"):new Promise((t,b)=>{const n=r(()=>{e?.removeEventListener("abort",i)},"cleanup"),i=r(()=>{n(),t("aborted")},"onAbort");e?.addEventListener("abort",i,{once:!0}),o.next().then(a=>{n(),t(a)},a=>{n(),b(a)})})}r(p,"waitForAssistantStreamEvent");export{u as waitForAbortableOperation,c as waitForAssistantStream,p as waitForAssistantStreamEvent};
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides enforceToolResultBatchSize(), createInterruptedToolResults(), and createSkippedToolCallLimitResults() for bounded and complete tool-result batches.
|
|
3
|
+
* [FROM]: Depends on @catui/ai AssistantMessage/ToolResultMessage/TextContent shapes.
|
|
4
|
+
* [TO]: Consumed by standard and structured-adaptive agent loops before appending tool results.
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/agent-loop-tool-results.ts within agent-core; shared tool-result budget policy.
|
|
6
|
+
*/
|
|
7
|
+
import type { AssistantMessage, ToolResultMessage } from "@catui/ai/types";
|
|
8
|
+
export declare function enforceToolResultBatchSize(toolResults: ToolResultMessage[], maxChars: number | undefined): ToolResultMessage[];
|
|
9
|
+
export declare function createInterruptedToolResults(assistantMessage: AssistantMessage, existingToolResultIds?: ReadonlySet<string>): ToolResultMessage[];
|
|
10
|
+
export declare function createSkippedToolCallLimitResults(assistantMessage: AssistantMessage, reasonText: string): ToolResultMessage[];
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
var x=Object.defineProperty;var a=(t,e)=>x(t,"name",{value:e,configurable:!0});function m(t,e){if(!e||e<=0||t.length===0)return t;const r=Math.floor(e);let n=p(t);if(n<=r)return t;const s=[...t],i=t.map((o,l)=>({index:l,size:d(o.content),isError:o.isError})).filter(o=>o.size>0).sort((o,l)=>o.isError!==l.isError?o.isError?1:-1:l.size-o.size||o.index-l.index);for(const o of i){if(n<=r)break;const l=n-r,c=Math.max(0,o.size-l),u=f(s[o.index],c,r);s[o.index]=u.result,n=n-o.size+u.textChars}return s}a(m,"enforceToolResultBatchSize");function y(t,e=new Set){const r=t.content.filter(i=>i.type==="toolCall");if(r.length===0)return[];const n=t.stopReason,s=n==="aborted"?"Tool call interrupted because the assistant response was aborted.":"Tool call interrupted because the assistant response ended with an error.";return r.filter(i=>!e.has(i.id)).map(i=>({role:"toolResult",toolCallId:i.id,toolName:i.name,content:[{type:"text",text:s}],details:{errorType:"interrupted_tool_call",stopReason:n,errorMessage:t.errorMessage},isError:!0,timestamp:Date.now()}))}a(y,"createInterruptedToolResults");function b(t,e){return t.content.filter(n=>n.type==="toolCall").map(n=>({role:"toolResult",toolCallId:n.id,toolName:n.name,content:[{type:"text",text:e}],details:{errorType:"tool_call_limit_reached",toolName:n.name,toolCallId:n.id},isError:!0,timestamp:Date.now()}))}a(b,"createSkippedToolCallLimitResults");function f(t,e,r){const n=d(t.content);if(n<=e)return{result:t,textChars:n};const s=`[Tool result truncated by batch budget: original ${n} chars.]`;let i="";if(e>0)if(e<=s.length)i=s.slice(0,e);else{const c=`
|
|
2
|
+
|
|
3
|
+
${s}`,u=Math.max(0,e-c.length);i=`${h(t.content).slice(0,u)}${c}`}let o=!1;const l=t.content.map(c=>c.type!=="text"?c:o?{...c,text:""}:(o=!0,{...c,text:i}));return o||l.push({type:"text",text:i}),{result:{...t,content:l,details:{...typeof t.details=="object"&&t.details!==null?t.details:{},truncationReason:"tool_result_batch_budget",originalTextChars:n,retainedTextChars:i.length,maxToolResultBatchSizeChars:r}},textChars:i.length}}a(f,"truncateToolResultToTextChars");function p(t){return t.reduce((e,r)=>e+d(r.content),0)}a(p,"sumToolResultTextChars");function d(t){return t.reduce((e,r)=>e+(r.type==="text"?r.text.length:0),0)}a(d,"sumTextContentChars");function h(t){return t.filter(e=>e.type==="text").map(e=>e.text).join("")}a(h,"flattenTextContent");export{y as createInterruptedToolResults,b as createSkippedToolCallLimitResults,m as enforceToolResultBatchSize};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides PendingToolUseSummary, flushReadyToolUseSummaries(), and startToolUseSummary().
|
|
3
|
+
* [FROM]: Depends on AgentLoopConfig/AgentMessage contracts and tool result message shapes.
|
|
4
|
+
* [TO]: Consumed by standard and structured-adaptive agent loops for non-blocking tool summaries.
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/agent-loop-tool-summaries.ts within agent-core; shared tool summary policy.
|
|
6
|
+
*/
|
|
7
|
+
import type { ToolResultMessage } from "@catui/ai/types";
|
|
8
|
+
import type { EventStream } from "@catui/ai/events";
|
|
9
|
+
import type { AgentEvent, AgentLoopConfig, AgentMessage } from "./types.js";
|
|
10
|
+
export type PendingToolUseSummary = {
|
|
11
|
+
read(): {
|
|
12
|
+
settled: boolean;
|
|
13
|
+
value?: AgentMessage;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
export declare function flushReadyToolUseSummaries(pendingSummaries: PendingToolUseSummary[], currentMessages: AgentMessage[], newMessages: AgentMessage[], stream: EventStream<AgentEvent, AgentMessage[]>): PendingToolUseSummary[];
|
|
17
|
+
export declare function startToolUseSummary(config: AgentLoopConfig, event: {
|
|
18
|
+
assistantMessage: AgentMessage;
|
|
19
|
+
toolResults: ToolResultMessage[];
|
|
20
|
+
contextMessages: AgentMessage[];
|
|
21
|
+
messages: AgentMessage[];
|
|
22
|
+
}): PendingToolUseSummary | undefined;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var l=Object.defineProperty;var r=(e,t)=>l(e,"name",{value:t,configurable:!0});function c(e,t,u,n){if(e.length===0)return e;const a=[];for(const o of e){const s=o.read();if(!s.settled){a.push(o);continue}s.value&&(t.push(s.value),u.push(s.value),n.push({type:"message_start",message:s.value}),n.push({type:"message_end",message:s.value}))}return a}r(c,"flushReadyToolUseSummaries");function i(e,t){if(e.createToolUseSummary)try{const u=e.createToolUseSummary({...t,messages:[...t.messages]});return f(u)}catch{return}}r(i,"startToolUseSummary");function f(e){if(!e)return;if(typeof e.then!="function")return{read:r(()=>({settled:!0,value:e}),"read")};let t=!1,u;return e.then(n=>{t=!0,u=n},()=>{t=!0,u=void 0}),{read:r(()=>({settled:t,value:u}),"read")}}r(f,"trackToolUseSummary");export{c as flushReadyToolUseSummaries,i as startToolUseSummary};
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent loop that works with AgentMessage throughout.
|
|
3
|
+
* Transforms to Message[] only at the LLM call boundary.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* [WHO]: Provides agentLoop(), agentLoopContinue(), standard loop event emission, continuation recovery, recovered-error tombstoning, and serial tool execution.
|
|
7
|
+
* [FROM]: Depends on @catui/ai streams/messages, ./types contracts, ./errors, and shared loop helpers.
|
|
8
|
+
* [TO]: Consumed by agent.ts and package exports as the default agent execution loop.
|
|
9
|
+
* [HERE]: core/lib/agent-core/src/agent-loop.ts within agent-core; standard counterpart to structured-adaptive-agent-loop.ts.
|
|
10
|
+
*/
|
|
11
|
+
import { EventStream } from "@catui/ai/events";
|
|
12
|
+
import type { AgentContext, AgentEvent, AgentLoopConfig, AgentMessage, StreamFn } from "./types.js";
|
|
13
|
+
/**
|
|
14
|
+
* Start an agent loop with a new prompt message.
|
|
15
|
+
* The prompt is added to the context and events are emitted for it.
|
|
16
|
+
*/
|
|
17
|
+
export declare function agentLoop(prompts: AgentMessage[], context: AgentContext, config: AgentLoopConfig, signal?: AbortSignal, streamFn?: StreamFn): EventStream<AgentEvent, AgentMessage[]>;
|
|
18
|
+
/**
|
|
19
|
+
* Continue an agent loop from the current context without adding a new message.
|
|
20
|
+
* Used for retries - context already has user message or tool results.
|
|
21
|
+
*
|
|
22
|
+
* **Important:** The last message in context must convert to a `user` or `toolResult` message
|
|
23
|
+
* via `convertToLlm`. If it doesn't, the LLM provider will reject the request.
|
|
24
|
+
* This cannot be validated here since `convertToLlm` is only called once per turn.
|
|
25
|
+
*/
|
|
26
|
+
export declare function agentLoopContinue(context: AgentContext, config: AgentLoopConfig, signal?: AbortSignal, streamFn?: StreamFn): EventStream<AgentEvent, AgentMessage[]>;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
var se=Object.defineProperty;var h=(e,t)=>se(e,"name",{value:t,configurable:!0});import{EventStream as oe}from"@catui/ai/events";import{isContextOverflow as ae}from"@catui/ai/overflow";import{validateToolArguments as ne}from"@catui/ai/schema";import{streamSimple as re}from"@catui/ai/stream";import{ToolNotFoundError as le,ValidationError as G}from"./errors.js";import{computeRecoveryMaxTokens as ue,createOutputTokenRecoveryMessage as pe,createTokenBudgetContinuation as ie}from"./agent-loop-continuations.js";import{createInterruptedToolResults as me,createSkippedToolCallLimitResults as de,enforceToolResultBatchSize as ce}from"./agent-loop-tool-results.js";import{flushReadyToolUseSummaries as he,startToolUseSummary as ge}from"./agent-loop-tool-summaries.js";import{buildAgentRunPolicy as _e,resolveAgentRunLoopFramework as ye}from"./agent-run-result.js";import{waitForAbortableOperation as U,waitForAssistantStream as fe,waitForAssistantStreamEvent as Re}from"./agent-loop-stream-events.js";const Te=256,ke=512,Me=3,Se=1,be=1;function O(e){if(process.env.CATUI_DEBUG==="1")try{const{appendFileSync:t}=require("fs"),{join:s}=require("path"),{homedir:a}=require("os");t(s(a(),".catui","agent","catui-debug.log"),`[${new Date().toISOString()}] [loop] ${e}
|
|
2
|
+
`)}catch{}}h(O,"_tlog");function Ke(e,t,s,a,o){const i=J();return(async()=>{const p=[...e],n={...t,messages:[...t.messages,...e]};try{i.push({type:"agent_start"}),i.push({type:"turn_start"});for(const d of e)i.push({type:"message_start",message:d}),i.push({type:"message_end",message:d});await Z(n,p,s,a,i,o)}catch(d){Q(i,p,s,d,a)}})(),i}h(Ke,"agentLoop");function Xe(e,t,s,a){if(e.messages.length===0)throw new G("Cannot continue: no messages in context");if(e.messages[e.messages.length-1].role==="assistant")throw new G("Cannot continue from message role: assistant");const o=J();return(async()=>{const i=[],p={...e};try{o.push({type:"agent_start"}),o.push({type:"turn_start"}),await Z(p,i,t,s,o,a)}catch(n){Q(o,i,t,n,s)}})(),o}h(Xe,"agentLoopContinue");function J(){return new oe(e=>e.type==="agent_end",e=>e.type==="agent_end"?e.messages:[])}h(J,"createAgentStream");function x(e,t){return{role:"assistant",content:[{type:"text",text:""}],api:e.model.api,provider:e.model.provider,model:e.model.id,usage:{input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},stopReason:"error",errorMessage:t,timestamp:Date.now()}}h(x,"createLoopLimitMessage");function Q(e,t,s,a,o){const i=x(s,a instanceof Error?a.message:String(a));o?.aborted&&(i.stopReason="aborted"),t.push(i),e.push({type:"message_start",message:{...i}}),e.push({type:"message_end",message:i}),e.push({type:"turn_end",message:i,toolResults:[]}),N(e,t,{config:s,turnCount:0,toolCallCount:0,startedAt:Date.now(),usage:ee(),permissionDenials:[],stopReason:i.stopReason,errorMessage:i.errorMessage,errorSubtype:o?.aborted?"aborted":"loop_error"})}h(Q,"endWithLoopError");async function Z(e,t,s,a,o,i){let p=!0,n=0,d=0;const k=Date.now(),D={loopStart:performance.now(),streamStart:0,firstTokenAt:0,turnCount:0};O("run_loop start");const g=ee(),r=[],T=s.maxTurnsPerPrompt??Te,C=s.maxToolCallsPerPrompt??ke,_=s.maxStopHookContinuations??Me,M=s.maxModelErrorRecoveryAttempts??Se,P=s.maxOutputTokenRecoveryAttempts??be;let S=0,l=0,y=0,c,R={reason:"start"};const E=[],$=h(A=>(R=A,E.push(A),A),"recordTransition");let H=[],B=!1,L=0;const j=await U(s.getSteeringMessages?s.getSteeringMessages():[],a);if(j.type==="aborted"){X(o,e,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,transitions:E,lastTransition:R});return}let v=j.value||[];for(;;){let A=!0,F=null;for(;A||v.length>0;){if(p?p=!1:o.push({type:"turn_start"}),H=he(H,e.messages,t,o),v.length>0){for(const u of v)o.push({type:"message_start",message:u}),o.push({type:"message_end",message:u}),e.messages.push(u),t.push(u);v=[]}if(n++,n>T){const u=x(s,`Stopped after ${T} assistant turns to prevent a runaway agent loop.`);e.messages.push(u),t.push(u),o.push({type:"message_start",message:{...u}}),o.push({type:"message_end",message:u}),o.push({type:"turn_end",message:u,toolResults:[]}),N(o,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,stopReason:u.stopReason,transitions:E,lastTransition:$({reason:"max_turns_reached",maxTurns:T,turnCount:n}),errorMessage:u.errorMessage,errorSubtype:"max_turns_reached"});return}D.turnCount++;const te=t.length,f=await Ce(e,s,a,o,i,c,D);if(ve(g,f.usage),c=void 0,t.push(f),f.stopReason==="error"||f.stopReason==="aborted"){const u=f.stopReason==="aborted"?"aborted":ae(f,s.model.contextWindow)?"context_overflow":"model_error",w=me(f);for(const m of w)e.messages.push(m),t.push(m),o.push({type:"message_start",message:m}),o.push({type:"message_end",message:m});if(f.stopReason==="error"&&s.recoverModelError&&S<M){const m=S+1,b=await s.recoverModelError({message:f,messages:e.messages,errorSubtype:u,attempt:m});if(b.action==="retry"){o.push({type:"turn_end",message:f,toolResults:w}),S=m,t.splice(te),e.messages=b.messages,$(b.transition??{reason:"model_error_recovery",subtype:u,attempt:m});continue}}o.push({type:"turn_end",message:f,toolResults:w}),N(o,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,stopReason:f.stopReason,transitions:E,lastTransition:R,errorMessage:f.errorMessage,errorSubtype:u});return}const I=f.content.filter(u=>u.type==="toolCall");A=I.length>0;const q=[];if(A){if(d+I.length>C){const m=de(f,`Tool call skipped because this prompt reached the ${C} tool-call limit.`);for(const W of m)e.messages.push(W),t.push(W),o.push({type:"message_start",message:W}),o.push({type:"message_end",message:W});const b=x(s,`Stopped before executing ${I.length} tool call${I.length===1?"":"s"} because this prompt reached the ${C} tool-call limit.`);e.messages.push(b),t.push(b),o.push({type:"message_start",message:{...b}}),o.push({type:"message_end",message:b}),o.push({type:"turn_end",message:b,toolResults:m}),N(o,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,stopReason:b.stopReason,transitions:E,lastTransition:$({reason:"tool_call_limit_reached",maxToolCalls:C,requestedToolCalls:I.length,toolCallCount:d}),errorMessage:b.errorMessage,errorSubtype:"tool_call_limit_reached"});return}d+=I.length;const u=await we(e.tools,f,a,o,s.getSteeringMessages,s.canUseTool);q.push(...ce(u.toolResults,s.maxToolResultBatchSizeChars)),r.push(...Ae(u.toolResults)),F=u.steeringMessages??null;for(const m of q)e.messages.push(m),t.push(m),o.push({type:"message_start",message:m}),o.push({type:"message_end",message:m});for(const m of u.contextMessages)e.messages.push(m),t.push(m),o.push({type:"message_start",message:m}),o.push({type:"message_end",message:m});const w=ge(s,{assistantMessage:f,toolResults:q,contextMessages:u.contextMessages,messages:e.messages});w&&H.push(w),$({reason:"tool_result",toolCallCount:I.length})}if(o.push({type:"turn_end",message:f,toolResults:q}),!A&&f.stopReason==="length"&&l<P){l+=1,c=ue(s,f),v=[pe(l)],$({reason:"max_output_tokens_recovery",attempt:l});continue}if(!A&&s.runStopHooks&&!B){B=!0;const u=await U(s.runStopHooks({message:f,messages:e.messages}),a);if(B=!1,u.type==="aborted"){X(o,e,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,transitions:E,lastTransition:R});return}const w=u.value;if(w.action==="continue"&&w.messages.length>0){if(L>=_){const m=x(s,`stop_hook_limit_reached: stopped after ${_} stop-hook continuation turns.`);e.messages.push(m),t.push(m),o.push({type:"message_start",message:{...m}}),o.push({type:"message_end",message:m}),o.push({type:"turn_end",message:m,toolResults:[]}),N(o,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,stopReason:m.stopReason,transitions:E,lastTransition:$({reason:"stop_hook_limit_reached",maxContinuations:_,continuationCount:L}),errorMessage:m.errorMessage,errorSubtype:"stop_hook_limit_reached"});return}L+=1,v=w.messages,$({reason:"stop_hook_blocking",continuationCount:L});continue}}if(!A){const u=ie(s,g.output,y);if(u){y+=1,v=[u.message],$({reason:"token_budget_continuation",continuationCount:y,outputTokens:u.outputTokens,targetTokens:u.targetTokens});continue}}F&&F.length>0?(v=F,F=null):v=await s.getSteeringMessages?.()||[]}const Y=await U(s.getFollowUpMessages?s.getFollowUpMessages():[],a);if(Y.type==="aborted"){X(o,e,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,transitions:E,lastTransition:R});return}const z=Y.value||[];if(z.length>0){v=z,$({reason:"follow_up"});continue}break}N(o,t,{config:s,turnCount:n,toolCallCount:d,startedAt:k,usage:g,permissionDenials:r,stopReason:V(t),transitions:E,lastTransition:R})}h(Z,"runLoop");async function Ce(e,t,s,a,o,i,p){let n=e.messages;if(t.transformContext){const l=await U(t.transformContext(n,s),s);if(l.type==="aborted")return K(e,a,t);n=l.value}const d=await U(t.convertToLlm(n),s);if(d.type==="aborted")return K(e,a,t);const k=d.value,D={systemPrompt:e.systemPrompt,messages:k,tools:e.tools},g=o||re,r=await U(t.getApiKey?t.getApiKey(t.model.provider):void 0,s);if(r.type==="aborted")return K(e,a,t);const T=r.value||t.apiKey;p&&(p.streamStart=performance.now(),O(`stream_request_start model=${t.model.id} provider=${t.model.provider} msgCount=${k.length} maxTokens=${i??t.maxTokens} (+${(p.streamStart-p.loopStart).toFixed(0)}ms from loop_start)`)),a.push({type:"stream_request_start",model:t.model.id,provider:t.model.provider,api:t.model.api,messageCount:k.length,maxTokens:i??t.maxTokens});const C=await fe(g(t.model,D,{...t,maxTokens:i??t.maxTokens,apiKey:T,signal:s}),s);if(C==="aborted"){const l=x(t,"Request was aborted");return l.stopReason="aborted",e.messages.push(l),a.push({type:"message_start",message:{...l}}),a.push({type:"message_end",message:l}),l}let _=null,M=!1;const P=C[Symbol.asyncIterator]();for(;;){let l;try{l=await Re(P,s)}catch(c){const R=x(t,c instanceof Error?c.message:String(c));return M?e.messages[e.messages.length-1]=R:(e.messages.push(R),a.push({type:"message_start",message:{...R}})),a.push({type:"message_end",message:R}),R}if(l==="aborted"){P.return?.();const c=x(t,"Request was aborted");return c.stopReason="aborted",M?e.messages[e.messages.length-1]=c:(e.messages.push(c),a.push({type:"message_start",message:{...c}})),a.push({type:"message_end",message:c}),c}if(l.done)break;const y=l.value;switch(p&&!p.firstTokenAt&&(p.firstTokenAt=performance.now(),O(`first_token ttft=${(p.firstTokenAt-p.streamStart).toFixed(0)}ms (+${(p.firstTokenAt-p.loopStart).toFixed(0)}ms from loop_start)`)),y.type){case"start":_=y.partial,e.messages.push(_),M=!0,a.push({type:"message_start",message:{..._}});break;case"text_start":case"text_delta":case"text_end":case"thinking_start":case"thinking_delta":case"thinking_end":case"toolcall_start":case"toolcall_delta":case"toolcall_end":_&&(_=y.partial,e.messages[e.messages.length-1]=_,a.push({type:"message_update",assistantMessageEvent:y,message:{..._}}));break;case"done":case"error":{const c=y.type==="done"?y.message:y.error;return M?e.messages[e.messages.length-1]=c:e.messages.push(c),M||a.push({type:"message_start",message:{...c}}),a.push({type:"message_end",message:c}),c}}}if(p){const l=performance.now();O(`stream_end duration=${(l-p.streamStart).toFixed(0)}ms total=${(l-p.loopStart).toFixed(0)}ms`)}const S=C.resultIfResolved()??x(t,"Provider stream ended without a final assistant message");return M?e.messages[e.messages.length-1]=S:(e.messages.push(S),a.push({type:"message_start",message:{...S}})),a.push({type:"message_end",message:S}),S}h(Ce,"streamAssistantResponse");function K(e,t,s){const a=x(s,"Request was aborted");return a.stopReason="aborted",e.messages.push(a),t.push({type:"message_start",message:{...a}}),t.push({type:"message_end",message:a}),a}h(K,"pushAbortedAssistantMessage");function X(e,t,s,a){const o=x(a.config,"Request was aborted");o.stopReason="aborted",t.messages.push(o),s.push(o),e.push({type:"message_start",message:{...o}}),e.push({type:"message_end",message:o}),e.push({type:"turn_end",message:o,toolResults:[]}),N(e,s,{...a,stopReason:"aborted",errorMessage:o.errorMessage,errorSubtype:"aborted"})}h(X,"finishStandardLoopWithAbortedTurn");function N(e,t,s){e.push({type:"agent_result",stopReason:s.stopReason??V(t),loopFramework:ye(s.config),loopPolicy:_e(s.config),turnCount:s.turnCount,toolCallCount:s.toolCallCount,durationMs:Date.now()-s.startedAt,usage:s.usage,permissionDenialCount:s.permissionDenials.length,permissionDenials:s.permissionDenials,transitions:s.transitions&&s.transitions.length>0?s.transitions:void 0,lastTransition:s.lastTransition,errorMessage:s.errorMessage,errorSubtype:s.errorSubtype}),O(`loop_finished stopReason=${s.stopReason??V(t)} turns=${s.turnCount} tools=${s.toolCallCount} duration=${Date.now()-s.startedAt}ms`),e.push({type:"agent_end",messages:t}),e.end(t)}h(N,"finishStandardLoop");function ee(){return{input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}}}h(ee,"emptyUsage");function ve(e,t){e.input+=t.input,e.output+=t.output,e.cacheRead+=t.cacheRead,e.cacheWrite+=t.cacheWrite,e.totalTokens+=t.totalTokens,e.cost.input+=t.cost.input,e.cost.output+=t.cost.output,e.cost.cacheRead+=t.cost.cacheRead,e.cost.cacheWrite+=t.cost.cacheWrite,e.cost.total+=t.cost.total}h(ve,"addUsage");function V(e){for(let t=e.length-1;t>=0;t-=1){const s=e[t];if(s?.role==="assistant")return s.stopReason??"stop"}return"stop"}h(V,"inferStopReason");function Ae(e){const t=[];for(const s of e){const a=s.details;if(!a||typeof a!="object"||a.errorType!=="permission_denied")continue;const o=a.reason;t.push({toolCallId:s.toolCallId,toolName:s.toolName,reason:typeof o=="string"&&o.length>0?o:void 0})}return t}h(Ae,"collectPermissionDenials");async function we(e,t,s,a,o,i){const p=t.content.filter(g=>g.type==="toolCall"),n=xe(e),d=[],k=[];let D;for(let g=0;g<p.length;g++){const r=p[g],T=n.get(r.name),C=Date.now();O(`tool_exec_start [${g}] name=${r.name}`),a.push({type:"tool_execution_start",toolCallId:r.id,toolName:r.name,args:r.arguments});let _,M=!1;try{if(!T)throw new le(r.name);const l=ne(T,r),y=await T.validateInput?.(l);if(typeof y=="string"&&y.trim())throw new Error(y);const c=await i?.({toolCallId:r.id,toolName:T.name,requestedToolName:r.name,input:l,rawInput:r.arguments,tool:T});if(c?.decision==="deny"){const R=c.reason?.trim();_={content:[{type:"text",text:R?`Permission denied: ${R}`:`Permission denied for ${T.name}`}],details:{errorType:"permission_denied",reason:R,toolName:T.name,toolCallId:r.id}},M=!0}else _=await T.execute(r.id,l,s,R=>{a.push({type:"tool_execution_update",toolCallId:r.id,toolName:r.name,args:r.arguments,partialResult:R})}),_=$e(_,T.maxResultSizeChars)}catch(l){const y=l instanceof Error?l.message:String(l);_={content:[{type:"text",text:y}],details:Ee(y)?{errorType:"permission_denied",reason:y,toolName:T?.name??r.name,toolCallId:r.id}:{}},M=!0}const P=Date.now()-C;a.push({type:"tool_execution_end",toolCallId:r.id,toolName:r.name,result:_,isError:M,durationMs:P}),O(`tool_exec_end [${g}] name=${r.name} duration=${P}ms`);const S={role:"toolResult",toolCallId:r.id,toolName:r.name,content:_.content,details:_.details,isError:M,timestamp:Date.now()};if(d.push(S),k.push(..._.contextMessages??[]),o){const l=await o();if(l.length>0){D=l;const y=p.slice(g+1);for(const c of y)d.push(De(c,a));break}}}return{toolResults:d,contextMessages:k,steeringMessages:D}}h(we,"executeToolCalls");function xe(e){const t=new Map;for(const s of e??[]){t.set(s.name,s);for(const a of s.aliases??[])t.has(a)||t.set(a,s)}return t}h(xe,"buildToolMap");function Ee(e){return/^Permission (denied|request was cancelled)/i.test(e.trim())}h(Ee,"isPermissionDeniedMessage");function $e(e,t){if(!t||t<=0)return e;let s=Math.floor(t),a=!1;const o=e.content.map(n=>{if(n.type!=="text")return n;if(s<=0)return a=!0,{...n,text:""};if(n.text.length<=s)return s-=n.text.length,n;a=!0;const d=n.text.slice(0,s);return s=0,{...n,text:d}});if(!a)return e;const i=`
|
|
3
|
+
|
|
4
|
+
[Tool result truncated to ${Math.floor(t)} characters.]`;let p=-1;for(let n=o.length-1;n>=0;n-=1)if(o[n]?.type==="text"){p=n;break}if(p>=0){const n=o[p];o[p]={...n,text:`${n.text}${i}`}}else o.push({type:"text",text:i.trimStart()});return{...e,content:o}}h($e,"enforceMaxResultSize");function De(e,t){const s={content:[{type:"text",text:"Skipped due to queued user message."}],details:{}};return t.push({type:"tool_execution_start",toolCallId:e.id,toolName:e.name,args:e.arguments}),t.push({type:"tool_execution_end",toolCallId:e.id,toolName:e.name,result:s,isError:!0}),{role:"toolResult",toolCallId:e.id,toolName:e.name,content:s.content,details:{},isError:!0,timestamp:Date.now()}}h(De,"skipToolCall");export{Ke as agentLoop,Xe as agentLoopContinue};
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides resolveAgentRunLoopFramework(), buildAgentRunPolicy()
|
|
3
|
+
* [FROM]: Depends on AgentLoopConfig, AgentRunPolicy, normalizeAgentLoopFramework
|
|
4
|
+
* [TO]: Consumed by standard and structured-adaptive agent loops
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/agent-run-result.ts - shared result telemetry helpers
|
|
6
|
+
*/
|
|
7
|
+
import type { AgentLoopConfig, AgentLoopFramework, AgentRunPolicy } from "./types.js";
|
|
8
|
+
export declare function resolveAgentRunLoopFramework(config: AgentLoopConfig): AgentLoopFramework;
|
|
9
|
+
export declare function buildAgentRunPolicy(config: AgentLoopConfig): AgentRunPolicy;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var r=Object.defineProperty;var t=(e,o)=>r(e,"name",{value:o,configurable:!0});import{normalizeAgentLoopFramework as u}from"./types.js";function n(e){return u(e.loopFramework)??"standard"}t(n,"resolveAgentRunLoopFramework");function p(e){const o={};return e.maxModelErrorRecoveryAttempts!==void 0&&(o.maxModelErrorRecoveryAttempts=e.maxModelErrorRecoveryAttempts),e.maxOutputTokenRecoveryAttempts!==void 0&&(o.maxOutputTokenRecoveryAttempts=e.maxOutputTokenRecoveryAttempts),e.outputTokenBudget!==void 0&&(o.outputTokenBudget={...e.outputTokenBudget}),e.maxStopHookContinuations!==void 0&&(o.maxStopHookContinuations=e.maxStopHookContinuations),e.maxToolConcurrency!==void 0&&(o.maxToolConcurrency=e.maxToolConcurrency),e.maxToolResultBatchSizeChars!==void 0&&(o.maxToolResultBatchSizeChars=e.maxToolResultBatchSizeChars),e.maxTurnsPerPrompt!==void 0&&(o.maxTurnsPerPrompt=e.maxTurnsPerPrompt),e.maxToolCallsPerPrompt!==void 0&&(o.maxToolCallsPerPrompt=e.maxToolCallsPerPrompt),o}t(p,"buildAgentRunPolicy");export{p as buildAgentRunPolicy,n as resolveAgentRunLoopFramework};
|
|
@@ -0,0 +1,215 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Agent class that uses the agent-loop directly.
|
|
3
|
+
* No transport abstraction - calls streamSimple via the loop.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* [WHO]: AgentOptions, Agent, and loop policy option plumbing
|
|
7
|
+
* [FROM]: Depends on ./agent-loop.js and ./structured-adaptive-agent-loop.js
|
|
8
|
+
* [TO]: Consumed by core/lib/agent-core/src/index.ts
|
|
9
|
+
* [HERE]: core/lib/agent-core/src/agent.ts -
|
|
10
|
+
*/
|
|
11
|
+
import { type ImageContent, type Message, type Model, type ThinkingBudgets, type Transport } from "@catui/ai/types";
|
|
12
|
+
import type { AgentEvent, AgentLoopFramework, AgentLoopFrameworkInput, AgentLoopConfig, AgentMessage, AgentState, AgentTool, StreamFn, ThinkingLevel } from "./types.js";
|
|
13
|
+
export interface AgentOptions {
|
|
14
|
+
initialState?: Partial<AgentState>;
|
|
15
|
+
/**
|
|
16
|
+
* Converts AgentMessage[] to LLM-compatible Message[] before each LLM call.
|
|
17
|
+
* Default filters to user/assistant/toolResult and converts attachments.
|
|
18
|
+
*/
|
|
19
|
+
convertToLlm?: (messages: AgentMessage[]) => Message[] | Promise<Message[]>;
|
|
20
|
+
/**
|
|
21
|
+
* Optional transform applied to context before convertToLlm.
|
|
22
|
+
* Use for context pruning, injecting external context, etc.
|
|
23
|
+
*/
|
|
24
|
+
transformContext?: (messages: AgentMessage[], signal?: AbortSignal) => Promise<AgentMessage[]>;
|
|
25
|
+
/**
|
|
26
|
+
* Steering mode: "all" = send all steering messages at once, "one-at-a-time" = one per turn
|
|
27
|
+
*/
|
|
28
|
+
steeringMode?: "all" | "one-at-a-time";
|
|
29
|
+
/**
|
|
30
|
+
* Follow-up mode: "all" = send all follow-up messages at once, "one-at-a-time" = one per turn
|
|
31
|
+
*/
|
|
32
|
+
followUpMode?: "all" | "one-at-a-time";
|
|
33
|
+
/**
|
|
34
|
+
* Custom stream function (for proxy backends, etc.). Default uses streamSimple.
|
|
35
|
+
*/
|
|
36
|
+
streamFn?: StreamFn;
|
|
37
|
+
/**
|
|
38
|
+
* Optional session identifier forwarded to LLM providers.
|
|
39
|
+
* Used by providers that support session-based caching (e.g., OpenAI Codex).
|
|
40
|
+
*/
|
|
41
|
+
sessionId?: string;
|
|
42
|
+
/**
|
|
43
|
+
* Resolves an API key dynamically for each LLM call.
|
|
44
|
+
* Useful for expiring tokens (e.g., GitHub Copilot OAuth).
|
|
45
|
+
*/
|
|
46
|
+
getApiKey?: (provider: string) => Promise<string | undefined> | string | undefined;
|
|
47
|
+
/**
|
|
48
|
+
* Custom token budgets for thinking levels (token-based providers only).
|
|
49
|
+
*/
|
|
50
|
+
thinkingBudgets?: ThinkingBudgets;
|
|
51
|
+
/**
|
|
52
|
+
* Preferred transport for providers that support multiple transports.
|
|
53
|
+
*/
|
|
54
|
+
transport?: Transport;
|
|
55
|
+
/**
|
|
56
|
+
* Maximum delay in milliseconds to wait for a retry when the server requests a long wait.
|
|
57
|
+
* If the server's requested delay exceeds this value, the request fails immediately,
|
|
58
|
+
* allowing higher-level retry logic to handle it with user visibility.
|
|
59
|
+
* Default: 60000 (60 seconds). Set to 0 to disable the cap.
|
|
60
|
+
*/
|
|
61
|
+
maxRetryDelayMs?: number;
|
|
62
|
+
/**
|
|
63
|
+
* Force a loop framework for all models in this Agent.
|
|
64
|
+
* When omitted, the current model's `agentLoopFramework` setting is used.
|
|
65
|
+
*/
|
|
66
|
+
agentLoopFramework?: AgentLoopFrameworkInput;
|
|
67
|
+
/**
|
|
68
|
+
* Optional tool permission gate used by loop execution.
|
|
69
|
+
*/
|
|
70
|
+
canUseTool?: AgentLoopConfig["canUseTool"];
|
|
71
|
+
/**
|
|
72
|
+
* Optional aggregate tool-result batch budget used by loop execution.
|
|
73
|
+
*/
|
|
74
|
+
maxToolResultBatchSizeChars?: AgentLoopConfig["maxToolResultBatchSizeChars"];
|
|
75
|
+
/**
|
|
76
|
+
* Optional in-loop model error recovery hook used by loop execution.
|
|
77
|
+
*/
|
|
78
|
+
recoverModelError?: AgentLoopConfig["recoverModelError"];
|
|
79
|
+
/** Maximum in-loop model error recoveries per prompt. */
|
|
80
|
+
maxModelErrorRecoveryAttempts?: number;
|
|
81
|
+
/** Maximum automatic output-token recovery turns per prompt. */
|
|
82
|
+
maxOutputTokenRecoveryAttempts?: number;
|
|
83
|
+
/** Optional target for automatic continuation when output is under-complete. */
|
|
84
|
+
outputTokenBudget?: AgentLoopConfig["outputTokenBudget"];
|
|
85
|
+
/** Optional stop hook for validation/correction continuation turns. */
|
|
86
|
+
runStopHooks?: AgentLoopConfig["runStopHooks"];
|
|
87
|
+
/** Maximum stop-hook continuation turns per prompt. */
|
|
88
|
+
maxStopHookContinuations?: number;
|
|
89
|
+
/** Optional non-blocking summary hook for completed tool batches. */
|
|
90
|
+
createToolUseSummary?: AgentLoopConfig["createToolUseSummary"];
|
|
91
|
+
/** Maximum concurrency for concurrency-safe tool batches. */
|
|
92
|
+
maxToolConcurrency?: number;
|
|
93
|
+
/** Maximum assistant turns allowed for one prompt/continue loop. */
|
|
94
|
+
maxTurnsPerPrompt?: number;
|
|
95
|
+
/** Maximum tool calls allowed for one prompt/continue loop. */
|
|
96
|
+
maxToolCallsPerPrompt?: number;
|
|
97
|
+
}
|
|
98
|
+
export type AgentLoopPolicyOptions = Pick<AgentOptions, "canUseTool" | "maxToolResultBatchSizeChars" | "recoverModelError" | "maxModelErrorRecoveryAttempts" | "maxOutputTokenRecoveryAttempts" | "outputTokenBudget" | "runStopHooks" | "maxStopHookContinuations" | "createToolUseSummary" | "maxToolConcurrency" | "maxTurnsPerPrompt" | "maxToolCallsPerPrompt">;
|
|
99
|
+
export declare class Agent {
|
|
100
|
+
private _state;
|
|
101
|
+
private listeners;
|
|
102
|
+
private abortController?;
|
|
103
|
+
private convertToLlm;
|
|
104
|
+
private transformContext?;
|
|
105
|
+
private steeringQueue;
|
|
106
|
+
private followUpQueue;
|
|
107
|
+
private steeringMode;
|
|
108
|
+
private followUpMode;
|
|
109
|
+
streamFn: StreamFn;
|
|
110
|
+
private _sessionId?;
|
|
111
|
+
getApiKey?: (provider: string) => Promise<string | undefined> | string | undefined;
|
|
112
|
+
private runningPrompt?;
|
|
113
|
+
private resolveRunningPrompt?;
|
|
114
|
+
private _thinkingBudgets?;
|
|
115
|
+
private _transport;
|
|
116
|
+
private _maxRetryDelayMs?;
|
|
117
|
+
private _agentLoopFramework?;
|
|
118
|
+
private canUseTool?;
|
|
119
|
+
private maxToolResultBatchSizeChars?;
|
|
120
|
+
private recoverModelError?;
|
|
121
|
+
private maxModelErrorRecoveryAttempts?;
|
|
122
|
+
private maxOutputTokenRecoveryAttempts?;
|
|
123
|
+
private outputTokenBudget?;
|
|
124
|
+
private runStopHooks?;
|
|
125
|
+
private maxStopHookContinuations?;
|
|
126
|
+
private createToolUseSummary?;
|
|
127
|
+
private maxToolConcurrency?;
|
|
128
|
+
private maxTurnsPerPrompt?;
|
|
129
|
+
private maxToolCallsPerPrompt?;
|
|
130
|
+
constructor(opts?: AgentOptions);
|
|
131
|
+
/**
|
|
132
|
+
* Get the current session ID used for provider caching.
|
|
133
|
+
*/
|
|
134
|
+
get sessionId(): string | undefined;
|
|
135
|
+
/**
|
|
136
|
+
* Set the session ID for provider caching.
|
|
137
|
+
* Call this when switching sessions (new session, branch, resume).
|
|
138
|
+
*/
|
|
139
|
+
set sessionId(value: string | undefined);
|
|
140
|
+
/**
|
|
141
|
+
* Get the current thinking budgets.
|
|
142
|
+
*/
|
|
143
|
+
get thinkingBudgets(): ThinkingBudgets | undefined;
|
|
144
|
+
/**
|
|
145
|
+
* Set custom thinking budgets for token-based providers.
|
|
146
|
+
*/
|
|
147
|
+
set thinkingBudgets(value: ThinkingBudgets | undefined);
|
|
148
|
+
/**
|
|
149
|
+
* Get the current preferred transport.
|
|
150
|
+
*/
|
|
151
|
+
get transport(): Transport;
|
|
152
|
+
/**
|
|
153
|
+
* Set the preferred transport.
|
|
154
|
+
*/
|
|
155
|
+
setTransport(value: Transport): void;
|
|
156
|
+
/**
|
|
157
|
+
* Get the current max retry delay in milliseconds.
|
|
158
|
+
*/
|
|
159
|
+
get maxRetryDelayMs(): number | undefined;
|
|
160
|
+
/**
|
|
161
|
+
* Set the maximum delay to wait for server-requested retries.
|
|
162
|
+
* Set to 0 to disable the cap.
|
|
163
|
+
*/
|
|
164
|
+
set maxRetryDelayMs(value: number | undefined);
|
|
165
|
+
get agentLoopFramework(): AgentLoopFramework;
|
|
166
|
+
setAgentLoopFramework(value: AgentLoopFrameworkInput | undefined): void;
|
|
167
|
+
get state(): AgentState;
|
|
168
|
+
subscribe(fn: (e: AgentEvent) => void): () => void;
|
|
169
|
+
setSystemPrompt(v: string): void;
|
|
170
|
+
setModel(m: Model<any>): void;
|
|
171
|
+
setThinkingLevel(l: ThinkingLevel): void;
|
|
172
|
+
setSteeringMode(mode: "all" | "one-at-a-time"): void;
|
|
173
|
+
getSteeringMode(): "all" | "one-at-a-time";
|
|
174
|
+
setFollowUpMode(mode: "all" | "one-at-a-time"): void;
|
|
175
|
+
getFollowUpMode(): "all" | "one-at-a-time";
|
|
176
|
+
setTools(t: AgentTool<any>[]): void;
|
|
177
|
+
setLoopPolicy(options: Partial<AgentLoopPolicyOptions>): void;
|
|
178
|
+
setModelErrorRecovery(recoverModelError: AgentLoopConfig["recoverModelError"] | undefined): void;
|
|
179
|
+
replaceMessages(ms: AgentMessage[]): void;
|
|
180
|
+
appendMessage(m: AgentMessage): void;
|
|
181
|
+
/**
|
|
182
|
+
* Queue a steering message to interrupt the agent mid-run.
|
|
183
|
+
* Delivered after current tool execution, skips remaining tools.
|
|
184
|
+
*/
|
|
185
|
+
steer(m: AgentMessage): void;
|
|
186
|
+
/**
|
|
187
|
+
* Queue a follow-up message to be processed after the agent finishes.
|
|
188
|
+
* Delivered only when agent has no more tool calls or steering messages.
|
|
189
|
+
*/
|
|
190
|
+
followUp(m: AgentMessage): void;
|
|
191
|
+
clearSteeringQueue(): void;
|
|
192
|
+
clearFollowUpQueue(): void;
|
|
193
|
+
clearAllQueues(): void;
|
|
194
|
+
hasQueuedMessages(): boolean;
|
|
195
|
+
private dequeueSteeringMessages;
|
|
196
|
+
private dequeueFollowUpMessages;
|
|
197
|
+
clearMessages(): void;
|
|
198
|
+
abort(): void;
|
|
199
|
+
waitForIdle(): Promise<void>;
|
|
200
|
+
reset(): void;
|
|
201
|
+
/** Send a prompt with an AgentMessage */
|
|
202
|
+
prompt(message: AgentMessage | AgentMessage[]): Promise<void>;
|
|
203
|
+
prompt(input: string, images?: ImageContent[]): Promise<void>;
|
|
204
|
+
/**
|
|
205
|
+
* Continue from current context (used for retries and resuming queued messages).
|
|
206
|
+
*/
|
|
207
|
+
continue(): Promise<void>;
|
|
208
|
+
/**
|
|
209
|
+
* Run the agent loop.
|
|
210
|
+
* If messages are provided, starts a new conversation turn with those messages.
|
|
211
|
+
* Otherwise, continues from existing context.
|
|
212
|
+
*/
|
|
213
|
+
private _runLoop;
|
|
214
|
+
private emit;
|
|
215
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var c=Object.defineProperty;var h=(g,e)=>c(g,"name",{value:e,configurable:!0});import{getModel as f}from"@catui/ai/models";import{streamSimple as y}from"@catui/ai/stream";import{agentLoop as _,agentLoopContinue as T}from"./agent-loop.js";import{structuredAdaptiveAgentLoop as x,structuredAdaptiveAgentLoopContinue as w}from"./structured-adaptive-agent-loop.js";import{normalizeAgentLoopFramework as p}from"./types.js";function k(g){return g.filter(e=>e.role==="user"||e.role==="assistant"||e.role==="toolResult")}h(k,"defaultConvertToLlm");class U{static{h(this,"Agent")}_state={systemPrompt:"",model:f("google","gemini-2.5-flash-lite"),thinkingLevel:"off",tools:[],messages:[],isStreaming:!1,streamMessage:null,pendingToolCalls:new Set,lastResult:void 0,error:void 0};listeners=new Set;abortController;convertToLlm;transformContext;steeringQueue=[];followUpQueue=[];steeringMode;followUpMode;streamFn;_sessionId;getApiKey;runningPrompt;resolveRunningPrompt;_thinkingBudgets;_transport;_maxRetryDelayMs;_agentLoopFramework;canUseTool;maxToolResultBatchSizeChars;recoverModelError;maxModelErrorRecoveryAttempts;maxOutputTokenRecoveryAttempts;outputTokenBudget;runStopHooks;maxStopHookContinuations;createToolUseSummary;maxToolConcurrency;maxTurnsPerPrompt;maxToolCallsPerPrompt;constructor(e={}){this._state={...this._state,...e.initialState},this.convertToLlm=e.convertToLlm||k,this.transformContext=e.transformContext,this.steeringMode=e.steeringMode||"one-at-a-time",this.followUpMode=e.followUpMode||"one-at-a-time",this.streamFn=e.streamFn||y,this._sessionId=e.sessionId,this.getApiKey=e.getApiKey,this._thinkingBudgets=e.thinkingBudgets,this._transport=e.transport??"sse",this._maxRetryDelayMs=e.maxRetryDelayMs,this._agentLoopFramework=p(e.agentLoopFramework),this.canUseTool=e.canUseTool,this.maxToolResultBatchSizeChars=e.maxToolResultBatchSizeChars,this.recoverModelError=e.recoverModelError,this.maxModelErrorRecoveryAttempts=e.maxModelErrorRecoveryAttempts,this.maxOutputTokenRecoveryAttempts=e.maxOutputTokenRecoveryAttempts,this.outputTokenBudget=e.outputTokenBudget,this.runStopHooks=e.runStopHooks,this.maxStopHookContinuations=e.maxStopHookContinuations,this.createToolUseSummary=e.createToolUseSummary,this.maxToolConcurrency=e.maxToolConcurrency,this.maxTurnsPerPrompt=e.maxTurnsPerPrompt,this.maxToolCallsPerPrompt=e.maxToolCallsPerPrompt}get sessionId(){return this._sessionId}set sessionId(e){this._sessionId=e}get thinkingBudgets(){return this._thinkingBudgets}set thinkingBudgets(e){this._thinkingBudgets=e}get transport(){return this._transport}setTransport(e){this._transport=e}get maxRetryDelayMs(){return this._maxRetryDelayMs}set maxRetryDelayMs(e){this._maxRetryDelayMs=e}get agentLoopFramework(){return p(this._agentLoopFramework??this._state.model.agentLoopFramework)??"standard"}setAgentLoopFramework(e){this._agentLoopFramework=p(e)}get state(){return this._state}subscribe(e){return this.listeners.add(e),()=>this.listeners.delete(e)}setSystemPrompt(e){this._state.systemPrompt=e}setModel(e){this._state.model=e}setThinkingLevel(e){this._state.thinkingLevel=e}setSteeringMode(e){this.steeringMode=e}getSteeringMode(){return this.steeringMode}setFollowUpMode(e){this.followUpMode=e}getFollowUpMode(){return this.followUpMode}setTools(e){this._state.tools=e}setLoopPolicy(e){"canUseTool"in e&&(this.canUseTool=e.canUseTool),"maxToolResultBatchSizeChars"in e&&(this.maxToolResultBatchSizeChars=e.maxToolResultBatchSizeChars),"recoverModelError"in e&&(this.recoverModelError=e.recoverModelError),"maxModelErrorRecoveryAttempts"in e&&(this.maxModelErrorRecoveryAttempts=e.maxModelErrorRecoveryAttempts),"maxOutputTokenRecoveryAttempts"in e&&(this.maxOutputTokenRecoveryAttempts=e.maxOutputTokenRecoveryAttempts),"outputTokenBudget"in e&&(this.outputTokenBudget=e.outputTokenBudget),"runStopHooks"in e&&(this.runStopHooks=e.runStopHooks),"maxStopHookContinuations"in e&&(this.maxStopHookContinuations=e.maxStopHookContinuations),"createToolUseSummary"in e&&(this.createToolUseSummary=e.createToolUseSummary),"maxToolConcurrency"in e&&(this.maxToolConcurrency=e.maxToolConcurrency),"maxTurnsPerPrompt"in e&&(this.maxTurnsPerPrompt=e.maxTurnsPerPrompt),"maxToolCallsPerPrompt"in e&&(this.maxToolCallsPerPrompt=e.maxToolCallsPerPrompt)}setModelErrorRecovery(e){this.setLoopPolicy({recoverModelError:e})}replaceMessages(e){this._state.messages=e.slice()}appendMessage(e){this._state.messages=[...this._state.messages,e]}steer(e){this.steeringQueue.push(e)}followUp(e){this.followUpQueue.push(e)}clearSteeringQueue(){this.steeringQueue=[]}clearFollowUpQueue(){this.followUpQueue=[]}clearAllQueues(){this.steeringQueue=[],this.followUpQueue=[]}hasQueuedMessages(){return this.steeringQueue.length>0||this.followUpQueue.length>0}dequeueSteeringMessages(){if(this.steeringMode==="one-at-a-time"){if(this.steeringQueue.length>0){const s=this.steeringQueue[0];return this.steeringQueue=this.steeringQueue.slice(1),[s]}return[]}const e=this.steeringQueue.slice();return this.steeringQueue=[],e}dequeueFollowUpMessages(){if(this.followUpMode==="one-at-a-time"){if(this.followUpQueue.length>0){const s=this.followUpQueue[0];return this.followUpQueue=this.followUpQueue.slice(1),[s]}return[]}const e=this.followUpQueue.slice();return this.followUpQueue=[],e}clearMessages(){this._state.messages=[],this._state.lastResult=void 0}abort(){this.abortController?.abort()}waitForIdle(){return this.runningPrompt??Promise.resolve()}reset(){this._state.messages=[],this._state.isStreaming=!1,this._state.streamMessage=null,this._state.pendingToolCalls=new Set,this._state.lastResult=void 0,this._state.error=void 0,this.steeringQueue=[],this.followUpQueue=[]}async prompt(e,s){if(this._state.isStreaming)throw new Error("Agent is already processing a prompt. Use steer() or followUp() to queue messages, or wait for completion.");if(!this._state.model)throw new Error("No model configured");let l;if(Array.isArray(e))l=e;else if(typeof e=="string"){const i=[{type:"text",text:e}];s&&s.length>0&&i.push(...s),l=[{role:"user",content:i,timestamp:Date.now()}]}else l=[e];await this._runLoop(l)}async continue(){if(this._state.isStreaming)throw new Error("Agent is already processing. Wait for completion before continuing.");const e=this._state.messages;if(e.length===0)throw new Error("No messages to continue from");if(e[e.length-1].role==="assistant"){const s=this.dequeueSteeringMessages();if(s.length>0){await this._runLoop(s,{skipInitialSteeringPoll:!0});return}const r=this.dequeueFollowUpMessages();if(r.length>0){await this._runLoop(r);return}throw new Error("Cannot continue from message role: assistant")}await this._runLoop(void 0)}async _runLoop(e,s){const r=this._state.model;if(!r)throw new Error("No model configured");this.runningPrompt=new Promise(a=>{this.resolveRunningPrompt=a}),this.abortController=new AbortController,this._state.isStreaming=!0,this._state.streamMessage=null,this._state.lastResult=void 0,this._state.error=void 0;const l=this._state.thinkingLevel==="off"?void 0:this._state.thinkingLevel,i={systemPrompt:this._state.systemPrompt,messages:this._state.messages.slice(),tools:this._state.tools};let d=s?.skipInitialSteeringPoll===!0;const m={model:r,loopFramework:this.agentLoopFramework,reasoning:l,sessionId:this._sessionId,transport:this._transport,thinkingBudgets:this._thinkingBudgets,maxRetryDelayMs:this._maxRetryDelayMs,convertToLlm:this.convertToLlm,transformContext:this.transformContext,getApiKey:this.getApiKey,canUseTool:this.canUseTool,maxToolResultBatchSizeChars:this.maxToolResultBatchSizeChars,recoverModelError:this.recoverModelError,maxModelErrorRecoveryAttempts:this.maxModelErrorRecoveryAttempts,maxOutputTokenRecoveryAttempts:this.maxOutputTokenRecoveryAttempts,outputTokenBudget:this.outputTokenBudget,runStopHooks:this.runStopHooks,maxStopHookContinuations:this.maxStopHookContinuations,createToolUseSummary:this.createToolUseSummary,maxToolConcurrency:this.maxToolConcurrency,maxTurnsPerPrompt:this.maxTurnsPerPrompt,maxToolCallsPerPrompt:this.maxToolCallsPerPrompt,getSteeringMessages:h(async()=>d?(d=!1,[]):this.dequeueSteeringMessages(),"getSteeringMessages"),getFollowUpMessages:h(async()=>this.dequeueFollowUpMessages(),"getFollowUpMessages")};let n=null;try{const a=m.loopFramework==="weak-model-compatible",u=e?a?x(e,i,m,this.abortController.signal,this.streamFn):_(e,i,m,this.abortController.signal,this.streamFn):a?w(i,m,this.abortController.signal,this.streamFn):T(i,m,this.abortController.signal,this.streamFn);for await(const t of u){switch(t.type){case"message_start":n=t.message,this._state.streamMessage=t.message;break;case"message_update":n=t.message,this._state.streamMessage=t.message;break;case"message_end":n=null,this._state.streamMessage=null,this.appendMessage(t.message);break;case"tool_execution_start":{const o=new Set(this._state.pendingToolCalls);o.add(t.toolCallId),this._state.pendingToolCalls=o;break}case"tool_execution_end":{const o=new Set(this._state.pendingToolCalls);o.delete(t.toolCallId),this._state.pendingToolCalls=o;break}case"turn_end":t.message.role==="assistant"&&t.message.errorMessage&&(this._state.error=t.message.errorMessage);break;case"agent_result":this._state.lastResult={stopReason:t.stopReason,loopFramework:t.loopFramework,loopPolicy:t.loopPolicy,turnCount:t.turnCount,toolCallCount:t.toolCallCount,durationMs:t.durationMs,usage:t.usage,permissionDenialCount:t.permissionDenialCount,permissionDenials:t.permissionDenials,transitions:t.transitions,lastTransition:t.lastTransition,errorMessage:t.errorMessage,errorSubtype:t.errorSubtype};break;case"agent_end":this._state.isStreaming=!1,this._state.streamMessage=null;break}this.emit(t)}if(n&&n.role==="assistant"&&n.content.length>0){if(!!n.content.some(o=>o.type==="thinking"&&o.thinking.trim().length>0||o.type==="text"&&o.text.trim().length>0||o.type==="toolCall"&&o.name.trim().length>0))this.appendMessage(n);else if(this.abortController?.signal.aborted)throw new Error("Request was aborted")}}catch(a){const u={role:"assistant",content:[{type:"text",text:""}],api:r.api,provider:r.provider,model:r.id,usage:{input:0,output:0,cacheRead:0,cacheWrite:0,totalTokens:0,cost:{input:0,output:0,cacheRead:0,cacheWrite:0,total:0}},stopReason:this.abortController?.signal.aborted?"aborted":"error",errorMessage:a?.message||String(a),timestamp:Date.now()};this.appendMessage(u),this._state.error=a?.message||String(a),this.emit({type:"message_start",message:u}),this.emit({type:"message_end",message:u}),this.emit({type:"agent_end",messages:[u]})}finally{this._state.isStreaming=!1,this._state.streamMessage=null,this._state.pendingToolCalls=new Set,this.abortController=void 0,this.resolveRunningPrompt?.(),this.runningPrompt=void 0,this.resolveRunningPrompt=void 0}}emit(e){for(const s of this.listeners)s(e)}}export{U as Agent};
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: AgentError hierarchy — AgentError, NetworkError, ContextOverflowError, ToolExecutionError, ValidationError, ExtensionError
|
|
3
|
+
* [FROM]: No external dependencies
|
|
4
|
+
* [TO]: Consumed by agent-loop, agent, proxy, and downstream consumers
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/errors.ts - unified error type system
|
|
6
|
+
*/
|
|
7
|
+
/**
|
|
8
|
+
* Base error class for all agent-related errors.
|
|
9
|
+
* Provides structured error info (code, retriable flag) for consistent handling.
|
|
10
|
+
*/
|
|
11
|
+
export declare class AgentError extends Error {
|
|
12
|
+
readonly code: string;
|
|
13
|
+
readonly retriable: boolean;
|
|
14
|
+
readonly details?: unknown;
|
|
15
|
+
constructor(message: string, code: string, retriable?: boolean, details?: unknown);
|
|
16
|
+
}
|
|
17
|
+
export declare class NetworkError extends AgentError {
|
|
18
|
+
readonly statusCode?: number;
|
|
19
|
+
constructor(message: string, statusCode?: number, details?: unknown);
|
|
20
|
+
}
|
|
21
|
+
export declare class RateLimitError extends NetworkError {
|
|
22
|
+
readonly retryAfterMs?: number;
|
|
23
|
+
constructor(message: string, retryAfterMs?: number);
|
|
24
|
+
}
|
|
25
|
+
export declare class TimeoutError extends NetworkError {
|
|
26
|
+
constructor(message: string, details?: unknown);
|
|
27
|
+
}
|
|
28
|
+
export declare class ConnectionError extends NetworkError {
|
|
29
|
+
constructor(message: string, details?: unknown);
|
|
30
|
+
}
|
|
31
|
+
export declare class ContextOverflowError extends AgentError {
|
|
32
|
+
readonly estimatedTokens?: number;
|
|
33
|
+
readonly contextWindow?: number;
|
|
34
|
+
constructor(message: string, estimatedTokens?: number, contextWindow?: number);
|
|
35
|
+
}
|
|
36
|
+
export declare class ToolExecutionError extends AgentError {
|
|
37
|
+
readonly toolName: string;
|
|
38
|
+
readonly toolCallId?: string;
|
|
39
|
+
constructor(message: string, toolName: string, toolCallId?: string);
|
|
40
|
+
}
|
|
41
|
+
export declare class ToolTimeoutError extends ToolExecutionError {
|
|
42
|
+
constructor(toolName: string, toolCallId: string, timeoutMs: number);
|
|
43
|
+
}
|
|
44
|
+
export declare class ToolNotFoundError extends ToolExecutionError {
|
|
45
|
+
constructor(toolName: string);
|
|
46
|
+
}
|
|
47
|
+
export declare class ValidationError extends AgentError {
|
|
48
|
+
constructor(message: string, details?: unknown);
|
|
49
|
+
}
|
|
50
|
+
export declare class ExtensionError extends AgentError {
|
|
51
|
+
readonly extensionName?: string;
|
|
52
|
+
constructor(message: string, extensionName?: string);
|
|
53
|
+
}
|
|
54
|
+
/** Type guard: is the error retriable? */
|
|
55
|
+
export declare function isRetriableError(error: unknown): boolean;
|
|
56
|
+
/** Type guard: is this a context overflow error? */
|
|
57
|
+
export declare function isContextOverflowError(error: unknown): boolean;
|
|
58
|
+
/**
|
|
59
|
+
* Classify an HTTP-like error (status code + message) into the appropriate AgentError subclass.
|
|
60
|
+
* Useful for normalizing raw provider errors into the typed hierarchy.
|
|
61
|
+
*/
|
|
62
|
+
export declare function classifyApiError(statusCode: number | undefined, message: string): AgentError;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var l=Object.defineProperty;var o=(t,r)=>l(t,"name",{value:r,configurable:!0});class s extends Error{static{o(this,"AgentError")}code;retriable;details;constructor(r,e,n=!1,E){super(r),this.name="AgentError",this.code=e,this.retriable=n,this.details=E}}class i extends s{static{o(this,"NetworkError")}statusCode;constructor(r,e,n){super(r,"NETWORK_ERROR",!0,n),this.name="NetworkError",this.statusCode=e}}class a extends i{static{o(this,"RateLimitError")}retryAfterMs;constructor(r,e){super(r,429),this.name="RateLimitError",this.retryAfterMs=e}}class p extends i{static{o(this,"TimeoutError")}constructor(r,e){super(r,void 0,e),this.name="TimeoutError"}}class d extends i{static{o(this,"ConnectionError")}constructor(r,e){super(r,void 0,e),this.name="ConnectionError"}}class c extends s{static{o(this,"ContextOverflowError")}estimatedTokens;contextWindow;constructor(r,e,n){super(r,"CONTEXT_OVERFLOW",!1,{estimatedTokens:e,contextWindow:n}),this.name="ContextOverflowError",this.estimatedTokens=e,this.contextWindow=n}}class u extends s{static{o(this,"ToolExecutionError")}toolName;toolCallId;constructor(r,e,n){super(r,"TOOL_EXECUTION_ERROR",!1,{toolName:e,toolCallId:n}),this.name="ToolExecutionError",this.toolName=e,this.toolCallId=n}}class h extends u{static{o(this,"ToolTimeoutError")}constructor(r,e,n){super(`Tool "${r}" timed out after ${n}ms`,r,e),this.name="ToolTimeoutError"}}class T extends u{static{o(this,"ToolNotFoundError")}constructor(r){super(`Tool "${r}" not found`,r),this.name="ToolNotFoundError"}}class x extends s{static{o(this,"ValidationError")}constructor(r,e){super(r,"VALIDATION_ERROR",!1,e),this.name="ValidationError"}}class m extends s{static{o(this,"ExtensionError")}extensionName;constructor(r,e){super(r,"EXTENSION_ERROR",!1,{extensionName:e}),this.name="ExtensionError",this.extensionName=e}}function R(t){return t instanceof s&&t.retriable}o(R,"isRetriableError");function O(t){return t instanceof c}o(O,"isContextOverflowError");function w(t,r){if(t===429){const e=r.match(/retry[_-]after[:\s]+(\d+)/i),n=e?parseInt(e[1],10)*1e3:void 0;return new a(r,n)}return t===413||t===400&&/context|token|prompt.*too long|overflow/i.test(r)?new c(r):t!==void 0&&t>=500?new i(r,t):t!==void 0&&t>=400?new x(r,{statusCode:t}):new i(r,t)}o(w,"classifyApiError");export{s as AgentError,d as ConnectionError,c as ContextOverflowError,m as ExtensionError,i as NetworkError,a as RateLimitError,p as TimeoutError,u as ToolExecutionError,T as ToolNotFoundError,h as ToolTimeoutError,x as ValidationError,w as classifyApiError,O as isContextOverflowError,R as isRetriableError};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: agent-core barrel exports
|
|
3
|
+
* [FROM]: Depends on agent.js, agent-loop.js, structured-adaptive-agent-loop.js, structured-adaptive-tool-orchestration.js, structured-adaptive-streaming-tool-executor.js, proxy.js, types.js
|
|
4
|
+
* [TO]: Consumed by @catui/agent-core package consumers
|
|
5
|
+
* [HERE]: core/lib/agent-core/src/index.ts - agent-core entry point
|
|
6
|
+
*/
|
|
7
|
+
export * from "./agent.js";
|
|
8
|
+
export * from "./agent-loop.js";
|
|
9
|
+
export * from "./structured-adaptive-agent-loop.js";
|
|
10
|
+
export * from "./structured-adaptive-tool-orchestration.js";
|
|
11
|
+
export * from "./structured-adaptive-streaming-tool-executor.js";
|
|
12
|
+
export * from "./proxy.js";
|
|
13
|
+
export * from "./types.js";
|
|
14
|
+
export * from "./errors.js";
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export*from"./agent.js";export*from"./agent-loop.js";export*from"./structured-adaptive-agent-loop.js";export*from"./structured-adaptive-tool-orchestration.js";export*from"./structured-adaptive-streaming-tool-executor.js";export*from"./proxy.js";export*from"./types.js";export*from"./errors.js";
|