@skaft/hamr 0.4.1
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/CHANGELOG.md +314 -0
- package/LICENSE +27 -0
- package/README.md +96 -0
- package/dist/bun/cli.d.ts +3 -0
- package/dist/bun/cli.d.ts.map +1 -0
- package/dist/bun/cli.js +9 -0
- package/dist/bun/cli.js.map +1 -0
- package/dist/bun/register-bedrock.d.ts +2 -0
- package/dist/bun/register-bedrock.d.ts.map +1 -0
- package/dist/bun/register-bedrock.js +4 -0
- package/dist/bun/register-bedrock.js.map +1 -0
- package/dist/bun/restore-sandbox-env.d.ts +17 -0
- package/dist/bun/restore-sandbox-env.d.ts.map +1 -0
- package/dist/bun/restore-sandbox-env.js +36 -0
- package/dist/bun/restore-sandbox-env.js.map +1 -0
- package/dist/cli/args.d.ts +57 -0
- package/dist/cli/args.d.ts.map +1 -0
- package/dist/cli/args.js +379 -0
- package/dist/cli/args.js.map +1 -0
- package/dist/cli/config-selector.d.ts +14 -0
- package/dist/cli/config-selector.d.ts.map +1 -0
- package/dist/cli/config-selector.js +31 -0
- package/dist/cli/config-selector.js.map +1 -0
- package/dist/cli/file-processor.d.ts +15 -0
- package/dist/cli/file-processor.d.ts.map +1 -0
- package/dist/cli/file-processor.js +82 -0
- package/dist/cli/file-processor.js.map +1 -0
- package/dist/cli/initial-message.d.ts +18 -0
- package/dist/cli/initial-message.d.ts.map +1 -0
- package/dist/cli/initial-message.js +22 -0
- package/dist/cli/initial-message.js.map +1 -0
- package/dist/cli/list-models.d.ts +9 -0
- package/dist/cli/list-models.d.ts.map +1 -0
- package/dist/cli/list-models.js +98 -0
- package/dist/cli/list-models.js.map +1 -0
- package/dist/cli/project-trust.d.ts +10 -0
- package/dist/cli/project-trust.d.ts.map +1 -0
- package/dist/cli/project-trust.js +48 -0
- package/dist/cli/project-trust.js.map +1 -0
- package/dist/cli/session-picker.d.ts +9 -0
- package/dist/cli/session-picker.d.ts.map +1 -0
- package/dist/cli/session-picker.js +35 -0
- package/dist/cli/session-picker.js.map +1 -0
- package/dist/cli/startup-ui.d.ts +17 -0
- package/dist/cli/startup-ui.d.ts.map +1 -0
- package/dist/cli/startup-ui.js +135 -0
- package/dist/cli/startup-ui.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +40 -0
- package/dist/cli.js.map +1 -0
- package/dist/config.d.ts +92 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +449 -0
- package/dist/config.js.map +1 -0
- package/dist/core/agent-session-runtime.d.ts +119 -0
- package/dist/core/agent-session-runtime.d.ts.map +1 -0
- package/dist/core/agent-session-runtime.js +295 -0
- package/dist/core/agent-session-runtime.js.map +1 -0
- package/dist/core/agent-session-services.d.ts +88 -0
- package/dist/core/agent-session-services.d.ts.map +1 -0
- package/dist/core/agent-session-services.js +129 -0
- package/dist/core/agent-session-services.js.map +1 -0
- package/dist/core/agent-session.d.ts +633 -0
- package/dist/core/agent-session.d.ts.map +1 -0
- package/dist/core/agent-session.js +2512 -0
- package/dist/core/agent-session.js.map +1 -0
- package/dist/core/auth-guidance.d.ts +5 -0
- package/dist/core/auth-guidance.d.ts.map +1 -0
- package/dist/core/auth-guidance.js +21 -0
- package/dist/core/auth-guidance.js.map +1 -0
- package/dist/core/auth-storage.d.ts +150 -0
- package/dist/core/auth-storage.d.ts.map +1 -0
- package/dist/core/auth-storage.js +446 -0
- package/dist/core/auth-storage.js.map +1 -0
- package/dist/core/bash-executor.d.ts +32 -0
- package/dist/core/bash-executor.d.ts.map +1 -0
- package/dist/core/bash-executor.js +111 -0
- package/dist/core/bash-executor.js.map +1 -0
- package/dist/core/compaction/branch-summarization.d.ts +92 -0
- package/dist/core/compaction/branch-summarization.d.ts.map +1 -0
- package/dist/core/compaction/branch-summarization.js +249 -0
- package/dist/core/compaction/branch-summarization.js.map +1 -0
- package/dist/core/compaction/compaction.d.ts +121 -0
- package/dist/core/compaction/compaction.d.ts.map +1 -0
- package/dist/core/compaction/compaction.js +619 -0
- package/dist/core/compaction/compaction.js.map +1 -0
- package/dist/core/compaction/index.d.ts +7 -0
- package/dist/core/compaction/index.d.ts.map +1 -0
- package/dist/core/compaction/index.js +7 -0
- package/dist/core/compaction/index.js.map +1 -0
- package/dist/core/compaction/utils.d.ts +38 -0
- package/dist/core/compaction/utils.d.ts.map +1 -0
- package/dist/core/compaction/utils.js +153 -0
- package/dist/core/compaction/utils.js.map +1 -0
- package/dist/core/defaults.d.ts +3 -0
- package/dist/core/defaults.d.ts.map +1 -0
- package/dist/core/defaults.js +2 -0
- package/dist/core/defaults.js.map +1 -0
- package/dist/core/diagnostics.d.ts +15 -0
- package/dist/core/diagnostics.d.ts.map +1 -0
- package/dist/core/diagnostics.js +2 -0
- package/dist/core/diagnostics.js.map +1 -0
- package/dist/core/event-bus.d.ts +9 -0
- package/dist/core/event-bus.d.ts.map +1 -0
- package/dist/core/event-bus.js +25 -0
- package/dist/core/event-bus.js.map +1 -0
- package/dist/core/exec.d.ts +29 -0
- package/dist/core/exec.d.ts.map +1 -0
- package/dist/core/exec.js +75 -0
- package/dist/core/exec.js.map +1 -0
- package/dist/core/experimental.d.ts +2 -0
- package/dist/core/experimental.d.ts.map +1 -0
- package/dist/core/experimental.js +4 -0
- package/dist/core/experimental.js.map +1 -0
- package/dist/core/export-html/ansi-to-html.d.ts +22 -0
- package/dist/core/export-html/ansi-to-html.d.ts.map +1 -0
- package/dist/core/export-html/ansi-to-html.js +249 -0
- package/dist/core/export-html/ansi-to-html.js.map +1 -0
- package/dist/core/export-html/index.d.ts +37 -0
- package/dist/core/export-html/index.d.ts.map +1 -0
- package/dist/core/export-html/index.js +226 -0
- package/dist/core/export-html/index.js.map +1 -0
- package/dist/core/export-html/template.css +1066 -0
- package/dist/core/export-html/template.html +55 -0
- package/dist/core/export-html/template.js +1864 -0
- package/dist/core/export-html/tool-renderer.d.ts +34 -0
- package/dist/core/export-html/tool-renderer.d.ts.map +1 -0
- package/dist/core/export-html/tool-renderer.js +108 -0
- package/dist/core/export-html/tool-renderer.js.map +1 -0
- package/dist/core/export-html/vendor/highlight.min.js +1213 -0
- package/dist/core/export-html/vendor/marked.min.js +78 -0
- package/dist/core/extensions/index.d.ts +12 -0
- package/dist/core/extensions/index.d.ts.map +1 -0
- package/dist/core/extensions/index.js +9 -0
- package/dist/core/extensions/index.js.map +1 -0
- package/dist/core/extensions/loader.d.ts +24 -0
- package/dist/core/extensions/loader.d.ts.map +1 -0
- package/dist/core/extensions/loader.js +481 -0
- package/dist/core/extensions/loader.js.map +1 -0
- package/dist/core/extensions/runner.d.ts +166 -0
- package/dist/core/extensions/runner.d.ts.map +1 -0
- package/dist/core/extensions/runner.js +877 -0
- package/dist/core/extensions/runner.js.map +1 -0
- package/dist/core/extensions/types.d.ts +1201 -0
- package/dist/core/extensions/types.d.ts.map +1 -0
- package/dist/core/extensions/types.js +45 -0
- package/dist/core/extensions/types.js.map +1 -0
- package/dist/core/extensions/wrapper.d.ts +20 -0
- package/dist/core/extensions/wrapper.d.ts.map +1 -0
- package/dist/core/extensions/wrapper.js +22 -0
- package/dist/core/extensions/wrapper.js.map +1 -0
- package/dist/core/footer-data-provider.d.ts +55 -0
- package/dist/core/footer-data-provider.d.ts.map +1 -0
- package/dist/core/footer-data-provider.js +348 -0
- package/dist/core/footer-data-provider.js.map +1 -0
- package/dist/core/http-dispatcher.d.ts +22 -0
- package/dist/core/http-dispatcher.d.ts.map +1 -0
- package/dist/core/http-dispatcher.js +64 -0
- package/dist/core/http-dispatcher.js.map +1 -0
- package/dist/core/index.d.ts +13 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +13 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/keybindings.d.ts +353 -0
- package/dist/core/keybindings.d.ts.map +1 -0
- package/dist/core/keybindings.js +294 -0
- package/dist/core/keybindings.js.map +1 -0
- package/dist/core/messages.d.ts +77 -0
- package/dist/core/messages.d.ts.map +1 -0
- package/dist/core/messages.js +123 -0
- package/dist/core/messages.js.map +1 -0
- package/dist/core/model-registry.d.ts +151 -0
- package/dist/core/model-registry.d.ts.map +1 -0
- package/dist/core/model-registry.js +734 -0
- package/dist/core/model-registry.js.map +1 -0
- package/dist/core/model-resolver.d.ts +111 -0
- package/dist/core/model-resolver.d.ts.map +1 -0
- package/dist/core/model-resolver.js +533 -0
- package/dist/core/model-resolver.js.map +1 -0
- package/dist/core/output-guard.d.ts +7 -0
- package/dist/core/output-guard.d.ts.map +1 -0
- package/dist/core/output-guard.js +89 -0
- package/dist/core/output-guard.js.map +1 -0
- package/dist/core/package-manager.d.ts +208 -0
- package/dist/core/package-manager.d.ts.map +1 -0
- package/dist/core/package-manager.js +2061 -0
- package/dist/core/package-manager.js.map +1 -0
- package/dist/core/project-trust.d.ts +15 -0
- package/dist/core/project-trust.d.ts.map +1 -0
- package/dist/core/project-trust.js +58 -0
- package/dist/core/project-trust.js.map +1 -0
- package/dist/core/prompt-templates.d.ts +53 -0
- package/dist/core/prompt-templates.d.ts.map +1 -0
- package/dist/core/prompt-templates.js +236 -0
- package/dist/core/prompt-templates.js.map +1 -0
- package/dist/core/provider-attribution.d.ts +4 -0
- package/dist/core/provider-attribution.d.ts.map +1 -0
- package/dist/core/provider-attribution.js +80 -0
- package/dist/core/provider-attribution.js.map +1 -0
- package/dist/core/provider-display-names.d.ts +2 -0
- package/dist/core/provider-display-names.d.ts.map +1 -0
- package/dist/core/provider-display-names.js +36 -0
- package/dist/core/provider-display-names.js.map +1 -0
- package/dist/core/resolve-config-value.d.ts +30 -0
- package/dist/core/resolve-config-value.d.ts.map +1 -0
- package/dist/core/resolve-config-value.js +245 -0
- package/dist/core/resolve-config-value.js.map +1 -0
- package/dist/core/resource-loader.d.ts +205 -0
- package/dist/core/resource-loader.d.ts.map +1 -0
- package/dist/core/resource-loader.js +769 -0
- package/dist/core/resource-loader.js.map +1 -0
- package/dist/core/sdk.d.ts +109 -0
- package/dist/core/sdk.d.ts.map +1 -0
- package/dist/core/sdk.js +267 -0
- package/dist/core/sdk.js.map +1 -0
- package/dist/core/session-cwd.d.ts +19 -0
- package/dist/core/session-cwd.d.ts.map +1 -0
- package/dist/core/session-cwd.js +37 -0
- package/dist/core/session-cwd.js.map +1 -0
- package/dist/core/session-manager.d.ts +332 -0
- package/dist/core/session-manager.d.ts.map +1 -0
- package/dist/core/session-manager.js +1222 -0
- package/dist/core/session-manager.js.map +1 -0
- package/dist/core/settings-manager.d.ts +288 -0
- package/dist/core/settings-manager.d.ts.map +1 -0
- package/dist/core/settings-manager.js +862 -0
- package/dist/core/settings-manager.js.map +1 -0
- package/dist/core/skills.d.ts +60 -0
- package/dist/core/skills.d.ts.map +1 -0
- package/dist/core/skills.js +386 -0
- package/dist/core/skills.js.map +1 -0
- package/dist/core/slash-commands.d.ts +14 -0
- package/dist/core/slash-commands.d.ts.map +1 -0
- package/dist/core/slash-commands.js +26 -0
- package/dist/core/slash-commands.js.map +1 -0
- package/dist/core/source-info.d.ts +18 -0
- package/dist/core/source-info.d.ts.map +1 -0
- package/dist/core/source-info.js +19 -0
- package/dist/core/source-info.js.map +1 -0
- package/dist/core/system-prompt.d.ts +28 -0
- package/dist/core/system-prompt.d.ts.map +1 -0
- package/dist/core/system-prompt.js +134 -0
- package/dist/core/system-prompt.js.map +1 -0
- package/dist/core/telemetry.d.ts +3 -0
- package/dist/core/telemetry.d.ts.map +1 -0
- package/dist/core/telemetry.js +9 -0
- package/dist/core/telemetry.js.map +1 -0
- package/dist/core/timings.d.ts +8 -0
- package/dist/core/timings.d.ts.map +1 -0
- package/dist/core/timings.js +31 -0
- package/dist/core/timings.js.map +1 -0
- package/dist/core/tools/bash.d.ts +68 -0
- package/dist/core/tools/bash.d.ts.map +1 -0
- package/dist/core/tools/bash.js +373 -0
- package/dist/core/tools/bash.js.map +1 -0
- package/dist/core/tools/edit-diff.d.ts +87 -0
- package/dist/core/tools/edit-diff.d.ts.map +1 -0
- package/dist/core/tools/edit-diff.js +345 -0
- package/dist/core/tools/edit-diff.js.map +1 -0
- package/dist/core/tools/edit.d.ts +51 -0
- package/dist/core/tools/edit.d.ts.map +1 -0
- package/dist/core/tools/edit.js +289 -0
- package/dist/core/tools/edit.js.map +1 -0
- package/dist/core/tools/file-mutation-queue.d.ts +6 -0
- package/dist/core/tools/file-mutation-queue.d.ts.map +1 -0
- package/dist/core/tools/file-mutation-queue.js +52 -0
- package/dist/core/tools/file-mutation-queue.js.map +1 -0
- package/dist/core/tools/find.d.ts +35 -0
- package/dist/core/tools/find.d.ts.map +1 -0
- package/dist/core/tools/find.js +297 -0
- package/dist/core/tools/find.js.map +1 -0
- package/dist/core/tools/grep.d.ts +37 -0
- package/dist/core/tools/grep.d.ts.map +1 -0
- package/dist/core/tools/grep.js +301 -0
- package/dist/core/tools/grep.js.map +1 -0
- package/dist/core/tools/index.d.ts +40 -0
- package/dist/core/tools/index.d.ts.map +1 -0
- package/dist/core/tools/index.js +112 -0
- package/dist/core/tools/index.js.map +1 -0
- package/dist/core/tools/ls.d.ts +37 -0
- package/dist/core/tools/ls.d.ts.map +1 -0
- package/dist/core/tools/ls.js +167 -0
- package/dist/core/tools/ls.js.map +1 -0
- package/dist/core/tools/output-accumulator.d.ts +52 -0
- package/dist/core/tools/output-accumulator.d.ts.map +1 -0
- package/dist/core/tools/output-accumulator.js +178 -0
- package/dist/core/tools/output-accumulator.js.map +1 -0
- package/dist/core/tools/path-utils.d.ts +10 -0
- package/dist/core/tools/path-utils.d.ts.map +1 -0
- package/dist/core/tools/path-utils.js +99 -0
- package/dist/core/tools/path-utils.js.map +1 -0
- package/dist/core/tools/read.d.ts +35 -0
- package/dist/core/tools/read.d.ts.map +1 -0
- package/dist/core/tools/read.js +286 -0
- package/dist/core/tools/read.js.map +1 -0
- package/dist/core/tools/render-utils.d.ts +24 -0
- package/dist/core/tools/render-utils.d.ts.map +1 -0
- package/dist/core/tools/render-utils.js +65 -0
- package/dist/core/tools/render-utils.js.map +1 -0
- package/dist/core/tools/tool-definition-wrapper.d.ts +14 -0
- package/dist/core/tools/tool-definition-wrapper.d.ts.map +1 -0
- package/dist/core/tools/tool-definition-wrapper.js +34 -0
- package/dist/core/tools/tool-definition-wrapper.js.map +1 -0
- package/dist/core/tools/truncate.d.ts +70 -0
- package/dist/core/tools/truncate.d.ts.map +1 -0
- package/dist/core/tools/truncate.js +215 -0
- package/dist/core/tools/truncate.js.map +1 -0
- package/dist/core/tools/write.d.ts +26 -0
- package/dist/core/tools/write.d.ts.map +1 -0
- package/dist/core/tools/write.js +196 -0
- package/dist/core/tools/write.js.map +1 -0
- package/dist/core/trust-manager.d.ts +36 -0
- package/dist/core/trust-manager.d.ts.map +1 -0
- package/dist/core/trust-manager.js +201 -0
- package/dist/core/trust-manager.js.map +1 -0
- package/dist/hamr/extensions/context.d.ts +14 -0
- package/dist/hamr/extensions/context.d.ts.map +1 -0
- package/dist/hamr/extensions/context.js +106 -0
- package/dist/hamr/extensions/context.js.map +1 -0
- package/dist/hamr/extensions/index.d.ts +13 -0
- package/dist/hamr/extensions/index.d.ts.map +1 -0
- package/dist/hamr/extensions/index.js +25 -0
- package/dist/hamr/extensions/index.js.map +1 -0
- package/dist/hamr/extensions/memory.d.ts +67 -0
- package/dist/hamr/extensions/memory.d.ts.map +1 -0
- package/dist/hamr/extensions/memory.js +405 -0
- package/dist/hamr/extensions/memory.js.map +1 -0
- package/dist/hamr/extensions/providers.d.ts +8 -0
- package/dist/hamr/extensions/providers.d.ts.map +1 -0
- package/dist/hamr/extensions/providers.js +81 -0
- package/dist/hamr/extensions/providers.js.map +1 -0
- package/dist/hamr/extensions/read-loop-guard.d.ts +3 -0
- package/dist/hamr/extensions/read-loop-guard.d.ts.map +1 -0
- package/dist/hamr/extensions/read-loop-guard.js +26 -0
- package/dist/hamr/extensions/read-loop-guard.js.map +1 -0
- package/dist/hamr/extensions/subagents.d.ts +15 -0
- package/dist/hamr/extensions/subagents.d.ts.map +1 -0
- package/dist/hamr/extensions/subagents.js +264 -0
- package/dist/hamr/extensions/subagents.js.map +1 -0
- package/dist/hamr/handoff/HandoffManager.d.ts +46 -0
- package/dist/hamr/handoff/HandoffManager.d.ts.map +1 -0
- package/dist/hamr/handoff/HandoffManager.js +147 -0
- package/dist/hamr/handoff/HandoffManager.js.map +1 -0
- package/dist/hamr/helpers.d.ts +8 -0
- package/dist/hamr/helpers.d.ts.map +1 -0
- package/dist/hamr/helpers.js +35 -0
- package/dist/hamr/helpers.js.map +1 -0
- package/dist/hamr/memory/HolographicMemory.d.ts +138 -0
- package/dist/hamr/memory/HolographicMemory.d.ts.map +1 -0
- package/dist/hamr/memory/HolographicMemory.js +525 -0
- package/dist/hamr/memory/HolographicMemory.js.map +1 -0
- package/dist/hamr/memory/fts-marks.d.ts +2 -0
- package/dist/hamr/memory/fts-marks.d.ts.map +1 -0
- package/dist/hamr/memory/fts-marks.js +4 -0
- package/dist/hamr/memory/fts-marks.js.map +1 -0
- package/dist/hamr/memory.d.ts +16 -0
- package/dist/hamr/memory.d.ts.map +1 -0
- package/dist/hamr/memory.js +223 -0
- package/dist/hamr/memory.js.map +1 -0
- package/dist/hamr/persistent-editor.d.ts +3 -0
- package/dist/hamr/persistent-editor.d.ts.map +1 -0
- package/dist/hamr/persistent-editor.js +103 -0
- package/dist/hamr/persistent-editor.js.map +1 -0
- package/dist/hamr/providers/parsers/deepseek.d.ts +28 -0
- package/dist/hamr/providers/parsers/deepseek.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/deepseek.js +150 -0
- package/dist/hamr/providers/parsers/deepseek.js.map +1 -0
- package/dist/hamr/providers/parsers/generic.d.ts +19 -0
- package/dist/hamr/providers/parsers/generic.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/generic.js +263 -0
- package/dist/hamr/providers/parsers/generic.js.map +1 -0
- package/dist/hamr/providers/parsers/glm-step.d.ts +28 -0
- package/dist/hamr/providers/parsers/glm-step.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/glm-step.js +289 -0
- package/dist/hamr/providers/parsers/glm-step.js.map +1 -0
- package/dist/hamr/providers/parsers/hermes.d.ts +21 -0
- package/dist/hamr/providers/parsers/hermes.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/hermes.js +114 -0
- package/dist/hamr/providers/parsers/hermes.js.map +1 -0
- package/dist/hamr/providers/parsers/index.d.ts +15 -0
- package/dist/hamr/providers/parsers/index.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/index.js +66 -0
- package/dist/hamr/providers/parsers/index.js.map +1 -0
- package/dist/hamr/providers/parsers/json-in-tags.d.ts +100 -0
- package/dist/hamr/providers/parsers/json-in-tags.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/json-in-tags.js +395 -0
- package/dist/hamr/providers/parsers/json-in-tags.js.map +1 -0
- package/dist/hamr/providers/parsers/llama3-json.d.ts +24 -0
- package/dist/hamr/providers/parsers/llama3-json.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/llama3-json.js +157 -0
- package/dist/hamr/providers/parsers/llama3-json.js.map +1 -0
- package/dist/hamr/providers/parsers/mistral.d.ts +22 -0
- package/dist/hamr/providers/parsers/mistral.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/mistral.js +157 -0
- package/dist/hamr/providers/parsers/mistral.js.map +1 -0
- package/dist/hamr/providers/parsers/pythonic.d.ts +30 -0
- package/dist/hamr/providers/parsers/pythonic.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/pythonic.js +243 -0
- package/dist/hamr/providers/parsers/pythonic.js.map +1 -0
- package/dist/hamr/providers/parsers/qwen3-xml.d.ts +19 -0
- package/dist/hamr/providers/parsers/qwen3-xml.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/qwen3-xml.js +107 -0
- package/dist/hamr/providers/parsers/qwen3-xml.js.map +1 -0
- package/dist/hamr/providers/parsers/registry.d.ts +13 -0
- package/dist/hamr/providers/parsers/registry.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/registry.js +51 -0
- package/dist/hamr/providers/parsers/registry.js.map +1 -0
- package/dist/hamr/providers/parsers/types.d.ts +83 -0
- package/dist/hamr/providers/parsers/types.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/types.js +93 -0
- package/dist/hamr/providers/parsers/types.js.map +1 -0
- package/dist/hamr/providers/parsers/utils.d.ts +106 -0
- package/dist/hamr/providers/parsers/utils.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/utils.js +477 -0
- package/dist/hamr/providers/parsers/utils.js.map +1 -0
- package/dist/hamr/providers/parsers/xlam.d.ts +23 -0
- package/dist/hamr/providers/parsers/xlam.d.ts.map +1 -0
- package/dist/hamr/providers/parsers/xlam.js +119 -0
- package/dist/hamr/providers/parsers/xlam.js.map +1 -0
- package/dist/hamr/providers/relay-provider.d.ts +34 -0
- package/dist/hamr/providers/relay-provider.d.ts.map +1 -0
- package/dist/hamr/providers/relay-provider.js +228 -0
- package/dist/hamr/providers/relay-provider.js.map +1 -0
- package/dist/hamr/providers/repair/json-repair.d.ts +30 -0
- package/dist/hamr/providers/repair/json-repair.d.ts.map +1 -0
- package/dist/hamr/providers/repair/json-repair.js +315 -0
- package/dist/hamr/providers/repair/json-repair.js.map +1 -0
- package/dist/hamr/providers/repair/reasoning-sanitizer.d.ts +28 -0
- package/dist/hamr/providers/repair/reasoning-sanitizer.d.ts.map +1 -0
- package/dist/hamr/providers/repair/reasoning-sanitizer.js +115 -0
- package/dist/hamr/providers/repair/reasoning-sanitizer.js.map +1 -0
- package/dist/hamr/providers/repair/xml-repair.d.ts +31 -0
- package/dist/hamr/providers/repair/xml-repair.d.ts.map +1 -0
- package/dist/hamr/providers/repair/xml-repair.js +295 -0
- package/dist/hamr/providers/repair/xml-repair.js.map +1 -0
- package/dist/hamr/providers/tool-calls.d.ts +7 -0
- package/dist/hamr/providers/tool-calls.d.ts.map +1 -0
- package/dist/hamr/providers/tool-calls.js +148 -0
- package/dist/hamr/providers/tool-calls.js.map +1 -0
- package/dist/hamr/providers/types.d.ts +17 -0
- package/dist/hamr/providers/types.d.ts.map +1 -0
- package/dist/hamr/providers/types.js +2 -0
- package/dist/hamr/providers/types.js.map +1 -0
- package/dist/hamr/repair.d.ts +8 -0
- package/dist/hamr/repair.d.ts.map +1 -0
- package/dist/hamr/repair.js +85 -0
- package/dist/hamr/repair.js.map +1 -0
- package/dist/hamr/shimmer.d.ts +2 -0
- package/dist/hamr/shimmer.d.ts.map +1 -0
- package/dist/hamr/shimmer.js +9 -0
- package/dist/hamr/shimmer.js.map +1 -0
- package/dist/hamr/startup-config.d.ts +78 -0
- package/dist/hamr/startup-config.d.ts.map +1 -0
- package/dist/hamr/startup-config.js +344 -0
- package/dist/hamr/startup-config.js.map +1 -0
- package/dist/hamr/store/sqlite-loader.d.ts +26 -0
- package/dist/hamr/store/sqlite-loader.d.ts.map +1 -0
- package/dist/hamr/store/sqlite-loader.js +36 -0
- package/dist/hamr/store/sqlite-loader.js.map +1 -0
- package/dist/index.d.ts +32 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +45 -0
- package/dist/index.js.map +1 -0
- package/dist/main.d.ts +12 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +739 -0
- package/dist/main.js.map +1 -0
- package/dist/migrations.d.ts +33 -0
- package/dist/migrations.d.ts.map +1 -0
- package/dist/migrations.js +281 -0
- package/dist/migrations.js.map +1 -0
- package/dist/modes/index.d.ts +9 -0
- package/dist/modes/index.d.ts.map +1 -0
- package/dist/modes/index.js +8 -0
- package/dist/modes/index.js.map +1 -0
- package/dist/modes/interactive/components/armin.d.ts +34 -0
- package/dist/modes/interactive/components/armin.d.ts.map +1 -0
- package/dist/modes/interactive/components/armin.js +329 -0
- package/dist/modes/interactive/components/armin.js.map +1 -0
- package/dist/modes/interactive/components/assistant-message.d.ts +28 -0
- package/dist/modes/interactive/components/assistant-message.d.ts.map +1 -0
- package/dist/modes/interactive/components/assistant-message.js +172 -0
- package/dist/modes/interactive/components/assistant-message.js.map +1 -0
- package/dist/modes/interactive/components/bash-execution.d.ts +35 -0
- package/dist/modes/interactive/components/bash-execution.d.ts.map +1 -0
- package/dist/modes/interactive/components/bash-execution.js +171 -0
- package/dist/modes/interactive/components/bash-execution.js.map +1 -0
- package/dist/modes/interactive/components/bordered-loader.d.ts +16 -0
- package/dist/modes/interactive/components/bordered-loader.d.ts.map +1 -0
- package/dist/modes/interactive/components/bordered-loader.js +51 -0
- package/dist/modes/interactive/components/bordered-loader.js.map +1 -0
- package/dist/modes/interactive/components/branch-summary-message.d.ts +16 -0
- package/dist/modes/interactive/components/branch-summary-message.d.ts.map +1 -0
- package/dist/modes/interactive/components/branch-summary-message.js +42 -0
- package/dist/modes/interactive/components/branch-summary-message.js.map +1 -0
- package/dist/modes/interactive/components/compaction-summary-message.d.ts +16 -0
- package/dist/modes/interactive/components/compaction-summary-message.d.ts.map +1 -0
- package/dist/modes/interactive/components/compaction-summary-message.js +43 -0
- package/dist/modes/interactive/components/compaction-summary-message.js.map +1 -0
- package/dist/modes/interactive/components/config-selector.d.ts +71 -0
- package/dist/modes/interactive/components/config-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/config-selector.js +496 -0
- package/dist/modes/interactive/components/config-selector.js.map +1 -0
- package/dist/modes/interactive/components/countdown-timer.d.ts +14 -0
- package/dist/modes/interactive/components/countdown-timer.d.ts.map +1 -0
- package/dist/modes/interactive/components/countdown-timer.js +28 -0
- package/dist/modes/interactive/components/countdown-timer.js.map +1 -0
- package/dist/modes/interactive/components/custom-editor.d.ts +21 -0
- package/dist/modes/interactive/components/custom-editor.d.ts.map +1 -0
- package/dist/modes/interactive/components/custom-editor.js +63 -0
- package/dist/modes/interactive/components/custom-editor.js.map +1 -0
- package/dist/modes/interactive/components/custom-message.d.ts +20 -0
- package/dist/modes/interactive/components/custom-message.d.ts.map +1 -0
- package/dist/modes/interactive/components/custom-message.js +73 -0
- package/dist/modes/interactive/components/custom-message.js.map +1 -0
- package/dist/modes/interactive/components/daxnuts.d.ts +23 -0
- package/dist/modes/interactive/components/daxnuts.d.ts.map +1 -0
- package/dist/modes/interactive/components/daxnuts.js +138 -0
- package/dist/modes/interactive/components/daxnuts.js.map +1 -0
- package/dist/modes/interactive/components/diff.d.ts +24 -0
- package/dist/modes/interactive/components/diff.d.ts.map +1 -0
- package/dist/modes/interactive/components/diff.js +172 -0
- package/dist/modes/interactive/components/diff.js.map +1 -0
- package/dist/modes/interactive/components/dynamic-border.d.ts +15 -0
- package/dist/modes/interactive/components/dynamic-border.d.ts.map +1 -0
- package/dist/modes/interactive/components/dynamic-border.js +20 -0
- package/dist/modes/interactive/components/dynamic-border.js.map +1 -0
- package/dist/modes/interactive/components/extension-editor.d.ts +20 -0
- package/dist/modes/interactive/components/extension-editor.d.ts.map +1 -0
- package/dist/modes/interactive/components/extension-editor.js +114 -0
- package/dist/modes/interactive/components/extension-editor.js.map +1 -0
- package/dist/modes/interactive/components/extension-input.d.ts +23 -0
- package/dist/modes/interactive/components/extension-input.d.ts.map +1 -0
- package/dist/modes/interactive/components/extension-input.js +55 -0
- package/dist/modes/interactive/components/extension-input.js.map +1 -0
- package/dist/modes/interactive/components/extension-selector.d.ts +26 -0
- package/dist/modes/interactive/components/extension-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/extension-selector.js +75 -0
- package/dist/modes/interactive/components/extension-selector.js.map +1 -0
- package/dist/modes/interactive/components/first-time-setup.d.ts +24 -0
- package/dist/modes/interactive/components/first-time-setup.d.ts.map +1 -0
- package/dist/modes/interactive/components/first-time-setup.js +104 -0
- package/dist/modes/interactive/components/first-time-setup.js.map +1 -0
- package/dist/modes/interactive/components/footer.d.ts +38 -0
- package/dist/modes/interactive/components/footer.d.ts.map +1 -0
- package/dist/modes/interactive/components/footer.js +314 -0
- package/dist/modes/interactive/components/footer.js.map +1 -0
- package/dist/modes/interactive/components/index.d.ts +34 -0
- package/dist/modes/interactive/components/index.d.ts.map +1 -0
- package/dist/modes/interactive/components/index.js +35 -0
- package/dist/modes/interactive/components/index.js.map +1 -0
- package/dist/modes/interactive/components/keybinding-hints.d.ts +13 -0
- package/dist/modes/interactive/components/keybinding-hints.d.ts.map +1 -0
- package/dist/modes/interactive/components/keybinding-hints.js +36 -0
- package/dist/modes/interactive/components/keybinding-hints.js.map +1 -0
- package/dist/modes/interactive/components/login-dialog.d.ts +52 -0
- package/dist/modes/interactive/components/login-dialog.d.ts.map +1 -0
- package/dist/modes/interactive/components/login-dialog.js +175 -0
- package/dist/modes/interactive/components/login-dialog.js.map +1 -0
- package/dist/modes/interactive/components/model-selector.d.ts +47 -0
- package/dist/modes/interactive/components/model-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/model-selector.js +268 -0
- package/dist/modes/interactive/components/model-selector.js.map +1 -0
- package/dist/modes/interactive/components/oauth-selector.d.ts +31 -0
- package/dist/modes/interactive/components/oauth-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/oauth-selector.js +156 -0
- package/dist/modes/interactive/components/oauth-selector.js.map +1 -0
- package/dist/modes/interactive/components/scoped-models-selector.d.ts +42 -0
- package/dist/modes/interactive/components/scoped-models-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/scoped-models-selector.js +286 -0
- package/dist/modes/interactive/components/scoped-models-selector.js.map +1 -0
- package/dist/modes/interactive/components/session-selector-search.d.ts +23 -0
- package/dist/modes/interactive/components/session-selector-search.d.ts.map +1 -0
- package/dist/modes/interactive/components/session-selector-search.js +155 -0
- package/dist/modes/interactive/components/session-selector-search.js.map +1 -0
- package/dist/modes/interactive/components/session-selector.d.ts +95 -0
- package/dist/modes/interactive/components/session-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/session-selector.js +832 -0
- package/dist/modes/interactive/components/session-selector.js.map +1 -0
- package/dist/modes/interactive/components/settings-selector.d.ts +73 -0
- package/dist/modes/interactive/components/settings-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/settings-selector.js +410 -0
- package/dist/modes/interactive/components/settings-selector.js.map +1 -0
- package/dist/modes/interactive/components/show-images-selector.d.ts +10 -0
- package/dist/modes/interactive/components/show-images-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/show-images-selector.js +38 -0
- package/dist/modes/interactive/components/show-images-selector.js.map +1 -0
- package/dist/modes/interactive/components/skill-invocation-message.d.ts +17 -0
- package/dist/modes/interactive/components/skill-invocation-message.d.ts.map +1 -0
- package/dist/modes/interactive/components/skill-invocation-message.js +46 -0
- package/dist/modes/interactive/components/skill-invocation-message.js.map +1 -0
- package/dist/modes/interactive/components/theme-selector.d.ts +11 -0
- package/dist/modes/interactive/components/theme-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/theme-selector.js +48 -0
- package/dist/modes/interactive/components/theme-selector.js.map +1 -0
- package/dist/modes/interactive/components/thinking-selector.d.ts +11 -0
- package/dist/modes/interactive/components/thinking-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/thinking-selector.js +50 -0
- package/dist/modes/interactive/components/thinking-selector.js.map +1 -0
- package/dist/modes/interactive/components/tool-execution.d.ts +66 -0
- package/dist/modes/interactive/components/tool-execution.d.ts.map +1 -0
- package/dist/modes/interactive/components/tool-execution.js +315 -0
- package/dist/modes/interactive/components/tool-execution.js.map +1 -0
- package/dist/modes/interactive/components/tree-selector.d.ts +89 -0
- package/dist/modes/interactive/components/tree-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/tree-selector.js +1186 -0
- package/dist/modes/interactive/components/tree-selector.js.map +1 -0
- package/dist/modes/interactive/components/trust-selector.d.ts +23 -0
- package/dist/modes/interactive/components/trust-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/trust-selector.js +85 -0
- package/dist/modes/interactive/components/trust-selector.js.map +1 -0
- package/dist/modes/interactive/components/user-message-selector.d.ts +30 -0
- package/dist/modes/interactive/components/user-message-selector.d.ts.map +1 -0
- package/dist/modes/interactive/components/user-message-selector.js +111 -0
- package/dist/modes/interactive/components/user-message-selector.js.map +1 -0
- package/dist/modes/interactive/components/user-message.d.ts +15 -0
- package/dist/modes/interactive/components/user-message.d.ts.map +1 -0
- package/dist/modes/interactive/components/user-message.js +61 -0
- package/dist/modes/interactive/components/user-message.js.map +1 -0
- package/dist/modes/interactive/components/visual-truncate.d.ts +24 -0
- package/dist/modes/interactive/components/visual-truncate.d.ts.map +1 -0
- package/dist/modes/interactive/components/visual-truncate.js +33 -0
- package/dist/modes/interactive/components/visual-truncate.js.map +1 -0
- package/dist/modes/interactive/interactive-mode.d.ts +416 -0
- package/dist/modes/interactive/interactive-mode.d.ts.map +1 -0
- package/dist/modes/interactive/interactive-mode.js +4958 -0
- package/dist/modes/interactive/interactive-mode.js.map +1 -0
- package/dist/modes/interactive/interrupt-routing.d.ts +23 -0
- package/dist/modes/interactive/interrupt-routing.d.ts.map +1 -0
- package/dist/modes/interactive/interrupt-routing.js +10 -0
- package/dist/modes/interactive/interrupt-routing.js.map +1 -0
- package/dist/modes/interactive/theme/dark.json +112 -0
- package/dist/modes/interactive/theme/default.json +102 -0
- package/dist/modes/interactive/theme/hamr.json +121 -0
- package/dist/modes/interactive/theme/kawaii.json +120 -0
- package/dist/modes/interactive/theme/light.json +111 -0
- package/dist/modes/interactive/theme/pinkOut.json +116 -0
- package/dist/modes/interactive/theme/theme-schema.json +428 -0
- package/dist/modes/interactive/theme/theme.d.ts +196 -0
- package/dist/modes/interactive/theme/theme.d.ts.map +1 -0
- package/dist/modes/interactive/theme/theme.js +1461 -0
- package/dist/modes/interactive/theme/theme.js.map +1 -0
- package/dist/modes/print-mode.d.ts +28 -0
- package/dist/modes/print-mode.d.ts.map +1 -0
- package/dist/modes/print-mode.js +132 -0
- package/dist/modes/print-mode.js.map +1 -0
- package/dist/modes/rpc/jsonl.d.ts +17 -0
- package/dist/modes/rpc/jsonl.d.ts.map +1 -0
- package/dist/modes/rpc/jsonl.js +49 -0
- package/dist/modes/rpc/jsonl.js.map +1 -0
- package/dist/modes/rpc/rpc-client.d.ts +227 -0
- package/dist/modes/rpc/rpc-client.d.ts.map +1 -0
- package/dist/modes/rpc/rpc-client.js +466 -0
- package/dist/modes/rpc/rpc-client.js.map +1 -0
- package/dist/modes/rpc/rpc-mode.d.ts +20 -0
- package/dist/modes/rpc/rpc-mode.d.ts.map +1 -0
- package/dist/modes/rpc/rpc-mode.js +613 -0
- package/dist/modes/rpc/rpc-mode.js.map +1 -0
- package/dist/modes/rpc/rpc-types.d.ts +420 -0
- package/dist/modes/rpc/rpc-types.d.ts.map +1 -0
- package/dist/modes/rpc/rpc-types.js +8 -0
- package/dist/modes/rpc/rpc-types.js.map +1 -0
- package/dist/package-manager-cli.d.ts +8 -0
- package/dist/package-manager-cli.d.ts.map +1 -0
- package/dist/package-manager-cli.js +616 -0
- package/dist/package-manager-cli.js.map +1 -0
- package/dist/skills/frontend-design.md +22 -0
- package/dist/skills/using-hamr.md +38 -0
- package/dist/utils/ansi.d.ts +2 -0
- package/dist/utils/ansi.d.ts.map +1 -0
- package/dist/utils/ansi.js +52 -0
- package/dist/utils/ansi.js.map +1 -0
- package/dist/utils/changelog.d.ts +22 -0
- package/dist/utils/changelog.d.ts.map +1 -0
- package/dist/utils/changelog.js +165 -0
- package/dist/utils/changelog.js.map +1 -0
- package/dist/utils/child-process.d.ts +18 -0
- package/dist/utils/child-process.d.ts.map +1 -0
- package/dist/utils/child-process.js +104 -0
- package/dist/utils/child-process.js.map +1 -0
- package/dist/utils/clipboard-image.d.ts +11 -0
- package/dist/utils/clipboard-image.d.ts.map +1 -0
- package/dist/utils/clipboard-image.js +245 -0
- package/dist/utils/clipboard-image.js.map +1 -0
- package/dist/utils/clipboard-native.d.ts +10 -0
- package/dist/utils/clipboard-native.d.ts.map +1 -0
- package/dist/utils/clipboard-native.js +20 -0
- package/dist/utils/clipboard-native.js.map +1 -0
- package/dist/utils/clipboard.d.ts +2 -0
- package/dist/utils/clipboard.d.ts.map +1 -0
- package/dist/utils/clipboard.js +117 -0
- package/dist/utils/clipboard.js.map +1 -0
- package/dist/utils/deprecation.d.ts +4 -0
- package/dist/utils/deprecation.d.ts.map +1 -0
- package/dist/utils/deprecation.js +13 -0
- package/dist/utils/deprecation.js.map +1 -0
- package/dist/utils/exif-orientation.d.ts +5 -0
- package/dist/utils/exif-orientation.d.ts.map +1 -0
- package/dist/utils/exif-orientation.js +158 -0
- package/dist/utils/exif-orientation.js.map +1 -0
- package/dist/utils/frontmatter.d.ts +8 -0
- package/dist/utils/frontmatter.d.ts.map +1 -0
- package/dist/utils/frontmatter.js +26 -0
- package/dist/utils/frontmatter.js.map +1 -0
- package/dist/utils/fs-watch.d.ts +5 -0
- package/dist/utils/fs-watch.d.ts.map +1 -0
- package/dist/utils/fs-watch.js +25 -0
- package/dist/utils/fs-watch.js.map +1 -0
- package/dist/utils/git.d.ts +26 -0
- package/dist/utils/git.d.ts.map +1 -0
- package/dist/utils/git.js +195 -0
- package/dist/utils/git.js.map +1 -0
- package/dist/utils/hamr-user-agent.d.ts +2 -0
- package/dist/utils/hamr-user-agent.d.ts.map +1 -0
- package/dist/utils/hamr-user-agent.js +5 -0
- package/dist/utils/hamr-user-agent.js.map +1 -0
- package/dist/utils/html.d.ts +7 -0
- package/dist/utils/html.d.ts.map +1 -0
- package/dist/utils/html.js +40 -0
- package/dist/utils/html.js.map +1 -0
- package/dist/utils/image-convert.d.ts +9 -0
- package/dist/utils/image-convert.d.ts.map +1 -0
- package/dist/utils/image-convert.js +39 -0
- package/dist/utils/image-convert.js.map +1 -0
- package/dist/utils/image-resize-core.d.ts +30 -0
- package/dist/utils/image-resize-core.d.ts.map +1 -0
- package/dist/utils/image-resize-core.js +124 -0
- package/dist/utils/image-resize-core.js.map +1 -0
- package/dist/utils/image-resize-worker.d.ts +2 -0
- package/dist/utils/image-resize-worker.d.ts.map +1 -0
- package/dist/utils/image-resize-worker.js +31 -0
- package/dist/utils/image-resize-worker.js.map +1 -0
- package/dist/utils/image-resize.d.ts +16 -0
- package/dist/utils/image-resize.d.ts.map +1 -0
- package/dist/utils/image-resize.js +97 -0
- package/dist/utils/image-resize.js.map +1 -0
- package/dist/utils/json.d.ts +3 -0
- package/dist/utils/json.d.ts.map +1 -0
- package/dist/utils/json.js +7 -0
- package/dist/utils/json.js.map +1 -0
- package/dist/utils/mime.d.ts +3 -0
- package/dist/utils/mime.d.ts.map +1 -0
- package/dist/utils/mime.js +69 -0
- package/dist/utils/mime.js.map +1 -0
- package/dist/utils/open-browser.d.ts +9 -0
- package/dist/utils/open-browser.d.ts.map +1 -0
- package/dist/utils/open-browser.js +22 -0
- package/dist/utils/open-browser.js.map +1 -0
- package/dist/utils/paths.d.ts +31 -0
- package/dist/utils/paths.d.ts.map +1 -0
- package/dist/utils/paths.js +91 -0
- package/dist/utils/paths.js.map +1 -0
- package/dist/utils/photon.d.ts +21 -0
- package/dist/utils/photon.d.ts.map +1 -0
- package/dist/utils/photon.js +121 -0
- package/dist/utils/photon.js.map +1 -0
- package/dist/utils/shell.d.ts +30 -0
- package/dist/utils/shell.d.ts.map +1 -0
- package/dist/utils/shell.js +195 -0
- package/dist/utils/shell.js.map +1 -0
- package/dist/utils/sleep.d.ts +5 -0
- package/dist/utils/sleep.d.ts.map +1 -0
- package/dist/utils/sleep.js +17 -0
- package/dist/utils/sleep.js.map +1 -0
- package/dist/utils/syntax-highlight.d.ts +12 -0
- package/dist/utils/syntax-highlight.d.ts.map +1 -0
- package/dist/utils/syntax-highlight.js +118 -0
- package/dist/utils/syntax-highlight.js.map +1 -0
- package/dist/utils/tools-manager.d.ts +3 -0
- package/dist/utils/tools-manager.d.ts.map +1 -0
- package/dist/utils/tools-manager.js +328 -0
- package/dist/utils/tools-manager.js.map +1 -0
- package/dist/utils/version-check.d.ts +20 -0
- package/dist/utils/version-check.d.ts.map +1 -0
- package/dist/utils/version-check.js +92 -0
- package/dist/utils/version-check.js.map +1 -0
- package/dist/utils/windows-self-update.d.ts +3 -0
- package/dist/utils/windows-self-update.d.ts.map +1 -0
- package/dist/utils/windows-self-update.js +77 -0
- package/dist/utils/windows-self-update.js.map +1 -0
- package/docs/compaction.md +394 -0
- package/docs/containerization.md +111 -0
- package/docs/custom-provider.md +736 -0
- package/docs/development.md +71 -0
- package/docs/docs.json +156 -0
- package/docs/extensions.md +2662 -0
- package/docs/images/doom-extension.png +0 -0
- package/docs/images/exy.png +0 -0
- package/docs/images/interactive-mode.png +0 -0
- package/docs/images/tree-view.png +0 -0
- package/docs/index.md +82 -0
- package/docs/json.md +82 -0
- package/docs/keybindings.md +197 -0
- package/docs/models.md +492 -0
- package/docs/packages.md +228 -0
- package/docs/prompt-templates.md +95 -0
- package/docs/providers.md +274 -0
- package/docs/quickstart.md +165 -0
- package/docs/rpc.md +1408 -0
- package/docs/sdk.md +1142 -0
- package/docs/security.md +59 -0
- package/docs/session-format.md +412 -0
- package/docs/sessions.md +145 -0
- package/docs/settings.md +308 -0
- package/docs/shell-aliases.md +13 -0
- package/docs/skills.md +231 -0
- package/docs/terminal-setup.md +148 -0
- package/docs/termux.md +127 -0
- package/docs/themes.md +295 -0
- package/docs/tmux.md +63 -0
- package/docs/tui.md +927 -0
- package/docs/usage.md +305 -0
- package/docs/visual-parity-handoff.md +110 -0
- package/docs/windows.md +17 -0
- package/examples/README.md +25 -0
- package/examples/extensions/README.md +211 -0
- package/examples/extensions/auto-commit-on-exit.ts +49 -0
- package/examples/extensions/bash-spawn-hook.ts +30 -0
- package/examples/extensions/bookmark.ts +50 -0
- package/examples/extensions/border-status-editor.ts +150 -0
- package/examples/extensions/built-in-tool-renderer.ts +249 -0
- package/examples/extensions/claude-rules.ts +86 -0
- package/examples/extensions/commands.ts +72 -0
- package/examples/extensions/confirm-destructive.ts +59 -0
- package/examples/extensions/custom-compaction.ts +127 -0
- package/examples/extensions/custom-footer.ts +64 -0
- package/examples/extensions/custom-header.ts +73 -0
- package/examples/extensions/custom-provider-anthropic/index.ts +604 -0
- package/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
- package/examples/extensions/custom-provider-anthropic/package.json +19 -0
- package/examples/extensions/custom-provider-gitlab-duo/index.ts +400 -0
- package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
- package/examples/extensions/custom-provider-gitlab-duo/test.ts +82 -0
- package/examples/extensions/dirty-repo-guard.ts +56 -0
- package/examples/extensions/doom-overlay/README.md +46 -0
- package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
- package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
- package/examples/extensions/doom-overlay/doom/build.sh +152 -0
- package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
- package/examples/extensions/doom-overlay/doom-component.ts +132 -0
- package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
- package/examples/extensions/doom-overlay/doom-keys.ts +104 -0
- package/examples/extensions/doom-overlay/index.ts +74 -0
- package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
- package/examples/extensions/dynamic-resources/SKILL.md +8 -0
- package/examples/extensions/dynamic-resources/dynamic.json +79 -0
- package/examples/extensions/dynamic-resources/dynamic.md +5 -0
- package/examples/extensions/dynamic-resources/index.ts +15 -0
- package/examples/extensions/dynamic-tools.ts +74 -0
- package/examples/extensions/event-bus.ts +43 -0
- package/examples/extensions/file-trigger.ts +41 -0
- package/examples/extensions/git-checkpoint.ts +53 -0
- package/examples/extensions/git-merge-and-resolve.ts +115 -0
- package/examples/extensions/github-issue-autocomplete.ts +185 -0
- package/examples/extensions/gondolin/index.ts +531 -0
- package/examples/extensions/gondolin/package-lock.json +185 -0
- package/examples/extensions/gondolin/package.json +19 -0
- package/examples/extensions/hamr-browser/README.md +79 -0
- package/examples/extensions/hamr-browser/bun.lock +235 -0
- package/examples/extensions/hamr-browser/index.ts +264 -0
- package/examples/extensions/hamr-browser/package.json +25 -0
- package/examples/extensions/hamr-browser/skills/hamr-browser.md +25 -0
- package/examples/extensions/hamr-browser/src/browser-controller.ts +206 -0
- package/examples/extensions/hamr-browser/src/deps.ts +39 -0
- package/examples/extensions/hamr-browser/src/paths.ts +25 -0
- package/examples/extensions/hamr-browser/src/shims.d.ts +1 -0
- package/examples/extensions/hamr-browser/src/snapshot.ts +84 -0
- package/examples/extensions/hamr-browser/src/targeting.ts +79 -0
- package/examples/extensions/hamr-browser/test/deps.test.ts +23 -0
- package/examples/extensions/hamr-browser/test/paths.test.ts +25 -0
- package/examples/extensions/hamr-browser/test/targeting.test.ts +27 -0
- package/examples/extensions/hamr-browser/tsconfig.json +10 -0
- package/examples/extensions/handoff.ts +191 -0
- package/examples/extensions/hello.ts +26 -0
- package/examples/extensions/hidden-thinking-label.ts +53 -0
- package/examples/extensions/inline-bash.ts +94 -0
- package/examples/extensions/input-transform-streaming.ts +39 -0
- package/examples/extensions/input-transform.ts +43 -0
- package/examples/extensions/interactive-shell.ts +196 -0
- package/examples/extensions/mac-system-theme.ts +47 -0
- package/examples/extensions/message-renderer.ts +59 -0
- package/examples/extensions/minimal-mode.ts +426 -0
- package/examples/extensions/modal-editor.ts +85 -0
- package/examples/extensions/model-status.ts +31 -0
- package/examples/extensions/notify.ts +55 -0
- package/examples/extensions/overlay-qa-tests.ts +1450 -0
- package/examples/extensions/overlay-test.ts +153 -0
- package/examples/extensions/permission-gate.ts +34 -0
- package/examples/extensions/pirate.ts +47 -0
- package/examples/extensions/plan-mode/README.md +65 -0
- package/examples/extensions/plan-mode/index.ts +340 -0
- package/examples/extensions/plan-mode/utils.ts +168 -0
- package/examples/extensions/preset.ts +430 -0
- package/examples/extensions/project-trust.ts +64 -0
- package/examples/extensions/prompt-customizer.ts +97 -0
- package/examples/extensions/protected-paths.ts +30 -0
- package/examples/extensions/provider-payload.ts +18 -0
- package/examples/extensions/qna.ts +122 -0
- package/examples/extensions/question.ts +285 -0
- package/examples/extensions/questionnaire.ts +448 -0
- package/examples/extensions/rainbow-editor.ts +88 -0
- package/examples/extensions/read-loop-guard.ts +32 -0
- package/examples/extensions/reload-runtime.ts +37 -0
- package/examples/extensions/rpc-demo.ts +118 -0
- package/examples/extensions/sandbox/index.ts +321 -0
- package/examples/extensions/sandbox/package-lock.json +92 -0
- package/examples/extensions/sandbox/package.json +19 -0
- package/examples/extensions/send-user-message.ts +97 -0
- package/examples/extensions/session-name.ts +27 -0
- package/examples/extensions/shutdown-command.ts +63 -0
- package/examples/extensions/snake.ts +343 -0
- package/examples/extensions/space-invaders.ts +560 -0
- package/examples/extensions/ssh.ts +220 -0
- package/examples/extensions/status-line.ts +32 -0
- package/examples/extensions/structured-output.ts +65 -0
- package/examples/extensions/subagent/README.md +175 -0
- package/examples/extensions/subagent/agents/planner.md +37 -0
- package/examples/extensions/subagent/agents/reviewer.md +35 -0
- package/examples/extensions/subagent/agents/scout.md +50 -0
- package/examples/extensions/subagent/agents/worker.md +24 -0
- package/examples/extensions/subagent/agents.ts +126 -0
- package/examples/extensions/subagent/index.ts +1009 -0
- package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
- package/examples/extensions/subagent/prompts/implement.md +10 -0
- package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
- package/examples/extensions/summarize.ts +206 -0
- package/examples/extensions/system-prompt-header.ts +17 -0
- package/examples/extensions/tic-tac-toe.ts +1008 -0
- package/examples/extensions/timed-confirm.ts +70 -0
- package/examples/extensions/titlebar-spinner.ts +58 -0
- package/examples/extensions/todo.ts +297 -0
- package/examples/extensions/tool-override.ts +144 -0
- package/examples/extensions/tools.ts +146 -0
- package/examples/extensions/trigger-compact.ts +50 -0
- package/examples/extensions/truncated-tool.ts +195 -0
- package/examples/extensions/widget-placement.ts +9 -0
- package/examples/extensions/with-deps/index.ts +32 -0
- package/examples/extensions/with-deps/package-lock.json +31 -0
- package/examples/extensions/with-deps/package.json +22 -0
- package/examples/extensions/working-indicator.ts +123 -0
- package/examples/extensions/working-message-test.ts +25 -0
- package/examples/rpc-extension-ui.ts +632 -0
- package/examples/sdk/01-minimal.ts +26 -0
- package/examples/sdk/02-custom-model.ts +53 -0
- package/examples/sdk/03-custom-prompt.ts +75 -0
- package/examples/sdk/04-skills.ts +55 -0
- package/examples/sdk/05-tools.ts +48 -0
- package/examples/sdk/06-extensions.ts +99 -0
- package/examples/sdk/07-context-files.ts +47 -0
- package/examples/sdk/08-prompt-templates.ts +51 -0
- package/examples/sdk/09-api-keys-and-oauth.ts +52 -0
- package/examples/sdk/10-settings.ts +53 -0
- package/examples/sdk/11-sessions.ts +52 -0
- package/examples/sdk/12-full-control.ts +77 -0
- package/examples/sdk/13-session-runtime.ts +67 -0
- package/examples/sdk/README.md +144 -0
- package/node_modules/@hamr/agent/dist/agent-loop.d.ts +24 -0
- package/node_modules/@hamr/agent/dist/agent-loop.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/agent-loop.js +510 -0
- package/node_modules/@hamr/agent/dist/agent-loop.js.map +1 -0
- package/node_modules/@hamr/agent/dist/agent.d.ts +125 -0
- package/node_modules/@hamr/agent/dist/agent.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/agent.js +378 -0
- package/node_modules/@hamr/agent/dist/agent.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/agent-harness.d.ts +95 -0
- package/node_modules/@hamr/agent/dist/harness/agent-harness.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/agent-harness.js +950 -0
- package/node_modules/@hamr/agent/dist/harness/agent-harness.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/branch-summarization.d.ts +53 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/branch-summarization.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/branch-summarization.js +175 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/branch-summarization.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/compaction.d.ts +95 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/compaction.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/compaction.js +528 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/compaction.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/utils.d.ts +25 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/utils.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/utils.js +131 -0
- package/node_modules/@hamr/agent/dist/harness/compaction/utils.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/env/nodejs.d.ts +51 -0
- package/node_modules/@hamr/agent/dist/harness/env/nodejs.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/env/nodejs.js +483 -0
- package/node_modules/@hamr/agent/dist/harness/env/nodejs.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/messages.d.ts +51 -0
- package/node_modules/@hamr/agent/dist/harness/messages.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/messages.js +102 -0
- package/node_modules/@hamr/agent/dist/harness/messages.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/prompt-templates.d.ts +48 -0
- package/node_modules/@hamr/agent/dist/harness/prompt-templates.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/prompt-templates.js +230 -0
- package/node_modules/@hamr/agent/dist/harness/prompt-templates.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-repo.d.ts +26 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-repo.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-repo.js +95 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-repo.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-storage.d.ts +33 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-storage.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-storage.js +224 -0
- package/node_modules/@hamr/agent/dist/harness/session/jsonl-storage.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-repo.d.ts +18 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-repo.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-repo.js +44 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-repo.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-storage.d.ts +25 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-storage.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-storage.js +109 -0
- package/node_modules/@hamr/agent/dist/harness/session/memory-storage.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/repo-utils.d.ts +11 -0
- package/node_modules/@hamr/agent/dist/harness/session/repo-utils.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/repo-utils.js +39 -0
- package/node_modules/@hamr/agent/dist/harness/session/repo-utils.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/session.d.ts +33 -0
- package/node_modules/@hamr/agent/dist/harness/session/session.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/session.js +209 -0
- package/node_modules/@hamr/agent/dist/harness/session/session.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/uuid.d.ts +2 -0
- package/node_modules/@hamr/agent/dist/harness/session/uuid.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/session/uuid.js +50 -0
- package/node_modules/@hamr/agent/dist/harness/session/uuid.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/skills.d.ts +44 -0
- package/node_modules/@hamr/agent/dist/harness/skills.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/skills.js +311 -0
- package/node_modules/@hamr/agent/dist/harness/skills.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/system-prompt.d.ts +3 -0
- package/node_modules/@hamr/agent/dist/harness/system-prompt.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/system-prompt.js +30 -0
- package/node_modules/@hamr/agent/dist/harness/system-prompt.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/types.d.ts +615 -0
- package/node_modules/@hamr/agent/dist/harness/types.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/types.js +81 -0
- package/node_modules/@hamr/agent/dist/harness/types.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/utils/shell-output.d.ts +14 -0
- package/node_modules/@hamr/agent/dist/harness/utils/shell-output.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/utils/shell-output.js +126 -0
- package/node_modules/@hamr/agent/dist/harness/utils/shell-output.js.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/utils/truncate.d.ts +70 -0
- package/node_modules/@hamr/agent/dist/harness/utils/truncate.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/harness/utils/truncate.js +290 -0
- package/node_modules/@hamr/agent/dist/harness/utils/truncate.js.map +1 -0
- package/node_modules/@hamr/agent/dist/index.d.ts +20 -0
- package/node_modules/@hamr/agent/dist/index.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/index.js +25 -0
- package/node_modules/@hamr/agent/dist/index.js.map +1 -0
- package/node_modules/@hamr/agent/dist/node.d.ts +3 -0
- package/node_modules/@hamr/agent/dist/node.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/node.js +3 -0
- package/node_modules/@hamr/agent/dist/node.js.map +1 -0
- package/node_modules/@hamr/agent/dist/proxy.d.ts +69 -0
- package/node_modules/@hamr/agent/dist/proxy.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/proxy.js +278 -0
- package/node_modules/@hamr/agent/dist/proxy.js.map +1 -0
- package/node_modules/@hamr/agent/dist/types.d.ts +405 -0
- package/node_modules/@hamr/agent/dist/types.d.ts.map +1 -0
- package/node_modules/@hamr/agent/dist/types.js +2 -0
- package/node_modules/@hamr/agent/dist/types.js.map +1 -0
- package/node_modules/@hamr/agent/package.json +51 -0
- package/node_modules/@hamr/ai/dist/api-registry.d.ts +20 -0
- package/node_modules/@hamr/ai/dist/api-registry.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/api-registry.js +44 -0
- package/node_modules/@hamr/ai/dist/api-registry.js.map +1 -0
- package/node_modules/@hamr/ai/dist/bedrock-provider.d.ts +5 -0
- package/node_modules/@hamr/ai/dist/bedrock-provider.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/bedrock-provider.js +6 -0
- package/node_modules/@hamr/ai/dist/bedrock-provider.js.map +1 -0
- package/node_modules/@hamr/ai/dist/cli.d.ts +3 -0
- package/node_modules/@hamr/ai/dist/cli.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/cli.js +130 -0
- package/node_modules/@hamr/ai/dist/cli.js.map +1 -0
- package/node_modules/@hamr/ai/dist/env-api-keys.d.ts +20 -0
- package/node_modules/@hamr/ai/dist/env-api-keys.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/env-api-keys.js +163 -0
- package/node_modules/@hamr/ai/dist/env-api-keys.js.map +1 -0
- package/node_modules/@hamr/ai/dist/image-models.d.ts +10 -0
- package/node_modules/@hamr/ai/dist/image-models.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/image-models.generated.d.ts +515 -0
- package/node_modules/@hamr/ai/dist/image-models.generated.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/image-models.generated.js +517 -0
- package/node_modules/@hamr/ai/dist/image-models.generated.js.map +1 -0
- package/node_modules/@hamr/ai/dist/image-models.js +23 -0
- package/node_modules/@hamr/ai/dist/image-models.js.map +1 -0
- package/node_modules/@hamr/ai/dist/images-api-registry.d.ts +14 -0
- package/node_modules/@hamr/ai/dist/images-api-registry.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/images-api-registry.js +22 -0
- package/node_modules/@hamr/ai/dist/images-api-registry.js.map +1 -0
- package/node_modules/@hamr/ai/dist/images.d.ts +4 -0
- package/node_modules/@hamr/ai/dist/images.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/images.js +14 -0
- package/node_modules/@hamr/ai/dist/images.js.map +1 -0
- package/node_modules/@hamr/ai/dist/index.d.ts +32 -0
- package/node_modules/@hamr/ai/dist/index.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/index.js +20 -0
- package/node_modules/@hamr/ai/dist/index.js.map +1 -0
- package/node_modules/@hamr/ai/dist/models.d.ts +18 -0
- package/node_modules/@hamr/ai/dist/models.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/models.generated.d.ts +18774 -0
- package/node_modules/@hamr/ai/dist/models.generated.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/models.generated.js +17803 -0
- package/node_modules/@hamr/ai/dist/models.generated.js.map +1 -0
- package/node_modules/@hamr/ai/dist/models.js +74 -0
- package/node_modules/@hamr/ai/dist/models.js.map +1 -0
- package/node_modules/@hamr/ai/dist/oauth.d.ts +2 -0
- package/node_modules/@hamr/ai/dist/oauth.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/oauth.js +2 -0
- package/node_modules/@hamr/ai/dist/oauth.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/amazon-bedrock.d.ts +38 -0
- package/node_modules/@hamr/ai/dist/providers/amazon-bedrock.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/amazon-bedrock.js +860 -0
- package/node_modules/@hamr/ai/dist/providers/amazon-bedrock.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/anthropic.d.ts +71 -0
- package/node_modules/@hamr/ai/dist/providers/anthropic.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/anthropic.js +966 -0
- package/node_modules/@hamr/ai/dist/providers/anthropic.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/azure-openai-responses.d.ts +15 -0
- package/node_modules/@hamr/ai/dist/providers/azure-openai-responses.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/azure-openai-responses.js +225 -0
- package/node_modules/@hamr/ai/dist/providers/azure-openai-responses.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/cloudflare.d.ts +13 -0
- package/node_modules/@hamr/ai/dist/providers/cloudflare.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/cloudflare.js +27 -0
- package/node_modules/@hamr/ai/dist/providers/cloudflare.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/faux.d.ts +56 -0
- package/node_modules/@hamr/ai/dist/providers/faux.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/faux.js +368 -0
- package/node_modules/@hamr/ai/dist/providers/faux.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/github-copilot-headers.d.ts +8 -0
- package/node_modules/@hamr/ai/dist/providers/github-copilot-headers.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/github-copilot-headers.js +29 -0
- package/node_modules/@hamr/ai/dist/providers/github-copilot-headers.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/google-shared.d.ts +70 -0
- package/node_modules/@hamr/ai/dist/providers/google-shared.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/google-shared.js +329 -0
- package/node_modules/@hamr/ai/dist/providers/google-shared.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/google-vertex.d.ts +15 -0
- package/node_modules/@hamr/ai/dist/providers/google-vertex.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/google-vertex.js +452 -0
- package/node_modules/@hamr/ai/dist/providers/google-vertex.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/google.d.ts +13 -0
- package/node_modules/@hamr/ai/dist/providers/google.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/google.js +403 -0
- package/node_modules/@hamr/ai/dist/providers/google.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/images/openrouter.d.ts +3 -0
- package/node_modules/@hamr/ai/dist/providers/images/openrouter.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/images/openrouter.js +128 -0
- package/node_modules/@hamr/ai/dist/providers/images/openrouter.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/images/register-builtins.d.ts +4 -0
- package/node_modules/@hamr/ai/dist/providers/images/register-builtins.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/images/register-builtins.js +34 -0
- package/node_modules/@hamr/ai/dist/providers/images/register-builtins.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/mistral.d.ts +25 -0
- package/node_modules/@hamr/ai/dist/providers/mistral.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/mistral.js +534 -0
- package/node_modules/@hamr/ai/dist/providers/mistral.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-codex-responses.d.ts +30 -0
- package/node_modules/@hamr/ai/dist/providers/openai-codex-responses.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-codex-responses.js +1164 -0
- package/node_modules/@hamr/ai/dist/providers/openai-codex-responses.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-completions.d.ts +19 -0
- package/node_modules/@hamr/ai/dist/providers/openai-completions.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-completions.js +1201 -0
- package/node_modules/@hamr/ai/dist/providers/openai-completions.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-prompt-cache.d.ts +3 -0
- package/node_modules/@hamr/ai/dist/providers/openai-prompt-cache.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-prompt-cache.js +10 -0
- package/node_modules/@hamr/ai/dist/providers/openai-prompt-cache.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses-shared.d.ts +18 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses-shared.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses-shared.js +494 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses-shared.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses.d.ts +13 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses.js +235 -0
- package/node_modules/@hamr/ai/dist/providers/openai-responses.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/register-builtins.d.ts +35 -0
- package/node_modules/@hamr/ai/dist/providers/register-builtins.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/register-builtins.js +254 -0
- package/node_modules/@hamr/ai/dist/providers/register-builtins.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/simple-options.d.ts +8 -0
- package/node_modules/@hamr/ai/dist/providers/simple-options.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/simple-options.js +43 -0
- package/node_modules/@hamr/ai/dist/providers/simple-options.js.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/transform-messages.d.ts +8 -0
- package/node_modules/@hamr/ai/dist/providers/transform-messages.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/providers/transform-messages.js +182 -0
- package/node_modules/@hamr/ai/dist/providers/transform-messages.js.map +1 -0
- package/node_modules/@hamr/ai/dist/session-resources.d.ts +4 -0
- package/node_modules/@hamr/ai/dist/session-resources.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/session-resources.js +22 -0
- package/node_modules/@hamr/ai/dist/session-resources.js.map +1 -0
- package/node_modules/@hamr/ai/dist/stream.d.ts +8 -0
- package/node_modules/@hamr/ai/dist/stream.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/stream.js +39 -0
- package/node_modules/@hamr/ai/dist/stream.js.map +1 -0
- package/node_modules/@hamr/ai/dist/types.d.ts +526 -0
- package/node_modules/@hamr/ai/dist/types.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/types.js +2 -0
- package/node_modules/@hamr/ai/dist/types.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/abort-signals.d.ts +6 -0
- package/node_modules/@hamr/ai/dist/utils/abort-signals.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/abort-signals.js +34 -0
- package/node_modules/@hamr/ai/dist/utils/abort-signals.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/diagnostics.d.ts +19 -0
- package/node_modules/@hamr/ai/dist/utils/diagnostics.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/diagnostics.js +25 -0
- package/node_modules/@hamr/ai/dist/utils/diagnostics.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/event-stream.d.ts +21 -0
- package/node_modules/@hamr/ai/dist/utils/event-stream.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/event-stream.js +77 -0
- package/node_modules/@hamr/ai/dist/utils/event-stream.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/hash.d.ts +3 -0
- package/node_modules/@hamr/ai/dist/utils/hash.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/hash.js +14 -0
- package/node_modules/@hamr/ai/dist/utils/hash.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/headers.d.ts +2 -0
- package/node_modules/@hamr/ai/dist/utils/headers.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/headers.js +8 -0
- package/node_modules/@hamr/ai/dist/utils/headers.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/json-parse.d.ts +16 -0
- package/node_modules/@hamr/ai/dist/utils/json-parse.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/json-parse.js +113 -0
- package/node_modules/@hamr/ai/dist/utils/json-parse.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/node-http-proxy.d.ts +4 -0
- package/node_modules/@hamr/ai/dist/utils/node-http-proxy.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/node-http-proxy.js +92 -0
- package/node_modules/@hamr/ai/dist/utils/node-http-proxy.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/anthropic.d.ts +25 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/anthropic.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/anthropic.js +336 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/anthropic.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/device-code.d.ts +21 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/device-code.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/device-code.js +56 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/device-code.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/github-copilot.d.ts +30 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/github-copilot.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/github-copilot.js +280 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/github-copilot.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/index.d.ts +58 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/index.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/index.js +122 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/index.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/oauth-page.d.ts +3 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/oauth-page.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/oauth-page.js +118 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/oauth-page.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/openai-codex.d.ts +43 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/openai-codex.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/openai-codex.js +488 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/openai-codex.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/pkce.d.ts +13 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/pkce.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/pkce.js +31 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/pkce.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/types.d.ts +64 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/types.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/types.js +2 -0
- package/node_modules/@hamr/ai/dist/utils/oauth/types.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/overflow.d.ts +57 -0
- package/node_modules/@hamr/ai/dist/utils/overflow.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/overflow.js +155 -0
- package/node_modules/@hamr/ai/dist/utils/overflow.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/provider-env.d.ts +7 -0
- package/node_modules/@hamr/ai/dist/utils/provider-env.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/provider-env.js +44 -0
- package/node_modules/@hamr/ai/dist/utils/provider-env.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/sanitize-unicode.d.ts +22 -0
- package/node_modules/@hamr/ai/dist/utils/sanitize-unicode.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/sanitize-unicode.js +26 -0
- package/node_modules/@hamr/ai/dist/utils/sanitize-unicode.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/typebox-helpers.d.ts +17 -0
- package/node_modules/@hamr/ai/dist/utils/typebox-helpers.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/typebox-helpers.js +21 -0
- package/node_modules/@hamr/ai/dist/utils/typebox-helpers.js.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/validation.d.ts +18 -0
- package/node_modules/@hamr/ai/dist/utils/validation.d.ts.map +1 -0
- package/node_modules/@hamr/ai/dist/utils/validation.js +281 -0
- package/node_modules/@hamr/ai/dist/utils/validation.js.map +1 -0
- package/node_modules/@hamr/ai/package.json +93 -0
- package/node_modules/@hamr/tui/dist/autocomplete.d.ts +56 -0
- package/node_modules/@hamr/tui/dist/autocomplete.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/autocomplete.js +629 -0
- package/node_modules/@hamr/tui/dist/autocomplete.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/box.d.ts +23 -0
- package/node_modules/@hamr/tui/dist/components/box.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/box.js +105 -0
- package/node_modules/@hamr/tui/dist/components/box.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/cancellable-loader.d.ts +22 -0
- package/node_modules/@hamr/tui/dist/components/cancellable-loader.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/cancellable-loader.js +36 -0
- package/node_modules/@hamr/tui/dist/components/cancellable-loader.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/editor.d.ts +255 -0
- package/node_modules/@hamr/tui/dist/components/editor.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/editor.js +1905 -0
- package/node_modules/@hamr/tui/dist/components/editor.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/image.d.ts +28 -0
- package/node_modules/@hamr/tui/dist/components/image.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/image.js +81 -0
- package/node_modules/@hamr/tui/dist/components/image.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/input.d.ts +37 -0
- package/node_modules/@hamr/tui/dist/components/input.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/input.js +378 -0
- package/node_modules/@hamr/tui/dist/components/input.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/loader.d.ts +31 -0
- package/node_modules/@hamr/tui/dist/components/loader.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/loader.js +67 -0
- package/node_modules/@hamr/tui/dist/components/loader.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/markdown.d.ts +97 -0
- package/node_modules/@hamr/tui/dist/components/markdown.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/markdown.js +643 -0
- package/node_modules/@hamr/tui/dist/components/markdown.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/select-list.d.ts +50 -0
- package/node_modules/@hamr/tui/dist/components/select-list.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/select-list.js +154 -0
- package/node_modules/@hamr/tui/dist/components/select-list.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/settings-list.d.ts +53 -0
- package/node_modules/@hamr/tui/dist/components/settings-list.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/settings-list.js +185 -0
- package/node_modules/@hamr/tui/dist/components/settings-list.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/spacer.d.ts +12 -0
- package/node_modules/@hamr/tui/dist/components/spacer.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/spacer.js +22 -0
- package/node_modules/@hamr/tui/dist/components/spacer.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/text.d.ts +21 -0
- package/node_modules/@hamr/tui/dist/components/text.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/text.js +97 -0
- package/node_modules/@hamr/tui/dist/components/text.js.map +1 -0
- package/node_modules/@hamr/tui/dist/components/truncated-text.d.ts +13 -0
- package/node_modules/@hamr/tui/dist/components/truncated-text.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/components/truncated-text.js +48 -0
- package/node_modules/@hamr/tui/dist/components/truncated-text.js.map +1 -0
- package/node_modules/@hamr/tui/dist/editor-component.d.ts +39 -0
- package/node_modules/@hamr/tui/dist/editor-component.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/editor-component.js +2 -0
- package/node_modules/@hamr/tui/dist/editor-component.js.map +1 -0
- package/node_modules/@hamr/tui/dist/fuzzy.d.ts +16 -0
- package/node_modules/@hamr/tui/dist/fuzzy.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/fuzzy.js +110 -0
- package/node_modules/@hamr/tui/dist/fuzzy.js.map +1 -0
- package/node_modules/@hamr/tui/dist/index.d.ts +24 -0
- package/node_modules/@hamr/tui/dist/index.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/index.js +34 -0
- package/node_modules/@hamr/tui/dist/index.js.map +1 -0
- package/node_modules/@hamr/tui/dist/keybindings.d.ts +193 -0
- package/node_modules/@hamr/tui/dist/keybindings.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/keybindings.js +172 -0
- package/node_modules/@hamr/tui/dist/keybindings.js.map +1 -0
- package/node_modules/@hamr/tui/dist/keys.d.ts +184 -0
- package/node_modules/@hamr/tui/dist/keys.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/keys.js +1168 -0
- package/node_modules/@hamr/tui/dist/keys.js.map +1 -0
- package/node_modules/@hamr/tui/dist/kill-ring.d.ts +28 -0
- package/node_modules/@hamr/tui/dist/kill-ring.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/kill-ring.js +46 -0
- package/node_modules/@hamr/tui/dist/kill-ring.js.map +1 -0
- package/node_modules/@hamr/tui/dist/native-modifiers.d.ts +3 -0
- package/node_modules/@hamr/tui/dist/native-modifiers.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/native-modifiers.js +53 -0
- package/node_modules/@hamr/tui/dist/native-modifiers.js.map +1 -0
- package/node_modules/@hamr/tui/dist/stdin-buffer.d.ts +50 -0
- package/node_modules/@hamr/tui/dist/stdin-buffer.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/stdin-buffer.js +359 -0
- package/node_modules/@hamr/tui/dist/stdin-buffer.js.map +1 -0
- package/node_modules/@hamr/tui/dist/terminal-colors.d.ts +8 -0
- package/node_modules/@hamr/tui/dist/terminal-colors.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/terminal-colors.js +51 -0
- package/node_modules/@hamr/tui/dist/terminal-colors.js.map +1 -0
- package/node_modules/@hamr/tui/dist/terminal-image.d.ts +90 -0
- package/node_modules/@hamr/tui/dist/terminal-image.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/terminal-image.js +366 -0
- package/node_modules/@hamr/tui/dist/terminal-image.js.map +1 -0
- package/node_modules/@hamr/tui/dist/terminal.d.ts +110 -0
- package/node_modules/@hamr/tui/dist/terminal.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/terminal.js +429 -0
- package/node_modules/@hamr/tui/dist/terminal.js.map +1 -0
- package/node_modules/@hamr/tui/dist/tui.d.ts +255 -0
- package/node_modules/@hamr/tui/dist/tui.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/tui.js +1343 -0
- package/node_modules/@hamr/tui/dist/tui.js.map +1 -0
- package/node_modules/@hamr/tui/dist/undo-stack.d.ts +17 -0
- package/node_modules/@hamr/tui/dist/undo-stack.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/undo-stack.js +27 -0
- package/node_modules/@hamr/tui/dist/undo-stack.js.map +1 -0
- package/node_modules/@hamr/tui/dist/utils.d.ts +85 -0
- package/node_modules/@hamr/tui/dist/utils.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/utils.js +1062 -0
- package/node_modules/@hamr/tui/dist/utils.js.map +1 -0
- package/node_modules/@hamr/tui/dist/word-navigation.d.ts +25 -0
- package/node_modules/@hamr/tui/dist/word-navigation.d.ts.map +1 -0
- package/node_modules/@hamr/tui/dist/word-navigation.js +96 -0
- package/node_modules/@hamr/tui/dist/word-navigation.js.map +1 -0
- package/node_modules/@hamr/tui/package.json +42 -0
- package/node_modules/protobufjs/LICENSE +39 -0
- package/node_modules/protobufjs/README.md +727 -0
- package/node_modules/protobufjs/dist/light/protobuf.js +8041 -0
- package/node_modules/protobufjs/dist/light/protobuf.js.map +1 -0
- package/node_modules/protobufjs/dist/light/protobuf.min.js +8 -0
- package/node_modules/protobufjs/dist/light/protobuf.min.js.map +1 -0
- package/node_modules/protobufjs/dist/minimal/protobuf.js +2791 -0
- package/node_modules/protobufjs/dist/minimal/protobuf.js.map +1 -0
- package/node_modules/protobufjs/dist/minimal/protobuf.min.js +8 -0
- package/node_modules/protobufjs/dist/minimal/protobuf.min.js.map +1 -0
- package/node_modules/protobufjs/dist/protobuf.js +9865 -0
- package/node_modules/protobufjs/dist/protobuf.js.map +1 -0
- package/node_modules/protobufjs/dist/protobuf.min.js +8 -0
- package/node_modules/protobufjs/dist/protobuf.min.js.map +1 -0
- package/node_modules/protobufjs/ext/debug/README.md +4 -0
- package/node_modules/protobufjs/ext/debug/index.js +71 -0
- package/node_modules/protobufjs/ext/descriptor/README.md +72 -0
- package/node_modules/protobufjs/ext/descriptor/index.d.ts +195 -0
- package/node_modules/protobufjs/ext/descriptor/index.js +1186 -0
- package/node_modules/protobufjs/ext/descriptor/test.js +54 -0
- package/node_modules/protobufjs/google/LICENSE +27 -0
- package/node_modules/protobufjs/google/README.md +1 -0
- package/node_modules/protobufjs/google/api/annotations.json +83 -0
- package/node_modules/protobufjs/google/api/annotations.proto +11 -0
- package/node_modules/protobufjs/google/api/http.json +86 -0
- package/node_modules/protobufjs/google/api/http.proto +31 -0
- package/node_modules/protobufjs/google/protobuf/api.json +118 -0
- package/node_modules/protobufjs/google/protobuf/api.proto +34 -0
- package/node_modules/protobufjs/google/protobuf/descriptor.json +1382 -0
- package/node_modules/protobufjs/google/protobuf/descriptor.proto +535 -0
- package/node_modules/protobufjs/google/protobuf/source_context.json +20 -0
- package/node_modules/protobufjs/google/protobuf/source_context.proto +7 -0
- package/node_modules/protobufjs/google/protobuf/type.json +202 -0
- package/node_modules/protobufjs/google/protobuf/type.proto +89 -0
- package/node_modules/protobufjs/index.d.ts +2832 -0
- package/node_modules/protobufjs/index.js +4 -0
- package/node_modules/protobufjs/light.d.ts +2 -0
- package/node_modules/protobufjs/light.js +4 -0
- package/node_modules/protobufjs/minimal.d.ts +2 -0
- package/node_modules/protobufjs/minimal.js +4 -0
- package/node_modules/protobufjs/package.json +118 -0
- package/node_modules/protobufjs/scripts/postinstall.js +32 -0
- package/node_modules/protobufjs/src/common.js +399 -0
- package/node_modules/protobufjs/src/converter.js +318 -0
- package/node_modules/protobufjs/src/decoder.js +135 -0
- package/node_modules/protobufjs/src/encoder.js +103 -0
- package/node_modules/protobufjs/src/enum.js +226 -0
- package/node_modules/protobufjs/src/field.js +453 -0
- package/node_modules/protobufjs/src/index-light.js +104 -0
- package/node_modules/protobufjs/src/index-minimal.js +36 -0
- package/node_modules/protobufjs/src/index.js +12 -0
- package/node_modules/protobufjs/src/mapfield.js +126 -0
- package/node_modules/protobufjs/src/message.js +143 -0
- package/node_modules/protobufjs/src/method.js +160 -0
- package/node_modules/protobufjs/src/namespace.js +558 -0
- package/node_modules/protobufjs/src/object.js +382 -0
- package/node_modules/protobufjs/src/oneof.js +222 -0
- package/node_modules/protobufjs/src/parse.js +989 -0
- package/node_modules/protobufjs/src/reader.js +426 -0
- package/node_modules/protobufjs/src/reader_buffer.js +51 -0
- package/node_modules/protobufjs/src/root.js +412 -0
- package/node_modules/protobufjs/src/roots.js +18 -0
- package/node_modules/protobufjs/src/rpc/service.js +142 -0
- package/node_modules/protobufjs/src/rpc.js +36 -0
- package/node_modules/protobufjs/src/service.js +193 -0
- package/node_modules/protobufjs/src/tokenize.js +416 -0
- package/node_modules/protobufjs/src/type.js +632 -0
- package/node_modules/protobufjs/src/types.js +196 -0
- package/node_modules/protobufjs/src/typescript.jsdoc +15 -0
- package/node_modules/protobufjs/src/util/fs.js +11 -0
- package/node_modules/protobufjs/src/util/longbits.js +200 -0
- package/node_modules/protobufjs/src/util/minimal.js +491 -0
- package/node_modules/protobufjs/src/util/patterns.js +7 -0
- package/node_modules/protobufjs/src/util.js +230 -0
- package/node_modules/protobufjs/src/verifier.js +180 -0
- package/node_modules/protobufjs/src/wrappers.js +107 -0
- package/node_modules/protobufjs/src/writer.js +467 -0
- package/node_modules/protobufjs/src/writer_buffer.js +85 -0
- package/node_modules/protobufjs/tsconfig.json +8 -0
- package/package.json +91 -0
- package/skills/frontend-design.md +22 -0
- package/skills/using-hamr.md +38 -0
|
@@ -0,0 +1,289 @@
|
|
|
1
|
+
import { Box, Container, Spacer, Text } from "@hamr/tui";
|
|
2
|
+
import { constants } from "fs";
|
|
3
|
+
import { access as fsAccess, readFile as fsReadFile, writeFile as fsWriteFile } from "fs/promises";
|
|
4
|
+
import { Type } from "typebox";
|
|
5
|
+
import { createDiffComponent } from "../../modes/interactive/components/diff.js";
|
|
6
|
+
import { applyEditsToNormalizedContent, computeEditsDiff, detectLineEnding, generateDiffString, generateUnifiedPatch, normalizeToLF, restoreLineEndings, stripBom, } from "./edit-diff.js";
|
|
7
|
+
import { withFileMutationQueue } from "./file-mutation-queue.js";
|
|
8
|
+
import { resolveToCwd } from "./path-utils.js";
|
|
9
|
+
import { renderToolPath, str } from "./render-utils.js";
|
|
10
|
+
import { wrapToolDefinition } from "./tool-definition-wrapper.js";
|
|
11
|
+
const replaceEditSchema = Type.Object({
|
|
12
|
+
oldText: Type.String({
|
|
13
|
+
description: "Exact text for one targeted replacement. It must be unique in the original file and must not overlap with any other edits[].oldText in the same call.",
|
|
14
|
+
}),
|
|
15
|
+
newText: Type.String({ description: "Replacement text for this targeted edit." }),
|
|
16
|
+
}, { additionalProperties: false });
|
|
17
|
+
const editSchema = Type.Object({
|
|
18
|
+
path: Type.String({ description: "Path to the file to edit (relative or absolute)" }),
|
|
19
|
+
edits: Type.Array(replaceEditSchema, {
|
|
20
|
+
description: "One or more targeted replacements. Each edit is matched against the original file, not incrementally. Do not include overlapping or nested edits. If two changes touch the same block or nearby lines, merge them into one edit instead.",
|
|
21
|
+
}),
|
|
22
|
+
}, { additionalProperties: false });
|
|
23
|
+
const defaultEditOperations = {
|
|
24
|
+
readFile: (path) => fsReadFile(path),
|
|
25
|
+
writeFile: (path, content) => fsWriteFile(path, content, "utf-8"),
|
|
26
|
+
access: (path) => fsAccess(path, constants.R_OK | constants.W_OK),
|
|
27
|
+
};
|
|
28
|
+
function prepareEditArguments(input) {
|
|
29
|
+
if (!input || typeof input !== "object") {
|
|
30
|
+
return input;
|
|
31
|
+
}
|
|
32
|
+
const args = input;
|
|
33
|
+
// Some models (Opus 4.6, GLM-5.1) send edits as a JSON string instead of an array
|
|
34
|
+
if (typeof args.edits === "string") {
|
|
35
|
+
try {
|
|
36
|
+
const parsed = JSON.parse(args.edits);
|
|
37
|
+
if (Array.isArray(parsed))
|
|
38
|
+
args.edits = parsed;
|
|
39
|
+
}
|
|
40
|
+
catch { }
|
|
41
|
+
}
|
|
42
|
+
const legacy = args;
|
|
43
|
+
if (typeof legacy.oldText !== "string" || typeof legacy.newText !== "string") {
|
|
44
|
+
return args;
|
|
45
|
+
}
|
|
46
|
+
const edits = Array.isArray(legacy.edits) ? [...legacy.edits] : [];
|
|
47
|
+
edits.push({ oldText: legacy.oldText, newText: legacy.newText });
|
|
48
|
+
const { oldText: _oldText, newText: _newText, ...rest } = legacy;
|
|
49
|
+
return { ...rest, edits };
|
|
50
|
+
}
|
|
51
|
+
function validateEditInput(input) {
|
|
52
|
+
if (!Array.isArray(input.edits) || input.edits.length === 0) {
|
|
53
|
+
throw new Error("Edit tool input is invalid. edits must contain at least one replacement.");
|
|
54
|
+
}
|
|
55
|
+
return { path: input.path, edits: input.edits };
|
|
56
|
+
}
|
|
57
|
+
function createEditCallRenderComponent() {
|
|
58
|
+
return Object.assign(new Container(), {
|
|
59
|
+
preview: undefined,
|
|
60
|
+
previewArgsKey: undefined,
|
|
61
|
+
previewPending: false,
|
|
62
|
+
settledError: false,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
function getEditCallRenderComponent(state, lastComponent) {
|
|
66
|
+
if (lastComponent instanceof Container) {
|
|
67
|
+
const component = lastComponent;
|
|
68
|
+
state.callComponent = component;
|
|
69
|
+
return component;
|
|
70
|
+
}
|
|
71
|
+
if (state.callComponent) {
|
|
72
|
+
return state.callComponent;
|
|
73
|
+
}
|
|
74
|
+
const component = createEditCallRenderComponent();
|
|
75
|
+
state.callComponent = component;
|
|
76
|
+
return component;
|
|
77
|
+
}
|
|
78
|
+
function getRenderablePreviewInput(args) {
|
|
79
|
+
if (!args) {
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
const path = typeof args.path === "string" ? args.path : typeof args.file_path === "string" ? args.file_path : null;
|
|
83
|
+
if (!path) {
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
86
|
+
if (Array.isArray(args.edits) &&
|
|
87
|
+
args.edits.length > 0 &&
|
|
88
|
+
args.edits.every((edit) => typeof edit?.oldText === "string" && typeof edit?.newText === "string")) {
|
|
89
|
+
return { path, edits: args.edits };
|
|
90
|
+
}
|
|
91
|
+
if (typeof args.oldText === "string" && typeof args.newText === "string") {
|
|
92
|
+
return { path, edits: [{ oldText: args.oldText, newText: args.newText }] };
|
|
93
|
+
}
|
|
94
|
+
return null;
|
|
95
|
+
}
|
|
96
|
+
function formatEditCall(args, theme, cwd) {
|
|
97
|
+
const pathDisplay = renderToolPath(str(args?.file_path ?? args?.path), theme, cwd);
|
|
98
|
+
return `${theme.fg("toolTitle", theme.bold("edit"))} ${pathDisplay}`;
|
|
99
|
+
}
|
|
100
|
+
function buildEditResultBody(args, preview, result, theme, isError) {
|
|
101
|
+
const rawPath = str(args?.file_path ?? args?.path);
|
|
102
|
+
const previewDiff = preview && !("error" in preview) ? preview.diff : undefined;
|
|
103
|
+
const previewError = preview && "error" in preview ? preview.error : undefined;
|
|
104
|
+
if (isError) {
|
|
105
|
+
const errorText = result.content
|
|
106
|
+
.filter((c) => c.type === "text")
|
|
107
|
+
.map((c) => c.text || "")
|
|
108
|
+
.join("\n");
|
|
109
|
+
if (!errorText || errorText === previewError) {
|
|
110
|
+
return undefined;
|
|
111
|
+
}
|
|
112
|
+
return new Text(theme.fg("error", errorText), theme.cards.toolResultIndent, 0);
|
|
113
|
+
}
|
|
114
|
+
const resultDiff = result.details?.diff;
|
|
115
|
+
if (resultDiff && resultDiff !== previewDiff) {
|
|
116
|
+
return createDiffComponent(resultDiff, { filePath: rawPath ?? undefined });
|
|
117
|
+
}
|
|
118
|
+
return undefined;
|
|
119
|
+
}
|
|
120
|
+
function getEditSurfaceBgToken(preview, settledError, theme) {
|
|
121
|
+
if (!theme.cards.shadedSurfaces) {
|
|
122
|
+
return undefined;
|
|
123
|
+
}
|
|
124
|
+
if (preview) {
|
|
125
|
+
return "error" in preview ? "toolErrorBg" : "toolSuccessBg";
|
|
126
|
+
}
|
|
127
|
+
if (settledError) {
|
|
128
|
+
return "toolErrorBg";
|
|
129
|
+
}
|
|
130
|
+
return "toolPendingBg";
|
|
131
|
+
}
|
|
132
|
+
function buildEditCallComponent(component, args, theme, cwd) {
|
|
133
|
+
component.clear();
|
|
134
|
+
const surfaceBg = getEditSurfaceBgToken(component.preview, component.settledError, theme);
|
|
135
|
+
const card = new Box(theme.cards.cardPadX, theme.cards.cardPadY, surfaceBg ? (text) => theme.bg(surfaceBg, text) : undefined);
|
|
136
|
+
card.addChild(new Text(formatEditCall(args, theme, cwd), theme.cards.toolIndent, 0));
|
|
137
|
+
component.addChild(card);
|
|
138
|
+
if (!component.preview) {
|
|
139
|
+
return component;
|
|
140
|
+
}
|
|
141
|
+
card.addChild(new Spacer(1));
|
|
142
|
+
if ("error" in component.preview) {
|
|
143
|
+
card.addChild(new Text(theme.fg("error", component.preview.error), theme.cards.bodyIndent, 0));
|
|
144
|
+
}
|
|
145
|
+
else {
|
|
146
|
+
const filePath = str(args?.file_path ?? args?.path) ?? undefined;
|
|
147
|
+
card.addChild(createDiffComponent(component.preview.diff, { filePath, surroundBg: surfaceBg }));
|
|
148
|
+
}
|
|
149
|
+
return component;
|
|
150
|
+
}
|
|
151
|
+
function setEditPreview(component, preview, argsKey) {
|
|
152
|
+
const current = component.preview;
|
|
153
|
+
const changed = current === undefined ||
|
|
154
|
+
("error" in current && "error" in preview
|
|
155
|
+
? current.error !== preview.error
|
|
156
|
+
: "error" in current !== "error" in preview) ||
|
|
157
|
+
(!("error" in current) &&
|
|
158
|
+
!("error" in preview) &&
|
|
159
|
+
(current.diff !== preview.diff || current.firstChangedLine !== preview.firstChangedLine));
|
|
160
|
+
component.preview = preview;
|
|
161
|
+
component.previewArgsKey = argsKey;
|
|
162
|
+
component.previewPending = false;
|
|
163
|
+
return changed;
|
|
164
|
+
}
|
|
165
|
+
export function createEditToolDefinition(cwd, options) {
|
|
166
|
+
const ops = options?.operations ?? defaultEditOperations;
|
|
167
|
+
return {
|
|
168
|
+
name: "edit",
|
|
169
|
+
label: "edit",
|
|
170
|
+
description: "Edit a single file using exact text replacement. Every edits[].oldText must match a unique, non-overlapping region of the original file. If two changes affect the same block or nearby lines, merge them into one edit instead of emitting overlapping edits. Do not include large unchanged regions just to connect distant changes.",
|
|
171
|
+
promptSnippet: "Make precise file edits with exact text replacement, including multiple disjoint edits in one call",
|
|
172
|
+
promptGuidelines: [
|
|
173
|
+
"Use edit for precise changes (edits[].oldText must match exactly)",
|
|
174
|
+
"When changing multiple separate locations in one file, use one edit call with multiple entries in edits[] instead of multiple edit calls",
|
|
175
|
+
"Each edits[].oldText is matched against the original file, not after earlier edits are applied. Do not emit overlapping or nested edits. Merge nearby changes into one edit.",
|
|
176
|
+
"Keep edits[].oldText as small as possible while still being unique in the file. Do not pad with large unchanged regions.",
|
|
177
|
+
],
|
|
178
|
+
parameters: editSchema,
|
|
179
|
+
renderShell: "self",
|
|
180
|
+
prepareArguments: prepareEditArguments,
|
|
181
|
+
async execute(_toolCallId, input, signal, _onUpdate, _ctx) {
|
|
182
|
+
const { path, edits } = validateEditInput(input);
|
|
183
|
+
const absolutePath = resolveToCwd(path, cwd);
|
|
184
|
+
return withFileMutationQueue(absolutePath, async () => {
|
|
185
|
+
// Do not reject from an abort event listener here: that would release the
|
|
186
|
+
// mutation queue while an in-flight filesystem operation may still finish.
|
|
187
|
+
// Checking signal.aborted after each await observes the same aborts while
|
|
188
|
+
// keeping the queue locked until the current operation has settled.
|
|
189
|
+
const throwIfAborted = () => {
|
|
190
|
+
if (signal?.aborted)
|
|
191
|
+
throw new Error("Operation aborted");
|
|
192
|
+
};
|
|
193
|
+
throwIfAborted();
|
|
194
|
+
// Check if file exists.
|
|
195
|
+
try {
|
|
196
|
+
await ops.access(absolutePath);
|
|
197
|
+
}
|
|
198
|
+
catch (error) {
|
|
199
|
+
throwIfAborted();
|
|
200
|
+
const errorMessage = error instanceof Error && "code" in error ? `Error code: ${error.code}` : String(error);
|
|
201
|
+
throw new Error(`Could not edit file: ${path}. ${errorMessage}.`);
|
|
202
|
+
}
|
|
203
|
+
throwIfAborted();
|
|
204
|
+
// Read the file.
|
|
205
|
+
const buffer = await ops.readFile(absolutePath);
|
|
206
|
+
const rawContent = buffer.toString("utf-8");
|
|
207
|
+
throwIfAborted();
|
|
208
|
+
// Strip BOM before matching. The model will not include an invisible BOM in oldText.
|
|
209
|
+
const { bom, text: content } = stripBom(rawContent);
|
|
210
|
+
const originalEnding = detectLineEnding(content);
|
|
211
|
+
const normalizedContent = normalizeToLF(content);
|
|
212
|
+
const { baseContent, newContent } = applyEditsToNormalizedContent(normalizedContent, edits, path);
|
|
213
|
+
throwIfAborted();
|
|
214
|
+
const finalContent = bom + restoreLineEndings(newContent, originalEnding);
|
|
215
|
+
await ops.writeFile(absolutePath, finalContent);
|
|
216
|
+
throwIfAborted();
|
|
217
|
+
const diffResult = generateDiffString(baseContent, newContent);
|
|
218
|
+
const patch = generateUnifiedPatch(path, baseContent, newContent);
|
|
219
|
+
return {
|
|
220
|
+
content: [
|
|
221
|
+
{
|
|
222
|
+
type: "text",
|
|
223
|
+
text: `Successfully replaced ${edits.length} block(s) in ${path}.`,
|
|
224
|
+
},
|
|
225
|
+
],
|
|
226
|
+
details: { diff: diffResult.diff, patch, firstChangedLine: diffResult.firstChangedLine },
|
|
227
|
+
};
|
|
228
|
+
});
|
|
229
|
+
},
|
|
230
|
+
renderCall(args, theme, context) {
|
|
231
|
+
const component = getEditCallRenderComponent(context.state, context.lastComponent);
|
|
232
|
+
const previewInput = getRenderablePreviewInput(args);
|
|
233
|
+
const argsKey = previewInput ? JSON.stringify({ path: previewInput.path, edits: previewInput.edits }) : undefined;
|
|
234
|
+
if (component.previewArgsKey !== argsKey) {
|
|
235
|
+
component.preview = undefined;
|
|
236
|
+
component.previewArgsKey = argsKey;
|
|
237
|
+
component.previewPending = false;
|
|
238
|
+
component.settledError = false;
|
|
239
|
+
}
|
|
240
|
+
if (context.argsComplete && previewInput && !component.preview && !component.previewPending) {
|
|
241
|
+
component.previewPending = true;
|
|
242
|
+
const requestKey = argsKey;
|
|
243
|
+
void computeEditsDiff(previewInput.path, previewInput.edits, context.cwd).then((preview) => {
|
|
244
|
+
if (component.previewArgsKey === requestKey) {
|
|
245
|
+
setEditPreview(component, preview, requestKey);
|
|
246
|
+
context.invalidate();
|
|
247
|
+
}
|
|
248
|
+
});
|
|
249
|
+
}
|
|
250
|
+
return buildEditCallComponent(component, args, theme, context.cwd);
|
|
251
|
+
},
|
|
252
|
+
renderResult(result, _options, theme, context) {
|
|
253
|
+
const callComponent = context.state.callComponent;
|
|
254
|
+
const previewInput = getRenderablePreviewInput(context.args);
|
|
255
|
+
const argsKey = previewInput ? JSON.stringify({ path: previewInput.path, edits: previewInput.edits }) : undefined;
|
|
256
|
+
const typedResult = result;
|
|
257
|
+
const resultDiff = !context.isError ? typedResult.details?.diff : undefined;
|
|
258
|
+
let changed = false;
|
|
259
|
+
if (callComponent) {
|
|
260
|
+
if (typeof resultDiff === "string") {
|
|
261
|
+
changed =
|
|
262
|
+
setEditPreview(callComponent, { diff: resultDiff, firstChangedLine: typedResult.details?.firstChangedLine }, argsKey) || changed;
|
|
263
|
+
}
|
|
264
|
+
if (callComponent.settledError !== context.isError) {
|
|
265
|
+
callComponent.settledError = context.isError;
|
|
266
|
+
changed = true;
|
|
267
|
+
}
|
|
268
|
+
if (changed) {
|
|
269
|
+
buildEditCallComponent(callComponent, context.args, theme, context.cwd);
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
const body = buildEditResultBody(context.args, callComponent?.preview, typedResult, theme, context.isError);
|
|
273
|
+
const component = context.lastComponent ?? new Container();
|
|
274
|
+
component.clear();
|
|
275
|
+
if (!body) {
|
|
276
|
+
return component;
|
|
277
|
+
}
|
|
278
|
+
if (!theme.cards.gaplessCards) {
|
|
279
|
+
component.addChild(new Spacer(1));
|
|
280
|
+
}
|
|
281
|
+
component.addChild(body);
|
|
282
|
+
return component;
|
|
283
|
+
},
|
|
284
|
+
};
|
|
285
|
+
}
|
|
286
|
+
export function createEditTool(cwd, options) {
|
|
287
|
+
return wrapToolDefinition(createEditToolDefinition(cwd, options));
|
|
288
|
+
}
|
|
289
|
+
//# sourceMappingURL=edit.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"edit.js","sourceRoot":"","sources":["../../../src/core/tools/edit.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,GAAG,EAAkB,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACzE,OAAO,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAC/B,OAAO,EAAE,MAAM,IAAI,QAAQ,EAAE,QAAQ,IAAI,UAAU,EAAE,SAAS,IAAI,WAAW,EAAE,MAAM,aAAa,CAAC;AACnG,OAAO,EAAe,IAAI,EAAE,MAAM,SAAS,CAAC;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,4CAA4C,CAAC;AAGjF,OAAO,EACN,6BAA6B,EAC7B,gBAAgB,EAChB,gBAAgB,EAIhB,kBAAkB,EAClB,oBAAoB,EACpB,aAAa,EACb,kBAAkB,EAClB,QAAQ,GACR,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACjE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,GAAG,EAAE,MAAM,mBAAmB,CAAC;AACxD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAQlE,MAAM,iBAAiB,GAAG,IAAI,CAAC,MAAM,CACpC;IACC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC;QACpB,WAAW,EACV,uJAAuJ;KACxJ,CAAC;IACF,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,0CAA0C,EAAE,CAAC;CACjF,EACD,EAAE,oBAAoB,EAAE,KAAK,EAAE,CAC/B,CAAC;AAEF,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAC7B;IACC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,iDAAiD,EAAE,CAAC;IACrF,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,iBAAiB,EAAE;QACpC,WAAW,EACV,0OAA0O;KAC3O,CAAC;CACF,EACD,EAAE,oBAAoB,EAAE,KAAK,EAAE,CAC/B,CAAC;AA8BF,MAAM,qBAAqB,GAAmB;IAC7C,QAAQ,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;IACpC,SAAS,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,CAAC,WAAW,CAAC,IAAI,EAAE,OAAO,EAAE,OAAO,CAAC;IACjE,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,GAAG,SAAS,CAAC,IAAI,CAAC;CACjE,CAAC;AAOF,SAAS,oBAAoB,CAAC,KAAc;IAC3C,IAAI,CAAC,KAAK,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QACzC,OAAO,KAAsB,CAAC;IAC/B,CAAC;IAED,MAAM,IAAI,GAAG,KAAgC,CAAC;IAE9C,kFAAkF;IAClF,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;QACpC,IAAI,CAAC;YACJ,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACtC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;gBAAE,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;QAChD,CAAC;QAAC,MAAM,CAAC,CAAA,CAAC;IACX,CAAC;IAED,MAAM,MAAM,GAAG,IAA2B,CAAC;IAC3C,IAAI,OAAO,MAAM,CAAC,OAAO,KAAK,QAAQ,IAAI,OAAO,MAAM,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;QAC9E,OAAO,IAAqB,CAAC;IAC9B,CAAC;IAED,MAAM,KAAK,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACnE,KAAK,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC;IACjE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,QAAQ,EAAE,GAAG,IAAI,EAAE,GAAG,MAAM,CAAC;IACjE,OAAO,EAAE,GAAG,IAAI,EAAE,KAAK,EAAmB,CAAC;AAC5C,CAAC;AAED,SAAS,iBAAiB,CAAC,KAAoB;IAC9C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,KAAK,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7D,MAAM,IAAI,KAAK,CAAC,0EAA0E,CAAC,CAAC;IAC7F,CAAC;IACD,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC;AACjD,CAAC;AAsBD,SAAS,6BAA6B;IACrC,OAAO,MAAM,CAAC,MAAM,CAAC,IAAI,SAAS,EAAE,EAAE;QACrC,OAAO,EAAE,SAAoC;QAC7C,cAAc,EAAE,SAA+B;QAC/C,cAAc,EAAE,KAAK;QACrB,YAAY,EAAE,KAAK;KACnB,CAAC,CAAC;AACJ,CAAC;AAED,SAAS,0BAA0B,CAAC,KAAsB,EAAE,aAAsB;IACjF,IAAI,aAAa,YAAY,SAAS,EAAE,CAAC;QACxC,MAAM,SAAS,GAAG,aAAwC,CAAC;QAC3D,KAAK,CAAC,aAAa,GAAG,SAAS,CAAC;QAChC,OAAO,SAAS,CAAC;IAClB,CAAC;IACD,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;QACzB,OAAO,KAAK,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,MAAM,SAAS,GAAG,6BAA6B,EAAE,CAAC;IAClD,KAAK,CAAC,aAAa,GAAG,SAAS,CAAC;IAChC,OAAO,SAAS,CAAC;AAClB,CAAC;AAED,SAAS,yBAAyB,CAAC,IAAoC;IACtE,IAAI,CAAC,IAAI,EAAE,CAAC;QACX,OAAO,IAAI,CAAC;IACb,CAAC;IAED,MAAM,IAAI,GAAG,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC;IACpH,IAAI,CAAC,IAAI,EAAE,CAAC;QACX,OAAO,IAAI,CAAC;IACb,CAAC;IAED,IACC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC;QACzB,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,OAAO,IAAI,EAAE,OAAO,KAAK,QAAQ,IAAI,OAAO,IAAI,EAAE,OAAO,KAAK,QAAQ,CAAC,EACjG,CAAC;QACF,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC;IACpC,CAAC;IAED,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,QAAQ,EAAE,CAAC;QAC1E,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,CAAC;IAC5E,CAAC;IAED,OAAO,IAAI,CAAC;AACb,CAAC;AAED,SAAS,cAAc,CAAC,IAAoC,EAAE,KAAY,EAAE,GAAW;IACtF,MAAM,WAAW,GAAG,cAAc,CAAC,GAAG,CAAC,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,IAAI,CAAC,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;IACnF,OAAO,GAAG,KAAK,CAAC,EAAE,CAAC,WAAW,EAAE,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC;AACtE,CAAC;AAED,SAAS,mBAAmB,CAC3B,IAAoC,EACpC,OAAgC,EAChC,MAA0B,EAC1B,KAAY,EACZ,OAAgB;IAEhB,MAAM,OAAO,GAAG,GAAG,CAAC,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,IAAI,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,OAAO,IAAI,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;IAChF,MAAM,YAAY,GAAG,OAAO,IAAI,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC;IAC/E,IAAI,OAAO,EAAE,CAAC;QACb,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO;aAC9B,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,CAAC;aAChC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;aACxB,IAAI,CAAC,IAAI,CAAC,CAAC;QACb,IAAI,CAAC,SAAS,IAAI,SAAS,KAAK,YAAY,EAAE,CAAC;YAC9C,OAAO,SAAS,CAAC;QAClB,CAAC;QACD,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,SAAS,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,gBAAgB,EAAE,CAAC,CAAC,CAAC;IAChF,CAAC;IAED,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,EAAE,IAAI,CAAC;IACxC,IAAI,UAAU,IAAI,UAAU,KAAK,WAAW,EAAE,CAAC;QAC9C,OAAO,mBAAmB,CAAC,UAAU,EAAE,EAAE,QAAQ,EAAE,OAAO,IAAI,SAAS,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,OAAO,SAAS,CAAC;AAClB,CAAC;AAED,SAAS,qBAAqB,CAC7B,OAAgC,EAChC,YAAiC,EACjC,KAAY;IAEZ,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;QACjC,OAAO,SAAS,CAAC;IAClB,CAAC;IACD,IAAI,OAAO,EAAE,CAAC;QACb,OAAO,OAAO,IAAI,OAAO,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,eAAe,CAAC;IAC7D,CAAC;IACD,IAAI,YAAY,EAAE,CAAC;QAClB,OAAO,aAAa,CAAC;IACtB,CAAC;IACD,OAAO,eAAe,CAAC;AACxB,CAAC;AAED,SAAS,sBAAsB,CAC9B,SAAkC,EAClC,IAAoC,EACpC,KAAY,EACZ,GAAW;IAEX,SAAS,CAAC,KAAK,EAAE,CAAC;IAElB,MAAM,SAAS,GAAG,qBAAqB,CAAC,SAAS,CAAC,OAAO,EAAE,SAAS,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAE1F,MAAM,IAAI,GAAG,IAAI,GAAG,CACnB,KAAK,CAAC,KAAK,CAAC,QAAQ,EACpB,KAAK,CAAC,KAAK,CAAC,QAAQ,EACpB,SAAS,CAAC,CAAC,CAAC,CAAC,IAAY,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS,CACnE,CAAC;IACF,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;IACrF,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IAEzB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;QACxB,OAAO,SAAS,CAAC;IAClB,CAAC;IAED,IAAI,CAAC,QAAQ,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7B,IAAI,OAAO,IAAI,SAAS,CAAC,OAAO,EAAE,CAAC;QAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC;IAChG,CAAC;SAAM,CAAC;QACP,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,EAAE,SAAS,IAAI,IAAI,EAAE,IAAI,CAAC,IAAI,SAAS,CAAC;QACjE,IAAI,CAAC,QAAQ,CAAC,mBAAmB,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;IACjG,CAAC;IACD,OAAO,SAAS,CAAC;AAClB,CAAC;AAED,SAAS,cAAc,CACtB,SAAkC,EAClC,OAAoB,EACpB,OAA2B;IAE3B,MAAM,OAAO,GAAG,SAAS,CAAC,OAAO,CAAC;IAClC,MAAM,OAAO,GACZ,OAAO,KAAK,SAAS;QACrB,CAAC,OAAO,IAAI,OAAO,IAAI,OAAO,IAAI,OAAO;YACxC,CAAC,CAAC,OAAO,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK;YACjC,CAAC,CAAC,OAAO,IAAI,OAAO,KAAK,OAAO,IAAI,OAAO,CAAC;QAC7C,CAAC,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC;YACrB,CAAC,CAAC,OAAO,IAAI,OAAO,CAAC;YACrB,CAAC,OAAO,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC,gBAAgB,KAAK,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC;IAC5F,SAAS,CAAC,OAAO,GAAG,OAAO,CAAC;IAC5B,SAAS,CAAC,cAAc,GAAG,OAAO,CAAC;IACnC,SAAS,CAAC,cAAc,GAAG,KAAK,CAAC;IACjC,OAAO,OAAO,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,wBAAwB,CACvC,GAAW,EACX,OAAyB;IAEzB,MAAM,GAAG,GAAG,OAAO,EAAE,UAAU,IAAI,qBAAqB,CAAC;IACzD,OAAO;QACN,IAAI,EAAE,MAAM;QACZ,KAAK,EAAE,MAAM;QACb,WAAW,EACV,wUAAwU;QACzU,aAAa,EAAE,oGAAoG;QACnH,gBAAgB,EAAE;YACjB,mEAAmE;YACnE,0IAA0I;YAC1I,8KAA8K;YAC9K,0HAA0H;SAC1H;QACD,UAAU,EAAE,UAAU;QACtB,WAAW,EAAE,MAAM;QACnB,gBAAgB,EAAE,oBAAoB;QACtC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,KAAoB,EAAE,MAAoB,EAAE,SAAU,EAAE,IAAK;YACvF,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,iBAAiB,CAAC,KAAK,CAAC,CAAC;YACjD,MAAM,YAAY,GAAG,YAAY,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YAE7C,OAAO,qBAAqB,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE;gBACrD,0EAA0E;gBAC1E,2EAA2E;gBAC3E,0EAA0E;gBAC1E,oEAAoE;gBACpE,MAAM,cAAc,GAAG,GAAS,EAAE;oBACjC,IAAI,MAAM,EAAE,OAAO;wBAAE,MAAM,IAAI,KAAK,CAAC,mBAAmB,CAAC,CAAC;gBAC3D,CAAC,CAAC;gBAEF,cAAc,EAAE,CAAC;gBAEjB,wBAAwB;gBACxB,IAAI,CAAC;oBACJ,MAAM,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;gBAChC,CAAC;gBAAC,OAAO,KAAc,EAAE,CAAC;oBACzB,cAAc,EAAE,CAAC;oBACjB,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,IAAI,MAAM,IAAI,KAAK,CAAC,CAAC,CAAC,eAAe,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBAC7G,MAAM,IAAI,KAAK,CAAC,wBAAwB,IAAI,KAAK,YAAY,GAAG,CAAC,CAAC;gBACnE,CAAC;gBACD,cAAc,EAAE,CAAC;gBAEjB,iBAAiB;gBACjB,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC;gBAChD,MAAM,UAAU,GAAG,MAAM,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;gBAC5C,cAAc,EAAE,CAAC;gBAEjB,qFAAqF;gBACrF,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;gBACpD,MAAM,cAAc,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;gBACjD,MAAM,iBAAiB,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC;gBACjD,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,GAAG,6BAA6B,CAAC,iBAAiB,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;gBAClG,cAAc,EAAE,CAAC;gBAEjB,MAAM,YAAY,GAAG,GAAG,GAAG,kBAAkB,CAAC,UAAU,EAAE,cAAc,CAAC,CAAC;gBAC1E,MAAM,GAAG,CAAC,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;gBAChD,cAAc,EAAE,CAAC;gBAEjB,MAAM,UAAU,GAAG,kBAAkB,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;gBAC/D,MAAM,KAAK,GAAG,oBAAoB,CAAC,IAAI,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;gBAClE,OAAO;oBACN,OAAO,EAAE;wBACR;4BACC,IAAI,EAAE,MAAM;4BACZ,IAAI,EAAE,yBAAyB,KAAK,CAAC,MAAM,gBAAgB,IAAI,GAAG;yBAClE;qBACD;oBACD,OAAO,EAAE,EAAE,IAAI,EAAE,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,gBAAgB,EAAE,UAAU,CAAC,gBAAgB,EAAE;iBACxF,CAAC;YACH,CAAC,CAAC,CAAC;QACJ,CAAC;QACD,UAAU,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO;YAC9B,MAAM,SAAS,GAAG,0BAA0B,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;YACnF,MAAM,YAAY,GAAG,yBAAyB,CAAC,IAAsC,CAAC,CAAC;YACvF,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YAElH,IAAI,SAAS,CAAC,cAAc,KAAK,OAAO,EAAE,CAAC;gBAC1C,SAAS,CAAC,OAAO,GAAG,SAAS,CAAC;gBAC9B,SAAS,CAAC,cAAc,GAAG,OAAO,CAAC;gBACnC,SAAS,CAAC,cAAc,GAAG,KAAK,CAAC;gBACjC,SAAS,CAAC,YAAY,GAAG,KAAK,CAAC;YAChC,CAAC;YAED,IAAI,OAAO,CAAC,YAAY,IAAI,YAAY,IAAI,CAAC,SAAS,CAAC,OAAO,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,CAAC;gBAC7F,SAAS,CAAC,cAAc,GAAG,IAAI,CAAC;gBAChC,MAAM,UAAU,GAAG,OAAO,CAAC;gBAC3B,KAAK,gBAAgB,CAAC,YAAY,CAAC,IAAI,EAAE,YAAY,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;oBAC1F,IAAI,SAAS,CAAC,cAAc,KAAK,UAAU,EAAE,CAAC;wBAC7C,cAAc,CAAC,SAAS,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;wBAC/C,OAAO,CAAC,UAAU,EAAE,CAAC;oBACtB,CAAC;gBACF,CAAC,CAAC,CAAC;YACJ,CAAC;YAED,OAAO,sBAAsB,CAAC,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;QACpE,CAAC;QACD,YAAY,CAAC,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,OAAO;YAC5C,MAAM,aAAa,GAAG,OAAO,CAAC,KAAK,CAAC,aAAa,CAAC;YAClD,MAAM,YAAY,GAAG,yBAAyB,CAAC,OAAO,CAAC,IAAsC,CAAC,CAAC;YAC/F,MAAM,OAAO,GAAG,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE,KAAK,EAAE,YAAY,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YAClH,MAAM,WAAW,GAAG,MAA4B,CAAC;YACjD,MAAM,UAAU,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC;YAC5E,IAAI,OAAO,GAAG,KAAK,CAAC;YACpB,IAAI,aAAa,EAAE,CAAC;gBACnB,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE,CAAC;oBACpC,OAAO;wBACN,cAAc,CACb,aAAa,EACb,EAAE,IAAI,EAAE,UAAU,EAAE,gBAAgB,EAAE,WAAW,CAAC,OAAO,EAAE,gBAAgB,EAAE,EAC7E,OAAO,CACP,IAAI,OAAO,CAAC;gBACf,CAAC;gBACD,IAAI,aAAa,CAAC,YAAY,KAAK,OAAO,CAAC,OAAO,EAAE,CAAC;oBACpD,aAAa,CAAC,YAAY,GAAG,OAAO,CAAC,OAAO,CAAC;oBAC7C,OAAO,GAAG,IAAI,CAAC;gBAChB,CAAC;gBACD,IAAI,OAAO,EAAE,CAAC;oBACb,sBAAsB,CAAC,aAAa,EAAE,OAAO,CAAC,IAAsC,EAAE,KAAK,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;gBAC3G,CAAC;YACF,CAAC;YAED,MAAM,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,IAAI,EAAE,aAAa,EAAE,OAAO,EAAE,WAAW,EAAE,KAAK,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;YAC5G,MAAM,SAAS,GAAI,OAAO,CAAC,aAAuC,IAAI,IAAI,SAAS,EAAE,CAAC;YACtF,SAAS,CAAC,KAAK,EAAE,CAAC;YAClB,IAAI,CAAC,IAAI,EAAE,CAAC;gBACX,OAAO,SAAS,CAAC;YAClB,CAAC;YACD,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;gBAC/B,SAAS,CAAC,QAAQ,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;YACnC,CAAC;YACD,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACzB,OAAO,SAAS,CAAC;QAClB,CAAC;KACD,CAAC;AACH,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,GAAW,EAAE,OAAyB;IACpE,OAAO,kBAAkB,CAAC,wBAAwB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC;AACnE,CAAC","sourcesContent":["import type { AgentTool } from \"@hamr/agent\";\nimport { Box, type Component, Container, Spacer, Text } from \"@hamr/tui\";\nimport { constants } from \"fs\";\nimport { access as fsAccess, readFile as fsReadFile, writeFile as fsWriteFile } from \"fs/promises\";\nimport { type Static, Type } from \"typebox\";\nimport { createDiffComponent } from \"../../modes/interactive/components/diff.ts\";\nimport type { Theme, ThemeBg } from \"../../modes/interactive/theme/theme.ts\";\nimport type { ToolDefinition } from \"../extensions/types.ts\";\nimport {\n\tapplyEditsToNormalizedContent,\n\tcomputeEditsDiff,\n\tdetectLineEnding,\n\ttype Edit,\n\ttype EditDiffError,\n\ttype EditDiffResult,\n\tgenerateDiffString,\n\tgenerateUnifiedPatch,\n\tnormalizeToLF,\n\trestoreLineEndings,\n\tstripBom,\n} from \"./edit-diff.ts\";\nimport { withFileMutationQueue } from \"./file-mutation-queue.ts\";\nimport { resolveToCwd } from \"./path-utils.ts\";\nimport { renderToolPath, str } from \"./render-utils.ts\";\nimport { wrapToolDefinition } from \"./tool-definition-wrapper.ts\";\n\ntype EditPreview = EditDiffResult | EditDiffError;\n\ntype EditRenderState = {\n\tcallComponent?: EditCallRenderComponent;\n};\n\nconst replaceEditSchema = Type.Object(\n\t{\n\t\toldText: Type.String({\n\t\t\tdescription:\n\t\t\t\t\"Exact text for one targeted replacement. It must be unique in the original file and must not overlap with any other edits[].oldText in the same call.\",\n\t\t}),\n\t\tnewText: Type.String({ description: \"Replacement text for this targeted edit.\" }),\n\t},\n\t{ additionalProperties: false },\n);\n\nconst editSchema = Type.Object(\n\t{\n\t\tpath: Type.String({ description: \"Path to the file to edit (relative or absolute)\" }),\n\t\tedits: Type.Array(replaceEditSchema, {\n\t\t\tdescription:\n\t\t\t\t\"One or more targeted replacements. Each edit is matched against the original file, not incrementally. Do not include overlapping or nested edits. If two changes touch the same block or nearby lines, merge them into one edit instead.\",\n\t\t}),\n\t},\n\t{ additionalProperties: false },\n);\n\nexport type EditToolInput = Static<typeof editSchema>;\ntype LegacyEditToolInput = EditToolInput & {\n\toldText?: unknown;\n\tnewText?: unknown;\n};\n\nexport interface EditToolDetails {\n\t/** Display-oriented diff of the changes made */\n\tdiff: string;\n\t/** Standard unified patch of the changes made */\n\tpatch: string;\n\t/** Line number of the first change in the new file (for editor navigation) */\n\tfirstChangedLine?: number;\n}\n\n/**\n * Pluggable operations for the edit tool.\n * Override these to delegate file editing to remote systems (for example SSH).\n */\nexport interface EditOperations {\n\t/** Read file contents as a Buffer */\n\treadFile: (absolutePath: string) => Promise<Buffer>;\n\t/** Write content to a file */\n\twriteFile: (absolutePath: string, content: string) => Promise<void>;\n\t/** Check if file is readable and writable (throw if not) */\n\taccess: (absolutePath: string) => Promise<void>;\n}\n\nconst defaultEditOperations: EditOperations = {\n\treadFile: (path) => fsReadFile(path),\n\twriteFile: (path, content) => fsWriteFile(path, content, \"utf-8\"),\n\taccess: (path) => fsAccess(path, constants.R_OK | constants.W_OK),\n};\n\nexport interface EditToolOptions {\n\t/** Custom operations for file editing. Default: local filesystem */\n\toperations?: EditOperations;\n}\n\nfunction prepareEditArguments(input: unknown): EditToolInput {\n\tif (!input || typeof input !== \"object\") {\n\t\treturn input as EditToolInput;\n\t}\n\n\tconst args = input as Record<string, unknown>;\n\n\t// Some models (Opus 4.6, GLM-5.1) send edits as a JSON string instead of an array\n\tif (typeof args.edits === \"string\") {\n\t\ttry {\n\t\t\tconst parsed = JSON.parse(args.edits);\n\t\t\tif (Array.isArray(parsed)) args.edits = parsed;\n\t\t} catch {}\n\t}\n\n\tconst legacy = args as LegacyEditToolInput;\n\tif (typeof legacy.oldText !== \"string\" || typeof legacy.newText !== \"string\") {\n\t\treturn args as EditToolInput;\n\t}\n\n\tconst edits = Array.isArray(legacy.edits) ? [...legacy.edits] : [];\n\tedits.push({ oldText: legacy.oldText, newText: legacy.newText });\n\tconst { oldText: _oldText, newText: _newText, ...rest } = legacy;\n\treturn { ...rest, edits } as EditToolInput;\n}\n\nfunction validateEditInput(input: EditToolInput): { path: string; edits: Edit[] } {\n\tif (!Array.isArray(input.edits) || input.edits.length === 0) {\n\t\tthrow new Error(\"Edit tool input is invalid. edits must contain at least one replacement.\");\n\t}\n\treturn { path: input.path, edits: input.edits };\n}\n\ntype RenderableEditArgs = {\n\tpath?: string;\n\tfile_path?: string;\n\tedits?: Edit[];\n\toldText?: string;\n\tnewText?: string;\n};\n\ntype EditToolResultLike = {\n\tcontent: Array<{ type: string; text?: string; data?: string; mimeType?: string }>;\n\tdetails?: EditToolDetails;\n};\n\ntype EditCallRenderComponent = Container & {\n\tpreview?: EditPreview;\n\tpreviewArgsKey?: string;\n\tpreviewPending?: boolean;\n\tsettledError?: boolean;\n};\n\nfunction createEditCallRenderComponent(): EditCallRenderComponent {\n\treturn Object.assign(new Container(), {\n\t\tpreview: undefined as EditPreview | undefined,\n\t\tpreviewArgsKey: undefined as string | undefined,\n\t\tpreviewPending: false,\n\t\tsettledError: false,\n\t});\n}\n\nfunction getEditCallRenderComponent(state: EditRenderState, lastComponent: unknown): EditCallRenderComponent {\n\tif (lastComponent instanceof Container) {\n\t\tconst component = lastComponent as EditCallRenderComponent;\n\t\tstate.callComponent = component;\n\t\treturn component;\n\t}\n\tif (state.callComponent) {\n\t\treturn state.callComponent;\n\t}\n\tconst component = createEditCallRenderComponent();\n\tstate.callComponent = component;\n\treturn component;\n}\n\nfunction getRenderablePreviewInput(args: RenderableEditArgs | undefined): { path: string; edits: Edit[] } | null {\n\tif (!args) {\n\t\treturn null;\n\t}\n\n\tconst path = typeof args.path === \"string\" ? args.path : typeof args.file_path === \"string\" ? args.file_path : null;\n\tif (!path) {\n\t\treturn null;\n\t}\n\n\tif (\n\t\tArray.isArray(args.edits) &&\n\t\targs.edits.length > 0 &&\n\t\targs.edits.every((edit) => typeof edit?.oldText === \"string\" && typeof edit?.newText === \"string\")\n\t) {\n\t\treturn { path, edits: args.edits };\n\t}\n\n\tif (typeof args.oldText === \"string\" && typeof args.newText === \"string\") {\n\t\treturn { path, edits: [{ oldText: args.oldText, newText: args.newText }] };\n\t}\n\n\treturn null;\n}\n\nfunction formatEditCall(args: RenderableEditArgs | undefined, theme: Theme, cwd: string): string {\n\tconst pathDisplay = renderToolPath(str(args?.file_path ?? args?.path), theme, cwd);\n\treturn `${theme.fg(\"toolTitle\", theme.bold(\"edit\"))} ${pathDisplay}`;\n}\n\nfunction buildEditResultBody(\n\targs: RenderableEditArgs | undefined,\n\tpreview: EditPreview | undefined,\n\tresult: EditToolResultLike,\n\ttheme: Theme,\n\tisError: boolean,\n): Component | undefined {\n\tconst rawPath = str(args?.file_path ?? args?.path);\n\tconst previewDiff = preview && !(\"error\" in preview) ? preview.diff : undefined;\n\tconst previewError = preview && \"error\" in preview ? preview.error : undefined;\n\tif (isError) {\n\t\tconst errorText = result.content\n\t\t\t.filter((c) => c.type === \"text\")\n\t\t\t.map((c) => c.text || \"\")\n\t\t\t.join(\"\\n\");\n\t\tif (!errorText || errorText === previewError) {\n\t\t\treturn undefined;\n\t\t}\n\t\treturn new Text(theme.fg(\"error\", errorText), theme.cards.toolResultIndent, 0);\n\t}\n\n\tconst resultDiff = result.details?.diff;\n\tif (resultDiff && resultDiff !== previewDiff) {\n\t\treturn createDiffComponent(resultDiff, { filePath: rawPath ?? undefined });\n\t}\n\n\treturn undefined;\n}\n\nfunction getEditSurfaceBgToken(\n\tpreview: EditPreview | undefined,\n\tsettledError: boolean | undefined,\n\ttheme: Theme,\n): ThemeBg | undefined {\n\tif (!theme.cards.shadedSurfaces) {\n\t\treturn undefined;\n\t}\n\tif (preview) {\n\t\treturn \"error\" in preview ? \"toolErrorBg\" : \"toolSuccessBg\";\n\t}\n\tif (settledError) {\n\t\treturn \"toolErrorBg\";\n\t}\n\treturn \"toolPendingBg\";\n}\n\nfunction buildEditCallComponent(\n\tcomponent: EditCallRenderComponent,\n\targs: RenderableEditArgs | undefined,\n\ttheme: Theme,\n\tcwd: string,\n): EditCallRenderComponent {\n\tcomponent.clear();\n\n\tconst surfaceBg = getEditSurfaceBgToken(component.preview, component.settledError, theme);\n\n\tconst card = new Box(\n\t\ttheme.cards.cardPadX,\n\t\ttheme.cards.cardPadY,\n\t\tsurfaceBg ? (text: string) => theme.bg(surfaceBg, text) : undefined,\n\t);\n\tcard.addChild(new Text(formatEditCall(args, theme, cwd), theme.cards.toolIndent, 0));\n\tcomponent.addChild(card);\n\n\tif (!component.preview) {\n\t\treturn component;\n\t}\n\n\tcard.addChild(new Spacer(1));\n\tif (\"error\" in component.preview) {\n\t\tcard.addChild(new Text(theme.fg(\"error\", component.preview.error), theme.cards.bodyIndent, 0));\n\t} else {\n\t\tconst filePath = str(args?.file_path ?? args?.path) ?? undefined;\n\t\tcard.addChild(createDiffComponent(component.preview.diff, { filePath, surroundBg: surfaceBg }));\n\t}\n\treturn component;\n}\n\nfunction setEditPreview(\n\tcomponent: EditCallRenderComponent,\n\tpreview: EditPreview,\n\targsKey: string | undefined,\n): boolean {\n\tconst current = component.preview;\n\tconst changed =\n\t\tcurrent === undefined ||\n\t\t(\"error\" in current && \"error\" in preview\n\t\t\t? current.error !== preview.error\n\t\t\t: \"error\" in current !== \"error\" in preview) ||\n\t\t(!(\"error\" in current) &&\n\t\t\t!(\"error\" in preview) &&\n\t\t\t(current.diff !== preview.diff || current.firstChangedLine !== preview.firstChangedLine));\n\tcomponent.preview = preview;\n\tcomponent.previewArgsKey = argsKey;\n\tcomponent.previewPending = false;\n\treturn changed;\n}\n\nexport function createEditToolDefinition(\n\tcwd: string,\n\toptions?: EditToolOptions,\n): ToolDefinition<typeof editSchema, EditToolDetails | undefined, EditRenderState> {\n\tconst ops = options?.operations ?? defaultEditOperations;\n\treturn {\n\t\tname: \"edit\",\n\t\tlabel: \"edit\",\n\t\tdescription:\n\t\t\t\"Edit a single file using exact text replacement. Every edits[].oldText must match a unique, non-overlapping region of the original file. If two changes affect the same block or nearby lines, merge them into one edit instead of emitting overlapping edits. Do not include large unchanged regions just to connect distant changes.\",\n\t\tpromptSnippet: \"Make precise file edits with exact text replacement, including multiple disjoint edits in one call\",\n\t\tpromptGuidelines: [\n\t\t\t\"Use edit for precise changes (edits[].oldText must match exactly)\",\n\t\t\t\"When changing multiple separate locations in one file, use one edit call with multiple entries in edits[] instead of multiple edit calls\",\n\t\t\t\"Each edits[].oldText is matched against the original file, not after earlier edits are applied. Do not emit overlapping or nested edits. Merge nearby changes into one edit.\",\n\t\t\t\"Keep edits[].oldText as small as possible while still being unique in the file. Do not pad with large unchanged regions.\",\n\t\t],\n\t\tparameters: editSchema,\n\t\trenderShell: \"self\",\n\t\tprepareArguments: prepareEditArguments,\n\t\tasync execute(_toolCallId, input: EditToolInput, signal?: AbortSignal, _onUpdate?, _ctx?) {\n\t\t\tconst { path, edits } = validateEditInput(input);\n\t\t\tconst absolutePath = resolveToCwd(path, cwd);\n\n\t\t\treturn withFileMutationQueue(absolutePath, async () => {\n\t\t\t\t// Do not reject from an abort event listener here: that would release the\n\t\t\t\t// mutation queue while an in-flight filesystem operation may still finish.\n\t\t\t\t// Checking signal.aborted after each await observes the same aborts while\n\t\t\t\t// keeping the queue locked until the current operation has settled.\n\t\t\t\tconst throwIfAborted = (): void => {\n\t\t\t\t\tif (signal?.aborted) throw new Error(\"Operation aborted\");\n\t\t\t\t};\n\n\t\t\t\tthrowIfAborted();\n\n\t\t\t\t// Check if file exists.\n\t\t\t\ttry {\n\t\t\t\t\tawait ops.access(absolutePath);\n\t\t\t\t} catch (error: unknown) {\n\t\t\t\t\tthrowIfAborted();\n\t\t\t\t\tconst errorMessage = error instanceof Error && \"code\" in error ? `Error code: ${error.code}` : String(error);\n\t\t\t\t\tthrow new Error(`Could not edit file: ${path}. ${errorMessage}.`);\n\t\t\t\t}\n\t\t\t\tthrowIfAborted();\n\n\t\t\t\t// Read the file.\n\t\t\t\tconst buffer = await ops.readFile(absolutePath);\n\t\t\t\tconst rawContent = buffer.toString(\"utf-8\");\n\t\t\t\tthrowIfAborted();\n\n\t\t\t\t// Strip BOM before matching. The model will not include an invisible BOM in oldText.\n\t\t\t\tconst { bom, text: content } = stripBom(rawContent);\n\t\t\t\tconst originalEnding = detectLineEnding(content);\n\t\t\t\tconst normalizedContent = normalizeToLF(content);\n\t\t\t\tconst { baseContent, newContent } = applyEditsToNormalizedContent(normalizedContent, edits, path);\n\t\t\t\tthrowIfAborted();\n\n\t\t\t\tconst finalContent = bom + restoreLineEndings(newContent, originalEnding);\n\t\t\t\tawait ops.writeFile(absolutePath, finalContent);\n\t\t\t\tthrowIfAborted();\n\n\t\t\t\tconst diffResult = generateDiffString(baseContent, newContent);\n\t\t\t\tconst patch = generateUnifiedPatch(path, baseContent, newContent);\n\t\t\t\treturn {\n\t\t\t\t\tcontent: [\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\ttype: \"text\",\n\t\t\t\t\t\t\ttext: `Successfully replaced ${edits.length} block(s) in ${path}.`,\n\t\t\t\t\t\t},\n\t\t\t\t\t],\n\t\t\t\t\tdetails: { diff: diffResult.diff, patch, firstChangedLine: diffResult.firstChangedLine },\n\t\t\t\t};\n\t\t\t});\n\t\t},\n\t\trenderCall(args, theme, context) {\n\t\t\tconst component = getEditCallRenderComponent(context.state, context.lastComponent);\n\t\t\tconst previewInput = getRenderablePreviewInput(args as RenderableEditArgs | undefined);\n\t\t\tconst argsKey = previewInput ? JSON.stringify({ path: previewInput.path, edits: previewInput.edits }) : undefined;\n\n\t\t\tif (component.previewArgsKey !== argsKey) {\n\t\t\t\tcomponent.preview = undefined;\n\t\t\t\tcomponent.previewArgsKey = argsKey;\n\t\t\t\tcomponent.previewPending = false;\n\t\t\t\tcomponent.settledError = false;\n\t\t\t}\n\n\t\t\tif (context.argsComplete && previewInput && !component.preview && !component.previewPending) {\n\t\t\t\tcomponent.previewPending = true;\n\t\t\t\tconst requestKey = argsKey;\n\t\t\t\tvoid computeEditsDiff(previewInput.path, previewInput.edits, context.cwd).then((preview) => {\n\t\t\t\t\tif (component.previewArgsKey === requestKey) {\n\t\t\t\t\t\tsetEditPreview(component, preview, requestKey);\n\t\t\t\t\t\tcontext.invalidate();\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t}\n\n\t\t\treturn buildEditCallComponent(component, args, theme, context.cwd);\n\t\t},\n\t\trenderResult(result, _options, theme, context) {\n\t\t\tconst callComponent = context.state.callComponent;\n\t\t\tconst previewInput = getRenderablePreviewInput(context.args as RenderableEditArgs | undefined);\n\t\t\tconst argsKey = previewInput ? JSON.stringify({ path: previewInput.path, edits: previewInput.edits }) : undefined;\n\t\t\tconst typedResult = result as EditToolResultLike;\n\t\t\tconst resultDiff = !context.isError ? typedResult.details?.diff : undefined;\n\t\t\tlet changed = false;\n\t\t\tif (callComponent) {\n\t\t\t\tif (typeof resultDiff === \"string\") {\n\t\t\t\t\tchanged =\n\t\t\t\t\t\tsetEditPreview(\n\t\t\t\t\t\t\tcallComponent,\n\t\t\t\t\t\t\t{ diff: resultDiff, firstChangedLine: typedResult.details?.firstChangedLine },\n\t\t\t\t\t\t\targsKey,\n\t\t\t\t\t\t) || changed;\n\t\t\t\t}\n\t\t\t\tif (callComponent.settledError !== context.isError) {\n\t\t\t\t\tcallComponent.settledError = context.isError;\n\t\t\t\t\tchanged = true;\n\t\t\t\t}\n\t\t\t\tif (changed) {\n\t\t\t\t\tbuildEditCallComponent(callComponent, context.args as RenderableEditArgs | undefined, theme, context.cwd);\n\t\t\t\t}\n\t\t\t}\n\n\t\t\tconst body = buildEditResultBody(context.args, callComponent?.preview, typedResult, theme, context.isError);\n\t\t\tconst component = (context.lastComponent as Container | undefined) ?? new Container();\n\t\t\tcomponent.clear();\n\t\t\tif (!body) {\n\t\t\t\treturn component;\n\t\t\t}\n\t\t\tif (!theme.cards.gaplessCards) {\n\t\t\t\tcomponent.addChild(new Spacer(1));\n\t\t\t}\n\t\t\tcomponent.addChild(body);\n\t\t\treturn component;\n\t\t},\n\t};\n}\n\nexport function createEditTool(cwd: string, options?: EditToolOptions): AgentTool<typeof editSchema> {\n\treturn wrapToolDefinition(createEditToolDefinition(cwd, options));\n}\n"]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Serialize file mutation operations targeting the same file.
|
|
3
|
+
* Operations for different files still run in parallel.
|
|
4
|
+
*/
|
|
5
|
+
export declare function withFileMutationQueue<T>(filePath: string, fn: () => Promise<T>): Promise<T>;
|
|
6
|
+
//# sourceMappingURL=file-mutation-queue.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-mutation-queue.d.ts","sourceRoot":"","sources":["../../../src/core/tools/file-mutation-queue.ts"],"names":[],"mappings":"AA2BA;;;GAGG;AACH,wBAAsB,qBAAqB,CAAC,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CA6BjG"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { realpath } from "node:fs/promises";
|
|
2
|
+
import { resolve } from "node:path";
|
|
3
|
+
const fileMutationQueues = new Map();
|
|
4
|
+
let registrationQueue = Promise.resolve();
|
|
5
|
+
function isMissingPathError(error) {
|
|
6
|
+
return (typeof error === "object" &&
|
|
7
|
+
error !== null &&
|
|
8
|
+
"code" in error &&
|
|
9
|
+
(error.code === "ENOENT" || error.code === "ENOTDIR"));
|
|
10
|
+
}
|
|
11
|
+
async function getMutationQueueKey(filePath) {
|
|
12
|
+
const resolvedPath = resolve(filePath);
|
|
13
|
+
try {
|
|
14
|
+
return await realpath(resolvedPath);
|
|
15
|
+
}
|
|
16
|
+
catch (error) {
|
|
17
|
+
if (isMissingPathError(error)) {
|
|
18
|
+
return resolvedPath;
|
|
19
|
+
}
|
|
20
|
+
throw error;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Serialize file mutation operations targeting the same file.
|
|
25
|
+
* Operations for different files still run in parallel.
|
|
26
|
+
*/
|
|
27
|
+
export async function withFileMutationQueue(filePath, fn) {
|
|
28
|
+
const registration = registrationQueue.then(async () => {
|
|
29
|
+
const key = await getMutationQueueKey(filePath);
|
|
30
|
+
const currentQueue = fileMutationQueues.get(key) ?? Promise.resolve();
|
|
31
|
+
let releaseNext;
|
|
32
|
+
const nextQueue = new Promise((resolveQueue) => {
|
|
33
|
+
releaseNext = resolveQueue;
|
|
34
|
+
});
|
|
35
|
+
const chainedQueue = currentQueue.then(() => nextQueue);
|
|
36
|
+
fileMutationQueues.set(key, chainedQueue);
|
|
37
|
+
return { key, currentQueue, chainedQueue, releaseNext };
|
|
38
|
+
});
|
|
39
|
+
registrationQueue = registration.then(() => undefined, () => undefined);
|
|
40
|
+
const { key, currentQueue, chainedQueue, releaseNext } = await registration;
|
|
41
|
+
await currentQueue;
|
|
42
|
+
try {
|
|
43
|
+
return await fn();
|
|
44
|
+
}
|
|
45
|
+
finally {
|
|
46
|
+
releaseNext();
|
|
47
|
+
if (fileMutationQueues.get(key) === chainedQueue) {
|
|
48
|
+
fileMutationQueues.delete(key);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=file-mutation-queue.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-mutation-queue.js","sourceRoot":"","sources":["../../../src/core/tools/file-mutation-queue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAC5C,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAEpC,MAAM,kBAAkB,GAAG,IAAI,GAAG,EAAyB,CAAC;AAC5D,IAAI,iBAAiB,GAAG,OAAO,CAAC,OAAO,EAAE,CAAC;AAE1C,SAAS,kBAAkB,CAAC,KAAc;IACzC,OAAO,CACN,OAAO,KAAK,KAAK,QAAQ;QACzB,KAAK,KAAK,IAAI;QACd,MAAM,IAAI,KAAK;QACf,CAAC,KAAK,CAAC,IAAI,KAAK,QAAQ,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,CACrD,CAAC;AACH,CAAC;AAED,KAAK,UAAU,mBAAmB,CAAC,QAAgB;IAClD,MAAM,YAAY,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC;IACvC,IAAI,CAAC;QACJ,OAAO,MAAM,QAAQ,CAAC,YAAY,CAAC,CAAC;IACrC,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QAChB,IAAI,kBAAkB,CAAC,KAAK,CAAC,EAAE,CAAC;YAC/B,OAAO,YAAY,CAAC;QACrB,CAAC;QACD,MAAM,KAAK,CAAC;IACb,CAAC;AACF,CAAC;AAED;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAI,QAAgB,EAAE,EAAoB;IACpF,MAAM,YAAY,GAAG,iBAAiB,CAAC,IAAI,CAAC,KAAK,IAAI,EAAE;QACtD,MAAM,GAAG,GAAG,MAAM,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QAChD,MAAM,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;QAEtE,IAAI,WAAwB,CAAC;QAC7B,MAAM,SAAS,GAAG,IAAI,OAAO,CAAO,CAAC,YAAY,EAAE,EAAE;YACpD,WAAW,GAAG,YAAY,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,MAAM,YAAY,GAAG,YAAY,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,CAAC;QACxD,kBAAkB,CAAC,GAAG,CAAC,GAAG,EAAE,YAAY,CAAC,CAAC;QAE1C,OAAO,EAAE,GAAG,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC;IACzD,CAAC,CAAC,CAAC;IACH,iBAAiB,GAAG,YAAY,CAAC,IAAI,CACpC,GAAG,EAAE,CAAC,SAAS,EACf,GAAG,EAAE,CAAC,SAAS,CACf,CAAC;IAEF,MAAM,EAAE,GAAG,EAAE,YAAY,EAAE,YAAY,EAAE,WAAW,EAAE,GAAG,MAAM,YAAY,CAAC;IAC5E,MAAM,YAAY,CAAC;IACnB,IAAI,CAAC;QACJ,OAAO,MAAM,EAAE,EAAE,CAAC;IACnB,CAAC;YAAS,CAAC;QACV,WAAW,EAAE,CAAC;QACd,IAAI,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,YAAY,EAAE,CAAC;YAClD,kBAAkB,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAChC,CAAC;IACF,CAAC;AACF,CAAC","sourcesContent":["import { realpath } from \"node:fs/promises\";\nimport { resolve } from \"node:path\";\n\nconst fileMutationQueues = new Map<string, Promise<void>>();\nlet registrationQueue = Promise.resolve();\n\nfunction isMissingPathError(error: unknown): boolean {\n\treturn (\n\t\ttypeof error === \"object\" &&\n\t\terror !== null &&\n\t\t\"code\" in error &&\n\t\t(error.code === \"ENOENT\" || error.code === \"ENOTDIR\")\n\t);\n}\n\nasync function getMutationQueueKey(filePath: string): Promise<string> {\n\tconst resolvedPath = resolve(filePath);\n\ttry {\n\t\treturn await realpath(resolvedPath);\n\t} catch (error) {\n\t\tif (isMissingPathError(error)) {\n\t\t\treturn resolvedPath;\n\t\t}\n\t\tthrow error;\n\t}\n}\n\n/**\n * Serialize file mutation operations targeting the same file.\n * Operations for different files still run in parallel.\n */\nexport async function withFileMutationQueue<T>(filePath: string, fn: () => Promise<T>): Promise<T> {\n\tconst registration = registrationQueue.then(async () => {\n\t\tconst key = await getMutationQueueKey(filePath);\n\t\tconst currentQueue = fileMutationQueues.get(key) ?? Promise.resolve();\n\n\t\tlet releaseNext!: () => void;\n\t\tconst nextQueue = new Promise<void>((resolveQueue) => {\n\t\t\treleaseNext = resolveQueue;\n\t\t});\n\t\tconst chainedQueue = currentQueue.then(() => nextQueue);\n\t\tfileMutationQueues.set(key, chainedQueue);\n\n\t\treturn { key, currentQueue, chainedQueue, releaseNext };\n\t});\n\tregistrationQueue = registration.then(\n\t\t() => undefined,\n\t\t() => undefined,\n\t);\n\n\tconst { key, currentQueue, chainedQueue, releaseNext } = await registration;\n\tawait currentQueue;\n\ttry {\n\t\treturn await fn();\n\t} finally {\n\t\treleaseNext();\n\t\tif (fileMutationQueues.get(key) === chainedQueue) {\n\t\t\tfileMutationQueues.delete(key);\n\t\t}\n\t}\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import type { AgentTool } from "@hamr/agent";
|
|
2
|
+
import { type Static, Type } from "typebox";
|
|
3
|
+
import type { ToolDefinition } from "../extensions/types.ts";
|
|
4
|
+
import { type TruncationResult } from "./truncate.ts";
|
|
5
|
+
declare const findSchema: Type.TObject<{
|
|
6
|
+
pattern: Type.TString;
|
|
7
|
+
path: Type.TOptional<Type.TString>;
|
|
8
|
+
limit: Type.TOptional<Type.TNumber>;
|
|
9
|
+
}>;
|
|
10
|
+
export type FindToolInput = Static<typeof findSchema>;
|
|
11
|
+
export interface FindToolDetails {
|
|
12
|
+
truncation?: TruncationResult;
|
|
13
|
+
resultLimitReached?: number;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Pluggable operations for the find tool.
|
|
17
|
+
* Override these to delegate file search to remote systems (for example SSH).
|
|
18
|
+
*/
|
|
19
|
+
export interface FindOperations {
|
|
20
|
+
/** Check if path exists */
|
|
21
|
+
exists: (absolutePath: string) => Promise<boolean> | boolean;
|
|
22
|
+
/** Find files matching glob pattern. Returns relative or absolute paths. */
|
|
23
|
+
glob: (pattern: string, cwd: string, options: {
|
|
24
|
+
ignore: string[];
|
|
25
|
+
limit: number;
|
|
26
|
+
}) => Promise<string[]> | string[];
|
|
27
|
+
}
|
|
28
|
+
export interface FindToolOptions {
|
|
29
|
+
/** Custom operations for find. Default: local filesystem plus fd */
|
|
30
|
+
operations?: FindOperations;
|
|
31
|
+
}
|
|
32
|
+
export declare function createFindToolDefinition(cwd: string, options?: FindToolOptions): ToolDefinition<typeof findSchema, FindToolDetails | undefined>;
|
|
33
|
+
export declare function createFindTool(cwd: string, options?: FindToolOptions): AgentTool<typeof findSchema>;
|
|
34
|
+
export {};
|
|
35
|
+
//# sourceMappingURL=find.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"find.d.ts","sourceRoot":"","sources":["../../../src/core/tools/find.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAI7C,OAAO,EAAE,KAAK,MAAM,EAAE,IAAI,EAAE,MAAM,SAAS,CAAC;AAI5C,OAAO,KAAK,EAAE,cAAc,EAA2B,MAAM,wBAAwB,CAAC;AAItF,OAAO,EAAiC,KAAK,gBAAgB,EAAgB,MAAM,eAAe,CAAC;AAMnG,QAAA,MAAM,UAAU;;;;EAMd,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,UAAU,CAAC,CAAC;AAItD,MAAM,WAAW,eAAe;IAC/B,UAAU,CAAC,EAAE,gBAAgB,CAAC;IAC9B,kBAAkB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAED;;;GAGG;AACH,MAAM,WAAW,cAAc;IAC9B,2BAA2B;IAC3B,MAAM,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IAC7D,4EAA4E;IAC5E,IAAI,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE;QAAE,MAAM,EAAE,MAAM,EAAE,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,MAAM,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC;CACnH;AAQD,MAAM,WAAW,eAAe;IAC/B,oEAAoE;IACpE,UAAU,CAAC,EAAE,cAAc,CAAC;CAC5B;AAoDD,wBAAgB,wBAAwB,CACvC,GAAG,EAAE,MAAM,EACX,OAAO,CAAC,EAAE,eAAe,GACvB,cAAc,CAAC,OAAO,UAAU,EAAE,eAAe,GAAG,SAAS,CAAC,CA2PhE;AAED,wBAAgB,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,eAAe,GAAG,SAAS,CAAC,OAAO,UAAU,CAAC,CAEnG"}
|