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 _=Object.defineProperty;var c=(s,t)=>_(s,"name",{value:t,configurable:!0});import{BatchingDispatcher as h,InsforgeHttpClient as p,safeHost as m}from"../../../../core/platform/telemetry/index.js";class k{static{c(this,"InsForgeEvalSink")}enabled=!0;http;dispatcher;onDiagnostic;confirmedRuns=new Set;failedRuns=new Set;constructor(t){this.onDiagnostic=t.onDiagnostic,this.http=new p({endpoint:t.endpoint,apiKey:t.apiKey,anonKey:t.anonKey,apiKeyHeader:t.apiKeyHeader,extraHeaders:t.headers,allowSelfSigned:t.allowSelfSigned,source:"sal.eval",onDiagnostic:this.onDiagnostic}),this.dispatcher=new h({handler:c(e=>this.routeEvent(e),"handler"),intervalMs:t.batchIntervalMs??2e3,source:"sal.eval",onDiagnostic:this.onDiagnostic})}async sendEvent(t){this.dispatcher.enqueue(t)}async flush(){await this.dispatcher.flush()}async close(){await this.dispatcher.close()}async routeEvent(t){try{switch(t.event_type){case"run_start":await this.handleRunStart(t);break;case"turn_anchor":await this.ensureRunExists(t)&&await this.handleTurnAnchor(t);break;case"memory_recalls":await this.ensureRunExists(t)&&await this.handleMemoryRecalls(t);break;case"tool_trace":await this.ensureRunExists(t)&&await this.handleToolTrace(t);break;case"run_end":await this.ensureRunExists(t)&&await this.handleRunEnd(t);break}}catch(e){this.reportDiagnostic("persistence",`SAL eval route ${t.event_type} failed.`,e,`route-${t.event_type}`)}}async handleRunStart(t){const e=t.payload,n={run_id:t.run_id,variant:t.variant,status:"running",task_description:r(e.task_description),task_file:r(e.task_file),model:r(e.model),thinking:e.thinking===!0,catui_version:r(e.catui_version),commit_hash:r(e.commit,"unknown"),branch_name:r(e.branch,"unknown"),workspace_root:r(e.workspace_root),started_at:t.ts},a=`${this.http.base}/api/database/records/eval_runs`;if((await this.http.postJson(a,[n],{prefer:"resolution=merge-duplicates",quietErrorCodes:["PGRST204"]})).ok){this.confirmedRuns.add(t.run_id),this.failedRuns.delete(t.run_id);return}if((await this.http.postJson(a,[f(n)],{prefer:"resolution=merge-duplicates"})).ok){this.confirmedRuns.add(t.run_id),this.failedRuns.delete(t.run_id);return}this.failedRuns.add(t.run_id)}async ensureRunExists(t){return this.confirmedRuns.has(t.run_id)||!this.failedRuns.has(t.run_id)&&(await this.handleRunStart({...t,event_type:"run_start",payload:{task_description:r(t.payload.prompt_summary),model:r(t.metadata?.model)??"unknown",thinking:!1,commit:"unknown",branch:"unknown",workspace_root:r(t.metadata?.workspace_root)}}),this.confirmedRuns.has(t.run_id))?!0:(this.reportDiagnostic("persistence",`SAL eval skipped ${t.event_type} because the eval run row is unavailable.`,{run_id:t.run_id,event_type:t.event_type},"missing-run"),!1)}async handleTurnAnchor(t){const e=t.payload,n=e.turn_id,a=e.duration_ms,o=t.ts,l=a!=null?new Date(new Date(t.ts).getTime()-a).toISOString():t.ts;await this.http.postJson(`${this.http.base}/api/database/records/eval_turns?on_conflict=run_id,turn_id`,[{run_id:t.run_id,turn_id:n,event_id:t.event_id,user_prompt:r(e.prompt_summary),duration_ms:a??null,started_at:l,ended_at:o}],{prefer:"resolution=merge-duplicates"});const u=e.task_anchor;u&&await this.http.postJson(`${this.http.base}/api/database/records/eval_sal_anchors?on_conflict=run_id,turn_id,anchor_type`,[{run_id:t.run_id,turn_id:n,event_id:`${t.event_id}-task`,anchor_type:"task",module_path:r(u.modulePath),file_path:r(u.filePath),confidence:i(u.confidence),candidates:e.task_candidates??null,recorded_at:t.ts}],{prefer:"resolution=merge-duplicates"});const d=e.action_anchor;await this.http.postJson(`${this.http.base}/api/database/records/eval_sal_anchors?on_conflict=run_id,turn_id,anchor_type`,[{run_id:t.run_id,turn_id:n,event_id:`${t.event_id}-action`,anchor_type:"action",module_path:r(d?.modulePath),file_path:r(d?.filePath),confidence:i(d?.confidence),touched_files:e.action_files??null,recorded_at:t.ts}],{prefer:"resolution=merge-duplicates"})}async handleRunEnd(t){const e=t.payload,n=r(e.status),a=n==="success"?"completed":n==="error"?"failed":n??"completed";await this.http.patchJson(`${this.http.base}/api/database/records/eval_runs?run_id=eq.${t.run_id}`,{status:a,turn_count:i(e.turn_count),total_duration_ms:i(e.total_duration_ms),ended_at:t.ts})}async handleMemoryRecalls(t){const e=t.payload.recalls;if(!e||e.length===0)return;const n=e.map((a,o)=>({run_id:t.run_id,turn_id:t.payload.turn_id,event_id:`${t.event_id}-${o}`,memory_id:a.memoryId,memory_kind:r(a.memoryKind),score_breakdown_status:r(a.scoreBreakdownStatus),anchor_module:r(a.anchorModule),anchor_file:r(a.anchorFile),score_recency:i(a.scoreRecency),score_importance:i(a.scoreImportance),score_relevance:i(a.scoreRelevance),score_structural:i(a.scoreStructural),score_final:i(a.scoreFinal),was_injected:a.wasInjected===!0,inject_rank:i(a.injectRank),recorded_at:t.ts}));await this.http.postJson(`${this.http.base}/api/database/records/eval_memory_recalls`,n,{prefer:"resolution=ignore-duplicates"})}async handleToolTrace(t){const e=t.payload,n=e.task_signals,a={run_id:t.run_id,turn_id:String(e.turn_id??0),event_id:t.event_id,tool_calls:e.tool_calls?JSON.stringify(e.tool_calls):null,tool_sequence:e.tool_sequence?JSON.stringify(e.tool_sequence):null,intent:r(n?.intent),prompt_length:String(n?.prompt_length??0),has_error_trace:String(n?.has_error_trace===!0),has_file_reference:String(n?.has_file_reference===!0),has_tool_usage:String(e.has_tool_usage===!0),total_tool_calls:String(e.total_tool_calls??0),total_errors:String(e.total_errors??0),completed_tool_calls:String(e.completed_tool_calls??0),truncated_tool_calls:String(e.truncated_tool_calls??0),truncated_tool_summary:String(e.truncated_tool_summary??0),duration_ms:String(e.duration_ms??0),recorded_at:t.ts},o=`${this.http.base}/api/database/records/eval_tool_traces`,l=await this.http.postJson(o,[a],{prefer:"resolution=ignore-duplicates",quietErrorCodes:["PGRST204"]});!l.ok&&l.errorCode==="PGRST204"&&await this.http.postJson(o,[g(a)],{prefer:"resolution=ignore-duplicates"})}reportDiagnostic(t,e,n,a){this.onDiagnostic?.({source:"sal.eval",severity:t==="config"?"warning":"error",category:t,message:e,detail:n,fingerprint:`sal.eval:${t}:${a}`,context:{adapter:"insforge",endpoint_host:m(this.http.base)}})}}function r(s,t){return s==null||s===""||s===t?null:String(s)}c(r,"strOrNull");function i(s){if(s==null)return null;const t=Number(s);return isNaN(t)?null:t}c(i,"numOrNull");function f(s){const{catui_version:t,commit_hash:e,branch_name:n,workspace_root:a,...o}=s;return o}c(f,"toLegacyRunStartRow");function g(s){const{has_tool_usage:t,completed_tool_calls:e,truncated_tool_calls:n,truncated_tool_summary:a,...o}=s;return o}c(g,"toLegacyToolTraceRow");export{k as InsForgeEvalSink};
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides JsonlEvalSink (filesystem append-only adapter)
|
|
3
|
+
* [FROM]: Depends on node:fs, node:path, node:url; ./types.js for EvalSink/EvalEventEnvelope/CreateEvalSinkOptions
|
|
4
|
+
* [TO]: Constructed by eval/index.ts factory when adapter resolves to "jsonl"
|
|
5
|
+
* [HERE]: extensions/builtin/sal/eval/jsonl-sink.ts - offline-friendly sink that appends one JSON object per line; useful for experiments that don't want a live backend, and for capturing replayable event traces
|
|
6
|
+
*
|
|
7
|
+
* Output schema: each line is a serialized EvalEventEnvelope. Downstream tools
|
|
8
|
+
* (analysis scripts, bulk import to InsForge / Postgres / BigQuery) consume the
|
|
9
|
+
* file directly. No transformation is applied — the file is the raw event log.
|
|
10
|
+
*/
|
|
11
|
+
import type { CreateEvalSinkOptions, EvalEventEnvelope, EvalSink } from "./types.js";
|
|
12
|
+
export declare class JsonlEvalSink implements EvalSink {
|
|
13
|
+
readonly enabled = true;
|
|
14
|
+
private filePath;
|
|
15
|
+
private pending;
|
|
16
|
+
private batchIntervalMs;
|
|
17
|
+
private flushTimer;
|
|
18
|
+
private closed;
|
|
19
|
+
private onDiagnostic;
|
|
20
|
+
constructor(options: CreateEvalSinkOptions);
|
|
21
|
+
sendEvent(event: EvalEventEnvelope): Promise<void>;
|
|
22
|
+
flush(): Promise<void>;
|
|
23
|
+
close(): Promise<void>;
|
|
24
|
+
private scheduleFlush;
|
|
25
|
+
private writeLines;
|
|
26
|
+
private reportDiagnostic;
|
|
27
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
var n=Object.defineProperty;var r=(s,e)=>n(s,"name",{value:e,configurable:!0});import{appendFileSync as h,existsSync as l,mkdirSync as a}from"node:fs";import{dirname as c}from"node:path";import{fileURLToPath as o}from"node:url";class g{static{r(this,"JsonlEvalSink")}enabled=!0;filePath;pending=[];batchIntervalMs;flushTimer;closed=!1;onDiagnostic;constructor(e){this.filePath=f(e.endpoint),this.batchIntervalMs=e.batchIntervalMs??2e3,this.onDiagnostic=e.onDiagnostic;const i=c(this.filePath);if(!l(i))try{a(i,{recursive:!0})}catch(t){this.reportDiagnostic("SAL eval JSONL directory could not be created.",{dir:i,error:t.message},"mkdir")}}async sendEvent(e){this.closed||(this.pending.push(e),this.scheduleFlush())}async flush(){this.flushTimer&&(clearTimeout(this.flushTimer),this.flushTimer=void 0);const e=this.pending.splice(0);e.length!==0&&this.writeLines(e)}async close(){this.closed=!0,await this.flush()}scheduleFlush(){this.flushTimer||(this.flushTimer=setTimeout(()=>{this.flushTimer=void 0;const e=this.pending.splice(0);e.length>0&&this.writeLines(e)},this.batchIntervalMs))}writeLines(e){const i=e.map(t=>JSON.stringify(t)).join(`
|
|
2
|
+
`)+`
|
|
3
|
+
`;try{h(this.filePath,i,"utf-8")}catch(t){this.reportDiagnostic("SAL eval JSONL append failed.",{filePath:this.filePath,error:t.message},"append")}}reportDiagnostic(e,i,t){this.onDiagnostic?.({source:"sal.eval",severity:"error",category:"persistence",message:e,detail:i,fingerprint:`sal.eval:persistence:jsonl-${t}`,context:{adapter:"jsonl"}})}}function f(s){return s.startsWith("file://")?o(s):s}r(f,"resolveFilePath");export{g as JsonlEvalSink};
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides noopSink (no-op EvalSink implementation)
|
|
3
|
+
* [FROM]: Depends on ./types.js for EvalSink interface
|
|
4
|
+
* [TO]: Consumed by eval/index.ts factory as the disabled-state default
|
|
5
|
+
* [HERE]: extensions/builtin/sal/eval/noop-sink.ts - silent sink used when eval collection is disabled or no adapter is configured
|
|
6
|
+
*/
|
|
7
|
+
import type { EvalSink } from "./types.js";
|
|
8
|
+
export declare const noopSink: EvalSink;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var a=Object.defineProperty;var n=(s,e)=>a(s,"name",{value:e,configurable:!0});const o={enabled:!1,sendEvent:n(async()=>{},"sendEvent"),flush:n(async()=>{},"flush"),close:n(async()=>{},"close")};export{o as noopSink};
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides EvalVariant, EvalEventType, EvalEventEnvelope, EvalSink, CreateEvalSinkOptions, EvalAdapterId, createEvalEvent
|
|
3
|
+
* [FROM]: Depends on node:crypto for randomUUID
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/eval/{insforge,jsonl,noop}-sink.ts and eval/index.ts factory; re-exported by eval/index.ts barrel
|
|
5
|
+
* [HERE]: extensions/builtin/sal/eval/types.ts - transport-agnostic event types and the EvalSink contract; concrete adapters live in sibling files
|
|
6
|
+
*/
|
|
7
|
+
export type EvalVariant = "sal" | "control" | "baseline" | "self-diagnosis";
|
|
8
|
+
export type EvalEventType = "run_start" | "run_end" | "turn_anchor" | "memory_recalls" | "tool_trace";
|
|
9
|
+
/** Wire format for eval events. Adapter implementations decide how to materialize. */
|
|
10
|
+
export interface EvalEventEnvelope {
|
|
11
|
+
run_id: string;
|
|
12
|
+
event_id: string;
|
|
13
|
+
event_type: EvalEventType;
|
|
14
|
+
variant: EvalVariant;
|
|
15
|
+
ts: string;
|
|
16
|
+
payload: Record<string, unknown>;
|
|
17
|
+
metadata?: Record<string, unknown>;
|
|
18
|
+
}
|
|
19
|
+
export interface EvalSink {
|
|
20
|
+
readonly enabled: boolean;
|
|
21
|
+
sendEvent(event: EvalEventEnvelope): Promise<void>;
|
|
22
|
+
flush(): Promise<void>;
|
|
23
|
+
close(): Promise<void>;
|
|
24
|
+
}
|
|
25
|
+
/** Adapter selector. When omitted, the factory infers from endpoint shape. */
|
|
26
|
+
export type EvalAdapterId = "insforge" | "jsonl" | "noop";
|
|
27
|
+
export interface CreateEvalSinkOptions {
|
|
28
|
+
enabled: boolean;
|
|
29
|
+
/** Explicit adapter selection. When omitted, inferred from endpoint scheme. */
|
|
30
|
+
adapter?: EvalAdapterId;
|
|
31
|
+
/**
|
|
32
|
+
* Adapter-dependent destination:
|
|
33
|
+
* - insforge: HTTPS URL like `https://app.region.insforge.app`
|
|
34
|
+
* - jsonl: Filesystem path or `file://` URL
|
|
35
|
+
*/
|
|
36
|
+
endpoint?: string;
|
|
37
|
+
runId: string;
|
|
38
|
+
/** Custom headers passed through to HTTP adapters. */
|
|
39
|
+
headers?: Record<string, string>;
|
|
40
|
+
/** Ingestion key (ik_…) — InsForge: sent as x-api-key header. */
|
|
41
|
+
apiKey?: string;
|
|
42
|
+
apiKeyHeader?: string;
|
|
43
|
+
/** Anon/JWT key — InsForge PostgREST auth: sent as apikey + Authorization: Bearer. */
|
|
44
|
+
anonKey?: string;
|
|
45
|
+
/** Skip TLS certificate verification (self-signed / private CA). */
|
|
46
|
+
allowSelfSigned?: boolean;
|
|
47
|
+
/** Flush interval ms (default 2000). */
|
|
48
|
+
batchIntervalMs?: number;
|
|
49
|
+
/** Optional extension-owned diagnostic publisher. Eval sinks must not import UI or reporter code. */
|
|
50
|
+
onDiagnostic?: (event: {
|
|
51
|
+
source: string;
|
|
52
|
+
severity: "debug" | "info" | "warning" | "error";
|
|
53
|
+
category: "network" | "fallback" | "persistence" | "config" | "extension_timeout" | "schema" | "unknown";
|
|
54
|
+
message: string;
|
|
55
|
+
detail?: unknown;
|
|
56
|
+
fingerprint?: string;
|
|
57
|
+
context?: Record<string, unknown>;
|
|
58
|
+
}) => void;
|
|
59
|
+
}
|
|
60
|
+
export declare function createEvalEvent(eventType: EvalEventType, runId: string, variant: EvalVariant, payload: Record<string, unknown>, metadata?: Record<string, unknown>): EvalEventEnvelope;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var a=Object.defineProperty;var n=(t,e)=>a(t,"name",{value:e,configurable:!0});import{randomUUID as v}from"node:crypto";function p(t,e,r,o,i={}){return{run_id:e,event_id:v(),event_type:t,variant:r,ts:new Date().toISOString(),payload:o,metadata:i}}n(p,"createEvalEvent");export{p as createEvalEvent};
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: SAL extension entry - enabled by default, registers --nosal/--sal-ab/--sal-rebuild-terrain flags, /sal:coverage /sal:status /sal:setup commands, before_agent_start/tool_execution_start/tool_execution_end/agent_result/agent_end hooks; runtime no-op when --nosal is set
|
|
3
|
+
* [FROM]: Depends on core/extensions-host/types.ts (ToolExecutionStartEvent, ToolExecutionEndEvent), core/runtime/turn-context.ts (publishes structuralAnchor), extensions/builtin/sal/terrain.ts, anchors.ts, weights.ts, eval/index.ts (pluggable adapters)
|
|
4
|
+
* [TO]: Loaded by builtin-extensions.ts as a default extension entry point
|
|
5
|
+
* [HERE]: extensions/builtin/sal/index.ts - pluggable Structural Anchor Localization (SAL) extension; emits run_start/turn_anchor/tool_trace/run_end eval events with best-effort flush/close isolation; tool_trace captures per-turn tool usage and loop outcome for self-awareness analytics
|
|
6
|
+
*/
|
|
7
|
+
import type { ExtensionAPI } from "../../../core/extensions-host/types.js";
|
|
8
|
+
import { SAL_DEFAULT_WEIGHTS } from "./weights.js";
|
|
9
|
+
import { normalizeExperimentId, resolveSalAbEnabled, resolveSalSidecarDir, resolveStaleCleanupEnabled } from "./sal-config.js";
|
|
10
|
+
import { buildToolTracePayload, inferIntent } from "./sal-trace.js";
|
|
11
|
+
export default function salExtension(api: ExtensionAPI): Promise<void>;
|
|
12
|
+
export { SAL_DEFAULT_WEIGHTS, buildToolTracePayload, inferIntent, normalizeExperimentId, resolveSalSidecarDir, resolveSalAbEnabled, resolveStaleCleanupEnabled, };
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
var ce=Object.defineProperty;var c=(t,o)=>ce(t,"name",{value:o,configurable:!0});import{existsSync as de,mkdirSync as ue,writeFileSync as pe}from"node:fs";import{homedir as fe}from"node:os";import{join as $}from"node:path";import{createEvalEvent as J,createEvalSink as z}from"./eval/index.js";import{getTurnContext as he,resetTurnContext as ve,setTurnContext as me}from"../../../core/runtime/turn-context.js";import{locateAction as ge,locateTask as _e}from"./anchors.js";import{buildTerrainIndex as Se,checkDipCoverage as Ae,isSnapshotStale as Y}from"./terrain.js";import{loadSalWeights as ye,SAL_DEFAULT_WEIGHTS as Ee}from"./weights.js";import{BUILD_META as I,EVAL_API_KEY_ENV as we,EVAL_API_KEY_HEADER_ENV as Ce,EVAL_ENDPOINT_ENV as be,EVAL_ENABLED_ENV as ke,EVAL_HEADERS_JSON_ENV as Ie,EVAL_RUN_ID_ENV as Le,EVAL_STALE_CLEANUP_ENV as Re,EVAL_VARIANT_ENV as Pe,isTruthy as X,normalizeExperimentId as De,parseHeadersJson as Te,resolveEvalCredentials as Ne,resolveSalAbEnabled as Q,resolveSalSidecarDir as Z,resolveStaleCleanupEnabled as ee}from"./sal-config.js";import{buildContextInjection as Me,persistTurnRecord as Fe}from"./sal-context.js";import{buildToolTracePayload as te,extractToolFilePaths as xe,inferIntent as $e}from"./sal-trace.js";const ne="nosal",ae="sal-ab",oe="sal-rebuild-terrain",se="diagnostic:event",Oe=[{value:"core/",label:"core/",description:"Check the core runtime files"},{value:"extensions/",label:"extensions/",description:"Check extension files"},{value:"modes/",label:"modes/",description:"Check interactive, print, and RPC mode files"},{value:"packages/",label:"packages/",description:"Check bundled package files"}],Ve=[{value:"https://",label:"https://",description:"Send evaluation records to a hosted endpoint"},{value:"file://",label:"file://",description:"Write evaluation records to a local JSONL file"},{value:"./",label:"./",description:"Write evaluation records to a file in this workspace"}];async function M(t,o){return t.snapshotErrored||t.snapshot&&!o&&!await Y(t.snapshot)?t.snapshot:(t.snapshotPromise||(t.snapshotPromise=(async()=>{try{const f=await Se(t.workspaceRoot);return t.snapshot=f,f}catch(f){t.snapshotErrored=!0,console.error("[sal] terrain index build failed:",f.message);return}finally{t.snapshotPromise=void 0}})()),t.snapshotPromise)}c(M,"ensureSnapshot");async function He(t,o){const f=await M(t,!1);if(!f)return"[sal] terrain snapshot unavailable";const h=Ae(f,o);if(h.length===0)return"[sal] no modules matched the requested filter";const d=["[SAL DIP Coverage]"];for(const p of h){const k=p.coveragePct>=90?"PASS":p.coveragePct>=70?"WARN":"FAIL";d.push(` ${k} ${p.module.padEnd(40)} P3 ${p.filesWithP3}/${p.totalFiles} (${p.coveragePct}%) ${p.hasP2?"P2:Y":"P2:N"} missingFields=${p.missingFields}`)}return d.push(""),d.push("Gate: >=90% PASS, >=70% WARN, otherwise FAIL. Layer 1 experiments require PASS in target modules."),d.join(`
|
|
2
|
+
`)}c(He,"formatCoverageReport");function Ke(t,o){return t.evalVariantOverride?t.evalVariantOverride:o?"sal":"control"}c(Ke,"resolveEvalVariant");async function b(t,o,f,h){if(t.evalEnabled)try{const d=J(o,t.evalRunId,Ke(t,f),h,t.evalMetadata);await t.evalSink.sendEvent(d)}catch(d){t.reportDiagnostic({source:"sal.eval",severity:"error",category:"persistence",message:"SAL eval failed to enqueue an event.",detail:{eventType:o,error:d.message},fingerprint:`sal.eval:persistence:emit-${o}`})}}c(b,"emitEval");async function O(t,o,f,h=6e3){let d;try{await Promise.race([f,new Promise(p=>{d=setTimeout(()=>{t.reportDiagnostic({source:"sal.eval",severity:"warning",category:"extension_timeout",message:`SAL eval ${o} timed out; session shutdown continues.`,fingerprint:`sal.eval:extension_timeout:${o}`}),p()},h)})])}catch(p){t.reportDiagnostic({source:"sal.eval",severity:"error",category:"persistence",message:`SAL eval ${o} failed.`,detail:{error:p.message},fingerprint:`sal.eval:persistence:${o}`})}finally{d&&clearTimeout(d)}}c(O,"evalBestEffort");async function Ue(t){if(!t.evalEndpoint)return;const f=`${t.evalEndpoint.replace(/\/+$/,"")}/api/database/records/eval_runs?status=eq.running&workspace_root=eq.${encodeURIComponent(t.workspaceRoot)}&run_id=neq.${encodeURIComponent(t.evalRunId)}`,h={"Content-Type":"application/json"};t.evalAnonKey&&(h.apikey=t.evalAnonKey,h.Authorization=`Bearer ${t.evalAnonKey}`),t.evalApiKey&&(h[t.evalApiKeyHeader??"x-api-key"]=t.evalApiKey,t.evalAnonKey||(h.Authorization=`Bearer ${t.evalApiKey}`)),Object.assign(h,t.evalHeaders);const d=JSON.stringify({status:"abandoned",ended_at:new Date().toISOString()}),{request:p}=await import("node:https"),{request:k}=await import("node:http"),{URL:C}=await import("node:url"),g=new C(f),u=g.protocol==="https:",L=u?p:k,R=g.port?Number(g.port):u?443:80;return new Promise(E=>{const _=L({hostname:g.hostname,port:R,path:g.pathname+g.search,method:"PATCH",headers:{...h,"Content-Length":Buffer.byteLength(d)},timeout:5e3,...u&&t.evalAllowSelfSigned?{rejectUnauthorized:!1}:{}},P=>{P.resume(),P.on("end",()=>E())});_.on("error",()=>E()),_.on("timeout",()=>{_.destroy(),E()}),_.write(d),_.end()})}c(Ue,"cleanupStaleRuns");async function qe(t){t.registerFlag(ne,{type:"boolean",description:"Turn off SAL workspace guidance for this run",default:!1}),t.registerFlag(ae,{type:"boolean",description:"Save local SAL comparison records under .memory-experiments",default:!1}),t.registerFlag(oe,{type:"boolean",description:"Refresh SAL's workspace map before the next turn",default:!1});const o=t.cwd,f=process.env.CATUI_EXPERIMENT_ID,h=Z(o,f),d=[o,$(o,".memory-experiments","sal")],{weights:p,source:k}=ye(d),C=process.env[Le]??`np-${new Date().toISOString().replace(/[:.]/g,"-").slice(0,19)}-${Math.random().toString(36).slice(2,8)}`,g=c(n=>t.events.emit(se,{...n,context:{...n.context??{},version:I.version,commit_hash:I.commitHash,session_id:C}}),"reportDiagnostic"),u=Ne(o,g),L=process.env[ke],R=L!==void 0?X(L):void 0,E=process.env[be]??u?.insforge_url??u?.endpoint,_=process.env[Pe],P=_==="control"||_==="sal"||_==="baseline"||_==="self-diagnosis"?_:void 0,V=process.env[we]??u?.api_key,H=process.env.CATUI_EVAL_ANON_KEY??u?.anon_key,K=process.env[Ce]??u?.api_key_header,D=process.env.CATUI_EVAL_ADAPTER,U=D==="insforge"||D==="jsonl"||D==="noop"?D:u?.adapter,q={...u?.headers??{},...Te(process.env[Ie],g)},re=!!(u?.endpoint??u?.insforge_url)&&!!u?.api_key&&u?.enabled!==!1,B=R===!1?!1:re||R===!0;B&&!E&&t.events.emit(se,{source:"sal.eval",severity:"warning",category:"config",message:"SAL eval is enabled but no endpoint was found; eval upload is disabled.",fingerprint:"sal.eval:config:missing-endpoint",context:{version:I.version,commit_hash:I.commitHash,session_id:C}});const W=X(process.env.CATUI_EVAL_ALLOW_SELF_SIGNED)||(u?.allow_self_signed??!1),ie=ee(process.env[Re],u),j=z({enabled:B&&!!E,adapter:U,endpoint:E,runId:C,headers:q,apiKey:V,anonKey:H,apiKeyHeader:K,allowSelfSigned:W,onDiagnostic:g}),e={workspaceRoot:o,weights:p,weightsSource:k,turn:{turnId:0,startedAtMs:Date.now(),touchedFiles:new Set,toolCalls:[]},sidecarDir:h,evalSink:j,evalAdapter:U,evalEndpoint:E,evalApiKey:V,evalAnonKey:H,evalApiKeyHeader:K,evalHeaders:q,evalAllowSelfSigned:W,evalEnabled:j.enabled,evalRunId:C,evalVariantOverride:P,evalStartedAtMs:Date.now(),evalRunStarted:!1,turnCounter:0,allowStaleCleanup:ie,evalMetadata:{workspace_root:o,session_id:C},buildMeta:I,staleCleanupDone:!1,pendingRebuild:!1,reportDiagnostic:g},m=c(()=>!t.getFlag(ne),"isEnabled"),F=c(()=>Q(t.getFlag(ae)),"isSalAbEnabled");t.registerCommand("sal:coverage",{description:"Check whether folders have the file map headers SAL needs. Usage: /sal:coverage [folder ...]",getArgumentCompletions:c((n,i)=>{const s=new Set(i?.previousTokens??[]),a=n.trim().toLowerCase(),r=Oe.filter(l=>!s.has(l.value)&&l.value.startsWith(a));return r.length>0?r:null},"getArgumentCompletions"),handler:c(async(n,i)=>{const s=(n??"").trim().split(/\s+/).filter(r=>r.length>0),a=await He(e,s);i.ui.notify(a,"info"),t.sendMessage({customType:"sal_coverage_report",content:a,display:!0,details:{modules:s,weightsSource:e.weightsSource}})},"handler")}),t.registerCommand("sal:setup",{description:"Connect evaluation records to a hosted endpoint or local JSONL file. Usage: /sal:setup <endpoint> [api_key] [anon_key].",getArgumentCompletions:c((n,i)=>{if(i&&i.tokenIndex>0)return null;const s=n.trim().toLowerCase(),a=Ve.filter(r=>r.value.startsWith(s));return a.length>0?a:null},"getArgumentCompletions"),handler:c(async(n,i)=>{const s=(n??"").trim().split(/\s+/).filter(w=>w.length>0),a=s[0],r=s[1],l=s[2];if(!a){i.ui.notify(`[SAL Setup] Usage: /sal:setup <endpoint> [api_key] [anon_key]
|
|
3
|
+
- InsForge: /sal:setup https://app.region.insforge.app ik_xxx [anon_jwt]
|
|
4
|
+
- Local JSONL: /sal:setup /path/to/eval-events.jsonl`,"error");return}const v=/^https?:\/\//i.test(a)?"insforge":a.startsWith("file://")||a.startsWith("/")||a.startsWith("./")||a.startsWith("../")?"jsonl":"insforge";if(v==="insforge"&&!r){i.ui.notify("[SAL Setup] InsForge adapter requires <api_key>","error");return}const A=$(fe(),".memory-experiments"),y=$(A,"credentials.json");try{de(A)||ue(A,{recursive:!0});const w={adapter:v,endpoint:a,enabled:!0};r&&(w.api_key=r),l&&(w.anon_key=l),v==="insforge"&&(w.allow_self_signed=!0),pe(y,JSON.stringify(w,null,2),"utf-8")}catch(w){i.ui.notify(`[SAL Setup] Failed to write credentials: ${w.message}`,"error");return}e.evalAdapter=v,e.evalEndpoint=a,e.evalApiKey=r,e.evalAnonKey=l;const N=z({enabled:!0,adapter:v,endpoint:a,runId:e.evalRunId,headers:e.evalHeaders,apiKey:r,anonKey:l,apiKeyHeader:e.evalApiKeyHeader,allowSelfSigned:v==="insforge"});e.evalSink=N,e.evalEnabled=!0,i.ui.notify(`[SAL Setup] Testing ${v} sink\u2026`,"info");const S=J("run_start",e.evalRunId,"sal",{_probe:!0,workspace_root:e.workspaceRoot,model:"unknown",thinking:!1,commit:"unknown",branch:"unknown"},e.evalMetadata);await N.sendEvent(S),await N.flush(),i.ui.notify(`[SAL Setup] Credentials saved to ${y}
|
|
5
|
+
Eval collection active. run_id: ${e.evalRunId}
|
|
6
|
+
Check terminal output for any HTTP errors from the probe request.`,"info")},"handler")}),t.registerCommand("sal:status",{description:"Show whether SAL is active and where its records are going",handler:c(async(n,i)=>{const s=m(),a=e.snapshot,r=e.evalEndpoint?e.evalEndpoint.replace(/^(https?:\/\/[^/]{0,20}).*/,"$1\u2026"):"(not configured \u2014 use /sal:setup <endpoint> <api_key>)",l=["[SAL Status]",` SAL: ${s?"ON (default)":"OFF (--nosal)"}`,` SAL A/B sidecar: ${F()?"ON (--sal-ab)":"OFF"}`,` eval: ${e.evalEnabled?"ON":"OFF"}`,` adapter: ${e.evalAdapter??"(inferred at sink creation)"}`,` endpoint: ${r}`,` run_id: ${e.evalRunId}`,` workspaceRoot: ${e.workspaceRoot}`,` weightsSource: ${e.weightsSource}`,` snapshotGeneratedAt: ${a?new Date(a.generatedAt).toISOString():"(not built)"}`,` nodes: ${a?.nodes.length??0}`,` sidecarDir: ${F()?e.sidecarDir:"(disabled; use --sal-ab)"}`];i.ui.notify(l.join(`
|
|
7
|
+
`),"info")},"handler")}),t.on("before_agent_start",async(n,i)=>{if(await new Promise(y=>setImmediate(y)),ve(),e.turnCounter+=1,e.turn={turnId:e.turnCounter,startedAtMs:Date.now(),touchedFiles:new Set,toolCalls:[],prompt:n.prompt},!e.evalRunStarted&&e.evalEnabled&&(e.evalRunStarted=!0,e.evalMetadata.model=e.evalMetadata.model??i.model?.id??i.model?.name,b(e,"run_start",m(),{task_description:(n.prompt??"").slice(0,500),task_file:process.env.CATUI_EXPERIMENT_TASK_FILE,model:e.evalMetadata.model??"unknown",thinking:!1,catui_version:e.buildMeta.version,commit:process.env.CATUI_EVAL_COMMIT??e.buildMeta.commitHash??"unknown",branch:process.env.CATUI_EVAL_BRANCH??e.buildMeta.branch??"unknown",workspace_root:e.workspaceRoot}),le()),!m())return;const s=(n.prompt??"").trim();if(s.length<12)return;const a=e.snapshot;if(!a)return;t.getFlag(oe)&&(e.pendingRebuild=!0);const r=_e({prompt:s,cwd:e.workspaceRoot,snapshot:a,weights:e.weights});e.turn.taskResolution=r;const l=r.selected,v=r.candidates.slice(0,4).flatMap(y=>[y.anchor.modulePath,y.anchor.filePath].filter(Boolean));(l||v.length>0)&&me("structuralAnchor",{modulePath:l?.modulePath,filePath:l?.filePath,candidatePaths:v});const A=Me(r,a);if(A)return{appendSystemPrompt:A}}),t.on("tool_execution_start",async(n,i)=>{const s=xe(n.toolName,n.args,e.workspaceRoot);for(const a of s)e.turn.touchedFiles.add(a);e.turn.toolCalls.push({toolCallId:n.toolCallId,tool:n.toolName,startMs:Date.now()})}),t.on("tool_execution_end",async(n,i)=>{const s=e.turn.toolCalls.find(a=>a.toolCallId===n.toolCallId);s&&(s.endMs=Date.now(),s.isError=n.isError)}),t.on("agent_result",async(n,i)=>{e.turn.agentResult={stopReason:n.stopReason,turnCount:n.turnCount,toolCallCount:n.toolCallCount,durationMs:n.durationMs,usage:n.usage,permissionDenialCount:n.permissionDenialCount,permissionDenials:n.permissionDenials,lastTransition:n.lastTransition,errorMessage:n.errorMessage,errorSubtype:n.errorSubtype}}),t.on("agent_end",async(n,i)=>{const s=Math.max(0,Date.now()-e.turn.startedAtMs),a=e.turn.taskResolution,r=e.snapshot;let l;m()&&r&&(l=ge({touchedFiles:Array.from(e.turn.touchedFiles),snapshot:r}));const v=a?.selected?.modulePath??a?.selected?.filePath??null,A=l?.selected?.modulePath??l?.selected?.filePath??null,y=!!(v&&A&&v===A);if(await b(e,"turn_anchor",m(),{turn_id:e.turn.turnId,prompt_summary:(e.turn.prompt??"").slice(0,200),task_anchor:a?.selected??null,task_candidates:(a?.candidates??[]).slice(0,3).map(S=>S.anchor.modulePath??S.anchor.filePath??null),action_files:Array.from(e.turn.touchedFiles).slice(0,10),action_anchor:l?.selected??null,hit:y,sal_enabled:m(),duration_ms:s}),(e.turn.prompt??"").trim().length>=12){const S=he("memoryRecallSnapshot");S&&S.length>0&&await b(e,"memory_recalls",m(),{turn_id:e.turn.turnId,recalls:S})}if(await b(e,"tool_trace",m(),te(e.turn,s)),F()&&l&&Fe(e,a,l),e.turn={turnId:e.turn.turnId,startedAtMs:Date.now(),touchedFiles:new Set,toolCalls:[]},m()){const S=e.pendingRebuild;e.pendingRebuild=!1,(async()=>{try{S?await M(e,!0):e.snapshot&&await Y(e.snapshot)&&await M(e,!0)}catch{}})()}}),t.on("session_shutdown",async()=>{process.off("beforeExit",x),process.off("SIGHUP",T),process.off("SIGTERM",T),e.evalEnabled&&(await b(e,"run_end",m(),{status:"completed",turn_count:e.turnCounter,total_duration_ms:Math.max(0,Date.now()-e.evalStartedAtMs)}),await O(e,"flush",e.evalSink.flush()),await O(e,"close",e.evalSink.close()))});let G=!1;const x=c(()=>{G||!e.evalEnabled||!e.evalRunStarted||(G=!0,b(e,"run_end",m(),{status:"interrupted",turn_count:e.turnCounter,total_duration_ms:Math.max(0,Date.now()-e.evalStartedAtMs)}).then(()=>O(e,"emergency flush",e.evalSink.flush())).catch(()=>{}))},"emergencyFlush");process.on("beforeExit",x);const T=c(()=>{x()},"signalFlush");process.on("SIGHUP",T),process.on("SIGTERM",T);function le(){e.staleCleanupDone||!e.evalEnabled||!e.evalEndpoint||!e.allowStaleCleanup||(e.staleCleanupDone=!0,setImmediate(()=>{Ue(e).catch(()=>{})}))}c(le,"scheduleStaleCleanup"),setImmediate(()=>{m()&&M(e,!1).catch(()=>{})})}c(qe,"salExtension");export{Ee as SAL_DEFAULT_WEIGHTS,te as buildToolTracePayload,qe as default,$e as inferIntent,De as normalizeExperimentId,Q as resolveSalAbEnabled,Z as resolveSalSidecarDir,ee as resolveStaleCleanupEnabled};
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides SAL build metadata, eval env constants, credential loading, and sidecar path resolution
|
|
3
|
+
* [FROM]: Depends on node fs/os/path/url and eval adapter type for local credential normalization
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/index.ts and tests that validate SAL experiment/config behavior
|
|
5
|
+
* [HERE]: extensions/builtin/sal/sal-config.ts - configuration and path boundary for Structural Anchor Localization
|
|
6
|
+
*/
|
|
7
|
+
import type { EvalAdapterId } from "./eval/index.js";
|
|
8
|
+
import type { BuildMeta, SalDiagnosticReporter } from "./sal-runtime.js";
|
|
9
|
+
export declare const SAL_AB_ENV = "CATUI_SAL_AB";
|
|
10
|
+
export declare const EVAL_ENABLED_ENV = "CATUI_EVAL_ENABLED";
|
|
11
|
+
export declare const EVAL_ENDPOINT_ENV = "CATUI_EVAL_ENDPOINT";
|
|
12
|
+
export declare const EVAL_RUN_ID_ENV = "CATUI_EVAL_RUN_ID";
|
|
13
|
+
export declare const EVAL_VARIANT_ENV = "CATUI_EVAL_VARIANT";
|
|
14
|
+
export declare const EVAL_LEGACY_FILE_ENV = "CATUI_EVAL_LEGACY_FILE";
|
|
15
|
+
export declare const EVAL_API_KEY_ENV = "CATUI_EVAL_API_KEY";
|
|
16
|
+
export declare const EVAL_API_KEY_HEADER_ENV = "CATUI_EVAL_API_KEY_HEADER";
|
|
17
|
+
export declare const EVAL_HEADERS_JSON_ENV = "CATUI_EVAL_HEADERS_JSON";
|
|
18
|
+
export declare const EVAL_CREDENTIALS_FILE_ENV = "CATUI_EVAL_CREDENTIALS_FILE";
|
|
19
|
+
export declare const EVAL_STALE_CLEANUP_ENV = "CATUI_EVAL_CLEANUP_STALE_RUNS";
|
|
20
|
+
export interface EvalCredentials {
|
|
21
|
+
insforge_url?: string;
|
|
22
|
+
endpoint?: string;
|
|
23
|
+
api_key?: string;
|
|
24
|
+
anon_key?: string;
|
|
25
|
+
api_key_header?: string;
|
|
26
|
+
headers?: Record<string, string>;
|
|
27
|
+
enabled?: boolean;
|
|
28
|
+
allow_self_signed?: boolean;
|
|
29
|
+
cleanup_stale_runs?: boolean;
|
|
30
|
+
/** Adapter selector. When omitted, inferred from endpoint scheme (http -> insforge, file/path -> jsonl). */
|
|
31
|
+
adapter?: EvalAdapterId;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Delegate to the shared core/platform/telemetry/build-meta loader so SAL eval, the
|
|
35
|
+
* ext-events sink, and any future telemetry consumer all stamp identical
|
|
36
|
+
* catui_version / commit_hash on emitted rows.
|
|
37
|
+
*/
|
|
38
|
+
export declare function loadBuildMeta(): BuildMeta;
|
|
39
|
+
export declare const BUILD_META: BuildMeta;
|
|
40
|
+
export declare function resolveStaleCleanupEnabled(envValue: string | undefined, credentials: EvalCredentials | undefined): boolean;
|
|
41
|
+
export declare function isTruthy(value: unknown): boolean;
|
|
42
|
+
export declare function parseHeadersJson(raw: string | undefined, reportDiagnostic?: SalDiagnosticReporter): Record<string, string>;
|
|
43
|
+
export declare function resolveEvalCredentials(workspaceRoot: string, reportDiagnostic?: SalDiagnosticReporter): EvalCredentials | undefined;
|
|
44
|
+
export declare function normalizeExperimentId(experimentId?: string): string | undefined;
|
|
45
|
+
export declare function resolveSalSidecarDir(workspaceRoot: string, experimentId?: string): string;
|
|
46
|
+
export declare function resolveSalAbEnabled(flagValue: unknown): boolean;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var i=Object.defineProperty;var n=(e,r)=>i(e,"name",{value:r,configurable:!0});import{join as _}from"node:path";import{loadBuildMeta as a,loadInsforgeCredentials as c}from"../../../core/platform/telemetry/index.js";const l="CATUI_SAL_AB",N="CATUI_EVAL_ENABLED",x="CATUI_EVAL_ENDPOINT",C="CATUI_EVAL_RUN_ID",T="CATUI_EVAL_VARIANT",S="CATUI_EVAL_LEGACY_FILE",m="CATUI_EVAL_API_KEY",U="CATUI_EVAL_API_KEY_HEADER",u="CATUI_EVAL_HEADERS_JSON",L="CATUI_EVAL_CREDENTIALS_FILE",g="CATUI_EVAL_CLEANUP_STALE_RUNS";function p(){return a()}n(p,"loadBuildMeta");const D=p();function v(e,r){return e!==void 0?s(e):r?.cleanup_stale_runs===!0}n(v,"resolveStaleCleanupEnabled");function s(e){return e===!0?!0:typeof e!="string"||!e?!1:["1","true","yes","on"].includes(e.toLowerCase())}n(s,"isTruthy");function y(e,r){if(!e)return{};try{const t=JSON.parse(e);if(!t||typeof t!="object")return{};const o={};for(const[A,E]of Object.entries(t))typeof E=="string"&&(o[A]=E);return o}catch{return r?.({source:"sal.eval",severity:"warning",category:"config",message:`SAL eval ignored invalid JSON in ${u}.`,fingerprint:"sal.eval:config:invalid-headers-json"}),{}}}n(y,"parseHeadersJson");function R(e,r){const t=process.env[L];return c(e,"sal.eval",r,t)??void 0}n(R,"resolveEvalCredentials");function f(e){const r=(e??"").trim();return r?r.replace(/[^a-zA-Z0-9-_/.\s]/g," ").replace(/[\/\s]+/g,"-").replace(/-+/g,"-").replace(/^-|-$/g,"").toLowerCase()||"run":void 0}n(f,"normalizeExperimentId");function P(e,r){const t=f(r);return t?_(e,".memory-experiments","runs",t,"sal","anchors"):_(e,".memory-experiments","sal","anchors")}n(P,"resolveSalSidecarDir");function B(e){return s(e)||s(process.env[l])}n(B,"resolveSalAbEnabled");export{D as BUILD_META,m as EVAL_API_KEY_ENV,U as EVAL_API_KEY_HEADER_ENV,L as EVAL_CREDENTIALS_FILE_ENV,N as EVAL_ENABLED_ENV,x as EVAL_ENDPOINT_ENV,u as EVAL_HEADERS_JSON_ENV,S as EVAL_LEGACY_FILE_ENV,C as EVAL_RUN_ID_ENV,g as EVAL_STALE_CLEANUP_ENV,T as EVAL_VARIANT_ENV,l as SAL_AB_ENV,s as isTruthy,p as loadBuildMeta,f as normalizeExperimentId,y as parseHeadersJson,R as resolveEvalCredentials,B as resolveSalAbEnabled,P as resolveSalSidecarDir,v as resolveStaleCleanupEnabled};
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides SAL system-prompt context injection and sidecar turn-record persistence
|
|
3
|
+
* [FROM]: Depends on node fs/path, SAL anchors, terrain snapshots, and SalRuntime state
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/index.ts during before_agent_start and agent_end hooks
|
|
5
|
+
* [HERE]: extensions/builtin/sal/sal-context.ts - context formatting and local sidecar persistence for Structural Anchor Localization
|
|
6
|
+
*/
|
|
7
|
+
import type { AnchorResolution } from "./anchors.js";
|
|
8
|
+
import type { TerrainSnapshot } from "./terrain.js";
|
|
9
|
+
import type { SalRuntime } from "./sal-runtime.js";
|
|
10
|
+
export declare function buildContextInjection(resolution: AnchorResolution, snapshot: TerrainSnapshot): string | undefined;
|
|
11
|
+
export declare function persistTurnRecord(runtime: SalRuntime, taskRes: AnchorResolution | undefined, actionRes: AnchorResolution): void;
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
var p=Object.defineProperty;var a=(e,t)=>p(e,"name",{value:t,configurable:!0});import{existsSync as g,mkdirSync as m,writeFileSync as S}from"node:fs";import{join as y}from"node:path";const A=800,f=.25;function P(e){return Math.ceil(e.length*f)}a(P,"approxTokens");function k(e,t){const n=[];let o=0;for(const i of e){const s=P(i);if(o+s>t){const d=Math.max(0,t-o);if(d>20){const u=Math.floor(d/f);n.push(`${i.slice(0,u)}...`)}break}n.push(i),o+=s}return n.join(`
|
|
2
|
+
`)}a(k,"truncateForBudget");function O(e,t){if(!e.selected||e.candidates.length===0)return;const n=e.candidates[0],o=n.anchor,s=`Likely task region: ${o.modulePath||o.filePath||"<root>"} (confidence ${o.confidence.toFixed(2)})`,d=n.reasons.slice(0,3).map(r=>` - ${r}`),u=e.candidates.slice(1,4).map(r=>` - ${r.anchor.modulePath||r.anchor.filePath||"<root>"} (${r.score.toFixed(2)})`),h=t.nodes.find(r=>(r.kind==="module"||r.kind==="root")&&(r.modulePath??"")===(o.modulePath??"")),l=h?.p2Summary?`Module brief: ${h.p2Summary}`:void 0,c=["[SAL Anchor]",s];return l&&c.push(l),d.length>0&&(c.push("Evidence:"),c.push(...d)),u.length>0&&(c.push("Alternative anchors:"),c.push(...u)),c.push("Use this anchor as a structural prior. If the prompt actually targets a different region, override it from tool evidence."),k(c,A)}a(O,"buildContextInjection");function x(e){if(!g(e.sidecarDir))try{m(e.sidecarDir,{recursive:!0})}catch{}}a(x,"ensureSidecarDir");function E(e,t,n){x(e);const o=new Date().toISOString().replace(/[:.]/g,"-"),i=y(e.sidecarDir,`turn-${o}.json`),s={generatedAt:new Date().toISOString(),workspaceRoot:e.workspaceRoot,weightsSource:e.weightsSource,prompt:e.turn.prompt?.slice(0,500),taskAnchor:t?.selected,taskCandidates:t?.candidates.slice(0,3),taskUnresolved:t?.unresolvedSignals,actionAnchor:n.selected,actionCandidates:n.candidates.slice(0,3),touchedFiles:Array.from(e.turn.touchedFiles)};try{S(i,JSON.stringify(s,null,2),"utf-8")}catch{}}a(E,"persistTurnRecord");export{O as buildContextInjection,E as persistTurnRecord};
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides BuildMeta, ToolCallRecord, TurnState, SalDiagnosticReporter, SalRuntime shared contracts for the SAL extension
|
|
3
|
+
* [FROM]: Depends on eval sink types, SAL anchors/terrain/weights types for runtime state shape
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/index.ts plus SAL config, trace, and context helpers
|
|
5
|
+
* [HERE]: extensions/builtin/sal/sal-runtime.ts - runtime contract boundary for Structural Anchor Localization modules, including per-turn loop outcome state
|
|
6
|
+
*/
|
|
7
|
+
import type { CreateEvalSinkOptions, EvalAdapterId, EvalSink, EvalVariant } from "./eval/index.js";
|
|
8
|
+
import type { AgentRunResult } from "@catui/agent-core";
|
|
9
|
+
import type { AnchorResolution } from "./anchors.js";
|
|
10
|
+
import type { TerrainSnapshot } from "./terrain.js";
|
|
11
|
+
import type { SalWeights } from "./weights.js";
|
|
12
|
+
export interface BuildMeta {
|
|
13
|
+
version: string;
|
|
14
|
+
commitHash?: string;
|
|
15
|
+
branch?: string;
|
|
16
|
+
}
|
|
17
|
+
export interface ToolCallRecord {
|
|
18
|
+
toolCallId: string;
|
|
19
|
+
tool: string;
|
|
20
|
+
startMs: number;
|
|
21
|
+
endMs?: number;
|
|
22
|
+
isError?: boolean;
|
|
23
|
+
}
|
|
24
|
+
export interface TurnState {
|
|
25
|
+
turnId: number;
|
|
26
|
+
startedAtMs: number;
|
|
27
|
+
taskResolution?: AnchorResolution;
|
|
28
|
+
agentResult?: AgentRunResult;
|
|
29
|
+
touchedFiles: Set<string>;
|
|
30
|
+
toolCalls: ToolCallRecord[];
|
|
31
|
+
prompt?: string;
|
|
32
|
+
}
|
|
33
|
+
export type SalDiagnosticReporter = NonNullable<CreateEvalSinkOptions["onDiagnostic"]>;
|
|
34
|
+
export interface SalRuntime {
|
|
35
|
+
workspaceRoot: string;
|
|
36
|
+
snapshot?: TerrainSnapshot;
|
|
37
|
+
snapshotErrored?: boolean;
|
|
38
|
+
/**
|
|
39
|
+
* In-flight terrain build. Deduplicates concurrent ensureSnapshot callers so
|
|
40
|
+
* we never kick off two scans at once (e.g. a prewarm and the first turn).
|
|
41
|
+
*/
|
|
42
|
+
snapshotPromise?: Promise<TerrainSnapshot | undefined>;
|
|
43
|
+
weights: SalWeights;
|
|
44
|
+
weightsSource: string;
|
|
45
|
+
turn: TurnState;
|
|
46
|
+
sidecarDir: string;
|
|
47
|
+
evalSink: EvalSink;
|
|
48
|
+
evalAdapter?: EvalAdapterId;
|
|
49
|
+
evalEndpoint?: string;
|
|
50
|
+
evalApiKey?: string;
|
|
51
|
+
evalAnonKey?: string;
|
|
52
|
+
evalApiKeyHeader?: string;
|
|
53
|
+
evalHeaders: Record<string, string>;
|
|
54
|
+
evalAllowSelfSigned: boolean;
|
|
55
|
+
evalEnabled: boolean;
|
|
56
|
+
evalRunId: string;
|
|
57
|
+
evalVariantOverride?: EvalVariant;
|
|
58
|
+
evalStartedAtMs: number;
|
|
59
|
+
evalRunStarted: boolean;
|
|
60
|
+
turnCounter: number;
|
|
61
|
+
allowStaleCleanup: boolean;
|
|
62
|
+
evalMetadata: {
|
|
63
|
+
workspace_root: string;
|
|
64
|
+
session_id: string;
|
|
65
|
+
model?: string;
|
|
66
|
+
};
|
|
67
|
+
buildMeta: BuildMeta;
|
|
68
|
+
staleCleanupDone: boolean;
|
|
69
|
+
/** Set by before_agent_start when --sal-rebuild-terrain is active; consumed by agent_end. */
|
|
70
|
+
pendingRebuild: boolean;
|
|
71
|
+
reportDiagnostic: SalDiagnosticReporter;
|
|
72
|
+
}
|
|
File without changes
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: Provides SAL tool-path extraction, task intent inference, and bounded tool_trace payload construction
|
|
3
|
+
* [FROM]: Depends on node path helpers and terrain path normalization
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/index.ts and SAL tool trace tests
|
|
5
|
+
* [HERE]: extensions/builtin/sal/sal-trace.ts - per-turn tool and loop-outcome analytics boundary for Structural Anchor Localization
|
|
6
|
+
*/
|
|
7
|
+
import type { TurnState } from "./sal-runtime.js";
|
|
8
|
+
export type TaskIntent = "fix" | "feat" | "refactor" | "explain" | "explore" | "unknown";
|
|
9
|
+
export declare function extractToolFilePaths(toolName: string, args: unknown, workspaceRoot: string): string[];
|
|
10
|
+
export declare function inferIntent(prompt: string): TaskIntent;
|
|
11
|
+
export declare function buildToolTracePayload(turn: TurnState, turnDuration: number): Record<string, unknown>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var u=Object.defineProperty;var p=(t,n)=>u(t,"name",{value:n,configurable:!0});import{isAbsolute as m,join as d,relative as _}from"node:path";import{toPosixPath as h}from"./terrain.js";const g=32,b=16;function f(t,n){if(!n)return;const l=m(n)?n:d(t,n),o=_(t,l);if(!(o.startsWith("..")||o===""))return h(o)}p(f,"workspaceRelativePath");function w(t,n,l){if(!n||typeof n!="object")return[];const o=n,c=[],a=[];if(typeof o.file_path=="string"&&a.push(o.file_path),typeof o.path=="string"&&a.push(o.path),Array.isArray(o.paths))for(const r of o.paths)typeof r=="string"&&a.push(r);for(const r of a){const i=f(l,r);i&&c.push(i)}if(t==="bash"&&typeof o.command=="string"){const r=o.command.match(/[\w./-]+\.(?:ts|tsx|js|jsx|md|json)/g)??[];for(const i of r){const e=f(l,i);e&&c.push(e)}}return c}p(w,"extractToolFilePaths");const x=[["fix",[/\b(fix|bug|error|issue|broken|crash|fail|wrong|debug|patch|repair)\b/i,/(修复|报错|问题|异常|崩溃|失败|错误)/]],["refactor",[/\b(refactor|rename|extract|move|split|merge|clean\s?up|restructure)\b/i,/(重构|整理|拆分|重命名|抽取)/]],["explain",[/\b(explain|how does|what is|why does|understand|read|review|audit|tell me|describe)\b/i,/(解释|为什么|怎么|什么|看一下|看下|评审|核审|说明)/]],["feat",[/\b(add|implement|create|build|new|feature|support|enable|integrate)\b/i,/(增加|新增|实现|添加|功能|支持|接入)/]],["explore",[/\b(find|search|look for|where|locate|explore|check|investigate|list)\b/i,/(查找|找|搜|在哪|检查|排查)/]]];function M(t){if(!t||t.length<4)return"unknown";for(const[n,l]of x)for(const o of l)if(o.test(t))return n;return"unknown"}p(M,"inferIntent");function R(t,n){const l=new Map;let o=0;for(const e of t.toolCalls){const s=l.get(e.tool)??{count:0,errors:0,totalMs:0,completed:0};s.count+=1,e.isError&&(s.errors+=1,o+=1),e.endMs!=null&&(s.totalMs+=e.endMs-e.startMs,s.completed+=1),l.set(e.tool,s)}const c=Array.from(l.entries()).sort((e,s)=>s[1].count-e[1].count||e[0].localeCompare(s[0])).slice(0,b).map(([e,s])=>({tool:e,count:s.count,errors:s.errors,avg_ms:s.completed>0?Math.round(s.totalMs/s.completed):null,completed_calls:s.completed})),a=t.toolCalls.slice(0,g).map(e=>e.tool),r=t.toolCalls.filter(e=>e.endMs!=null).length,i={turn_id:t.turnId,tool_calls:c,tool_sequence:a,task_signals:{prompt_length:(t.prompt??"").length,has_error_trace:/\b(error|exception|stack\s?trace|traceback|panic)\b/i.test(t.prompt??""),has_file_reference:/[\w./-]+\.(ts|tsx|js|jsx|py|go|rs|md|json)/.test(t.prompt??""),intent:M(t.prompt??"")},has_tool_usage:t.toolCalls.length>0,total_tool_calls:t.toolCalls.length,total_errors:o,completed_tool_calls:r,truncated_tool_calls:Math.max(0,t.toolCalls.length-a.length),truncated_tool_summary:Math.max(0,l.size-c.length),duration_ms:n};return t.agentResult&&(i.agent_loop={stop_reason:t.agentResult.stopReason,turn_count:t.agentResult.turnCount,tool_call_count:t.agentResult.toolCallCount,duration_ms:t.agentResult.durationMs,permission_denial_count:t.agentResult.permissionDenialCount??0,last_transition_reason:t.agentResult.lastTransition?.reason}),i}p(R,"buildToolTracePayload");export{R as buildToolTracePayload,w as extractToolFilePaths,M as inferIntent};
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: TerrainNode, TerrainEdge, TerrainSnapshot, buildTerrainIndex(), checkDipCoverage(), CoverageReport
|
|
3
|
+
* [FROM]: Depends on node:fs/promises, node:path
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/anchors.ts, extensions/builtin/sal/index.ts
|
|
5
|
+
* [HERE]: extensions/builtin/sal/terrain.ts - terrain graph builder from DIP P2/P3 headers
|
|
6
|
+
*/
|
|
7
|
+
export type TerrainNodeKind = "root" | "module" | "file";
|
|
8
|
+
export interface TerrainNode {
|
|
9
|
+
id: string;
|
|
10
|
+
kind: TerrainNodeKind;
|
|
11
|
+
label: string;
|
|
12
|
+
modulePath?: string;
|
|
13
|
+
filePath?: string;
|
|
14
|
+
p3Who?: string;
|
|
15
|
+
p3From?: string;
|
|
16
|
+
p3To?: string;
|
|
17
|
+
p3Here?: string;
|
|
18
|
+
hasP3: boolean;
|
|
19
|
+
p2Summary?: string;
|
|
20
|
+
mtimeMs: number;
|
|
21
|
+
}
|
|
22
|
+
export interface TerrainEdge {
|
|
23
|
+
fromId: string;
|
|
24
|
+
toId: string;
|
|
25
|
+
type: "contains" | "adjacent-to";
|
|
26
|
+
}
|
|
27
|
+
export interface TerrainSnapshot {
|
|
28
|
+
workspaceRoot: string;
|
|
29
|
+
generatedAt: number;
|
|
30
|
+
nodes: TerrainNode[];
|
|
31
|
+
edges: TerrainEdge[];
|
|
32
|
+
moduleByFile: Record<string, string>;
|
|
33
|
+
}
|
|
34
|
+
export interface CoverageReport {
|
|
35
|
+
module: string;
|
|
36
|
+
totalFiles: number;
|
|
37
|
+
filesWithP3: number;
|
|
38
|
+
coveragePct: number;
|
|
39
|
+
hasP2: boolean;
|
|
40
|
+
missingFields: number;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Build a terrain index from a workspace root.
|
|
44
|
+
* Coarse, file/module-level only. Symbol-level deferred.
|
|
45
|
+
*
|
|
46
|
+
* Async by design: walks the filesystem and reads DIP headers without blocking
|
|
47
|
+
* the Node event loop, so TUI render frames (e.g. the user's message bubble
|
|
48
|
+
* queued via process.nextTick right before session.prompt()) can flush between
|
|
49
|
+
* fs operations. A synchronous implementation holds stdout long enough that
|
|
50
|
+
* GPU block terminals (Warp) coalesce a whole turn into a single block and
|
|
51
|
+
* only render it when the turn ends.
|
|
52
|
+
*/
|
|
53
|
+
export declare function buildTerrainIndex(workspaceRoot: string): Promise<TerrainSnapshot>;
|
|
54
|
+
/**
|
|
55
|
+
* Check DIP coverage for the requested module list.
|
|
56
|
+
* Each module string is a posix-style path relative to workspace root, e.g. "core/runtime".
|
|
57
|
+
* If modules is empty, all known modules are reported.
|
|
58
|
+
*/
|
|
59
|
+
export declare function checkDipCoverage(snapshot: TerrainSnapshot, modules: string[]): CoverageReport[];
|
|
60
|
+
/**
|
|
61
|
+
* Determine whether the snapshot is stale relative to current DIP files.
|
|
62
|
+
* Returns true when any AGENT.md (or legacy CLAUDE.md) or source file mtime exceeds snapshot.generatedAt.
|
|
63
|
+
*
|
|
64
|
+
* Async to avoid blocking the event loop during the staleness probe that runs
|
|
65
|
+
* at the top of every before_agent_start hook.
|
|
66
|
+
*/
|
|
67
|
+
export declare function isSnapshotStale(snapshot: TerrainSnapshot): Promise<boolean>;
|
|
68
|
+
/**
|
|
69
|
+
* Look up the module id that contains a given relative file path.
|
|
70
|
+
* Used by action evidence accumulation to map touched files back to anchors.
|
|
71
|
+
*/
|
|
72
|
+
export declare function moduleIdForPath(snapshot: TerrainSnapshot, relPath: string): string | undefined;
|
|
73
|
+
export declare function toPosixPath(p: string): string;
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
var W=Object.defineProperty;var m=(e,o)=>W(e,"name",{value:o,configurable:!0});import{readdir as F,readFile as I,stat as x}from"node:fs/promises";import{join as y,relative as E,sep as S}from"node:path";async function M(){await new Promise(e=>setImmediate(e))}m(M,"yieldToEventLoop");const k=new Set(["node_modules",".git","dist","build",".next",".cache","coverage",".memory-experiments",".catui",".catui","out",".turbo"]),O=new Set([".ts",".tsx",".js",".jsx",".mts",".cts"]),D=["AGENT.md","CLAUDE.md"];function T(e){for(const o of D)if(e===o||e.endsWith(`/${o}`))return o}m(T,"dipModuleMapFileName");function b(e){return e.split(S).join("/")}m(b,"toPosix");async function v(e){const o=[],l=[],r=[e];let c=0;for(;r.length>0;){const n=r.pop();if(!n)break;let i;try{i=await F(n,{withFileTypes:!0})}catch{continue}const s=[];for(const u of i)if(!(u.name.startsWith(".")&&u.name!=="."&&(u.isDirectory()&&k.has(u.name)||u.isDirectory()))){if(u.isDirectory()){if(k.has(u.name))continue;const t=y(n,u.name),f=b(E(e,t));s.push(x(t).then(d=>{l.push({abs:t,rel:f,mtimeMs:d.mtimeMs}),r.push(t)},()=>{l.push({abs:t,rel:f,mtimeMs:0}),r.push(t)}))}else if(u.isFile()){const t=y(n,u.name),f=b(E(e,t));s.push(x(t).then(d=>{o.push({abs:t,rel:f,mtimeMs:d.mtimeMs})},()=>{o.push({abs:t,rel:f,mtimeMs:0})}))}}await Promise.all(s),++c%16===0&&await M()}return{files:o,dirs:l}}m(v,"walkAsync");const L=/\/\*\*([\s\S]*?)\*\//;function N(e){const o=e.match(L);if(!o)return;const l=o[1];if(!/\[WHO\]|\[FROM\]|\[TO\]|\[HERE\]/.test(l))return;const r=l.split(`
|
|
2
|
+
`).map(i=>i.replace(/^\s*\*\s?/,"").trim()),c={};let n;for(const i of r){const s=i.match(/^\[(WHO|FROM|TO|HERE)\]:\s*(.*)$/);s?(n=s[1].toLowerCase(),c[n]=s[2].trim()):n&&i.length>0&&(c[n]=`${c[n]??""} ${i}`.trim())}return c}m(N,"parseP3Header");function R(e){const o=e.split(`
|
|
3
|
+
`);let l=!1;const r=[];for(const c of o){if(/^##\s+Overview/i.test(c)){l=!0;continue}if(l&&(/^##\s+/.test(c)||(c.trim().length>0&&r.push(c.trim()),r.join(" ").length>400)))break}if(r.length>0)return r.join(" ").slice(0,400);for(const c of o){const n=c.trim();if(n&&!(n.startsWith("#")||n.startsWith(">")))return n.slice(0,400)}}m(R,"parseP2Summary");async function H(e){const{files:o}=await v(e),l=[],r=[],c={},n=new Map,i=[];let s=0;for(const t of o){const f=T(t.rel);if(!f)continue;const d=t.rel===f?"":t.rel.slice(0,t.rel.length-f.length-1);let a;try{const P=await I(t.abs,"utf-8");a=R(P)}catch{}const h=d||"<root>",p={id:h,kind:d?"module":"root",label:d||"<root>",modulePath:d||void 0,p2Summary:a,hasP3:!1,mtimeMs:t.mtimeMs};n.set(h,p),l.push(p),++s%32===0&&await M()}let u=0;for(const t of o){const f=t.rel.lastIndexOf(".");if(f<0)continue;const d=t.rel.slice(f);if(!O.has(d))continue;let a;try{const w=await I(t.abs,"utf-8");a=N(w)}catch{}let h="<root>",p=-1;for(const w of n.values()){const g=w.modulePath??"";g===""&&p<0&&(h="<root>"),g&&t.rel.startsWith(`${g}/`)&&g.length>p&&(h=w.id,p=g.length)}const P={id:t.rel,kind:"file",label:t.rel,modulePath:n.get(h)?.modulePath,filePath:t.rel,p3Who:a?.who,p3From:a?.from,p3To:a?.to,p3Here:a?.here,hasP3:!!a,mtimeMs:t.mtimeMs};i.push(P),l.push(P),c[P.id]=h,r.push({fromId:h,toId:P.id,type:"contains"}),++u%32===0&&await M()}return{workspaceRoot:e,generatedAt:Date.now(),nodes:l,edges:r,moduleByFile:c}}m(H,"buildTerrainIndex");function j(e,o){const l=[],r=o.length>0?o:null,c=e.nodes.filter(i=>i.kind==="module"||i.kind==="root").map(i=>i.modulePath??""),n=r??c;for(const i of n){const s=e.nodes.find(a=>(a.kind==="module"||a.kind==="root")&&(a.modulePath??"")===i),u=e.nodes.filter(a=>a.kind==="file"&&(a.modulePath??"")===i),t=u.length,f=u.filter(a=>a.hasP3).length,d=u.filter(a=>a.hasP3&&(!a.p3Who||!a.p3From||!a.p3To||!a.p3Here)).length;l.push({module:i||"<root>",totalFiles:t,filesWithP3:f,coveragePct:t===0?0:Math.round(f/t*1e3)/10,hasP2:!!s,missingFields:d})}return l}m(j,"checkDipCoverage");async function B(e){const o=[e.workspaceRoot];let l=0;for(;o.length>0;){const r=o.pop();if(!r)break;let c;try{c=await F(r,{withFileTypes:!0})}catch{continue}const n=[];for(const s of c){if(s.isDirectory()){if(k.has(s.name)||s.name.startsWith("."))continue;o.push(y(r,s.name));continue}if(!s.isFile())continue;const u=D.includes(s.name),t=s.name.lastIndexOf("."),f=t>=0?s.name.slice(t):"";!u&&!O.has(f)||n.push(y(r,s.name))}const i=await Promise.all(n.map(s=>x(s).then(u=>u.mtimeMs,()=>0)));for(const s of i)if(s>e.generatedAt)return!0;++l%16===0&&await M()}return!1}m(B,"isSnapshotStale");function $(e,o){const l=b(o);if(e.moduleByFile[l])return e.moduleByFile[l];let r,c=-1;for(const n of e.nodes){if(n.kind!=="module")continue;const i=n.modulePath??"";i&&l.startsWith(`${i}/`)&&i.length>c&&(r=n.id,c=i.length)}return r}m($,"moduleIdForPath");function U(e){return b(e)}m(U,"toPosixPath");export{H as buildTerrainIndex,j as checkDipCoverage,B as isSnapshotStale,$ as moduleIdForPath,U as toPosixPath};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* [WHO]: SalWeights interface, SAL_DEFAULT_WEIGHTS, loadSalWeights()
|
|
3
|
+
* [FROM]: Depends on node:fs, node:path
|
|
4
|
+
* [TO]: Consumed by extensions/builtin/sal/anchors.ts and extensions/builtin/sal/index.ts
|
|
5
|
+
* [HERE]: extensions/builtin/sal/weights.ts - tunable scoring weight loader
|
|
6
|
+
*/
|
|
7
|
+
export interface SalWeights {
|
|
8
|
+
directFileEvidence: number;
|
|
9
|
+
moduleResponsibilityMatch: number;
|
|
10
|
+
dipContractMatch: number;
|
|
11
|
+
importNeighborhoodMatch: number;
|
|
12
|
+
memoryHistoryMatch: number;
|
|
13
|
+
semanticScore: number;
|
|
14
|
+
recencyScore: number;
|
|
15
|
+
importanceScore: number;
|
|
16
|
+
structuralSalience: number;
|
|
17
|
+
proceduralApplicability: number;
|
|
18
|
+
}
|
|
19
|
+
export declare const SAL_DEFAULT_WEIGHTS: SalWeights;
|
|
20
|
+
/**
|
|
21
|
+
* Load SalWeights from sal-config.json adjacent to the memory directory or project root.
|
|
22
|
+
* Falls back to defaults if file is missing or invalid. Unknown fields are ignored;
|
|
23
|
+
* missing fields fall back individually to defaults.
|
|
24
|
+
*/
|
|
25
|
+
export declare function loadSalWeights(searchDirs: string[]): {
|
|
26
|
+
weights: SalWeights;
|
|
27
|
+
source: string;
|
|
28
|
+
};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var p=Object.defineProperty;var s=(t,o)=>p(t,"name",{value:o,configurable:!0});import{existsSync as u,readFileSync as f}from"node:fs";import{join as l}from"node:path";const c={directFileEvidence:.4,moduleResponsibilityMatch:.2,dipContractMatch:.15,importNeighborhoodMatch:.15,memoryHistoryMatch:.1,semanticScore:.25,recencyScore:.15,importanceScore:.15,structuralSalience:.3,proceduralApplicability:.15};function S(t){for(const o of t){const r=l(o,"sal-config.json");if(u(r))try{const a=f(r,"utf-8"),d=JSON.parse(a),i={...c};for(const n of Object.keys(c)){const e=d[n];typeof e=="number"&&Number.isFinite(e)&&e>=0&&(i[n]=e)}return{weights:i,source:r}}catch{}}return{weights:{...c},source:"default"}}s(S,"loadSalWeights");export{c as SAL_DEFAULT_WEIGHTS,S as loadSalWeights};
|