wotann 0.5.0 → 0.5.39
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agents/background-agent.d.ts.map +1 -1
- package/dist/agents/background-agent.js +2 -1
- package/dist/agents/background-agent.js.map +1 -1
- package/dist/agents/file-scope-policy.d.ts +116 -0
- package/dist/agents/file-scope-policy.d.ts.map +1 -0
- package/dist/agents/file-scope-policy.js +190 -0
- package/dist/agents/file-scope-policy.js.map +1 -0
- package/dist/agents/yaml-manifest.d.ts +125 -0
- package/dist/agents/yaml-manifest.d.ts.map +1 -0
- package/dist/agents/yaml-manifest.js +901 -0
- package/dist/agents/yaml-manifest.js.map +1 -0
- package/dist/auth/login.d.ts +3 -3
- package/dist/auth/login.d.ts.map +1 -1
- package/dist/auth/login.js +80 -23
- package/dist/auth/login.js.map +1 -1
- package/dist/autopilot/completion-oracle.d.ts.map +1 -1
- package/dist/autopilot/completion-oracle.js +3 -1
- package/dist/autopilot/completion-oracle.js.map +1 -1
- package/dist/autopilot/run-manifest.d.ts +90 -0
- package/dist/autopilot/run-manifest.d.ts.map +1 -0
- package/dist/autopilot/run-manifest.js +261 -0
- package/dist/autopilot/run-manifest.js.map +1 -0
- package/dist/browser/adaptive-selectors.d.ts +170 -0
- package/dist/browser/adaptive-selectors.d.ts.map +1 -0
- package/dist/browser/adaptive-selectors.js +317 -0
- package/dist/browser/adaptive-selectors.js.map +1 -0
- package/dist/browser/humanize-input.d.ts +76 -0
- package/dist/browser/humanize-input.d.ts.map +1 -0
- package/dist/browser/humanize-input.js +386 -0
- package/dist/browser/humanize-input.js.map +1 -0
- package/dist/channels/teams.d.ts +41 -19
- package/dist/channels/teams.d.ts.map +1 -1
- package/dist/channels/teams.js +121 -24
- package/dist/channels/teams.js.map +1 -1
- package/dist/channels/terminal-mention.d.ts.map +1 -1
- package/dist/channels/terminal-mention.js +4 -1
- package/dist/channels/terminal-mention.js.map +1 -1
- package/dist/cli/commands/blast-radius.d.ts +47 -0
- package/dist/cli/commands/blast-radius.d.ts.map +1 -0
- package/dist/cli/commands/blast-radius.js +123 -0
- package/dist/cli/commands/blast-radius.js.map +1 -0
- package/dist/cli/commands/evolve.d.ts +92 -0
- package/dist/cli/commands/evolve.d.ts.map +1 -0
- package/dist/cli/commands/evolve.js +336 -0
- package/dist/cli/commands/evolve.js.map +1 -0
- package/dist/cli/commands/learning.d.ts +54 -0
- package/dist/cli/commands/learning.d.ts.map +1 -0
- package/dist/cli/commands/learning.js +380 -0
- package/dist/cli/commands/learning.js.map +1 -0
- package/dist/cli/commands/persona.d.ts +42 -0
- package/dist/cli/commands/persona.d.ts.map +1 -0
- package/dist/cli/commands/persona.js +198 -0
- package/dist/cli/commands/persona.js.map +1 -0
- package/dist/cli/commands/stuck.d.ts.map +1 -1
- package/dist/cli/commands/stuck.js +5 -2
- package/dist/cli/commands/stuck.js.map +1 -1
- package/dist/cli/commands.d.ts.map +1 -1
- package/dist/cli/commands.js +5 -2
- package/dist/cli/commands.js.map +1 -1
- package/dist/cli/orphan-wires/agent-manifest-cmd.d.ts +17 -0
- package/dist/cli/orphan-wires/agent-manifest-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/agent-manifest-cmd.js +99 -0
- package/dist/cli/orphan-wires/agent-manifest-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/arena-cmd.d.ts +26 -0
- package/dist/cli/orphan-wires/arena-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/arena-cmd.js +167 -0
- package/dist/cli/orphan-wires/arena-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/artifact-cmd.d.ts +17 -0
- package/dist/cli/orphan-wires/artifact-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/artifact-cmd.js +175 -0
- package/dist/cli/orphan-wires/artifact-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/demo-cmd.d.ts +25 -0
- package/dist/cli/orphan-wires/demo-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/demo-cmd.js +164 -0
- package/dist/cli/orphan-wires/demo-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/extras-cmd.d.ts +20 -0
- package/dist/cli/orphan-wires/extras-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/extras-cmd.js +289 -0
- package/dist/cli/orphan-wires/extras-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/harness-introspect-cmd.d.ts +15 -0
- package/dist/cli/orphan-wires/harness-introspect-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/harness-introspect-cmd.js +36 -0
- package/dist/cli/orphan-wires/harness-introspect-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/index.d.ts.map +1 -1
- package/dist/cli/orphan-wires/index.js +30 -0
- package/dist/cli/orphan-wires/index.js.map +1 -1
- package/dist/cli/orphan-wires/integrations-cmd.d.ts +38 -0
- package/dist/cli/orphan-wires/integrations-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/integrations-cmd.js +345 -0
- package/dist/cli/orphan-wires/integrations-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/mcp-scaffold-cmd.d.ts +18 -0
- package/dist/cli/orphan-wires/mcp-scaffold-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/mcp-scaffold-cmd.js +127 -0
- package/dist/cli/orphan-wires/mcp-scaffold-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/memory-consolidate-cmd.d.ts +21 -0
- package/dist/cli/orphan-wires/memory-consolidate-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/memory-consolidate-cmd.js +86 -0
- package/dist/cli/orphan-wires/memory-consolidate-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/patch-cmd.d.ts +29 -0
- package/dist/cli/orphan-wires/patch-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/patch-cmd.js +150 -0
- package/dist/cli/orphan-wires/patch-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/redteam-scan-cmd.d.ts +28 -0
- package/dist/cli/orphan-wires/redteam-scan-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/redteam-scan-cmd.js +169 -0
- package/dist/cli/orphan-wires/redteam-scan-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/scrape-adapt-cmd.d.ts +21 -0
- package/dist/cli/orphan-wires/scrape-adapt-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/scrape-adapt-cmd.js +70 -0
- package/dist/cli/orphan-wires/scrape-adapt-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/shell-tier-cmd.d.ts +20 -0
- package/dist/cli/orphan-wires/shell-tier-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/shell-tier-cmd.js +74 -0
- package/dist/cli/orphan-wires/shell-tier-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/sub-recipes-cmd.d.ts +18 -0
- package/dist/cli/orphan-wires/sub-recipes-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/sub-recipes-cmd.js +87 -0
- package/dist/cli/orphan-wires/sub-recipes-cmd.js.map +1 -0
- package/dist/cli/orphan-wires/webapp-test-cmd.d.ts +20 -0
- package/dist/cli/orphan-wires/webapp-test-cmd.d.ts.map +1 -0
- package/dist/cli/orphan-wires/webapp-test-cmd.js +115 -0
- package/dist/cli/orphan-wires/webapp-test-cmd.js.map +1 -0
- package/dist/cli/thin-client.d.ts +17 -10
- package/dist/cli/thin-client.d.ts.map +1 -1
- package/dist/cli/thin-client.js +108 -26
- package/dist/cli/thin-client.js.map +1 -1
- package/dist/computer-use/action-history-compactor.d.ts +92 -0
- package/dist/computer-use/action-history-compactor.d.ts.map +1 -0
- package/dist/computer-use/action-history-compactor.js +204 -0
- package/dist/computer-use/action-history-compactor.js.map +1 -0
- package/dist/computer-use/action-repertoire.d.ts +8 -0
- package/dist/computer-use/action-repertoire.d.ts.map +1 -1
- package/dist/computer-use/action-repertoire.js +19 -0
- package/dist/computer-use/action-repertoire.js.map +1 -1
- package/dist/computer-use/computer-agent.d.ts +232 -2
- package/dist/computer-use/computer-agent.d.ts.map +1 -1
- package/dist/computer-use/computer-agent.js +558 -19
- package/dist/computer-use/computer-agent.js.map +1 -1
- package/dist/computer-use/coordinate-scaling.d.ts +104 -0
- package/dist/computer-use/coordinate-scaling.d.ts.map +1 -0
- package/dist/computer-use/coordinate-scaling.js +175 -0
- package/dist/computer-use/coordinate-scaling.js.map +1 -0
- package/dist/computer-use/driver-contract.d.ts +158 -0
- package/dist/computer-use/driver-contract.d.ts.map +1 -0
- package/dist/computer-use/driver-contract.js +471 -0
- package/dist/computer-use/driver-contract.js.map +1 -0
- package/dist/computer-use/perception-engine.d.ts +39 -0
- package/dist/computer-use/perception-engine.d.ts.map +1 -1
- package/dist/computer-use/perception-engine.js +27 -27
- package/dist/computer-use/perception-engine.js.map +1 -1
- package/dist/computer-use/platform-bindings.d.ts.map +1 -1
- package/dist/computer-use/platform-bindings.js +216 -2
- package/dist/computer-use/platform-bindings.js.map +1 -1
- package/dist/computer-use/safe-execute.d.ts +86 -0
- package/dist/computer-use/safe-execute.d.ts.map +1 -0
- package/dist/computer-use/safe-execute.js +152 -0
- package/dist/computer-use/safe-execute.js.map +1 -0
- package/dist/context/branch-summarization.d.ts +97 -0
- package/dist/context/branch-summarization.d.ts.map +1 -0
- package/dist/context/branch-summarization.js +170 -0
- package/dist/context/branch-summarization.js.map +1 -0
- package/dist/context/compaction.d.ts +16 -1
- package/dist/context/compaction.d.ts.map +1 -1
- package/dist/context/compaction.js +50 -2
- package/dist/context/compaction.js.map +1 -1
- package/dist/context/inspector.d.ts +2 -2
- package/dist/context/inspector.d.ts.map +1 -1
- package/dist/context/inspector.js +4 -3
- package/dist/context/inspector.js.map +1 -1
- package/dist/core/agent-bridge.d.ts.map +1 -1
- package/dist/core/agent-bridge.js +200 -69
- package/dist/core/agent-bridge.js.map +1 -1
- package/dist/core/config.d.ts.map +1 -1
- package/dist/core/config.js +7 -0
- package/dist/core/config.js.map +1 -1
- package/dist/core/mode-model-preference.d.ts +95 -0
- package/dist/core/mode-model-preference.d.ts.map +1 -0
- package/dist/core/mode-model-preference.js +170 -0
- package/dist/core/mode-model-preference.js.map +1 -0
- package/dist/core/prompt-override.d.ts.map +1 -1
- package/dist/core/prompt-override.js +1 -0
- package/dist/core/prompt-override.js.map +1 -1
- package/dist/core/runtime-intelligence.d.ts +11 -0
- package/dist/core/runtime-intelligence.d.ts.map +1 -1
- package/dist/core/runtime-intelligence.js +18 -3
- package/dist/core/runtime-intelligence.js.map +1 -1
- package/dist/core/runtime-tool-dispatch.js +1 -1
- package/dist/core/runtime-tool-dispatch.js.map +1 -1
- package/dist/core/runtime.d.ts +186 -13
- package/dist/core/runtime.d.ts.map +1 -1
- package/dist/core/runtime.js +717 -228
- package/dist/core/runtime.js.map +1 -1
- package/dist/core/session-rewind.d.ts +67 -0
- package/dist/core/session-rewind.d.ts.map +1 -0
- package/dist/core/session-rewind.js +120 -0
- package/dist/core/session-rewind.js.map +1 -0
- package/dist/core/types.d.ts +19 -0
- package/dist/core/types.d.ts.map +1 -1
- package/dist/daemon/file-watcher.d.ts +84 -0
- package/dist/daemon/file-watcher.d.ts.map +1 -0
- package/dist/daemon/file-watcher.js +193 -0
- package/dist/daemon/file-watcher.js.map +1 -0
- package/dist/daemon/jsonl-mode.d.ts +11 -0
- package/dist/daemon/jsonl-mode.d.ts.map +1 -0
- package/dist/daemon/jsonl-mode.js +77 -0
- package/dist/daemon/jsonl-mode.js.map +1 -0
- package/dist/daemon/kairos-ipc.d.ts +4 -1
- package/dist/daemon/kairos-ipc.d.ts.map +1 -1
- package/dist/daemon/kairos-ipc.js +38 -22
- package/dist/daemon/kairos-ipc.js.map +1 -1
- package/dist/daemon/kairos-rpc.d.ts +5 -1
- package/dist/daemon/kairos-rpc.d.ts.map +1 -1
- package/dist/daemon/kairos-rpc.js +1262 -114
- package/dist/daemon/kairos-rpc.js.map +1 -1
- package/dist/daemon/kairos.d.ts +35 -4
- package/dist/daemon/kairos.d.ts.map +1 -1
- package/dist/daemon/kairos.js +204 -24
- package/dist/daemon/kairos.js.map +1 -1
- package/dist/daemon/rpc-handlers/intelligence-rpc.d.ts.map +1 -1
- package/dist/daemon/rpc-handlers/intelligence-rpc.js +15 -3
- package/dist/daemon/rpc-handlers/intelligence-rpc.js.map +1 -1
- package/dist/daemon/transport/jsonl.d.ts +7 -0
- package/dist/daemon/transport/jsonl.d.ts.map +1 -0
- package/dist/daemon/transport/jsonl.js +38 -0
- package/dist/daemon/transport/jsonl.js.map +1 -0
- package/dist/daemon/transport/socket-path.d.ts +28 -0
- package/dist/daemon/transport/socket-path.d.ts.map +1 -0
- package/dist/daemon/transport/socket-path.js +36 -0
- package/dist/daemon/transport/socket-path.js.map +1 -0
- package/dist/design/theme-presets.d.ts +77 -0
- package/dist/design/theme-presets.d.ts.map +1 -0
- package/dist/design/theme-presets.js +274 -0
- package/dist/design/theme-presets.js.map +1 -0
- package/dist/desktop/companion-server.d.ts +67 -4
- package/dist/desktop/companion-server.d.ts.map +1 -1
- package/dist/desktop/companion-server.js +617 -70
- package/dist/desktop/companion-server.js.map +1 -1
- package/dist/desktop/web-artifacts-builder.d.ts +108 -0
- package/dist/desktop/web-artifacts-builder.d.ts.map +1 -0
- package/dist/desktop/web-artifacts-builder.js +184 -0
- package/dist/desktop/web-artifacts-builder.js.map +1 -0
- package/dist/hooks/built-in.d.ts.map +1 -1
- package/dist/hooks/built-in.js +15 -10
- package/dist/hooks/built-in.js.map +1 -1
- package/dist/index.js +1301 -167
- package/dist/index.js.map +1 -1
- package/dist/integrations/integration-manifest.d.ts +140 -0
- package/dist/integrations/integration-manifest.d.ts.map +1 -0
- package/dist/integrations/integration-manifest.js +268 -0
- package/dist/integrations/integration-manifest.js.map +1 -0
- package/dist/intelligence/apply-patch-dsl.d.ts +112 -0
- package/dist/intelligence/apply-patch-dsl.d.ts.map +1 -0
- package/dist/intelligence/apply-patch-dsl.js +264 -0
- package/dist/intelligence/apply-patch-dsl.js.map +1 -0
- package/dist/intelligence/apply-patch-executor.d.ts +147 -0
- package/dist/intelligence/apply-patch-executor.d.ts.map +1 -0
- package/dist/intelligence/apply-patch-executor.js +418 -0
- package/dist/intelligence/apply-patch-executor.js.map +1 -0
- package/dist/intelligence/blast-radius.d.ts +67 -0
- package/dist/intelligence/blast-radius.d.ts.map +1 -0
- package/dist/intelligence/blast-radius.js +536 -0
- package/dist/intelligence/blast-radius.js.map +1 -0
- package/dist/intelligence/code-graph.d.ts +58 -7
- package/dist/intelligence/code-graph.d.ts.map +1 -1
- package/dist/intelligence/code-graph.js +347 -16
- package/dist/intelligence/code-graph.js.map +1 -1
- package/dist/intelligence/codebase-health.d.ts.map +1 -1
- package/dist/intelligence/codebase-health.js +4 -3
- package/dist/intelligence/codebase-health.js.map +1 -1
- package/dist/intelligence/codemaps.d.ts +30 -1
- package/dist/intelligence/codemaps.d.ts.map +1 -1
- package/dist/intelligence/codemaps.js +99 -16
- package/dist/intelligence/codemaps.js.map +1 -1
- package/dist/intelligence/consecutive-error-counter.d.ts +89 -0
- package/dist/intelligence/consecutive-error-counter.d.ts.map +1 -0
- package/dist/intelligence/consecutive-error-counter.js +151 -0
- package/dist/intelligence/consecutive-error-counter.js.map +1 -0
- package/dist/intelligence/eval-frameworks/redteam-plugin-catalog.d.ts +87 -0
- package/dist/intelligence/eval-frameworks/redteam-plugin-catalog.d.ts.map +1 -0
- package/dist/intelligence/eval-frameworks/redteam-plugin-catalog.js +882 -0
- package/dist/intelligence/eval-frameworks/redteam-plugin-catalog.js.map +1 -0
- package/dist/intelligence/extractors/mineru.d.ts +108 -0
- package/dist/intelligence/extractors/mineru.d.ts.map +1 -0
- package/dist/intelligence/extractors/mineru.js +352 -0
- package/dist/intelligence/extractors/mineru.js.map +1 -0
- package/dist/intelligence/harness-introspect.d.ts +124 -0
- package/dist/intelligence/harness-introspect.d.ts.map +1 -0
- package/dist/intelligence/harness-introspect.js +349 -0
- package/dist/intelligence/harness-introspect.js.map +1 -0
- package/dist/intelligence/multi-patch-voter.d.ts +59 -1
- package/dist/intelligence/multi-patch-voter.d.ts.map +1 -1
- package/dist/intelligence/multi-patch-voter.js +191 -27
- package/dist/intelligence/multi-patch-voter.js.map +1 -1
- package/dist/intelligence/multimodal-extract.d.ts +44 -0
- package/dist/intelligence/multimodal-extract.d.ts.map +1 -1
- package/dist/intelligence/multimodal-extract.js +40 -1
- package/dist/intelligence/multimodal-extract.js.map +1 -1
- package/dist/intelligence/research-loops/budgeted-research.d.ts +7 -0
- package/dist/intelligence/research-loops/budgeted-research.d.ts.map +1 -1
- package/dist/intelligence/research-loops/budgeted-research.js +18 -0
- package/dist/intelligence/research-loops/budgeted-research.js.map +1 -1
- package/dist/intelligence/research-loops/constraint-guided-explorer.d.ts +124 -0
- package/dist/intelligence/research-loops/constraint-guided-explorer.d.ts.map +1 -0
- package/dist/intelligence/research-loops/constraint-guided-explorer.js +177 -0
- package/dist/intelligence/research-loops/constraint-guided-explorer.js.map +1 -0
- package/dist/intelligence/research-loops/results-collector.d.ts +62 -0
- package/dist/intelligence/research-loops/results-collector.d.ts.map +1 -0
- package/dist/intelligence/research-loops/results-collector.js +128 -0
- package/dist/intelligence/research-loops/results-collector.js.map +1 -0
- package/dist/intelligence/research-loops/results-log.d.ts +94 -0
- package/dist/intelligence/research-loops/results-log.d.ts.map +1 -0
- package/dist/intelligence/research-loops/results-log.js +178 -0
- package/dist/intelligence/research-loops/results-log.js.map +1 -0
- package/dist/intelligence/research-loops/strategies/base-strategy.d.ts +111 -0
- package/dist/intelligence/research-loops/strategies/base-strategy.d.ts.map +1 -0
- package/dist/intelligence/research-loops/strategies/base-strategy.js +72 -0
- package/dist/intelligence/research-loops/strategies/base-strategy.js.map +1 -0
- package/dist/intelligence/research-loops/strategies/dual-confidence.d.ts +57 -0
- package/dist/intelligence/research-loops/strategies/dual-confidence.d.ts.map +1 -0
- package/dist/intelligence/research-loops/strategies/dual-confidence.js +172 -0
- package/dist/intelligence/research-loops/strategies/dual-confidence.js.map +1 -0
- package/dist/intelligence/research-loops/strategies/langgraph-agent.d.ts +68 -0
- package/dist/intelligence/research-loops/strategies/langgraph-agent.d.ts.map +1 -0
- package/dist/intelligence/research-loops/strategies/langgraph-agent.js +221 -0
- package/dist/intelligence/research-loops/strategies/langgraph-agent.js.map +1 -0
- package/dist/intelligence/research-loops/strategies/parallel-constrained.d.ts +42 -0
- package/dist/intelligence/research-loops/strategies/parallel-constrained.d.ts.map +1 -0
- package/dist/intelligence/research-loops/strategies/parallel-constrained.js +132 -0
- package/dist/intelligence/research-loops/strategies/parallel-constrained.js.map +1 -0
- package/dist/intelligence/research-loops/strategies/recursive-decomposition.d.ts +55 -0
- package/dist/intelligence/research-loops/strategies/recursive-decomposition.d.ts.map +1 -0
- package/dist/intelligence/research-loops/strategies/recursive-decomposition.js +187 -0
- package/dist/intelligence/research-loops/strategies/recursive-decomposition.js.map +1 -0
- package/dist/intelligence/research-loops/strategy-registry.d.ts +43 -0
- package/dist/intelligence/research-loops/strategy-registry.d.ts.map +1 -0
- package/dist/intelligence/research-loops/strategy-registry.js +62 -0
- package/dist/intelligence/research-loops/strategy-registry.js.map +1 -0
- package/dist/intelligence/research-strategies.d.ts +133 -0
- package/dist/intelligence/research-strategies.d.ts.map +1 -0
- package/dist/intelligence/research-strategies.js +204 -0
- package/dist/intelligence/research-strategies.js.map +1 -0
- package/dist/lib.d.ts +49 -0
- package/dist/lib.d.ts.map +1 -1
- package/dist/lib.js +133 -0
- package/dist/lib.js.map +1 -1
- package/dist/loop/tool-description-reset.d.ts +113 -0
- package/dist/loop/tool-description-reset.d.ts.map +1 -0
- package/dist/loop/tool-description-reset.js +136 -0
- package/dist/loop/tool-description-reset.js.map +1 -0
- package/dist/lsp/server-registry.d.ts.map +1 -1
- package/dist/lsp/server-registry.js +2 -1
- package/dist/lsp/server-registry.js.map +1 -1
- package/dist/lsp/symbol-operations.d.ts.map +1 -1
- package/dist/lsp/symbol-operations.js +2 -1
- package/dist/lsp/symbol-operations.js.map +1 -1
- package/dist/marketplace/acp-agent-registry.d.ts.map +1 -1
- package/dist/marketplace/acp-agent-registry.js +2 -1
- package/dist/marketplace/acp-agent-registry.js.map +1 -1
- package/dist/marketplace/marketplace-source-git.d.ts +135 -0
- package/dist/marketplace/marketplace-source-git.d.ts.map +1 -0
- package/dist/marketplace/marketplace-source-git.js +211 -0
- package/dist/marketplace/marketplace-source-git.js.map +1 -0
- package/dist/marketplace/registry.d.ts +87 -0
- package/dist/marketplace/registry.d.ts.map +1 -1
- package/dist/marketplace/registry.js +113 -2
- package/dist/marketplace/registry.js.map +1 -1
- package/dist/mcp/chrome-devtools.d.ts +62 -2
- package/dist/mcp/chrome-devtools.d.ts.map +1 -1
- package/dist/mcp/chrome-devtools.js +183 -1
- package/dist/mcp/chrome-devtools.js.map +1 -1
- package/dist/mcp/health-probe.d.ts +1 -0
- package/dist/mcp/health-probe.d.ts.map +1 -1
- package/dist/mcp/health-probe.js +32 -1
- package/dist/mcp/health-probe.js.map +1 -1
- package/dist/mcp/mcp-scaffolder.d.ts +166 -0
- package/dist/mcp/mcp-scaffolder.d.ts.map +1 -0
- package/dist/mcp/mcp-scaffolder.js +526 -0
- package/dist/mcp/mcp-scaffolder.js.map +1 -0
- package/dist/mcp/mcp-server.d.ts.map +1 -1
- package/dist/mcp/mcp-server.js +55 -0
- package/dist/mcp/mcp-server.js.map +1 -1
- package/dist/mcp/memory-mcp.d.ts +163 -0
- package/dist/mcp/memory-mcp.d.ts.map +1 -0
- package/dist/mcp/memory-mcp.js +368 -0
- package/dist/mcp/memory-mcp.js.map +1 -0
- package/dist/mcp/tool-loader.d.ts.map +1 -1
- package/dist/mcp/tool-loader.js +13 -0
- package/dist/mcp/tool-loader.js.map +1 -1
- package/dist/meet/meeting-runtime.d.ts.map +1 -1
- package/dist/meet/meeting-runtime.js +3 -1
- package/dist/meet/meeting-runtime.js.map +1 -1
- package/dist/memory/incremental-indexer.d.ts.map +1 -1
- package/dist/memory/incremental-indexer.js +5 -1
- package/dist/memory/incremental-indexer.js.map +1 -1
- package/dist/memory/qmd-integration.d.ts.map +1 -1
- package/dist/memory/qmd-integration.js +47 -15
- package/dist/memory/qmd-integration.js.map +1 -1
- package/dist/memory/two-phase-consolidator.d.ts +118 -0
- package/dist/memory/two-phase-consolidator.d.ts.map +1 -0
- package/dist/memory/two-phase-consolidator.js +265 -0
- package/dist/memory/two-phase-consolidator.js.map +1 -0
- package/dist/middleware/doom-loop.d.ts +21 -0
- package/dist/middleware/doom-loop.d.ts.map +1 -1
- package/dist/middleware/doom-loop.js +49 -6
- package/dist/middleware/doom-loop.js.map +1 -1
- package/dist/middleware/loop-detection.d.ts +176 -6
- package/dist/middleware/loop-detection.d.ts.map +1 -1
- package/dist/middleware/loop-detection.js +341 -6
- package/dist/middleware/loop-detection.js.map +1 -1
- package/dist/middleware/pipeline.d.ts +9 -1
- package/dist/middleware/pipeline.d.ts.map +1 -1
- package/dist/middleware/pipeline.js +116 -1
- package/dist/middleware/pipeline.js.map +1 -1
- package/dist/middleware/tool-flow-gate.d.ts +20 -0
- package/dist/middleware/tool-flow-gate.d.ts.map +1 -1
- package/dist/middleware/tool-flow-gate.js +93 -0
- package/dist/middleware/tool-flow-gate.js.map +1 -1
- package/dist/mobile/ios-app.d.ts +18 -1
- package/dist/mobile/ios-app.d.ts.map +1 -1
- package/dist/mobile/ios-app.js +108 -8
- package/dist/mobile/ios-app.js.map +1 -1
- package/dist/orchestration/adversarial-cut.d.ts +85 -0
- package/dist/orchestration/adversarial-cut.d.ts.map +1 -0
- package/dist/orchestration/adversarial-cut.js +222 -0
- package/dist/orchestration/adversarial-cut.js.map +1 -0
- package/dist/orchestration/agent-kanban.d.ts +147 -0
- package/dist/orchestration/agent-kanban.d.ts.map +1 -0
- package/dist/orchestration/agent-kanban.js +414 -0
- package/dist/orchestration/agent-kanban.js.map +1 -0
- package/dist/orchestration/autonomous.d.ts +111 -0
- package/dist/orchestration/autonomous.d.ts.map +1 -1
- package/dist/orchestration/autonomous.js +183 -6
- package/dist/orchestration/autonomous.js.map +1 -1
- package/dist/orchestration/elo-tournament.d.ts +90 -0
- package/dist/orchestration/elo-tournament.d.ts.map +1 -0
- package/dist/orchestration/elo-tournament.js +203 -0
- package/dist/orchestration/elo-tournament.js.map +1 -0
- package/dist/orchestration/multi-model-arena.d.ts +138 -0
- package/dist/orchestration/multi-model-arena.d.ts.map +1 -0
- package/dist/orchestration/multi-model-arena.js +298 -0
- package/dist/orchestration/multi-model-arena.js.map +1 -0
- package/dist/orchestration/review-pipeline.d.ts +78 -0
- package/dist/orchestration/review-pipeline.d.ts.map +1 -0
- package/dist/orchestration/review-pipeline.js +202 -0
- package/dist/orchestration/review-pipeline.js.map +1 -0
- package/dist/orchestration/unified-state-thread.d.ts +186 -0
- package/dist/orchestration/unified-state-thread.d.ts.map +1 -0
- package/dist/orchestration/unified-state-thread.js +327 -0
- package/dist/orchestration/unified-state-thread.js.map +1 -0
- package/dist/plugins/manager.d.ts.map +1 -1
- package/dist/plugins/manager.js +2 -1
- package/dist/plugins/manager.js.map +1 -1
- package/dist/prompt/engine.d.ts +7 -0
- package/dist/prompt/engine.d.ts.map +1 -1
- package/dist/prompt/engine.js.map +1 -1
- package/dist/prompt/modules/caveman.d.ts +51 -0
- package/dist/prompt/modules/caveman.d.ts.map +1 -0
- package/dist/prompt/modules/caveman.js +97 -0
- package/dist/prompt/modules/caveman.js.map +1 -0
- package/dist/prompt/modules/index.d.ts +1 -0
- package/dist/prompt/modules/index.d.ts.map +1 -1
- package/dist/prompt/modules/index.js +3 -0
- package/dist/prompt/modules/index.js.map +1 -1
- package/dist/providers/account-pool.d.ts.map +1 -1
- package/dist/providers/account-pool.js +1 -0
- package/dist/providers/account-pool.js.map +1 -1
- package/dist/providers/anthropic-adapter.d.ts.map +1 -1
- package/dist/providers/anthropic-adapter.js +33 -0
- package/dist/providers/anthropic-adapter.js.map +1 -1
- package/dist/providers/cloud-offload/config-loader.d.ts +20 -0
- package/dist/providers/cloud-offload/config-loader.d.ts.map +1 -0
- package/dist/providers/cloud-offload/config-loader.js +148 -0
- package/dist/providers/cloud-offload/config-loader.js.map +1 -0
- package/dist/providers/codex-adapter.d.ts.map +1 -1
- package/dist/providers/codex-adapter.js +136 -4
- package/dist/providers/codex-adapter.js.map +1 -1
- package/dist/providers/discovery.d.ts.map +1 -1
- package/dist/providers/discovery.js +20 -0
- package/dist/providers/discovery.js.map +1 -1
- package/dist/providers/effort-cascade.d.ts +113 -0
- package/dist/providers/effort-cascade.d.ts.map +1 -0
- package/dist/providers/effort-cascade.js +215 -0
- package/dist/providers/effort-cascade.js.map +1 -0
- package/dist/providers/fallback-chain.d.ts.map +1 -1
- package/dist/providers/fallback-chain.js +1 -0
- package/dist/providers/fallback-chain.js.map +1 -1
- package/dist/providers/health-check.d.ts.map +1 -1
- package/dist/providers/health-check.js +8 -0
- package/dist/providers/health-check.js.map +1 -1
- package/dist/providers/model-defaults.d.ts +1 -1
- package/dist/providers/model-defaults.d.ts.map +1 -1
- package/dist/providers/model-defaults.js +13 -1
- package/dist/providers/model-defaults.js.map +1 -1
- package/dist/providers/model-discovery.d.ts.map +1 -1
- package/dist/providers/model-discovery.js +1 -0
- package/dist/providers/model-discovery.js.map +1 -1
- package/dist/providers/ollama-adapter.d.ts.map +1 -1
- package/dist/providers/ollama-adapter.js +21 -1
- package/dist/providers/ollama-adapter.js.map +1 -1
- package/dist/providers/openai-compat-adapter.d.ts.map +1 -1
- package/dist/providers/openai-compat-adapter.js +25 -0
- package/dist/providers/openai-compat-adapter.js.map +1 -1
- package/dist/providers/preset-library.d.ts.map +1 -1
- package/dist/providers/preset-library.js +9 -0
- package/dist/providers/preset-library.js.map +1 -1
- package/dist/providers/provider-service.d.ts.map +1 -1
- package/dist/providers/provider-service.js +40 -1
- package/dist/providers/provider-service.js.map +1 -1
- package/dist/providers/registry.d.ts.map +1 -1
- package/dist/providers/registry.js +7 -0
- package/dist/providers/registry.js.map +1 -1
- package/dist/providers/sticky-rotation.d.ts +100 -0
- package/dist/providers/sticky-rotation.d.ts.map +1 -0
- package/dist/providers/sticky-rotation.js +134 -0
- package/dist/providers/sticky-rotation.js.map +1 -0
- package/dist/providers/tool-parsers/parsers.d.ts.map +1 -1
- package/dist/providers/tool-parsers/parsers.js +17 -4
- package/dist/providers/tool-parsers/parsers.js.map +1 -1
- package/dist/providers/types.d.ts +25 -0
- package/dist/providers/types.d.ts.map +1 -1
- package/dist/recipes/final-output.d.ts +74 -0
- package/dist/recipes/final-output.d.ts.map +1 -0
- package/dist/recipes/final-output.js +232 -0
- package/dist/recipes/final-output.js.map +1 -0
- package/dist/recipes/recipe-loader.d.ts.map +1 -1
- package/dist/recipes/recipe-loader.js +29 -0
- package/dist/recipes/recipe-loader.js.map +1 -1
- package/dist/recipes/recipe-runtime.d.ts.map +1 -1
- package/dist/recipes/recipe-runtime.js +31 -0
- package/dist/recipes/recipe-runtime.js.map +1 -1
- package/dist/recipes/recipe-types.d.ts +28 -0
- package/dist/recipes/recipe-types.d.ts.map +1 -1
- package/dist/recipes/sop-crystallizer.d.ts +90 -0
- package/dist/recipes/sop-crystallizer.d.ts.map +1 -0
- package/dist/recipes/sop-crystallizer.js +238 -0
- package/dist/recipes/sop-crystallizer.js.map +1 -0
- package/dist/recipes/sub-recipe-orchestrator.d.ts +126 -0
- package/dist/recipes/sub-recipe-orchestrator.d.ts.map +1 -0
- package/dist/recipes/sub-recipe-orchestrator.js +225 -0
- package/dist/recipes/sub-recipe-orchestrator.js.map +1 -0
- package/dist/sandbox/extended-backends.d.ts.map +1 -1
- package/dist/sandbox/extended-backends.js +7 -2
- package/dist/sandbox/extended-backends.js.map +1 -1
- package/dist/sandbox/seatbelt-policy.d.ts +132 -0
- package/dist/sandbox/seatbelt-policy.d.ts.map +1 -0
- package/dist/sandbox/seatbelt-policy.js +562 -0
- package/dist/sandbox/seatbelt-policy.js.map +1 -0
- package/dist/sandbox/terminal-backends.d.ts.map +1 -1
- package/dist/sandbox/terminal-backends.js +3 -1
- package/dist/sandbox/terminal-backends.js.map +1 -1
- package/dist/security/auto-mode-ruleset.d.ts +142 -0
- package/dist/security/auto-mode-ruleset.d.ts.map +1 -0
- package/dist/security/auto-mode-ruleset.js +264 -0
- package/dist/security/auto-mode-ruleset.js.map +1 -0
- package/dist/security/bash-arity-policy.d.ts +70 -0
- package/dist/security/bash-arity-policy.d.ts.map +1 -0
- package/dist/security/bash-arity-policy.js +189 -0
- package/dist/security/bash-arity-policy.js.map +1 -0
- package/dist/security/command-sanitizer.d.ts.map +1 -1
- package/dist/security/command-sanitizer.js +24 -0
- package/dist/security/command-sanitizer.js.map +1 -1
- package/dist/security/credential-broker.d.ts +136 -0
- package/dist/security/credential-broker.d.ts.map +1 -0
- package/dist/security/credential-broker.js +284 -0
- package/dist/security/credential-broker.js.map +1 -0
- package/dist/security/invisible-text-sanitizer.d.ts +114 -0
- package/dist/security/invisible-text-sanitizer.d.ts.map +1 -0
- package/dist/security/invisible-text-sanitizer.js +221 -0
- package/dist/security/invisible-text-sanitizer.js.map +1 -0
- package/dist/security/osv-check.d.ts +174 -0
- package/dist/security/osv-check.d.ts.map +1 -0
- package/dist/security/osv-check.js +409 -0
- package/dist/security/osv-check.js.map +1 -0
- package/dist/security/process-hardening.d.ts +114 -0
- package/dist/security/process-hardening.d.ts.map +1 -0
- package/dist/security/process-hardening.js +132 -0
- package/dist/security/process-hardening.js.map +1 -0
- package/dist/security/shell-escalation-tiers.d.ts +73 -0
- package/dist/security/shell-escalation-tiers.d.ts.map +1 -0
- package/dist/security/shell-escalation-tiers.js +439 -0
- package/dist/security/shell-escalation-tiers.js.map +1 -0
- package/dist/session/fork.d.ts +100 -0
- package/dist/session/fork.d.ts.map +1 -0
- package/dist/session/fork.js +223 -0
- package/dist/session/fork.js.map +1 -0
- package/dist/skills/activation-telemetry.d.ts +154 -0
- package/dist/skills/activation-telemetry.d.ts.map +1 -0
- package/dist/skills/activation-telemetry.js +274 -0
- package/dist/skills/activation-telemetry.js.map +1 -0
- package/dist/skills/agentskills-registry.d.ts +12 -1
- package/dist/skills/agentskills-registry.d.ts.map +1 -1
- package/dist/skills/agentskills-registry.js +11 -0
- package/dist/skills/agentskills-registry.js.map +1 -1
- package/dist/skills/description-optimizer.d.ts +101 -0
- package/dist/skills/description-optimizer.d.ts.map +1 -0
- package/dist/skills/description-optimizer.js +304 -0
- package/dist/skills/description-optimizer.js.map +1 -0
- package/dist/skills/history-deduper.d.ts +109 -0
- package/dist/skills/history-deduper.d.ts.map +1 -0
- package/dist/skills/history-deduper.js +222 -0
- package/dist/skills/history-deduper.js.map +1 -0
- package/dist/skills/loader.d.ts.map +1 -1
- package/dist/skills/loader.js +2 -1
- package/dist/skills/loader.js.map +1 -1
- package/dist/skills/skill-source-adapter.d.ts +16 -0
- package/dist/skills/skill-source-adapter.d.ts.map +1 -1
- package/dist/skills/skill-source-adapter.js +0 -0
- package/dist/skills/skill-source-adapter.js.map +1 -1
- package/dist/skills/skill-standard.d.ts +29 -4
- package/dist/skills/skill-standard.d.ts.map +1 -1
- package/dist/skills/skill-standard.js +139 -66
- package/dist/skills/skill-standard.js.map +1 -1
- package/dist/skills/sop-completion-gate.d.ts +137 -0
- package/dist/skills/sop-completion-gate.d.ts.map +1 -0
- package/dist/skills/sop-completion-gate.js +159 -0
- package/dist/skills/sop-completion-gate.js.map +1 -0
- package/dist/skills/sop-template.d.ts +85 -0
- package/dist/skills/sop-template.d.ts.map +1 -0
- package/dist/skills/sop-template.js +106 -0
- package/dist/skills/sop-template.js.map +1 -0
- package/dist/skills/wotann-skills-registry.d.ts +1 -1
- package/dist/skills/wotann-skills-registry.d.ts.map +1 -1
- package/dist/skills/wotann-skills-registry.js +503 -0
- package/dist/skills/wotann-skills-registry.js.map +1 -1
- package/dist/snippets/prompt-corpus.d.ts +10 -0
- package/dist/snippets/prompt-corpus.d.ts.map +1 -0
- package/dist/snippets/prompt-corpus.js +158 -0
- package/dist/snippets/prompt-corpus.js.map +1 -0
- package/dist/snippets/snippet-store.d.ts +27 -0
- package/dist/snippets/snippet-store.d.ts.map +1 -1
- package/dist/snippets/snippet-store.js +109 -6
- package/dist/snippets/snippet-store.js.map +1 -1
- package/dist/storage/sqlite-node-backend.d.ts +47 -36
- package/dist/storage/sqlite-node-backend.d.ts.map +1 -1
- package/dist/storage/sqlite-node-backend.js +250 -94
- package/dist/storage/sqlite-node-backend.js.map +1 -1
- package/dist/testing/webapp-server-lifecycle.d.ts +74 -0
- package/dist/testing/webapp-server-lifecycle.d.ts.map +1 -0
- package/dist/testing/webapp-server-lifecycle.js +272 -0
- package/dist/testing/webapp-server-lifecycle.js.map +1 -0
- package/dist/tools/markitdown-bridge.d.ts +19 -0
- package/dist/tools/markitdown-bridge.d.ts.map +1 -1
- package/dist/tools/markitdown-bridge.js +167 -2
- package/dist/tools/markitdown-bridge.js.map +1 -1
- package/dist/tools/pdf-processor.d.ts.map +1 -1
- package/dist/tools/pdf-processor.js +7 -3
- package/dist/tools/pdf-processor.js.map +1 -1
- package/dist/tools/pptx-processor.d.ts +51 -0
- package/dist/tools/pptx-processor.d.ts.map +1 -0
- package/dist/tools/pptx-processor.js +334 -0
- package/dist/tools/pptx-processor.js.map +1 -0
- package/dist/ui/App.d.ts.map +1 -1
- package/dist/ui/App.js +1661 -149
- package/dist/ui/App.js.map +1 -1
- package/dist/ui/agent-tools.d.ts +60 -0
- package/dist/ui/agent-tools.d.ts.map +1 -0
- package/dist/ui/agent-tools.js +468 -0
- package/dist/ui/agent-tools.js.map +1 -0
- package/dist/ui/alt-buffer-mode.d.ts +68 -0
- package/dist/ui/alt-buffer-mode.d.ts.map +1 -0
- package/dist/ui/alt-buffer-mode.js +114 -0
- package/dist/ui/alt-buffer-mode.js.map +1 -0
- package/dist/ui/alt-buffer.d.ts +57 -10
- package/dist/ui/alt-buffer.d.ts.map +1 -1
- package/dist/ui/alt-buffer.js +54 -12
- package/dist/ui/alt-buffer.js.map +1 -1
- package/dist/ui/components/AgentStatusPanel.d.ts.map +1 -1
- package/dist/ui/components/AgentStatusPanel.js +14 -6
- package/dist/ui/components/AgentStatusPanel.js.map +1 -1
- package/dist/ui/components/AuditLogPanel.js +3 -3
- package/dist/ui/components/AuditLogPanel.js.map +1 -1
- package/dist/ui/components/AutomationsPanel.js +3 -3
- package/dist/ui/components/AutomationsPanel.js.map +1 -1
- package/dist/ui/components/ChatView.d.ts +9 -1
- package/dist/ui/components/ChatView.d.ts.map +1 -1
- package/dist/ui/components/ChatView.js +503 -14
- package/dist/ui/components/ChatView.js.map +1 -1
- package/dist/ui/components/CommandPaletteCommands.d.ts +2 -0
- package/dist/ui/components/CommandPaletteCommands.d.ts.map +1 -1
- package/dist/ui/components/CommandPaletteCommands.js +18 -2
- package/dist/ui/components/CommandPaletteCommands.js.map +1 -1
- package/dist/ui/components/ContextHUD.d.ts.map +1 -1
- package/dist/ui/components/ContextHUD.js +3 -3
- package/dist/ui/components/ContextHUD.js.map +1 -1
- package/dist/ui/components/DispatchInbox.js +3 -3
- package/dist/ui/components/DispatchInbox.js.map +1 -1
- package/dist/ui/components/GdprPanel.d.ts.map +1 -1
- package/dist/ui/components/GdprPanel.js +2 -3
- package/dist/ui/components/GdprPanel.js.map +1 -1
- package/dist/ui/components/HistoryPicker.js +3 -3
- package/dist/ui/components/HistoryPicker.js.map +1 -1
- package/dist/ui/components/ModelPicker.d.ts +9 -6
- package/dist/ui/components/ModelPicker.d.ts.map +1 -1
- package/dist/ui/components/ModelPicker.js +12 -9
- package/dist/ui/components/ModelPicker.js.map +1 -1
- package/dist/ui/components/OptionPicker.js +3 -3
- package/dist/ui/components/OptionPicker.js.map +1 -1
- package/dist/ui/components/PermissionPrompt.js +3 -3
- package/dist/ui/components/PermissionPrompt.js.map +1 -1
- package/dist/ui/components/PromptInput.d.ts.map +1 -1
- package/dist/ui/components/PromptInput.js +65 -10
- package/dist/ui/components/PromptInput.js.map +1 -1
- package/dist/ui/components/ProviderSetupOverlay.d.ts +19 -0
- package/dist/ui/components/ProviderSetupOverlay.d.ts.map +1 -0
- package/dist/ui/components/ProviderSetupOverlay.js +124 -0
- package/dist/ui/components/ProviderSetupOverlay.js.map +1 -0
- package/dist/ui/components/StartupScreen.d.ts.map +1 -1
- package/dist/ui/components/StartupScreen.js +10 -1
- package/dist/ui/components/StartupScreen.js.map +1 -1
- package/dist/ui/components/StatusBar.d.ts.map +1 -1
- package/dist/ui/components/StatusBar.js +3 -3
- package/dist/ui/components/StatusBar.js.map +1 -1
- package/dist/ui/components/TrustPanel.js +3 -3
- package/dist/ui/components/TrustPanel.js.map +1 -1
- package/dist/ui/components/UnifiedStatusBar.d.ts.map +1 -1
- package/dist/ui/components/UnifiedStatusBar.js +76 -5
- package/dist/ui/components/UnifiedStatusBar.js.map +1 -1
- package/dist/ui/computer-action-parser.d.ts +6 -0
- package/dist/ui/computer-action-parser.d.ts.map +1 -0
- package/dist/ui/computer-action-parser.js +119 -0
- package/dist/ui/computer-action-parser.js.map +1 -0
- package/dist/ui/helpers.d.ts +1 -1
- package/dist/ui/helpers.d.ts.map +1 -1
- package/dist/ui/helpers.js +1 -1
- package/dist/ui/helpers.js.map +1 -1
- package/dist/ui/keybindings.d.ts +12 -2
- package/dist/ui/keybindings.d.ts.map +1 -1
- package/dist/ui/keybindings.js +36 -4
- package/dist/ui/keybindings.js.map +1 -1
- package/dist/ui/markdown-stream.d.ts +99 -0
- package/dist/ui/markdown-stream.d.ts.map +1 -0
- package/dist/ui/markdown-stream.js +314 -0
- package/dist/ui/markdown-stream.js.map +1 -0
- package/dist/ui/terminal-keyboard-protocol.d.ts +23 -0
- package/dist/ui/terminal-keyboard-protocol.d.ts.map +1 -0
- package/dist/ui/terminal-keyboard-protocol.js +72 -0
- package/dist/ui/terminal-keyboard-protocol.js.map +1 -0
- package/dist/ui/theme/context.d.ts +39 -0
- package/dist/ui/theme/context.d.ts.map +1 -0
- package/dist/ui/theme/context.js +42 -0
- package/dist/ui/theme/context.js.map +1 -0
- package/dist/utils/platform.d.ts +115 -0
- package/dist/utils/platform.d.ts.map +1 -0
- package/dist/utils/platform.js +146 -0
- package/dist/utils/platform.js.map +1 -0
- package/dist/verification/auto-verify-policy.d.ts +107 -0
- package/dist/verification/auto-verify-policy.d.ts.map +1 -0
- package/dist/verification/auto-verify-policy.js +309 -0
- package/dist/verification/auto-verify-policy.js.map +1 -0
- package/package.json +4 -1
- package/skills/anthropic-finance/audit-spreadsheet.md +165 -0
- package/skills/anthropic-finance/clean-data-xls.md +59 -0
- package/skills/anthropic-finance/competitive-analysis.md +288 -0
- package/skills/anthropic-finance/compliance-rules-engine.md +56 -0
- package/skills/anthropic-finance/dd-checklist.md +126 -0
- package/skills/anthropic-finance/independent-recompute.md +47 -0
- package/skills/anthropic-finance/reconcile-root-cause.md +48 -0
- package/skills/anthropic-finance/roll-forward.md +42 -0
- package/skills/anthropic-finance/untrusted-doc-parse.md +57 -0
- package/skills/anthropic-finance/variance-commentary.md +43 -0
- package/skills/doubt-driven-development.md +95 -0
- package/skills/mattpocock/diagnose.md +126 -0
- package/skills/mattpocock/grill-with-docs.md +97 -0
- package/skills/mattpocock/improve-codebase-architecture.md +80 -0
- package/skills/mattpocock/prototype.md +39 -0
- package/skills/mattpocock/review.md +87 -0
- package/skills/mattpocock/tdd.md +118 -0
- package/skills/mattpocock/zoom-out.md +17 -0
- package/skills/scientific/citation-management/SKILL.md +1113 -0
- package/skills/scientific/citation-management/assets/bibtex_template.bib +264 -0
- package/skills/scientific/citation-management/assets/citation_checklist.md +386 -0
- package/skills/scientific/citation-management/references/bibtex_formatting.md +908 -0
- package/skills/scientific/citation-management/references/citation_validation.md +794 -0
- package/skills/scientific/citation-management/references/google_scholar_search.md +725 -0
- package/skills/scientific/citation-management/references/metadata_extraction.md +870 -0
- package/skills/scientific/citation-management/references/pubmed_search.md +839 -0
- package/skills/scientific/citation-management/scripts/doi_to_bibtex.py +204 -0
- package/skills/scientific/citation-management/scripts/extract_metadata.py +569 -0
- package/skills/scientific/citation-management/scripts/format_bibtex.py +349 -0
- package/skills/scientific/citation-management/scripts/generate_schematic.py +139 -0
- package/skills/scientific/citation-management/scripts/generate_schematic_ai.py +817 -0
- package/skills/scientific/citation-management/scripts/search_google_scholar.py +282 -0
- package/skills/scientific/citation-management/scripts/search_pubmed.py +398 -0
- package/skills/scientific/citation-management/scripts/validate_citations.py +497 -0
- package/skills/scientific/database-lookup/SKILL.md +480 -0
- package/skills/scientific/database-lookup/references/addgene.md +38 -0
- package/skills/scientific/database-lookup/references/alphafold.md +40 -0
- package/skills/scientific/database-lookup/references/alphavantage.md +261 -0
- package/skills/scientific/database-lookup/references/bea.md +409 -0
- package/skills/scientific/database-lookup/references/bindingdb.md +85 -0
- package/skills/scientific/database-lookup/references/biogrid.md +110 -0
- package/skills/scientific/database-lookup/references/bls.md +235 -0
- package/skills/scientific/database-lookup/references/brenda.md +71 -0
- package/skills/scientific/database-lookup/references/cbioportal.md +206 -0
- package/skills/scientific/database-lookup/references/census.md +251 -0
- package/skills/scientific/database-lookup/references/chebi.md +103 -0
- package/skills/scientific/database-lookup/references/chembl.md +80 -0
- package/skills/scientific/database-lookup/references/clinicaltrials.md +77 -0
- package/skills/scientific/database-lookup/references/clinpgx.md +64 -0
- package/skills/scientific/database-lookup/references/clinvar.md +91 -0
- package/skills/scientific/database-lookup/references/cod.md +121 -0
- package/skills/scientific/database-lookup/references/cosmic.md +59 -0
- package/skills/scientific/database-lookup/references/dailymed.md +65 -0
- package/skills/scientific/database-lookup/references/datacommons.md +237 -0
- package/skills/scientific/database-lookup/references/dbsnp.md +143 -0
- package/skills/scientific/database-lookup/references/disgenet.md +52 -0
- package/skills/scientific/database-lookup/references/drugbank.md +54 -0
- package/skills/scientific/database-lookup/references/ecb.md +191 -0
- package/skills/scientific/database-lookup/references/emdb.md +37 -0
- package/skills/scientific/database-lookup/references/ena.md +372 -0
- package/skills/scientific/database-lookup/references/encode.md +47 -0
- package/skills/scientific/database-lookup/references/ensembl.md +539 -0
- package/skills/scientific/database-lookup/references/epa.md +232 -0
- package/skills/scientific/database-lookup/references/eurostat.md +237 -0
- package/skills/scientific/database-lookup/references/fda.md +64 -0
- package/skills/scientific/database-lookup/references/federal-reserve.md +216 -0
- package/skills/scientific/database-lookup/references/fred.md +297 -0
- package/skills/scientific/database-lookup/references/gene-ontology.md +147 -0
- package/skills/scientific/database-lookup/references/geo.md +130 -0
- package/skills/scientific/database-lookup/references/gnomad.md +93 -0
- package/skills/scientific/database-lookup/references/gtex.md +136 -0
- package/skills/scientific/database-lookup/references/gwas-catalog.md +46 -0
- package/skills/scientific/database-lookup/references/hca.md +35 -0
- package/skills/scientific/database-lookup/references/hpo.md +48 -0
- package/skills/scientific/database-lookup/references/human-protein-atlas.md +57 -0
- package/skills/scientific/database-lookup/references/interpro.md +120 -0
- package/skills/scientific/database-lookup/references/jaspar.md +50 -0
- package/skills/scientific/database-lookup/references/kegg.md +78 -0
- package/skills/scientific/database-lookup/references/lincs-l1000.md +68 -0
- package/skills/scientific/database-lookup/references/materials-project.md +123 -0
- package/skills/scientific/database-lookup/references/metabolomics-workbench.md +98 -0
- package/skills/scientific/database-lookup/references/monarch.md +46 -0
- package/skills/scientific/database-lookup/references/mousemine.md +40 -0
- package/skills/scientific/database-lookup/references/nasa-exoplanet-archive.md +112 -0
- package/skills/scientific/database-lookup/references/nasa.md +121 -0
- package/skills/scientific/database-lookup/references/ncbi-gene.md +64 -0
- package/skills/scientific/database-lookup/references/ncbi-protein.md +104 -0
- package/skills/scientific/database-lookup/references/ncbi-taxonomy.md +121 -0
- package/skills/scientific/database-lookup/references/nist.md +105 -0
- package/skills/scientific/database-lookup/references/noaa.md +199 -0
- package/skills/scientific/database-lookup/references/omim.md +114 -0
- package/skills/scientific/database-lookup/references/opentargets.md +459 -0
- package/skills/scientific/database-lookup/references/openweathermap.md +255 -0
- package/skills/scientific/database-lookup/references/pdb.md +121 -0
- package/skills/scientific/database-lookup/references/pride.md +74 -0
- package/skills/scientific/database-lookup/references/pubchem.md +145 -0
- package/skills/scientific/database-lookup/references/quickgo.md +45 -0
- package/skills/scientific/database-lookup/references/reactome.md +140 -0
- package/skills/scientific/database-lookup/references/rummageo.md +32 -0
- package/skills/scientific/database-lookup/references/sdss.md +130 -0
- package/skills/scientific/database-lookup/references/sec-edgar.md +315 -0
- package/skills/scientific/database-lookup/references/simbad.md +131 -0
- package/skills/scientific/database-lookup/references/sra.md +149 -0
- package/skills/scientific/database-lookup/references/string.md +283 -0
- package/skills/scientific/database-lookup/references/tcga-gdc.md +58 -0
- package/skills/scientific/database-lookup/references/treasury.md +215 -0
- package/skills/scientific/database-lookup/references/ucsc-genome.md +135 -0
- package/skills/scientific/database-lookup/references/uniprot.md +283 -0
- package/skills/scientific/database-lookup/references/usgs.md +260 -0
- package/skills/scientific/database-lookup/references/uspto.md +130 -0
- package/skills/scientific/database-lookup/references/who.md +283 -0
- package/skills/scientific/database-lookup/references/worldbank.md +239 -0
- package/skills/scientific/database-lookup/references/zinc.md +202 -0
- package/skills/scientific/hypothesis-generation/SKILL.md +297 -0
- package/skills/scientific/hypothesis-generation/assets/FORMATTING_GUIDE.md +672 -0
- package/skills/scientific/hypothesis-generation/assets/hypothesis_generation.sty +307 -0
- package/skills/scientific/hypothesis-generation/assets/hypothesis_report_template.tex +572 -0
- package/skills/scientific/hypothesis-generation/references/experimental_design_patterns.md +329 -0
- package/skills/scientific/hypothesis-generation/references/hypothesis_quality_criteria.md +198 -0
- package/skills/scientific/hypothesis-generation/references/literature_search_strategies.md +622 -0
- package/skills/scientific/hypothesis-generation/scripts/generate_schematic.py +139 -0
- package/skills/scientific/hypothesis-generation/scripts/generate_schematic_ai.py +817 -0
- package/skills/scientific/literature-review/SKILL.md +699 -0
- package/skills/scientific/literature-review/assets/review_template.md +412 -0
- package/skills/scientific/literature-review/references/citation_styles.md +166 -0
- package/skills/scientific/literature-review/references/database_strategies.md +455 -0
- package/skills/scientific/literature-review/scripts/generate_pdf.py +176 -0
- package/skills/scientific/literature-review/scripts/generate_schematic.py +139 -0
- package/skills/scientific/literature-review/scripts/generate_schematic_ai.py +817 -0
- package/skills/scientific/literature-review/scripts/search_databases.py +303 -0
- package/skills/scientific/literature-review/scripts/verify_citations.py +222 -0
- package/skills/scientific/markdown-mermaid-writing/SKILL.md +327 -0
- package/skills/scientific/markdown-mermaid-writing/assets/examples/example-research-report.md +221 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/architecture.md +108 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/block.md +177 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/c4.md +136 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/class.md +246 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/complex_examples.md +384 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/er.md +222 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/flowchart.md +177 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/gantt.md +138 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/git_graph.md +74 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/kanban.md +107 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/mindmap.md +74 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/packet.md +55 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/pie.md +52 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/quadrant.md +66 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/radar.md +59 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/requirement.md +88 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/sankey.md +71 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/sequence.md +174 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/state.md +150 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/timeline.md +96 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/treemap.md +66 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/user_journey.md +108 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/xy_chart.md +53 -0
- package/skills/scientific/markdown-mermaid-writing/references/diagrams/zenuml.md +71 -0
- package/skills/scientific/markdown-mermaid-writing/references/markdown_style_guide.md +733 -0
- package/skills/scientific/markdown-mermaid-writing/references/mermaid_style_guide.md +458 -0
- package/skills/scientific/markdown-mermaid-writing/templates/decision_record.md +211 -0
- package/skills/scientific/markdown-mermaid-writing/templates/how_to_guide.md +275 -0
- package/skills/scientific/markdown-mermaid-writing/templates/issue.md +303 -0
- package/skills/scientific/markdown-mermaid-writing/templates/kanban.md +223 -0
- package/skills/scientific/markdown-mermaid-writing/templates/presentation.md +312 -0
- package/skills/scientific/markdown-mermaid-writing/templates/project_documentation.md +412 -0
- package/skills/scientific/markdown-mermaid-writing/templates/pull_request.md +319 -0
- package/skills/scientific/markdown-mermaid-writing/templates/research_paper.md +304 -0
- package/skills/scientific/markdown-mermaid-writing/templates/status_report.md +185 -0
- package/skills/scientific/paper-lookup/SKILL.md +193 -0
- package/skills/scientific/paper-lookup/references/arxiv.md +161 -0
- package/skills/scientific/paper-lookup/references/biorxiv.md +118 -0
- package/skills/scientific/paper-lookup/references/core.md +150 -0
- package/skills/scientific/paper-lookup/references/crossref.md +181 -0
- package/skills/scientific/paper-lookup/references/medrxiv.md +104 -0
- package/skills/scientific/paper-lookup/references/openalex.md +174 -0
- package/skills/scientific/paper-lookup/references/pmc.md +152 -0
- package/skills/scientific/paper-lookup/references/pubmed.md +124 -0
- package/skills/scientific/paper-lookup/references/semantic-scholar.md +203 -0
- package/skills/scientific/paper-lookup/references/unpaywall.md +127 -0
- package/skills/scientific/peer-review/SKILL.md +569 -0
- package/skills/scientific/peer-review/references/common_issues.md +552 -0
- package/skills/scientific/peer-review/references/reporting_standards.md +290 -0
- package/skills/scientific/peer-review/scripts/generate_schematic.py +139 -0
- package/skills/scientific/peer-review/scripts/generate_schematic_ai.py +817 -0
- package/skills/scientific/scholar-evaluation/SKILL.md +298 -0
- package/skills/scientific/scholar-evaluation/references/evaluation_framework.md +663 -0
- package/skills/scientific/scholar-evaluation/scripts/calculate_scores.py +378 -0
- package/skills/scientific/scholar-evaluation/scripts/generate_schematic.py +139 -0
- package/skills/scientific/scholar-evaluation/scripts/generate_schematic_ai.py +817 -0
- package/skills/scientific/scientific-brainstorming/SKILL.md +189 -0
- package/skills/scientific/scientific-brainstorming/references/brainstorming_methods.md +326 -0
- package/skills/scientific/scientific-critical-thinking/SKILL.md +570 -0
- package/skills/scientific/scientific-critical-thinking/references/common_biases.md +364 -0
- package/skills/scientific/scientific-critical-thinking/references/evidence_hierarchy.md +484 -0
- package/skills/scientific/scientific-critical-thinking/references/experimental_design.md +496 -0
- package/skills/scientific/scientific-critical-thinking/references/logical_fallacies.md +478 -0
- package/skills/scientific/scientific-critical-thinking/references/scientific_method.md +169 -0
- package/skills/scientific/scientific-critical-thinking/references/statistical_pitfalls.md +506 -0
- package/skills/scientific/scientific-critical-thinking/scripts/generate_schematic.py +139 -0
- package/skills/scientific/scientific-critical-thinking/scripts/generate_schematic_ai.py +817 -0
- package/skills/wotann-imports/incremental-implementation.md +241 -0
- package/skills/wotann-imports/security-threat-model.md +81 -0
- package/skills/wotann-imports/triage.md +103 -0
- package/dist/build/deploy-targets/coolify.d.ts +0 -148
- package/dist/build/deploy-targets/coolify.d.ts.map +0 -1
- package/dist/build/deploy-targets/coolify.js +0 -339
- package/dist/build/deploy-targets/coolify.js.map +0 -1
- package/dist/build/deploy-targets/dokploy.d.ts +0 -139
- package/dist/build/deploy-targets/dokploy.d.ts.map +0 -1
- package/dist/build/deploy-targets/dokploy.js +0 -339
- package/dist/build/deploy-targets/dokploy.js.map +0 -1
- package/dist/claude/hardening/error-handler.d.ts +0 -52
- package/dist/claude/hardening/error-handler.d.ts.map +0 -1
- package/dist/claude/hardening/error-handler.js +0 -158
- package/dist/claude/hardening/error-handler.js.map +0 -1
- package/dist/cli/onboarding.d.ts +0 -34
- package/dist/cli/onboarding.d.ts.map +0 -1
- package/dist/cli/onboarding.js +0 -150
- package/dist/cli/onboarding.js.map +0 -1
- package/dist/core/agent-profiles.d.ts +0 -65
- package/dist/core/agent-profiles.d.ts.map +0 -1
- package/dist/core/agent-profiles.js +0 -137
- package/dist/core/agent-profiles.js.map +0 -1
- package/dist/desktop/supabase-relay.d.ts +0 -86
- package/dist/desktop/supabase-relay.d.ts.map +0 -1
- package/dist/desktop/supabase-relay.js +0 -335
- package/dist/desktop/supabase-relay.js.map +0 -1
- package/dist/intelligence/kg-builder.d.ts +0 -181
- package/dist/intelligence/kg-builder.d.ts.map +0 -1
- package/dist/intelligence/kg-builder.js +0 -807
- package/dist/intelligence/kg-builder.js.map +0 -1
- package/dist/orchestration/jean-orchestrator.d.ts +0 -79
- package/dist/orchestration/jean-orchestrator.d.ts.map +0 -1
- package/dist/orchestration/jean-orchestrator.js +0 -253
- package/dist/orchestration/jean-orchestrator.js.map +0 -1
- package/dist/orchestration/jean-registries/command-registry.d.ts +0 -85
- package/dist/orchestration/jean-registries/command-registry.d.ts.map +0 -1
- package/dist/orchestration/jean-registries/command-registry.js +0 -120
- package/dist/orchestration/jean-registries/command-registry.js.map +0 -1
- package/dist/orchestration/jean-registries/event-registry.d.ts +0 -80
- package/dist/orchestration/jean-registries/event-registry.d.ts.map +0 -1
- package/dist/orchestration/jean-registries/event-registry.js +0 -147
- package/dist/orchestration/jean-registries/event-registry.js.map +0 -1
- package/dist/orchestration/jean-registries/process-registry.d.ts +0 -71
- package/dist/orchestration/jean-registries/process-registry.d.ts.map +0 -1
- package/dist/orchestration/jean-registries/process-registry.js +0 -104
- package/dist/orchestration/jean-registries/process-registry.js.map +0 -1
- package/dist/orchestration/jean-registries/result-registry.d.ts +0 -71
- package/dist/orchestration/jean-registries/result-registry.d.ts.map +0 -1
- package/dist/orchestration/jean-registries/result-registry.js +0 -97
- package/dist/orchestration/jean-registries/result-registry.js.map +0 -1
- package/dist/providers/bedrock-signer.d.ts +0 -23
- package/dist/providers/bedrock-signer.d.ts.map +0 -1
- package/dist/providers/bedrock-signer.js +0 -439
- package/dist/providers/bedrock-signer.js.map +0 -1
- package/dist/providers/harness-profiles.d.ts +0 -70
- package/dist/providers/harness-profiles.d.ts.map +0 -1
- package/dist/providers/harness-profiles.js +0 -210
- package/dist/providers/harness-profiles.js.map +0 -1
- package/dist/providers/vertex-oauth.d.ts +0 -21
- package/dist/providers/vertex-oauth.d.ts.map +0 -1
- package/dist/providers/vertex-oauth.js +0 -393
- package/dist/providers/vertex-oauth.js.map +0 -1
- package/dist/sandbox/backends/cloud-auth.d.ts +0 -50
- package/dist/sandbox/backends/cloud-auth.d.ts.map +0 -1
- package/dist/sandbox/backends/cloud-auth.js +0 -93
- package/dist/sandbox/backends/cloud-auth.js.map +0 -1
- package/dist/security/anti-distillation.d.ts +0 -46
- package/dist/security/anti-distillation.d.ts.map +0 -1
- package/dist/security/anti-distillation.js +0 -358
- package/dist/security/anti-distillation.js.map +0 -1
- package/dist/security/multi-encoding-decoder.d.ts +0 -47
- package/dist/security/multi-encoding-decoder.d.ts.map +0 -1
- package/dist/security/multi-encoding-decoder.js +0 -336
- package/dist/security/multi-encoding-decoder.js.map +0 -1
- package/dist/ui/accessibility.d.ts +0 -157
- package/dist/ui/accessibility.d.ts.map +0 -1
- package/dist/ui/accessibility.js +0 -232
- package/dist/ui/accessibility.js.map +0 -1
- package/dist/ui/animations.d.ts +0 -102
- package/dist/ui/animations.d.ts.map +0 -1
- package/dist/ui/animations.js +0 -277
- package/dist/ui/animations.js.map +0 -1
- package/dist/ui/components/Sparkline.d.ts +0 -81
- package/dist/ui/components/Sparkline.d.ts.map +0 -1
- package/dist/ui/components/Sparkline.js +0 -102
- package/dist/ui/components/Sparkline.js.map +0 -1
- package/dist/ui/input/mouse.d.ts +0 -139
- package/dist/ui/input/mouse.d.ts.map +0 -1
- package/dist/ui/input/mouse.js +0 -239
- package/dist/ui/input/mouse.js.map +0 -1
- package/dist/ui/sound.d.ts +0 -85
- package/dist/ui/sound.d.ts.map +0 -1
- package/dist/ui/sound.js +0 -126
- package/dist/ui/sound.js.map +0 -1
|
@@ -1,807 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* KG-First-Stage Builder — Blitzy port (Phase 2 P1-C3).
|
|
3
|
-
*
|
|
4
|
-
* Blitzy (66.5% SWE-bench Pro) front-loads a knowledge-graph build
|
|
5
|
-
* before any codebase-modification task. The agent queries the KG as a
|
|
6
|
-
* retrieval source alongside normal grep. This module ports that
|
|
7
|
-
* first-stage approach: walk a workspace, extract symbols, build a
|
|
8
|
-
* call/type graph, persist into MemoryStore's knowledge_nodes /
|
|
9
|
-
* knowledge_edges tables, support incremental per-file updates, and
|
|
10
|
-
* expose query helpers (findCallers, findUsages, findDefinition).
|
|
11
|
-
*
|
|
12
|
-
* Design:
|
|
13
|
-
*
|
|
14
|
-
* 1. Symbol extraction is pluggable. We try to dynamic-import the
|
|
15
|
-
* TypeScript compiler API (if available — it's a devDep of this
|
|
16
|
-
* repo). If the import fails in a published distribution that strips
|
|
17
|
-
* devDeps, we fall back to a conservative regex extractor. This is
|
|
18
|
-
* "honest failures" (Session 2 bar #6): the fallback is declared,
|
|
19
|
-
* not silent.
|
|
20
|
-
*
|
|
21
|
-
* 2. Builder state is per-workspace (Session 3 bar #11). Each
|
|
22
|
-
* `new KGBuilder(store, workspaceRoot, opts)` carries its own
|
|
23
|
-
* include/exclude/parser settings. Two builders over two roots do
|
|
24
|
-
* not share mutable state.
|
|
25
|
-
*
|
|
26
|
-
* 3. Persistence is delegated to MemoryStore. We populate
|
|
27
|
-
* knowledge_nodes with entity_type in {"code_symbol", "code_module"}
|
|
28
|
-
* and a properties JSON payload { kind, filePath, line, exported }.
|
|
29
|
-
* Edges use relation in {"calls", "uses_type", "imports",
|
|
30
|
-
* "defined_in"}. Those are additional to P1-M7's
|
|
31
|
-
* updates/extends/derives human-memory edges; the kinds namespace
|
|
32
|
-
* does not clash because code relations live alongside in the same
|
|
33
|
-
* knowledge_edges table and are filtered by relation-string.
|
|
34
|
-
*
|
|
35
|
-
* 4. Incremental update (`updateFile`) re-parses a single file and
|
|
36
|
-
* rewrites only that file's nodes + edges, so watcher-based
|
|
37
|
-
* pipelines stay linear-time in changed-file count.
|
|
38
|
-
*/
|
|
39
|
-
import { readFile, readdir } from "node:fs/promises";
|
|
40
|
-
import { join, relative, extname, resolve } from "node:path";
|
|
41
|
-
/** Relation strings emitted by this builder into knowledge_edges.relation. */
|
|
42
|
-
export const KG_EDGE_RELATIONS = {
|
|
43
|
-
calls: "code:calls",
|
|
44
|
-
usesType: "code:uses_type",
|
|
45
|
-
imports: "code:imports",
|
|
46
|
-
definedIn: "code:defined_in",
|
|
47
|
-
};
|
|
48
|
-
export const KG_NODE_TYPES = {
|
|
49
|
-
symbol: "code_symbol",
|
|
50
|
-
module: "code_module",
|
|
51
|
-
};
|
|
52
|
-
// ── Patterns ───────────────────────────────────────────
|
|
53
|
-
const DEFAULT_INCLUDES = ["**/*.ts", "**/*.tsx", "**/*.js", "**/*.jsx"];
|
|
54
|
-
const DEFAULT_EXCLUDES = [
|
|
55
|
-
"**/node_modules/**",
|
|
56
|
-
"**/dist/**",
|
|
57
|
-
"**/build/**",
|
|
58
|
-
"**/.git/**",
|
|
59
|
-
"**/coverage/**",
|
|
60
|
-
"**/.wotann/**",
|
|
61
|
-
"**/*.d.ts",
|
|
62
|
-
];
|
|
63
|
-
const DEFAULT_MAX_FILES = 5000;
|
|
64
|
-
// ── Glob helpers ──────────────────────────────────────
|
|
65
|
-
// Tiny, predictable glob→regex. Not a full-blown micromatch; enough for
|
|
66
|
-
// the patterns above.
|
|
67
|
-
function globToRegex(pattern) {
|
|
68
|
-
let out = "";
|
|
69
|
-
let i = 0;
|
|
70
|
-
while (i < pattern.length) {
|
|
71
|
-
const ch = pattern[i];
|
|
72
|
-
if (ch === "*") {
|
|
73
|
-
if (pattern[i + 1] === "*") {
|
|
74
|
-
out += ".*";
|
|
75
|
-
i += 2;
|
|
76
|
-
if (pattern[i] === "/")
|
|
77
|
-
i++;
|
|
78
|
-
}
|
|
79
|
-
else {
|
|
80
|
-
out += "[^/]*";
|
|
81
|
-
i++;
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
else if (ch === "?") {
|
|
85
|
-
out += "[^/]";
|
|
86
|
-
i++;
|
|
87
|
-
}
|
|
88
|
-
else if (ch === ".") {
|
|
89
|
-
out += "\\.";
|
|
90
|
-
i++;
|
|
91
|
-
}
|
|
92
|
-
else if ("+^$(){}|\\".includes(ch)) {
|
|
93
|
-
out += "\\" + ch;
|
|
94
|
-
i++;
|
|
95
|
-
}
|
|
96
|
-
else {
|
|
97
|
-
out += ch;
|
|
98
|
-
i++;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
return new RegExp("^" + out + "$");
|
|
102
|
-
}
|
|
103
|
-
function matchesAny(relPath, patterns) {
|
|
104
|
-
for (const p of patterns) {
|
|
105
|
-
if (globToRegex(p).test(relPath))
|
|
106
|
-
return true;
|
|
107
|
-
}
|
|
108
|
-
return false;
|
|
109
|
-
}
|
|
110
|
-
// ── Walker ────────────────────────────────────────────
|
|
111
|
-
async function walkWorkspace(rootDir, includePatterns, excludePatterns, maxFiles) {
|
|
112
|
-
const root = resolve(rootDir);
|
|
113
|
-
const result = [];
|
|
114
|
-
const queue = [root];
|
|
115
|
-
while (queue.length > 0) {
|
|
116
|
-
if (result.length >= maxFiles)
|
|
117
|
-
break;
|
|
118
|
-
const dir = queue.shift();
|
|
119
|
-
let entries;
|
|
120
|
-
try {
|
|
121
|
-
entries = await readdir(dir, { withFileTypes: true });
|
|
122
|
-
}
|
|
123
|
-
catch {
|
|
124
|
-
continue;
|
|
125
|
-
}
|
|
126
|
-
for (const entry of entries) {
|
|
127
|
-
const abs = join(dir, entry.name);
|
|
128
|
-
const rel = relative(root, abs).split("\\").join("/");
|
|
129
|
-
if (matchesAny(rel, excludePatterns))
|
|
130
|
-
continue;
|
|
131
|
-
if (entry.isDirectory()) {
|
|
132
|
-
queue.push(abs);
|
|
133
|
-
}
|
|
134
|
-
else if (entry.isFile()) {
|
|
135
|
-
if (matchesAny(rel, includePatterns)) {
|
|
136
|
-
result.push(abs);
|
|
137
|
-
if (result.length >= maxFiles)
|
|
138
|
-
break;
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
return result;
|
|
144
|
-
}
|
|
145
|
-
// ── Extractor: regex fallback ─────────────────────────
|
|
146
|
-
// JavaScript reserved words + common built-ins we should not treat as callees.
|
|
147
|
-
const RESERVED_WORDS = new Set([
|
|
148
|
-
"if",
|
|
149
|
-
"else",
|
|
150
|
-
"for",
|
|
151
|
-
"while",
|
|
152
|
-
"do",
|
|
153
|
-
"switch",
|
|
154
|
-
"case",
|
|
155
|
-
"break",
|
|
156
|
-
"continue",
|
|
157
|
-
"return",
|
|
158
|
-
"throw",
|
|
159
|
-
"try",
|
|
160
|
-
"catch",
|
|
161
|
-
"finally",
|
|
162
|
-
"function",
|
|
163
|
-
"class",
|
|
164
|
-
"interface",
|
|
165
|
-
"type",
|
|
166
|
-
"enum",
|
|
167
|
-
"const",
|
|
168
|
-
"let",
|
|
169
|
-
"var",
|
|
170
|
-
"import",
|
|
171
|
-
"export",
|
|
172
|
-
"from",
|
|
173
|
-
"as",
|
|
174
|
-
"default",
|
|
175
|
-
"new",
|
|
176
|
-
"delete",
|
|
177
|
-
"typeof",
|
|
178
|
-
"instanceof",
|
|
179
|
-
"in",
|
|
180
|
-
"of",
|
|
181
|
-
"void",
|
|
182
|
-
"true",
|
|
183
|
-
"false",
|
|
184
|
-
"null",
|
|
185
|
-
"undefined",
|
|
186
|
-
"this",
|
|
187
|
-
"super",
|
|
188
|
-
"async",
|
|
189
|
-
"await",
|
|
190
|
-
"yield",
|
|
191
|
-
"static",
|
|
192
|
-
"public",
|
|
193
|
-
"private",
|
|
194
|
-
"protected",
|
|
195
|
-
"readonly",
|
|
196
|
-
"declare",
|
|
197
|
-
"module",
|
|
198
|
-
"namespace",
|
|
199
|
-
"with",
|
|
200
|
-
]);
|
|
201
|
-
/**
|
|
202
|
-
* Conservative regex symbol/call/import extractor. Purposely narrower
|
|
203
|
-
* than the TS compiler API — only picks up obvious patterns. Accepts
|
|
204
|
-
* some false negatives to avoid false positives.
|
|
205
|
-
*/
|
|
206
|
-
export function extractFromSourceRegex(filePath, source) {
|
|
207
|
-
const symbols = [];
|
|
208
|
-
const imports = [];
|
|
209
|
-
const calls = [];
|
|
210
|
-
const typeRefs = [];
|
|
211
|
-
const lines = source.split(/\r?\n/);
|
|
212
|
-
// Imports — handles `import { A, B as C } from "..."`, `import * as ns from "..."`,
|
|
213
|
-
// `import D from "..."`, `import "..."`.
|
|
214
|
-
const importRe = /^\s*import\s+(?:(?:(?<def>[A-Za-z_$][\w$]*)\s*,?\s*)?(?:\{(?<named>[^}]*)\}|\*\s+as\s+(?<ns>[A-Za-z_$][\w$]*))?)?\s*(?:from\s*)?["'](?<spec>[^"']+)["']/;
|
|
215
|
-
for (const line of lines) {
|
|
216
|
-
const m = importRe.exec(line);
|
|
217
|
-
if (!m || !m.groups)
|
|
218
|
-
continue;
|
|
219
|
-
const named = [];
|
|
220
|
-
if (m.groups["def"])
|
|
221
|
-
named.push(m.groups["def"]);
|
|
222
|
-
if (m.groups["ns"])
|
|
223
|
-
named.push(m.groups["ns"]);
|
|
224
|
-
if (m.groups["named"]) {
|
|
225
|
-
for (const chunk of m.groups["named"].split(",")) {
|
|
226
|
-
const nm = chunk.replace(/\s+as\s+[A-Za-z_$][\w$]*/, "").trim();
|
|
227
|
-
if (nm.length > 0)
|
|
228
|
-
named.push(nm);
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
|
-
imports.push({ specifier: m.groups["spec"], named });
|
|
232
|
-
}
|
|
233
|
-
// Symbols
|
|
234
|
-
const symRe = /^(?<indent>\s*)(?<exp>export\s+(?:default\s+)?)?(?<async>async\s+)?(?<kind>function|class|interface|type|enum|const|let|var)\s+(?<name>[A-Za-z_$][\w$]*)/;
|
|
235
|
-
const methodRe = /^(?<indent>\s+)(?<async>async\s+)?(?<name>[A-Za-z_$][\w$]*)\s*\(/;
|
|
236
|
-
for (let i = 0; i < lines.length; i++) {
|
|
237
|
-
const line = lines[i];
|
|
238
|
-
if (/^\s*(?:\*|\/\/|\*\/)/.test(line))
|
|
239
|
-
continue;
|
|
240
|
-
const m = symRe.exec(line);
|
|
241
|
-
if (m && m.groups) {
|
|
242
|
-
const kindRaw = m.groups["kind"];
|
|
243
|
-
const kind = kindRaw === "function"
|
|
244
|
-
? "function"
|
|
245
|
-
: kindRaw === "class"
|
|
246
|
-
? "class"
|
|
247
|
-
: kindRaw === "interface"
|
|
248
|
-
? "interface"
|
|
249
|
-
: kindRaw === "type"
|
|
250
|
-
? "type"
|
|
251
|
-
: kindRaw === "enum"
|
|
252
|
-
? "enum"
|
|
253
|
-
: "variable";
|
|
254
|
-
symbols.push({
|
|
255
|
-
name: m.groups["name"],
|
|
256
|
-
kind,
|
|
257
|
-
line: i + 1,
|
|
258
|
-
exported: Boolean(m.groups["exp"]),
|
|
259
|
-
});
|
|
260
|
-
continue;
|
|
261
|
-
}
|
|
262
|
-
const mm = methodRe.exec(line);
|
|
263
|
-
if (mm && mm.groups && mm.groups["indent"].length > 0) {
|
|
264
|
-
const name = mm.groups["name"];
|
|
265
|
-
if (RESERVED_WORDS.has(name))
|
|
266
|
-
continue;
|
|
267
|
-
symbols.push({ name, kind: "method", line: i + 1, exported: false });
|
|
268
|
-
}
|
|
269
|
-
}
|
|
270
|
-
// Calls — `foo(` where foo is not a keyword. Attribute calls to the
|
|
271
|
-
// nearest preceding symbol as "enclosing".
|
|
272
|
-
const callRe = /(?<![\w$.])(?<callee>[A-Za-z_$][\w$]*)\s*\(/g;
|
|
273
|
-
let currentEnclosing = "module";
|
|
274
|
-
for (let i = 0; i < lines.length; i++) {
|
|
275
|
-
const line = lines[i];
|
|
276
|
-
const sym = symRe.exec(line);
|
|
277
|
-
if (sym && sym.groups) {
|
|
278
|
-
currentEnclosing = sym.groups["name"];
|
|
279
|
-
}
|
|
280
|
-
if (/^\s*(?:\*|\/\/|\*\/)/.test(line))
|
|
281
|
-
continue;
|
|
282
|
-
let m;
|
|
283
|
-
callRe.lastIndex = 0;
|
|
284
|
-
while ((m = callRe.exec(line)) !== null) {
|
|
285
|
-
const callee = m.groups?.["callee"] ?? "";
|
|
286
|
-
if (!callee)
|
|
287
|
-
continue;
|
|
288
|
-
if (RESERVED_WORDS.has(callee))
|
|
289
|
-
continue;
|
|
290
|
-
calls.push({ callee, enclosing: currentEnclosing, line: i + 1 });
|
|
291
|
-
}
|
|
292
|
-
}
|
|
293
|
-
// Type references — `: TypeName` and `<TypeName>` after identifiers.
|
|
294
|
-
const typeAnnRe = /(?<![\w$]):\s*(?<t>[A-Z][A-Za-z_$0-9]*)/g;
|
|
295
|
-
const typeArgRe = /<(?<t>[A-Z][A-Za-z_$0-9]*)(?:[<>,\s][^>]*)?>/g;
|
|
296
|
-
let enclosing = "module";
|
|
297
|
-
for (let i = 0; i < lines.length; i++) {
|
|
298
|
-
const line = lines[i];
|
|
299
|
-
const sym = symRe.exec(line);
|
|
300
|
-
if (sym && sym.groups)
|
|
301
|
-
enclosing = sym.groups["name"];
|
|
302
|
-
let m;
|
|
303
|
-
typeAnnRe.lastIndex = 0;
|
|
304
|
-
while ((m = typeAnnRe.exec(line)) !== null) {
|
|
305
|
-
const t = m.groups?.["t"];
|
|
306
|
-
if (!t)
|
|
307
|
-
continue;
|
|
308
|
-
typeRefs.push({ typeName: t, enclosing, line: i + 1 });
|
|
309
|
-
}
|
|
310
|
-
typeArgRe.lastIndex = 0;
|
|
311
|
-
while ((m = typeArgRe.exec(line)) !== null) {
|
|
312
|
-
const t = m.groups?.["t"];
|
|
313
|
-
if (!t)
|
|
314
|
-
continue;
|
|
315
|
-
typeRefs.push({ typeName: t, enclosing, line: i + 1 });
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
return { filePath, symbols, imports, calls, typeRefs, source: "regex" };
|
|
319
|
-
}
|
|
320
|
-
let cachedTsApi;
|
|
321
|
-
async function loadTsApi() {
|
|
322
|
-
if (cachedTsApi !== undefined)
|
|
323
|
-
return cachedTsApi;
|
|
324
|
-
try {
|
|
325
|
-
const mod = (await import("typescript"));
|
|
326
|
-
const api = mod.default ?? mod;
|
|
327
|
-
if (typeof api.createSourceFile !== "function") {
|
|
328
|
-
cachedTsApi = null;
|
|
329
|
-
return null;
|
|
330
|
-
}
|
|
331
|
-
cachedTsApi = api;
|
|
332
|
-
return api;
|
|
333
|
-
}
|
|
334
|
-
catch {
|
|
335
|
-
cachedTsApi = null;
|
|
336
|
-
return null;
|
|
337
|
-
}
|
|
338
|
-
}
|
|
339
|
-
/** Visible for tests — lets a test force a "no TS api" state. */
|
|
340
|
-
export function _resetTsApiCacheForTests() {
|
|
341
|
-
cachedTsApi = undefined;
|
|
342
|
-
}
|
|
343
|
-
function getScriptKindFor(ts, filePath) {
|
|
344
|
-
const ext = extname(filePath).toLowerCase();
|
|
345
|
-
if (ext === ".tsx")
|
|
346
|
-
return ts.ScriptKind.TSX;
|
|
347
|
-
if (ext === ".jsx")
|
|
348
|
-
return ts.ScriptKind.JSX;
|
|
349
|
-
if (ext === ".js")
|
|
350
|
-
return ts.ScriptKind.JS;
|
|
351
|
-
return ts.ScriptKind.TS;
|
|
352
|
-
}
|
|
353
|
-
function extractFromSourceTs(ts, filePath, source) {
|
|
354
|
-
const symbols = [];
|
|
355
|
-
const imports = [];
|
|
356
|
-
const calls = [];
|
|
357
|
-
const typeRefs = [];
|
|
358
|
-
const sf = ts.createSourceFile(filePath, source, ts.ScriptTarget.Latest, true, getScriptKindFor(ts, filePath));
|
|
359
|
-
const lineOf = (n) => {
|
|
360
|
-
try {
|
|
361
|
-
return sf.getLineAndCharacterOfPosition(n.pos).line + 1;
|
|
362
|
-
}
|
|
363
|
-
catch {
|
|
364
|
-
return 1;
|
|
365
|
-
}
|
|
366
|
-
};
|
|
367
|
-
const visitTop = (node) => {
|
|
368
|
-
if (ts.isImportDeclaration(node)) {
|
|
369
|
-
const mod = node["moduleSpecifier"];
|
|
370
|
-
const spec = mod && ts.isStringLiteral(mod) ? (mod["text"] ?? "") : "";
|
|
371
|
-
const clause = node["importClause"];
|
|
372
|
-
const named = [];
|
|
373
|
-
if (clause) {
|
|
374
|
-
const defName = clause["name"];
|
|
375
|
-
if (defName && ts.isIdentifier(defName)) {
|
|
376
|
-
named.push(defName["escapedText"] ?? defName["text"] ?? "");
|
|
377
|
-
}
|
|
378
|
-
const nb = clause["namedBindings"];
|
|
379
|
-
if (nb) {
|
|
380
|
-
const elements = nb["elements"];
|
|
381
|
-
if (Array.isArray(elements)) {
|
|
382
|
-
for (const el of elements) {
|
|
383
|
-
const nameNode = el["name"];
|
|
384
|
-
if (nameNode && ts.isIdentifier(nameNode)) {
|
|
385
|
-
const n = nameNode["escapedText"] ?? nameNode["text"] ?? "";
|
|
386
|
-
if (n)
|
|
387
|
-
named.push(n);
|
|
388
|
-
}
|
|
389
|
-
}
|
|
390
|
-
}
|
|
391
|
-
const ns = nb["name"];
|
|
392
|
-
if (ns && ts.isIdentifier(ns)) {
|
|
393
|
-
const n = ns["escapedText"] ?? ns["text"] ?? "";
|
|
394
|
-
if (n)
|
|
395
|
-
named.push(n);
|
|
396
|
-
}
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
imports.push({ specifier: spec, named });
|
|
400
|
-
}
|
|
401
|
-
ts.forEachChild(node, visitTop);
|
|
402
|
-
};
|
|
403
|
-
ts.forEachChild(sf, visitTop);
|
|
404
|
-
const isExported = (node) => {
|
|
405
|
-
const mods = node["modifiers"];
|
|
406
|
-
if (!Array.isArray(mods))
|
|
407
|
-
return false;
|
|
408
|
-
for (const m of mods) {
|
|
409
|
-
const name = Object.keys(ts.SyntaxKind).find((k) => ts.SyntaxKind[k] === m.kind);
|
|
410
|
-
if (name === "ExportKeyword")
|
|
411
|
-
return true;
|
|
412
|
-
}
|
|
413
|
-
return false;
|
|
414
|
-
};
|
|
415
|
-
const nameOf = (node) => {
|
|
416
|
-
const n = node["name"];
|
|
417
|
-
if (!n)
|
|
418
|
-
return undefined;
|
|
419
|
-
if (ts.isIdentifier(n)) {
|
|
420
|
-
return (n["escapedText"] ?? n["text"]);
|
|
421
|
-
}
|
|
422
|
-
return undefined;
|
|
423
|
-
};
|
|
424
|
-
const visitDecl = (node) => {
|
|
425
|
-
if (ts.isClassDeclaration(node)) {
|
|
426
|
-
const nm = nameOf(node);
|
|
427
|
-
if (nm)
|
|
428
|
-
symbols.push({ name: nm, kind: "class", line: lineOf(node), exported: isExported(node) });
|
|
429
|
-
}
|
|
430
|
-
else if (ts.isFunctionDeclaration(node)) {
|
|
431
|
-
const nm = nameOf(node);
|
|
432
|
-
if (nm)
|
|
433
|
-
symbols.push({
|
|
434
|
-
name: nm,
|
|
435
|
-
kind: "function",
|
|
436
|
-
line: lineOf(node),
|
|
437
|
-
exported: isExported(node),
|
|
438
|
-
});
|
|
439
|
-
}
|
|
440
|
-
else if (ts.isInterfaceDeclaration(node)) {
|
|
441
|
-
const nm = nameOf(node);
|
|
442
|
-
if (nm)
|
|
443
|
-
symbols.push({
|
|
444
|
-
name: nm,
|
|
445
|
-
kind: "interface",
|
|
446
|
-
line: lineOf(node),
|
|
447
|
-
exported: isExported(node),
|
|
448
|
-
});
|
|
449
|
-
}
|
|
450
|
-
else if (ts.isTypeAliasDeclaration(node)) {
|
|
451
|
-
const nm = nameOf(node);
|
|
452
|
-
if (nm)
|
|
453
|
-
symbols.push({ name: nm, kind: "type", line: lineOf(node), exported: isExported(node) });
|
|
454
|
-
}
|
|
455
|
-
else if (ts.isEnumDeclaration(node)) {
|
|
456
|
-
const nm = nameOf(node);
|
|
457
|
-
if (nm)
|
|
458
|
-
symbols.push({ name: nm, kind: "enum", line: lineOf(node), exported: isExported(node) });
|
|
459
|
-
}
|
|
460
|
-
else if (ts.isVariableStatement(node)) {
|
|
461
|
-
const decList = node["declarationList"];
|
|
462
|
-
const decls = decList?.["declarations"] ?? [];
|
|
463
|
-
const exp = isExported(node);
|
|
464
|
-
for (const d of decls) {
|
|
465
|
-
const n = d["name"];
|
|
466
|
-
if (n && ts.isIdentifier(n)) {
|
|
467
|
-
const nm = (n["escapedText"] ?? n["text"]) || "";
|
|
468
|
-
if (nm)
|
|
469
|
-
symbols.push({ name: nm, kind: "variable", line: lineOf(d), exported: exp });
|
|
470
|
-
}
|
|
471
|
-
}
|
|
472
|
-
}
|
|
473
|
-
else if (ts.isMethodDeclaration(node)) {
|
|
474
|
-
const n = node["name"];
|
|
475
|
-
if (n && ts.isIdentifier(n)) {
|
|
476
|
-
const nm = (n["escapedText"] ?? n["text"]) || "";
|
|
477
|
-
if (nm)
|
|
478
|
-
symbols.push({ name: nm, kind: "method", line: lineOf(node), exported: false });
|
|
479
|
-
}
|
|
480
|
-
}
|
|
481
|
-
ts.forEachChild(node, visitDecl);
|
|
482
|
-
};
|
|
483
|
-
ts.forEachChild(sf, visitDecl);
|
|
484
|
-
const walk = (node, enclosing) => {
|
|
485
|
-
let nextEnclosing = enclosing;
|
|
486
|
-
if (ts.isFunctionDeclaration(node) ||
|
|
487
|
-
ts.isMethodDeclaration(node) ||
|
|
488
|
-
ts.isClassDeclaration(node)) {
|
|
489
|
-
const nm = nameOf(node);
|
|
490
|
-
if (nm)
|
|
491
|
-
nextEnclosing = nm;
|
|
492
|
-
}
|
|
493
|
-
if (ts.isCallExpression(node)) {
|
|
494
|
-
const expr = node["expression"];
|
|
495
|
-
let callee = "";
|
|
496
|
-
if (expr) {
|
|
497
|
-
if (ts.isIdentifier(expr)) {
|
|
498
|
-
callee = (expr["escapedText"] ?? expr["text"]) || "";
|
|
499
|
-
}
|
|
500
|
-
else if (ts.isPropertyAccessExpression(expr)) {
|
|
501
|
-
const nm = expr["name"];
|
|
502
|
-
if (nm && ts.isIdentifier(nm)) {
|
|
503
|
-
callee = (nm["escapedText"] ?? nm["text"]) || "";
|
|
504
|
-
}
|
|
505
|
-
}
|
|
506
|
-
}
|
|
507
|
-
if (callee && !RESERVED_WORDS.has(callee)) {
|
|
508
|
-
calls.push({ callee, enclosing: nextEnclosing, line: lineOf(node) });
|
|
509
|
-
}
|
|
510
|
-
}
|
|
511
|
-
if (ts.isTypeReferenceNode(node)) {
|
|
512
|
-
const tn = node["typeName"];
|
|
513
|
-
if (tn && ts.isIdentifier(tn)) {
|
|
514
|
-
const t = (tn["escapedText"] ?? tn["text"]) || "";
|
|
515
|
-
if (t)
|
|
516
|
-
typeRefs.push({ typeName: t, enclosing: nextEnclosing, line: lineOf(node) });
|
|
517
|
-
}
|
|
518
|
-
}
|
|
519
|
-
ts.forEachChild(node, (child) => walk(child, nextEnclosing));
|
|
520
|
-
};
|
|
521
|
-
ts.forEachChild(sf, (child) => walk(child, "module"));
|
|
522
|
-
return { filePath, symbols, imports, calls, typeRefs, source: "ts-compiler" };
|
|
523
|
-
}
|
|
524
|
-
/**
|
|
525
|
-
* Light wrapper over MemoryStore that lets the builder track which
|
|
526
|
-
* nodes/edges it created, so incremental `updateFile` can deterministically
|
|
527
|
-
* wipe + repopulate file-scoped state.
|
|
528
|
-
*/
|
|
529
|
-
class KgPersistence {
|
|
530
|
-
store;
|
|
531
|
-
fileState = new Map();
|
|
532
|
-
constructor(store) {
|
|
533
|
-
this.store = store;
|
|
534
|
-
}
|
|
535
|
-
persistFile(workspaceRoot, extraction) {
|
|
536
|
-
const relPath = relative(workspaceRoot, extraction.filePath).split("\\").join("/");
|
|
537
|
-
const prior = this.fileState.get(relPath);
|
|
538
|
-
if (prior) {
|
|
539
|
-
for (const eid of prior.edgeIds) {
|
|
540
|
-
this.store.invalidateKnowledgeEdge(eid);
|
|
541
|
-
}
|
|
542
|
-
}
|
|
543
|
-
const moduleName = relPath;
|
|
544
|
-
const existingModuleId = prior?.moduleNodeId;
|
|
545
|
-
const moduleNodeId = existingModuleId ??
|
|
546
|
-
this.store.addKnowledgeNode(moduleName, KG_NODE_TYPES.module, {
|
|
547
|
-
path: relPath,
|
|
548
|
-
});
|
|
549
|
-
const symbolIdsByName = new Map();
|
|
550
|
-
const symbolsByName = new Map();
|
|
551
|
-
let inserted = 0;
|
|
552
|
-
let edges = 0;
|
|
553
|
-
const edgeIdsCollector = [];
|
|
554
|
-
for (const sym of extraction.symbols) {
|
|
555
|
-
const nodeName = `${relPath}#${sym.name}`;
|
|
556
|
-
const nodeId = this.store.addKnowledgeNode(nodeName, KG_NODE_TYPES.symbol, {
|
|
557
|
-
kind: sym.kind,
|
|
558
|
-
filePath: relPath,
|
|
559
|
-
line: sym.line !== undefined ? String(sym.line) : "",
|
|
560
|
-
exported: sym.exported ? "true" : "false",
|
|
561
|
-
displayName: sym.name,
|
|
562
|
-
});
|
|
563
|
-
symbolIdsByName.set(sym.name, nodeId);
|
|
564
|
-
symbolsByName.set(sym.name, sym);
|
|
565
|
-
inserted++;
|
|
566
|
-
const defEdgeId = this.store.addKnowledgeEdge(nodeId, moduleNodeId, KG_EDGE_RELATIONS.definedIn);
|
|
567
|
-
edges++;
|
|
568
|
-
edgeIdsCollector.push(defEdgeId);
|
|
569
|
-
}
|
|
570
|
-
for (const imp of extraction.imports) {
|
|
571
|
-
const edgeId = this.store.addKnowledgeEdge(moduleNodeId, moduleNodeId, KG_EDGE_RELATIONS.imports);
|
|
572
|
-
edgeIdsCollector.push(edgeId);
|
|
573
|
-
edges++;
|
|
574
|
-
void imp;
|
|
575
|
-
}
|
|
576
|
-
for (const call of extraction.calls) {
|
|
577
|
-
const callerId = symbolIdsByName.get(call.enclosing) ?? moduleNodeId;
|
|
578
|
-
const calleeId = symbolIdsByName.get(call.callee);
|
|
579
|
-
if (calleeId) {
|
|
580
|
-
const edgeId = this.store.addKnowledgeEdge(callerId, calleeId, KG_EDGE_RELATIONS.calls);
|
|
581
|
-
edgeIdsCollector.push(edgeId);
|
|
582
|
-
edges++;
|
|
583
|
-
}
|
|
584
|
-
}
|
|
585
|
-
for (const tr of extraction.typeRefs) {
|
|
586
|
-
const userId = symbolIdsByName.get(tr.enclosing) ?? moduleNodeId;
|
|
587
|
-
const typeId = symbolIdsByName.get(tr.typeName);
|
|
588
|
-
if (typeId) {
|
|
589
|
-
const edgeId = this.store.addKnowledgeEdge(userId, typeId, KG_EDGE_RELATIONS.usesType);
|
|
590
|
-
edgeIdsCollector.push(edgeId);
|
|
591
|
-
edges++;
|
|
592
|
-
}
|
|
593
|
-
}
|
|
594
|
-
this.fileState.set(relPath, {
|
|
595
|
-
symbolIdsByName,
|
|
596
|
-
symbolsByName,
|
|
597
|
-
callSites: extraction.calls,
|
|
598
|
-
typeReferences: extraction.typeRefs,
|
|
599
|
-
moduleNodeId,
|
|
600
|
-
edgeIds: edgeIdsCollector,
|
|
601
|
-
});
|
|
602
|
-
return { inserted, edges, moduleNodeId };
|
|
603
|
-
}
|
|
604
|
-
getFileInventory(relPath) {
|
|
605
|
-
return this.fileState.get(relPath);
|
|
606
|
-
}
|
|
607
|
-
getAllFilePaths() {
|
|
608
|
-
return Array.from(this.fileState.keys());
|
|
609
|
-
}
|
|
610
|
-
}
|
|
611
|
-
// ── Builder ───────────────────────────────────────────
|
|
612
|
-
export class KGBuilder {
|
|
613
|
-
store;
|
|
614
|
-
persistence;
|
|
615
|
-
workspaceRoot;
|
|
616
|
-
includePatterns;
|
|
617
|
-
excludePatterns;
|
|
618
|
-
maxFiles;
|
|
619
|
-
forceRegex;
|
|
620
|
-
constructor(store, workspaceRoot, options = {}) {
|
|
621
|
-
this.store = store;
|
|
622
|
-
this.workspaceRoot = resolve(workspaceRoot);
|
|
623
|
-
this.includePatterns = options.includePatterns ?? DEFAULT_INCLUDES;
|
|
624
|
-
this.excludePatterns = options.excludePatterns ?? DEFAULT_EXCLUDES;
|
|
625
|
-
this.maxFiles = options.maxFiles ?? DEFAULT_MAX_FILES;
|
|
626
|
-
this.forceRegex = options.forceRegex ?? false;
|
|
627
|
-
this.persistence = new KgPersistence(store);
|
|
628
|
-
}
|
|
629
|
-
/**
|
|
630
|
-
* Walk the workspace, extract symbols from each matched file, and
|
|
631
|
-
* persist into the knowledge graph. Returns a BuildSummary.
|
|
632
|
-
*/
|
|
633
|
-
async buildForWorkspace(options = {}) {
|
|
634
|
-
const files = await walkWorkspace(this.workspaceRoot, this.includePatterns, this.excludePatterns, this.maxFiles);
|
|
635
|
-
const ts = this.forceRegex ? null : await loadTsApi();
|
|
636
|
-
let filesProcessed = 0;
|
|
637
|
-
let symbolsInserted = 0;
|
|
638
|
-
let edgesInserted = 0;
|
|
639
|
-
const parseErrors = [];
|
|
640
|
-
const sources = new Set();
|
|
641
|
-
for (const filePath of files) {
|
|
642
|
-
let extraction;
|
|
643
|
-
let source;
|
|
644
|
-
try {
|
|
645
|
-
source = await readFile(filePath, "utf-8");
|
|
646
|
-
}
|
|
647
|
-
catch (err) {
|
|
648
|
-
parseErrors.push({ path: filePath, error: `read failed: ${String(err)}` });
|
|
649
|
-
continue;
|
|
650
|
-
}
|
|
651
|
-
try {
|
|
652
|
-
if (ts) {
|
|
653
|
-
extraction = extractFromSourceTs(ts, filePath, source);
|
|
654
|
-
}
|
|
655
|
-
else {
|
|
656
|
-
extraction = extractFromSourceRegex(filePath, source);
|
|
657
|
-
}
|
|
658
|
-
}
|
|
659
|
-
catch (err) {
|
|
660
|
-
const fallback = extractFromSourceRegex(filePath, source);
|
|
661
|
-
extraction = {
|
|
662
|
-
...fallback,
|
|
663
|
-
parseError: err instanceof Error ? err.message : String(err),
|
|
664
|
-
};
|
|
665
|
-
parseErrors.push({
|
|
666
|
-
path: filePath,
|
|
667
|
-
error: err instanceof Error ? err.message : String(err),
|
|
668
|
-
});
|
|
669
|
-
}
|
|
670
|
-
sources.add(extraction.source);
|
|
671
|
-
const { inserted, edges } = this.persistence.persistFile(this.workspaceRoot, extraction);
|
|
672
|
-
symbolsInserted += inserted;
|
|
673
|
-
edgesInserted += edges;
|
|
674
|
-
filesProcessed++;
|
|
675
|
-
if (options.onFile) {
|
|
676
|
-
const rel = relative(this.workspaceRoot, filePath).split("\\").join("/");
|
|
677
|
-
try {
|
|
678
|
-
options.onFile(rel, extraction);
|
|
679
|
-
}
|
|
680
|
-
catch {
|
|
681
|
-
/* ignore onFile errors */
|
|
682
|
-
}
|
|
683
|
-
}
|
|
684
|
-
}
|
|
685
|
-
const extractorUsed = sources.size === 0 ? "regex" : sources.size === 1 ? Array.from(sources)[0] : "mixed";
|
|
686
|
-
return {
|
|
687
|
-
filesVisited: files.length,
|
|
688
|
-
filesProcessed,
|
|
689
|
-
symbolsInserted,
|
|
690
|
-
edgesInserted,
|
|
691
|
-
parseErrors,
|
|
692
|
-
extractorUsed,
|
|
693
|
-
};
|
|
694
|
-
}
|
|
695
|
-
/**
|
|
696
|
-
* Re-parse a single file and replace its contribution to the graph.
|
|
697
|
-
* Accepts either an absolute path or a workspace-relative path.
|
|
698
|
-
*/
|
|
699
|
-
async updateFile(filePath) {
|
|
700
|
-
const abs = filePath.startsWith("/") ? filePath : join(this.workspaceRoot, filePath);
|
|
701
|
-
let source;
|
|
702
|
-
try {
|
|
703
|
-
source = await readFile(abs, "utf-8");
|
|
704
|
-
}
|
|
705
|
-
catch (err) {
|
|
706
|
-
return { inserted: 0, edges: 0, parseError: `read failed: ${String(err)}` };
|
|
707
|
-
}
|
|
708
|
-
const ts = this.forceRegex ? null : await loadTsApi();
|
|
709
|
-
let extraction;
|
|
710
|
-
try {
|
|
711
|
-
extraction = ts ? extractFromSourceTs(ts, abs, source) : extractFromSourceRegex(abs, source);
|
|
712
|
-
}
|
|
713
|
-
catch (err) {
|
|
714
|
-
const fb = extractFromSourceRegex(abs, source);
|
|
715
|
-
extraction = { ...fb, parseError: err instanceof Error ? err.message : String(err) };
|
|
716
|
-
}
|
|
717
|
-
const { inserted, edges } = this.persistence.persistFile(this.workspaceRoot, extraction);
|
|
718
|
-
const base = { inserted, edges };
|
|
719
|
-
if (extraction.parseError !== undefined)
|
|
720
|
-
base.parseError = extraction.parseError;
|
|
721
|
-
return base;
|
|
722
|
-
}
|
|
723
|
-
/**
|
|
724
|
-
* Return the set of symbols (by enclosing name + file) that call
|
|
725
|
-
* `symbolName` across the workspace. Uses the per-file inventory +
|
|
726
|
-
* extraction records kept on each buildForWorkspace / updateFile call.
|
|
727
|
-
*/
|
|
728
|
-
findCallers(symbolName) {
|
|
729
|
-
const out = [];
|
|
730
|
-
for (const filePath of this.persistence.getAllFilePaths()) {
|
|
731
|
-
const inv = this.persistence.getFileInventory(filePath);
|
|
732
|
-
if (!inv)
|
|
733
|
-
continue;
|
|
734
|
-
for (const call of inv.callSites) {
|
|
735
|
-
if (call.callee !== symbolName)
|
|
736
|
-
continue;
|
|
737
|
-
const row = {
|
|
738
|
-
file: filePath,
|
|
739
|
-
enclosing: call.enclosing,
|
|
740
|
-
};
|
|
741
|
-
if (call.line !== undefined)
|
|
742
|
-
row.line = call.line;
|
|
743
|
-
out.push(row);
|
|
744
|
-
}
|
|
745
|
-
}
|
|
746
|
-
return out;
|
|
747
|
-
}
|
|
748
|
-
/**
|
|
749
|
-
* Return the set of symbols that reference type `typeName` as a type
|
|
750
|
-
* argument / annotation.
|
|
751
|
-
*/
|
|
752
|
-
findUsages(typeName) {
|
|
753
|
-
const out = [];
|
|
754
|
-
for (const filePath of this.persistence.getAllFilePaths()) {
|
|
755
|
-
const inv = this.persistence.getFileInventory(filePath);
|
|
756
|
-
if (!inv)
|
|
757
|
-
continue;
|
|
758
|
-
for (const tr of inv.typeReferences) {
|
|
759
|
-
if (tr.typeName !== typeName)
|
|
760
|
-
continue;
|
|
761
|
-
if (tr.enclosing === typeName)
|
|
762
|
-
continue; // skip the definition site
|
|
763
|
-
const row = {
|
|
764
|
-
file: filePath,
|
|
765
|
-
enclosing: tr.enclosing,
|
|
766
|
-
};
|
|
767
|
-
if (tr.line !== undefined)
|
|
768
|
-
row.line = tr.line;
|
|
769
|
-
out.push(row);
|
|
770
|
-
}
|
|
771
|
-
}
|
|
772
|
-
return out;
|
|
773
|
-
}
|
|
774
|
-
/**
|
|
775
|
-
* Locate where a symbol is defined. Returns `{ file, kind, line }` for
|
|
776
|
-
* each definition (there may be more than one when the same name is
|
|
777
|
-
* used across files).
|
|
778
|
-
*/
|
|
779
|
-
findDefinition(symbolName) {
|
|
780
|
-
const out = [];
|
|
781
|
-
for (const filePath of this.persistence.getAllFilePaths()) {
|
|
782
|
-
const inv = this.persistence.getFileInventory(filePath);
|
|
783
|
-
if (!inv)
|
|
784
|
-
continue;
|
|
785
|
-
const sym = inv.symbolsByName.get(symbolName);
|
|
786
|
-
if (!sym)
|
|
787
|
-
continue;
|
|
788
|
-
const row = {
|
|
789
|
-
file: filePath,
|
|
790
|
-
kind: sym.kind,
|
|
791
|
-
};
|
|
792
|
-
if (sym.line !== undefined)
|
|
793
|
-
row.line = sym.line;
|
|
794
|
-
out.push(row);
|
|
795
|
-
}
|
|
796
|
-
return out;
|
|
797
|
-
}
|
|
798
|
-
/** File-paths that have been indexed (workspace-relative). */
|
|
799
|
-
indexedFiles() {
|
|
800
|
-
return this.persistence.getAllFilePaths();
|
|
801
|
-
}
|
|
802
|
-
/** Current workspace root (absolute). */
|
|
803
|
-
getWorkspaceRoot() {
|
|
804
|
-
return this.workspaceRoot;
|
|
805
|
-
}
|
|
806
|
-
}
|
|
807
|
-
//# sourceMappingURL=kg-builder.js.map
|