@kkvcrobatz107/codegraph 0.9.6-pkm.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +595 -0
- package/dist/bin/codegraph.d.ts +25 -0
- package/dist/bin/codegraph.d.ts.map +1 -0
- package/dist/bin/codegraph.js +1563 -0
- package/dist/bin/codegraph.js.map +1 -0
- package/dist/bin/node-version-check.d.ts +37 -0
- package/dist/bin/node-version-check.d.ts.map +1 -0
- package/dist/bin/node-version-check.js +79 -0
- package/dist/bin/node-version-check.js.map +1 -0
- package/dist/bin/uninstall.d.ts +14 -0
- package/dist/bin/uninstall.d.ts.map +1 -0
- package/dist/bin/uninstall.js +36 -0
- package/dist/bin/uninstall.js.map +1 -0
- package/dist/context/formatter.d.ts +30 -0
- package/dist/context/formatter.d.ts.map +1 -0
- package/dist/context/formatter.js +244 -0
- package/dist/context/formatter.js.map +1 -0
- package/dist/context/index.d.ts +110 -0
- package/dist/context/index.d.ts.map +1 -0
- package/dist/context/index.js +1169 -0
- package/dist/context/index.js.map +1 -0
- package/dist/db/index.d.ts +101 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +251 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/migrations.d.ts +44 -0
- package/dist/db/migrations.d.ts.map +1 -0
- package/dist/db/migrations.js +131 -0
- package/dist/db/migrations.js.map +1 -0
- package/dist/db/queries.d.ts +281 -0
- package/dist/db/queries.d.ts.map +1 -0
- package/dist/db/queries.js +1300 -0
- package/dist/db/queries.js.map +1 -0
- package/dist/db/schema.sql +151 -0
- package/dist/db/sqlite-adapter.d.ts +46 -0
- package/dist/db/sqlite-adapter.d.ts.map +1 -0
- package/dist/db/sqlite-adapter.js +114 -0
- package/dist/db/sqlite-adapter.js.map +1 -0
- package/dist/directory.d.ts +57 -0
- package/dist/directory.d.ts.map +1 -0
- package/dist/directory.js +264 -0
- package/dist/directory.js.map +1 -0
- package/dist/errors.d.ts +136 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +219 -0
- package/dist/errors.js.map +1 -0
- package/dist/extraction/dfm-extractor.d.ts +31 -0
- package/dist/extraction/dfm-extractor.d.ts.map +1 -0
- package/dist/extraction/dfm-extractor.js +151 -0
- package/dist/extraction/dfm-extractor.js.map +1 -0
- package/dist/extraction/grammars.d.ts +90 -0
- package/dist/extraction/grammars.d.ts.map +1 -0
- package/dist/extraction/grammars.js +407 -0
- package/dist/extraction/grammars.js.map +1 -0
- package/dist/extraction/index.d.ts +138 -0
- package/dist/extraction/index.d.ts.map +1 -0
- package/dist/extraction/index.js +1378 -0
- package/dist/extraction/index.js.map +1 -0
- package/dist/extraction/languages/c-cpp.d.ts +4 -0
- package/dist/extraction/languages/c-cpp.d.ts.map +1 -0
- package/dist/extraction/languages/c-cpp.js +171 -0
- package/dist/extraction/languages/c-cpp.js.map +1 -0
- package/dist/extraction/languages/csharp.d.ts +3 -0
- package/dist/extraction/languages/csharp.d.ts.map +1 -0
- package/dist/extraction/languages/csharp.js +73 -0
- package/dist/extraction/languages/csharp.js.map +1 -0
- package/dist/extraction/languages/dart.d.ts +3 -0
- package/dist/extraction/languages/dart.d.ts.map +1 -0
- package/dist/extraction/languages/dart.js +192 -0
- package/dist/extraction/languages/dart.js.map +1 -0
- package/dist/extraction/languages/go.d.ts +3 -0
- package/dist/extraction/languages/go.d.ts.map +1 -0
- package/dist/extraction/languages/go.js +70 -0
- package/dist/extraction/languages/go.js.map +1 -0
- package/dist/extraction/languages/index.d.ts +10 -0
- package/dist/extraction/languages/index.d.ts.map +1 -0
- package/dist/extraction/languages/index.js +51 -0
- package/dist/extraction/languages/index.js.map +1 -0
- package/dist/extraction/languages/java.d.ts +3 -0
- package/dist/extraction/languages/java.d.ts.map +1 -0
- package/dist/extraction/languages/java.js +70 -0
- package/dist/extraction/languages/java.js.map +1 -0
- package/dist/extraction/languages/javascript.d.ts +3 -0
- package/dist/extraction/languages/javascript.d.ts.map +1 -0
- package/dist/extraction/languages/javascript.js +90 -0
- package/dist/extraction/languages/javascript.js.map +1 -0
- package/dist/extraction/languages/kotlin.d.ts +3 -0
- package/dist/extraction/languages/kotlin.d.ts.map +1 -0
- package/dist/extraction/languages/kotlin.js +259 -0
- package/dist/extraction/languages/kotlin.js.map +1 -0
- package/dist/extraction/languages/lua.d.ts +3 -0
- package/dist/extraction/languages/lua.d.ts.map +1 -0
- package/dist/extraction/languages/lua.js +150 -0
- package/dist/extraction/languages/lua.js.map +1 -0
- package/dist/extraction/languages/luau.d.ts +3 -0
- package/dist/extraction/languages/luau.d.ts.map +1 -0
- package/dist/extraction/languages/luau.js +37 -0
- package/dist/extraction/languages/luau.js.map +1 -0
- package/dist/extraction/languages/objc.d.ts +3 -0
- package/dist/extraction/languages/objc.d.ts.map +1 -0
- package/dist/extraction/languages/objc.js +133 -0
- package/dist/extraction/languages/objc.js.map +1 -0
- package/dist/extraction/languages/pascal.d.ts +3 -0
- package/dist/extraction/languages/pascal.d.ts.map +1 -0
- package/dist/extraction/languages/pascal.js +66 -0
- package/dist/extraction/languages/pascal.js.map +1 -0
- package/dist/extraction/languages/php.d.ts +3 -0
- package/dist/extraction/languages/php.d.ts.map +1 -0
- package/dist/extraction/languages/php.js +107 -0
- package/dist/extraction/languages/php.js.map +1 -0
- package/dist/extraction/languages/python.d.ts +3 -0
- package/dist/extraction/languages/python.d.ts.map +1 -0
- package/dist/extraction/languages/python.js +56 -0
- package/dist/extraction/languages/python.js.map +1 -0
- package/dist/extraction/languages/ruby.d.ts +3 -0
- package/dist/extraction/languages/ruby.d.ts.map +1 -0
- package/dist/extraction/languages/ruby.js +114 -0
- package/dist/extraction/languages/ruby.js.map +1 -0
- package/dist/extraction/languages/rust.d.ts +3 -0
- package/dist/extraction/languages/rust.d.ts.map +1 -0
- package/dist/extraction/languages/rust.js +109 -0
- package/dist/extraction/languages/rust.js.map +1 -0
- package/dist/extraction/languages/scala.d.ts +3 -0
- package/dist/extraction/languages/scala.d.ts.map +1 -0
- package/dist/extraction/languages/scala.js +139 -0
- package/dist/extraction/languages/scala.js.map +1 -0
- package/dist/extraction/languages/swift.d.ts +3 -0
- package/dist/extraction/languages/swift.d.ts.map +1 -0
- package/dist/extraction/languages/swift.js +91 -0
- package/dist/extraction/languages/swift.js.map +1 -0
- package/dist/extraction/languages/typescript.d.ts +3 -0
- package/dist/extraction/languages/typescript.d.ts.map +1 -0
- package/dist/extraction/languages/typescript.js +129 -0
- package/dist/extraction/languages/typescript.js.map +1 -0
- package/dist/extraction/liquid-extractor.d.ts +52 -0
- package/dist/extraction/liquid-extractor.d.ts.map +1 -0
- package/dist/extraction/liquid-extractor.js +313 -0
- package/dist/extraction/liquid-extractor.js.map +1 -0
- package/dist/extraction/mybatis-extractor.d.ts +48 -0
- package/dist/extraction/mybatis-extractor.d.ts.map +1 -0
- package/dist/extraction/mybatis-extractor.js +198 -0
- package/dist/extraction/mybatis-extractor.js.map +1 -0
- package/dist/extraction/parse-worker.d.ts +8 -0
- package/dist/extraction/parse-worker.d.ts.map +1 -0
- package/dist/extraction/parse-worker.js +94 -0
- package/dist/extraction/parse-worker.js.map +1 -0
- package/dist/extraction/svelte-extractor.d.ts +56 -0
- package/dist/extraction/svelte-extractor.d.ts.map +1 -0
- package/dist/extraction/svelte-extractor.js +272 -0
- package/dist/extraction/svelte-extractor.js.map +1 -0
- package/dist/extraction/tree-sitter-helpers.d.ts +28 -0
- package/dist/extraction/tree-sitter-helpers.d.ts.map +1 -0
- package/dist/extraction/tree-sitter-helpers.js +103 -0
- package/dist/extraction/tree-sitter-helpers.js.map +1 -0
- package/dist/extraction/tree-sitter-types.d.ts +193 -0
- package/dist/extraction/tree-sitter-types.d.ts.map +1 -0
- package/dist/extraction/tree-sitter-types.js +10 -0
- package/dist/extraction/tree-sitter-types.js.map +1 -0
- package/dist/extraction/tree-sitter.d.ts +291 -0
- package/dist/extraction/tree-sitter.d.ts.map +1 -0
- package/dist/extraction/tree-sitter.js +2961 -0
- package/dist/extraction/tree-sitter.js.map +1 -0
- package/dist/extraction/vue-extractor.d.ts +36 -0
- package/dist/extraction/vue-extractor.d.ts.map +1 -0
- package/dist/extraction/vue-extractor.js +163 -0
- package/dist/extraction/vue-extractor.js.map +1 -0
- package/dist/extraction/wasm/tree-sitter-lua.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-luau.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-pascal.wasm +0 -0
- package/dist/extraction/wasm/tree-sitter-scala.wasm +0 -0
- package/dist/extraction/wasm-runtime-flags.d.ts +38 -0
- package/dist/extraction/wasm-runtime-flags.d.ts.map +1 -0
- package/dist/extraction/wasm-runtime-flags.js +105 -0
- package/dist/extraction/wasm-runtime-flags.js.map +1 -0
- package/dist/graph/index.d.ts +8 -0
- package/dist/graph/index.d.ts.map +1 -0
- package/dist/graph/index.js +13 -0
- package/dist/graph/index.js.map +1 -0
- package/dist/graph/queries.d.ts +106 -0
- package/dist/graph/queries.d.ts.map +1 -0
- package/dist/graph/queries.js +366 -0
- package/dist/graph/queries.js.map +1 -0
- package/dist/graph/traversal.d.ts +127 -0
- package/dist/graph/traversal.d.ts.map +1 -0
- package/dist/graph/traversal.js +528 -0
- package/dist/graph/traversal.js.map +1 -0
- package/dist/index.d.ts +460 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +863 -0
- package/dist/index.js.map +1 -0
- package/dist/installer/claude-md-template.d.ts +14 -0
- package/dist/installer/claude-md-template.d.ts.map +1 -0
- package/dist/installer/claude-md-template.js +21 -0
- package/dist/installer/claude-md-template.js.map +1 -0
- package/dist/installer/config-writer.d.ts +29 -0
- package/dist/installer/config-writer.d.ts.map +1 -0
- package/dist/installer/config-writer.js +111 -0
- package/dist/installer/config-writer.js.map +1 -0
- package/dist/installer/index.d.ts +117 -0
- package/dist/installer/index.d.ts.map +1 -0
- package/dist/installer/index.js +528 -0
- package/dist/installer/index.js.map +1 -0
- package/dist/installer/instructions-template.d.ts +28 -0
- package/dist/installer/instructions-template.d.ts.map +1 -0
- package/dist/installer/instructions-template.js +65 -0
- package/dist/installer/instructions-template.js.map +1 -0
- package/dist/installer/targets/antigravity.d.ts +57 -0
- package/dist/installer/targets/antigravity.d.ts.map +1 -0
- package/dist/installer/targets/antigravity.js +307 -0
- package/dist/installer/targets/antigravity.js.map +1 -0
- package/dist/installer/targets/claude.d.ts +47 -0
- package/dist/installer/targets/claude.d.ts.map +1 -0
- package/dist/installer/targets/claude.js +401 -0
- package/dist/installer/targets/claude.js.map +1 -0
- package/dist/installer/targets/codex.d.ts +18 -0
- package/dist/installer/targets/codex.d.ts.map +1 -0
- package/dist/installer/targets/codex.js +185 -0
- package/dist/installer/targets/codex.js.map +1 -0
- package/dist/installer/targets/cursor.d.ts +35 -0
- package/dist/installer/targets/cursor.d.ts.map +1 -0
- package/dist/installer/targets/cursor.js +283 -0
- package/dist/installer/targets/cursor.js.map +1 -0
- package/dist/installer/targets/gemini.d.ts +26 -0
- package/dist/installer/targets/gemini.d.ts.map +1 -0
- package/dist/installer/targets/gemini.js +165 -0
- package/dist/installer/targets/gemini.js.map +1 -0
- package/dist/installer/targets/hermes.d.ts +18 -0
- package/dist/installer/targets/hermes.d.ts.map +1 -0
- package/dist/installer/targets/hermes.js +359 -0
- package/dist/installer/targets/hermes.js.map +1 -0
- package/dist/installer/targets/kiro.d.ts +27 -0
- package/dist/installer/targets/kiro.d.ts.map +1 -0
- package/dist/installer/targets/kiro.js +196 -0
- package/dist/installer/targets/kiro.js.map +1 -0
- package/dist/installer/targets/opencode.d.ts +30 -0
- package/dist/installer/targets/opencode.d.ts.map +1 -0
- package/dist/installer/targets/opencode.js +235 -0
- package/dist/installer/targets/opencode.js.map +1 -0
- package/dist/installer/targets/registry.d.ts +35 -0
- package/dist/installer/targets/registry.d.ts.map +1 -0
- package/dist/installer/targets/registry.js +91 -0
- package/dist/installer/targets/registry.js.map +1 -0
- package/dist/installer/targets/shared.d.ts +77 -0
- package/dist/installer/targets/shared.d.ts.map +1 -0
- package/dist/installer/targets/shared.js +246 -0
- package/dist/installer/targets/shared.js.map +1 -0
- package/dist/installer/targets/toml.d.ts +52 -0
- package/dist/installer/targets/toml.d.ts.map +1 -0
- package/dist/installer/targets/toml.js +147 -0
- package/dist/installer/targets/toml.js.map +1 -0
- package/dist/installer/targets/types.d.ts +116 -0
- package/dist/installer/targets/types.d.ts.map +1 -0
- package/dist/installer/targets/types.js +16 -0
- package/dist/installer/targets/types.js.map +1 -0
- package/dist/mcp/daemon-paths.d.ts +46 -0
- package/dist/mcp/daemon-paths.d.ts.map +1 -0
- package/dist/mcp/daemon-paths.js +125 -0
- package/dist/mcp/daemon-paths.js.map +1 -0
- package/dist/mcp/daemon.d.ts +161 -0
- package/dist/mcp/daemon.d.ts.map +1 -0
- package/dist/mcp/daemon.js +403 -0
- package/dist/mcp/daemon.js.map +1 -0
- package/dist/mcp/engine.d.ts +100 -0
- package/dist/mcp/engine.d.ts.map +1 -0
- package/dist/mcp/engine.js +291 -0
- package/dist/mcp/engine.js.map +1 -0
- package/dist/mcp/index.d.ts +109 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +470 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/proxy.d.ts +46 -0
- package/dist/mcp/proxy.d.ts.map +1 -0
- package/dist/mcp/proxy.js +276 -0
- package/dist/mcp/proxy.js.map +1 -0
- package/dist/mcp/server-instructions.d.ts +19 -0
- package/dist/mcp/server-instructions.d.ts.map +1 -0
- package/dist/mcp/server-instructions.js +73 -0
- package/dist/mcp/server-instructions.js.map +1 -0
- package/dist/mcp/session.d.ts +67 -0
- package/dist/mcp/session.d.ts.map +1 -0
- package/dist/mcp/session.js +276 -0
- package/dist/mcp/session.js.map +1 -0
- package/dist/mcp/tools.d.ts +385 -0
- package/dist/mcp/tools.d.ts.map +1 -0
- package/dist/mcp/tools.js +2545 -0
- package/dist/mcp/tools.js.map +1 -0
- package/dist/mcp/transport.d.ts +188 -0
- package/dist/mcp/transport.d.ts.map +1 -0
- package/dist/mcp/transport.js +343 -0
- package/dist/mcp/transport.js.map +1 -0
- package/dist/mcp/version.d.ts +19 -0
- package/dist/mcp/version.d.ts.map +1 -0
- package/dist/mcp/version.js +71 -0
- package/dist/mcp/version.js.map +1 -0
- package/dist/resolution/callback-synthesizer.d.ts +10 -0
- package/dist/resolution/callback-synthesizer.d.ts.map +1 -0
- package/dist/resolution/callback-synthesizer.js +924 -0
- package/dist/resolution/callback-synthesizer.js.map +1 -0
- package/dist/resolution/frameworks/cargo-workspace.d.ts +18 -0
- package/dist/resolution/frameworks/cargo-workspace.d.ts.map +1 -0
- package/dist/resolution/frameworks/cargo-workspace.js +225 -0
- package/dist/resolution/frameworks/cargo-workspace.js.map +1 -0
- package/dist/resolution/frameworks/csharp.d.ts +8 -0
- package/dist/resolution/frameworks/csharp.d.ts.map +1 -0
- package/dist/resolution/frameworks/csharp.js +241 -0
- package/dist/resolution/frameworks/csharp.js.map +1 -0
- package/dist/resolution/frameworks/drupal.d.ts +51 -0
- package/dist/resolution/frameworks/drupal.d.ts.map +1 -0
- package/dist/resolution/frameworks/drupal.js +367 -0
- package/dist/resolution/frameworks/drupal.js.map +1 -0
- package/dist/resolution/frameworks/expo-modules.d.ts +3 -0
- package/dist/resolution/frameworks/expo-modules.d.ts.map +1 -0
- package/dist/resolution/frameworks/expo-modules.js +143 -0
- package/dist/resolution/frameworks/expo-modules.js.map +1 -0
- package/dist/resolution/frameworks/express.d.ts +8 -0
- package/dist/resolution/frameworks/express.d.ts.map +1 -0
- package/dist/resolution/frameworks/express.js +308 -0
- package/dist/resolution/frameworks/express.js.map +1 -0
- package/dist/resolution/frameworks/fabric.d.ts +3 -0
- package/dist/resolution/frameworks/fabric.d.ts.map +1 -0
- package/dist/resolution/frameworks/fabric.js +354 -0
- package/dist/resolution/frameworks/fabric.js.map +1 -0
- package/dist/resolution/frameworks/go.d.ts +8 -0
- package/dist/resolution/frameworks/go.d.ts.map +1 -0
- package/dist/resolution/frameworks/go.js +161 -0
- package/dist/resolution/frameworks/go.js.map +1 -0
- package/dist/resolution/frameworks/index.d.ts +48 -0
- package/dist/resolution/frameworks/index.d.ts.map +1 -0
- package/dist/resolution/frameworks/index.js +161 -0
- package/dist/resolution/frameworks/index.js.map +1 -0
- package/dist/resolution/frameworks/java.d.ts +8 -0
- package/dist/resolution/frameworks/java.d.ts.map +1 -0
- package/dist/resolution/frameworks/java.js +504 -0
- package/dist/resolution/frameworks/java.js.map +1 -0
- package/dist/resolution/frameworks/laravel.d.ts +13 -0
- package/dist/resolution/frameworks/laravel.d.ts.map +1 -0
- package/dist/resolution/frameworks/laravel.js +257 -0
- package/dist/resolution/frameworks/laravel.js.map +1 -0
- package/dist/resolution/frameworks/nestjs.d.ts +26 -0
- package/dist/resolution/frameworks/nestjs.d.ts.map +1 -0
- package/dist/resolution/frameworks/nestjs.js +698 -0
- package/dist/resolution/frameworks/nestjs.js.map +1 -0
- package/dist/resolution/frameworks/play.d.ts +19 -0
- package/dist/resolution/frameworks/play.d.ts.map +1 -0
- package/dist/resolution/frameworks/play.js +111 -0
- package/dist/resolution/frameworks/play.js.map +1 -0
- package/dist/resolution/frameworks/python.d.ts +10 -0
- package/dist/resolution/frameworks/python.d.ts.map +1 -0
- package/dist/resolution/frameworks/python.js +396 -0
- package/dist/resolution/frameworks/python.js.map +1 -0
- package/dist/resolution/frameworks/react-native.d.ts +3 -0
- package/dist/resolution/frameworks/react-native.d.ts.map +1 -0
- package/dist/resolution/frameworks/react-native.js +360 -0
- package/dist/resolution/frameworks/react-native.js.map +1 -0
- package/dist/resolution/frameworks/react.d.ts +8 -0
- package/dist/resolution/frameworks/react.d.ts.map +1 -0
- package/dist/resolution/frameworks/react.js +365 -0
- package/dist/resolution/frameworks/react.js.map +1 -0
- package/dist/resolution/frameworks/ruby.d.ts +8 -0
- package/dist/resolution/frameworks/ruby.d.ts.map +1 -0
- package/dist/resolution/frameworks/ruby.js +302 -0
- package/dist/resolution/frameworks/ruby.js.map +1 -0
- package/dist/resolution/frameworks/rust.d.ts +8 -0
- package/dist/resolution/frameworks/rust.d.ts.map +1 -0
- package/dist/resolution/frameworks/rust.js +304 -0
- package/dist/resolution/frameworks/rust.js.map +1 -0
- package/dist/resolution/frameworks/svelte.d.ts +9 -0
- package/dist/resolution/frameworks/svelte.d.ts.map +1 -0
- package/dist/resolution/frameworks/svelte.js +249 -0
- package/dist/resolution/frameworks/svelte.js.map +1 -0
- package/dist/resolution/frameworks/swift-objc.d.ts +37 -0
- package/dist/resolution/frameworks/swift-objc.d.ts.map +1 -0
- package/dist/resolution/frameworks/swift-objc.js +252 -0
- package/dist/resolution/frameworks/swift-objc.js.map +1 -0
- package/dist/resolution/frameworks/swift.d.ts +10 -0
- package/dist/resolution/frameworks/swift.d.ts.map +1 -0
- package/dist/resolution/frameworks/swift.js +400 -0
- package/dist/resolution/frameworks/swift.js.map +1 -0
- package/dist/resolution/frameworks/vue.d.ts +9 -0
- package/dist/resolution/frameworks/vue.d.ts.map +1 -0
- package/dist/resolution/frameworks/vue.js +306 -0
- package/dist/resolution/frameworks/vue.js.map +1 -0
- package/dist/resolution/go-module.d.ts +26 -0
- package/dist/resolution/go-module.d.ts.map +1 -0
- package/dist/resolution/go-module.js +78 -0
- package/dist/resolution/go-module.js.map +1 -0
- package/dist/resolution/import-resolver.d.ts +68 -0
- package/dist/resolution/import-resolver.d.ts.map +1 -0
- package/dist/resolution/import-resolver.js +1231 -0
- package/dist/resolution/import-resolver.js.map +1 -0
- package/dist/resolution/index.d.ts +116 -0
- package/dist/resolution/index.d.ts.map +1 -0
- package/dist/resolution/index.js +878 -0
- package/dist/resolution/index.js.map +1 -0
- package/dist/resolution/lru-cache.d.ts +24 -0
- package/dist/resolution/lru-cache.d.ts.map +1 -0
- package/dist/resolution/lru-cache.js +62 -0
- package/dist/resolution/lru-cache.js.map +1 -0
- package/dist/resolution/name-matcher.d.ts +32 -0
- package/dist/resolution/name-matcher.d.ts.map +1 -0
- package/dist/resolution/name-matcher.js +596 -0
- package/dist/resolution/name-matcher.js.map +1 -0
- package/dist/resolution/path-aliases.d.ts +68 -0
- package/dist/resolution/path-aliases.d.ts.map +1 -0
- package/dist/resolution/path-aliases.js +238 -0
- package/dist/resolution/path-aliases.js.map +1 -0
- package/dist/resolution/strip-comments.d.ts +27 -0
- package/dist/resolution/strip-comments.d.ts.map +1 -0
- package/dist/resolution/strip-comments.js +441 -0
- package/dist/resolution/strip-comments.js.map +1 -0
- package/dist/resolution/swift-objc-bridge.d.ts +134 -0
- package/dist/resolution/swift-objc-bridge.d.ts.map +1 -0
- package/dist/resolution/swift-objc-bridge.js +256 -0
- package/dist/resolution/swift-objc-bridge.js.map +1 -0
- package/dist/resolution/types.d.ts +209 -0
- package/dist/resolution/types.d.ts.map +1 -0
- package/dist/resolution/types.js +8 -0
- package/dist/resolution/types.js.map +1 -0
- package/dist/search/query-parser.d.ts +57 -0
- package/dist/search/query-parser.d.ts.map +1 -0
- package/dist/search/query-parser.js +177 -0
- package/dist/search/query-parser.js.map +1 -0
- package/dist/search/query-utils.d.ts +53 -0
- package/dist/search/query-utils.d.ts.map +1 -0
- package/dist/search/query-utils.js +350 -0
- package/dist/search/query-utils.js.map +1 -0
- package/dist/sync/git-hooks.d.ts +45 -0
- package/dist/sync/git-hooks.d.ts.map +1 -0
- package/dist/sync/git-hooks.js +223 -0
- package/dist/sync/git-hooks.js.map +1 -0
- package/dist/sync/index.d.ts +19 -0
- package/dist/sync/index.d.ts.map +1 -0
- package/dist/sync/index.js +35 -0
- package/dist/sync/index.js.map +1 -0
- package/dist/sync/watch-policy.d.ts +48 -0
- package/dist/sync/watch-policy.d.ts.map +1 -0
- package/dist/sync/watch-policy.js +124 -0
- package/dist/sync/watch-policy.js.map +1 -0
- package/dist/sync/watcher.d.ts +191 -0
- package/dist/sync/watcher.d.ts.map +1 -0
- package/dist/sync/watcher.js +398 -0
- package/dist/sync/watcher.js.map +1 -0
- package/dist/sync/worktree.d.ts +54 -0
- package/dist/sync/worktree.d.ts.map +1 -0
- package/dist/sync/worktree.js +136 -0
- package/dist/sync/worktree.js.map +1 -0
- package/dist/types.d.ts +369 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +78 -0
- package/dist/types.js.map +1 -0
- package/dist/ui/glyphs.d.ts +42 -0
- package/dist/ui/glyphs.d.ts.map +1 -0
- package/dist/ui/glyphs.js +78 -0
- package/dist/ui/glyphs.js.map +1 -0
- package/dist/ui/shimmer-progress.d.ts +11 -0
- package/dist/ui/shimmer-progress.d.ts.map +1 -0
- package/dist/ui/shimmer-progress.js +90 -0
- package/dist/ui/shimmer-progress.js.map +1 -0
- package/dist/ui/shimmer-worker.d.ts +2 -0
- package/dist/ui/shimmer-worker.d.ts.map +1 -0
- package/dist/ui/shimmer-worker.js +118 -0
- package/dist/ui/shimmer-worker.js.map +1 -0
- package/dist/ui/types.d.ts +17 -0
- package/dist/ui/types.d.ts.map +1 -0
- package/dist/ui/types.js +3 -0
- package/dist/ui/types.js.map +1 -0
- package/dist/utils.d.ts +205 -0
- package/dist/utils.d.ts.map +1 -0
- package/dist/utils.js +549 -0
- package/dist/utils.js.map +1 -0
- package/package.json +59 -0
- package/scripts/add-lang/bench.sh +60 -0
- package/scripts/add-lang/check-grammar.mjs +75 -0
- package/scripts/add-lang/dump-ast.mjs +103 -0
- package/scripts/add-lang/verify-extraction.mjs +70 -0
- package/scripts/agent-eval/arms-F.sh +21 -0
- package/scripts/agent-eval/arms-matrix.sh +37 -0
- package/scripts/agent-eval/audit.sh +68 -0
- package/scripts/agent-eval/bench-readme.sh +28 -0
- package/scripts/agent-eval/block-read-hook.sh +19 -0
- package/scripts/agent-eval/hook-settings.json +15 -0
- package/scripts/agent-eval/itrun.sh +107 -0
- package/scripts/agent-eval/parse-arms.mjs +116 -0
- package/scripts/agent-eval/parse-bench-readme.mjs +67 -0
- package/scripts/agent-eval/parse-run.mjs +45 -0
- package/scripts/agent-eval/parse-session.mjs +93 -0
- package/scripts/agent-eval/probe-context.mjs +21 -0
- package/scripts/agent-eval/probe-explore.mjs +40 -0
- package/scripts/agent-eval/probe-node.mjs +20 -0
- package/scripts/agent-eval/probe-trace.mjs +20 -0
- package/scripts/agent-eval/run-agent.sh +34 -0
- package/scripts/agent-eval/run-all.sh +67 -0
- package/scripts/agent-eval/run-arms.sh +56 -0
- package/scripts/agent-eval/seq-matrix.mjs +137 -0
- package/scripts/build-bundle.sh +118 -0
- package/scripts/extract-release-notes.mjs +130 -0
- package/scripts/local-install.sh +41 -0
- package/scripts/npm-shim.js +246 -0
- package/scripts/pack-npm.sh +95 -0
- package/scripts/prepare-release.mjs +270 -0
|
@@ -0,0 +1,198 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.MyBatisExtractor = void 0;
|
|
4
|
+
const tree_sitter_helpers_1 = require("./tree-sitter-helpers");
|
|
5
|
+
/**
|
|
6
|
+
* MyBatisExtractor — parses MyBatis mapper XML files.
|
|
7
|
+
*
|
|
8
|
+
* MyBatis splits a DAO interface across two files: a Java interface (parsed by
|
|
9
|
+
* tree-sitter) declares the method, and an XML mapper file holds the SQL keyed
|
|
10
|
+
* by `<namespace>` (the fully-qualified Java type name) and `id` (the method
|
|
11
|
+
* name). Without the XML side in the graph, `trace(Controller, ...DAO.method)`
|
|
12
|
+
* dead-ends at the interface method — the SQL it actually runs is invisible,
|
|
13
|
+
* and "what does this query touch" / "where is this column written" can't be
|
|
14
|
+
* answered.
|
|
15
|
+
*
|
|
16
|
+
* This extractor emits one method-shaped node per `<select|insert|update|
|
|
17
|
+
* delete>` and per `<sql>` fragment, qualified as `<namespace>::<id>` so the
|
|
18
|
+
* MyBatis framework synthesizer (`src/resolution/frameworks/mybatis.ts`) can
|
|
19
|
+
* link the matching Java method → XML statement by suffix-matching qualified
|
|
20
|
+
* names. `<include refid="...">` inside a statement yields an unresolved
|
|
21
|
+
* reference to the SQL fragment, also keyed by `<namespace>::<refid>`.
|
|
22
|
+
*
|
|
23
|
+
* Non-mapper XML (Maven `pom.xml`, Spring beans XML, `web.xml`, log4j config,
|
|
24
|
+
* etc.) is detected by the absence of a `<mapper namespace="...">` root and
|
|
25
|
+
* returns just a file node — we still need the file row so the watcher can
|
|
26
|
+
* track it, but we emit no symbols.
|
|
27
|
+
*/
|
|
28
|
+
class MyBatisExtractor {
|
|
29
|
+
filePath;
|
|
30
|
+
source;
|
|
31
|
+
nodes = [];
|
|
32
|
+
edges = [];
|
|
33
|
+
unresolvedReferences = [];
|
|
34
|
+
errors = [];
|
|
35
|
+
lineStarts = [];
|
|
36
|
+
constructor(filePath, source) {
|
|
37
|
+
this.filePath = filePath;
|
|
38
|
+
this.source = source;
|
|
39
|
+
this.computeLineStarts();
|
|
40
|
+
}
|
|
41
|
+
extract() {
|
|
42
|
+
const startTime = Date.now();
|
|
43
|
+
const fileNode = this.createFileNode();
|
|
44
|
+
try {
|
|
45
|
+
const mapperMatch = this.findMapperRoot();
|
|
46
|
+
if (mapperMatch) {
|
|
47
|
+
this.extractMapper(fileNode.id, mapperMatch.namespace, mapperMatch.bodyStart, mapperMatch.bodyEnd);
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
catch (error) {
|
|
51
|
+
this.errors.push({
|
|
52
|
+
message: `MyBatis extraction error: ${error instanceof Error ? error.message : String(error)}`,
|
|
53
|
+
severity: 'error',
|
|
54
|
+
code: 'parse_error',
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
return {
|
|
58
|
+
nodes: this.nodes,
|
|
59
|
+
edges: this.edges,
|
|
60
|
+
unresolvedReferences: this.unresolvedReferences,
|
|
61
|
+
errors: this.errors,
|
|
62
|
+
durationMs: Date.now() - startTime,
|
|
63
|
+
};
|
|
64
|
+
}
|
|
65
|
+
createFileNode() {
|
|
66
|
+
const lines = this.source.split('\n');
|
|
67
|
+
const id = (0, tree_sitter_helpers_1.generateNodeId)(this.filePath, 'file', this.filePath, 1);
|
|
68
|
+
const node = {
|
|
69
|
+
id,
|
|
70
|
+
kind: 'file',
|
|
71
|
+
name: this.filePath.split('/').pop() || this.filePath,
|
|
72
|
+
qualifiedName: this.filePath,
|
|
73
|
+
filePath: this.filePath,
|
|
74
|
+
language: 'xml',
|
|
75
|
+
startLine: 1,
|
|
76
|
+
endLine: lines.length || 1,
|
|
77
|
+
startColumn: 0,
|
|
78
|
+
endColumn: lines[lines.length - 1]?.length ?? 0,
|
|
79
|
+
updatedAt: Date.now(),
|
|
80
|
+
};
|
|
81
|
+
this.nodes.push(node);
|
|
82
|
+
return node;
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Find the `<mapper namespace="X">` opening tag. Returns the namespace and
|
|
86
|
+
* the byte offsets of the body (between the opening and closing tag) so
|
|
87
|
+
* statement extraction can be scoped to mapper contents.
|
|
88
|
+
*/
|
|
89
|
+
findMapperRoot() {
|
|
90
|
+
const open = /<mapper\b([^>]*)>/.exec(this.source);
|
|
91
|
+
if (!open)
|
|
92
|
+
return null;
|
|
93
|
+
const attrs = open[1] ?? '';
|
|
94
|
+
const nsMatch = /\bnamespace\s*=\s*"([^"]+)"/.exec(attrs);
|
|
95
|
+
if (!nsMatch)
|
|
96
|
+
return null;
|
|
97
|
+
const bodyStart = open.index + open[0].length;
|
|
98
|
+
const closeIdx = this.source.indexOf('</mapper>', bodyStart);
|
|
99
|
+
const bodyEnd = closeIdx >= 0 ? closeIdx : this.source.length;
|
|
100
|
+
return { namespace: nsMatch[1], bodyStart, bodyEnd };
|
|
101
|
+
}
|
|
102
|
+
extractMapper(fileNodeId, namespace, bodyStart, bodyEnd) {
|
|
103
|
+
const body = this.source.slice(bodyStart, bodyEnd);
|
|
104
|
+
// Match each top-level statement-shaped element. The body may have nested
|
|
105
|
+
// tags (`<if>`, `<foreach>`, `<include>`), so we scan with a regex that
|
|
106
|
+
// pairs an opening tag to its matching close — the simple form below works
|
|
107
|
+
// because MyBatis statement elements are not themselves nested.
|
|
108
|
+
const stmtRegex = /<(select|insert|update|delete|sql)\b([^>]*)>([\s\S]*?)<\/\1>/g;
|
|
109
|
+
let m;
|
|
110
|
+
while ((m = stmtRegex.exec(body)) !== null) {
|
|
111
|
+
const elemType = m[1];
|
|
112
|
+
const attrs = m[2] ?? '';
|
|
113
|
+
const elemBody = m[3] ?? '';
|
|
114
|
+
const idMatch = /\bid\s*=\s*"([^"]+)"/.exec(attrs);
|
|
115
|
+
if (!idMatch)
|
|
116
|
+
continue;
|
|
117
|
+
const id = idMatch[1];
|
|
118
|
+
const absoluteIndex = bodyStart + m.index;
|
|
119
|
+
const startLine = this.getLineNumber(absoluteIndex);
|
|
120
|
+
const endLine = this.getLineNumber(absoluteIndex + m[0].length);
|
|
121
|
+
const qualified = `${namespace}::${id}`;
|
|
122
|
+
const isSqlFragment = elemType === 'sql';
|
|
123
|
+
const nodeId = (0, tree_sitter_helpers_1.generateNodeId)(this.filePath, 'method', qualified, startLine);
|
|
124
|
+
const node = {
|
|
125
|
+
id: nodeId,
|
|
126
|
+
kind: 'method',
|
|
127
|
+
name: id,
|
|
128
|
+
qualifiedName: qualified,
|
|
129
|
+
filePath: this.filePath,
|
|
130
|
+
language: 'xml',
|
|
131
|
+
signature: this.buildSignature(elemType, attrs, isSqlFragment),
|
|
132
|
+
startLine,
|
|
133
|
+
endLine,
|
|
134
|
+
startColumn: 0,
|
|
135
|
+
endColumn: 0,
|
|
136
|
+
docstring: this.previewSql(elemBody),
|
|
137
|
+
updatedAt: Date.now(),
|
|
138
|
+
};
|
|
139
|
+
this.nodes.push(node);
|
|
140
|
+
this.edges.push({ source: fileNodeId, target: nodeId, kind: 'contains' });
|
|
141
|
+
// <include refid="X"/> → reference to the SQL fragment in this mapper
|
|
142
|
+
// (or in another mapper, when the refid is qualified — `ns.X`).
|
|
143
|
+
const includeRegex = /<include\b[^>]*\brefid\s*=\s*"([^"]+)"/g;
|
|
144
|
+
let inc;
|
|
145
|
+
while ((inc = includeRegex.exec(elemBody)) !== null) {
|
|
146
|
+
const refid = inc[1];
|
|
147
|
+
const refQualified = refid.includes('.') ? refid.replace(/\./g, '::') : `${namespace}::${refid}`;
|
|
148
|
+
const includeOffset = absoluteIndex + (m[0].length - m[3].length - `</${elemType}>`.length) + inc.index;
|
|
149
|
+
const line = this.getLineNumber(includeOffset);
|
|
150
|
+
this.unresolvedReferences.push({
|
|
151
|
+
fromNodeId: nodeId,
|
|
152
|
+
referenceName: refQualified,
|
|
153
|
+
referenceKind: 'references',
|
|
154
|
+
line,
|
|
155
|
+
column: 0,
|
|
156
|
+
});
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
buildSignature(elemType, attrs, isSqlFragment) {
|
|
161
|
+
if (isSqlFragment)
|
|
162
|
+
return '<sql>';
|
|
163
|
+
const verb = elemType.toUpperCase();
|
|
164
|
+
const result = /\bresultType\s*=\s*"([^"]+)"/.exec(attrs)?.[1];
|
|
165
|
+
const param = /\bparameterType\s*=\s*"([^"]+)"/.exec(attrs)?.[1];
|
|
166
|
+
const parts = [verb];
|
|
167
|
+
if (param)
|
|
168
|
+
parts.push(`param=${param}`);
|
|
169
|
+
if (result)
|
|
170
|
+
parts.push(`result=${result}`);
|
|
171
|
+
return parts.join(' ');
|
|
172
|
+
}
|
|
173
|
+
previewSql(body) {
|
|
174
|
+
return body.replace(/<[^>]+>/g, ' ').replace(/\s+/g, ' ').trim().slice(0, 200);
|
|
175
|
+
}
|
|
176
|
+
computeLineStarts() {
|
|
177
|
+
this.lineStarts = [0];
|
|
178
|
+
for (let i = 0; i < this.source.length; i++) {
|
|
179
|
+
if (this.source.charCodeAt(i) === 10)
|
|
180
|
+
this.lineStarts.push(i + 1);
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
getLineNumber(offset) {
|
|
184
|
+
// Binary search
|
|
185
|
+
let lo = 0;
|
|
186
|
+
let hi = this.lineStarts.length - 1;
|
|
187
|
+
while (lo < hi) {
|
|
188
|
+
const mid = (lo + hi + 1) >>> 1;
|
|
189
|
+
if (this.lineStarts[mid] <= offset)
|
|
190
|
+
lo = mid;
|
|
191
|
+
else
|
|
192
|
+
hi = mid - 1;
|
|
193
|
+
}
|
|
194
|
+
return lo + 1;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
exports.MyBatisExtractor = MyBatisExtractor;
|
|
198
|
+
//# sourceMappingURL=mybatis-extractor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mybatis-extractor.js","sourceRoot":"","sources":["../../src/extraction/mybatis-extractor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-worker.d.ts","sourceRoot":"","sources":["../../src/extraction/parse-worker.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Parse Worker
|
|
4
|
+
*
|
|
5
|
+
* Runs tree-sitter parsing in a separate thread so the main thread
|
|
6
|
+
* stays unblocked and the UI animation renders smoothly.
|
|
7
|
+
*/
|
|
8
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
const worker_threads_1 = require("worker_threads");
|
|
10
|
+
const tree_sitter_1 = require("./tree-sitter");
|
|
11
|
+
const grammars_1 = require("./grammars");
|
|
12
|
+
// Emscripten prints `Aborted()` (and a follow-up RuntimeError diag
|
|
13
|
+
// line) directly to stderr when WASM aborts — before the JS catch
|
|
14
|
+
// runs. Worker stderr is inherited by the parent, so each crash leaks
|
|
15
|
+
// a noise line to the user's terminal even though the JS layer
|
|
16
|
+
// already handles the failure cleanly. Filter these specific lines
|
|
17
|
+
// out at the source. Real diagnostic output (anything we log
|
|
18
|
+
// ourselves) goes through console.* / parentPort and is unaffected.
|
|
19
|
+
//
|
|
20
|
+
// Caveats deliberately accepted:
|
|
21
|
+
// - Per-call match: each `write()` call is matched in isolation.
|
|
22
|
+
// If Emscripten ever splits `Aborted(` across two write()s (it
|
|
23
|
+
// doesn't today — synchronous abort prints the whole line at
|
|
24
|
+
// once via libc puts) the first fragment would leak. Buffering
|
|
25
|
+
// across calls would add complexity for a hypothetical case.
|
|
26
|
+
// - Substring exactness: the prefix `Aborted(` is the literal
|
|
27
|
+
// Emscripten signature. Any user code that legitimately writes
|
|
28
|
+
// a stderr line starting with that prefix would also be filtered;
|
|
29
|
+
// in practice no real diagnostic does.
|
|
30
|
+
{
|
|
31
|
+
const realWrite = process.stderr.write.bind(process.stderr);
|
|
32
|
+
process.stderr.write = ((chunk, encoding, cb) => {
|
|
33
|
+
const s = typeof chunk === 'string' ? chunk : Buffer.from(chunk).toString('utf-8');
|
|
34
|
+
if (s.startsWith('Aborted(') ||
|
|
35
|
+
s.includes('Build with -sASSERTIONS for more info')) {
|
|
36
|
+
// Honour the Writable stream contract: callbacks must always
|
|
37
|
+
// fire even when the write is suppressed, or upstream code
|
|
38
|
+
// waiting on the drain signal would hang. Both overload forms
|
|
39
|
+
// are handled (`(chunk, cb)` and `(chunk, encoding, cb)`).
|
|
40
|
+
if (typeof encoding === 'function')
|
|
41
|
+
encoding();
|
|
42
|
+
else if (cb)
|
|
43
|
+
cb();
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
return realWrite(chunk, encoding, cb);
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
const PARSER_RESET_INTERVAL = 5000;
|
|
50
|
+
const parseCounts = new Map();
|
|
51
|
+
worker_threads_1.parentPort.on('message', async (msg) => {
|
|
52
|
+
if (msg.type === 'load-grammars') {
|
|
53
|
+
await (0, grammars_1.loadGrammarsForLanguages)(msg.languages);
|
|
54
|
+
worker_threads_1.parentPort.postMessage({ type: 'grammars-loaded' });
|
|
55
|
+
}
|
|
56
|
+
else if (msg.type === 'parse') {
|
|
57
|
+
const { id, filePath, content, frameworkNames } = msg;
|
|
58
|
+
try {
|
|
59
|
+
const language = (0, grammars_1.detectLanguage)(filePath, content);
|
|
60
|
+
const result = (0, tree_sitter_1.extractFromSource)(filePath, content, language, frameworkNames);
|
|
61
|
+
// Periodic parser reset to reclaim WASM heap memory
|
|
62
|
+
const count = (parseCounts.get(language) ?? 0) + 1;
|
|
63
|
+
parseCounts.set(language, count);
|
|
64
|
+
if (count % PARSER_RESET_INTERVAL === 0) {
|
|
65
|
+
(0, grammars_1.resetParser)(language);
|
|
66
|
+
}
|
|
67
|
+
worker_threads_1.parentPort.postMessage({ type: 'parse-result', id, result });
|
|
68
|
+
}
|
|
69
|
+
catch (err) {
|
|
70
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
71
|
+
// WASM memory errors leave the module in a corrupted state — all
|
|
72
|
+
// subsequent parses would also fail (cascading failures). Crash the
|
|
73
|
+
// worker so the main thread spawns a fresh one with a clean heap.
|
|
74
|
+
if (message.includes('memory access out of bounds') || message.includes('out of memory')) {
|
|
75
|
+
process.exit(1);
|
|
76
|
+
}
|
|
77
|
+
worker_threads_1.parentPort.postMessage({
|
|
78
|
+
type: 'parse-result',
|
|
79
|
+
id,
|
|
80
|
+
result: {
|
|
81
|
+
nodes: [],
|
|
82
|
+
edges: [],
|
|
83
|
+
unresolvedReferences: [],
|
|
84
|
+
errors: [{ message: `Parse worker error: ${message}`, filePath: filePath, severity: 'error', code: 'parse_error' }],
|
|
85
|
+
durationMs: 0,
|
|
86
|
+
},
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
else if (msg.type === 'shutdown') {
|
|
91
|
+
worker_threads_1.parentPort.postMessage({ type: 'shutdown-ack' });
|
|
92
|
+
}
|
|
93
|
+
});
|
|
94
|
+
//# sourceMappingURL=parse-worker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parse-worker.js","sourceRoot":"","sources":["../../src/extraction/parse-worker.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { ExtractionResult } from '../types';
|
|
2
|
+
/**
|
|
3
|
+
* SvelteExtractor - Extracts code relationships from Svelte component files
|
|
4
|
+
*
|
|
5
|
+
* Svelte files are multi-language (script + template + style). Rather than
|
|
6
|
+
* parsing the full Svelte grammar, we extract the <script> block content
|
|
7
|
+
* and delegate it to the TypeScript/JavaScript TreeSitterExtractor.
|
|
8
|
+
*
|
|
9
|
+
* Also extracts function calls from template expressions (`{fn(...)}`) so
|
|
10
|
+
* cross-file call edges are captured even when calls live in markup.
|
|
11
|
+
*
|
|
12
|
+
* Every .svelte file produces a component node (Svelte components are always importable).
|
|
13
|
+
*/
|
|
14
|
+
export declare class SvelteExtractor {
|
|
15
|
+
private filePath;
|
|
16
|
+
private source;
|
|
17
|
+
private nodes;
|
|
18
|
+
private edges;
|
|
19
|
+
private unresolvedReferences;
|
|
20
|
+
private errors;
|
|
21
|
+
constructor(filePath: string, source: string);
|
|
22
|
+
/**
|
|
23
|
+
* Extract from Svelte source
|
|
24
|
+
*/
|
|
25
|
+
extract(): ExtractionResult;
|
|
26
|
+
/**
|
|
27
|
+
* Create a component node for the .svelte file
|
|
28
|
+
*/
|
|
29
|
+
private createComponentNode;
|
|
30
|
+
/**
|
|
31
|
+
* Extract <script> blocks from the Svelte source
|
|
32
|
+
*/
|
|
33
|
+
private extractScriptBlocks;
|
|
34
|
+
/**
|
|
35
|
+
* Process a script block by delegating to TreeSitterExtractor
|
|
36
|
+
*/
|
|
37
|
+
private processScriptBlock;
|
|
38
|
+
/**
|
|
39
|
+
* Extract function calls from Svelte template expressions.
|
|
40
|
+
*
|
|
41
|
+
* In Svelte, many function calls happen in markup (e.g., `class={cn(...)}`),
|
|
42
|
+
* not inside `<script>` blocks. We scan the template portion for `{expression}`
|
|
43
|
+
* blocks and extract call patterns from them.
|
|
44
|
+
*/
|
|
45
|
+
private extractTemplateCalls;
|
|
46
|
+
/**
|
|
47
|
+
* Extract component usages from the Svelte template.
|
|
48
|
+
*
|
|
49
|
+
* PascalCase tags like <Modal>, <Button />, <DevServerPreview> represent
|
|
50
|
+
* component instantiations — analogous to function calls in imperative code.
|
|
51
|
+
* Capturing these creates graph edges from parent to child components and
|
|
52
|
+
* gives codegraph_explore anchor points in the template markup.
|
|
53
|
+
*/
|
|
54
|
+
private extractTemplateComponents;
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=svelte-extractor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"svelte-extractor.d.ts","sourceRoot":"","sources":["../../src/extraction/svelte-extractor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAc,gBAAgB,EAAkD,MAAM,UAAU,CAAC;AAWxG;;;;;;;;;;;GAWG;AACH,qBAAa,eAAe;IAC1B,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,oBAAoB,CAA6B;IACzD,OAAO,CAAC,MAAM,CAAyB;gBAE3B,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAK5C;;OAEG;IACH,OAAO,IAAI,gBAAgB;IAyC3B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAyB3B;;OAEG;IACH,OAAO,CAAC,mBAAmB;IA6C3B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IA4D1B;;;;;;OAMG;IACH,OAAO,CAAC,oBAAoB;IAqD5B;;;;;;;OAOG;IACH,OAAO,CAAC,yBAAyB;CAmClC"}
|
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SvelteExtractor = void 0;
|
|
4
|
+
const tree_sitter_helpers_1 = require("./tree-sitter-helpers");
|
|
5
|
+
const tree_sitter_1 = require("./tree-sitter");
|
|
6
|
+
const grammars_1 = require("./grammars");
|
|
7
|
+
/** Svelte 5 rune names — compiler builtins, not real functions */
|
|
8
|
+
const SVELTE_RUNES = new Set([
|
|
9
|
+
'$props', '$state', '$derived', '$effect', '$bindable',
|
|
10
|
+
'$inspect', '$host', '$snippet',
|
|
11
|
+
]);
|
|
12
|
+
/**
|
|
13
|
+
* SvelteExtractor - Extracts code relationships from Svelte component files
|
|
14
|
+
*
|
|
15
|
+
* Svelte files are multi-language (script + template + style). Rather than
|
|
16
|
+
* parsing the full Svelte grammar, we extract the <script> block content
|
|
17
|
+
* and delegate it to the TypeScript/JavaScript TreeSitterExtractor.
|
|
18
|
+
*
|
|
19
|
+
* Also extracts function calls from template expressions (`{fn(...)}`) so
|
|
20
|
+
* cross-file call edges are captured even when calls live in markup.
|
|
21
|
+
*
|
|
22
|
+
* Every .svelte file produces a component node (Svelte components are always importable).
|
|
23
|
+
*/
|
|
24
|
+
class SvelteExtractor {
|
|
25
|
+
filePath;
|
|
26
|
+
source;
|
|
27
|
+
nodes = [];
|
|
28
|
+
edges = [];
|
|
29
|
+
unresolvedReferences = [];
|
|
30
|
+
errors = [];
|
|
31
|
+
constructor(filePath, source) {
|
|
32
|
+
this.filePath = filePath;
|
|
33
|
+
this.source = source;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Extract from Svelte source
|
|
37
|
+
*/
|
|
38
|
+
extract() {
|
|
39
|
+
const startTime = Date.now();
|
|
40
|
+
try {
|
|
41
|
+
// Create component node for the .svelte file itself
|
|
42
|
+
const componentNode = this.createComponentNode();
|
|
43
|
+
// Extract and process script blocks
|
|
44
|
+
const scriptBlocks = this.extractScriptBlocks();
|
|
45
|
+
for (const block of scriptBlocks) {
|
|
46
|
+
this.processScriptBlock(block, componentNode.id);
|
|
47
|
+
}
|
|
48
|
+
// Extract function calls from template expressions ({fn(...)})
|
|
49
|
+
this.extractTemplateCalls(componentNode.id, scriptBlocks);
|
|
50
|
+
// Extract component usages from template (<ComponentName>)
|
|
51
|
+
this.extractTemplateComponents(componentNode.id);
|
|
52
|
+
// Filter out Svelte rune calls ($state, $props, $derived, etc.)
|
|
53
|
+
this.unresolvedReferences = this.unresolvedReferences.filter(ref => !SVELTE_RUNES.has(ref.referenceName));
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
this.errors.push({
|
|
57
|
+
message: `Svelte extraction error: ${error instanceof Error ? error.message : String(error)}`,
|
|
58
|
+
severity: 'error',
|
|
59
|
+
code: 'parse_error',
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
return {
|
|
63
|
+
nodes: this.nodes,
|
|
64
|
+
edges: this.edges,
|
|
65
|
+
unresolvedReferences: this.unresolvedReferences,
|
|
66
|
+
errors: this.errors,
|
|
67
|
+
durationMs: Date.now() - startTime,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Create a component node for the .svelte file
|
|
72
|
+
*/
|
|
73
|
+
createComponentNode() {
|
|
74
|
+
const lines = this.source.split('\n');
|
|
75
|
+
const fileName = this.filePath.split(/[/\\]/).pop() || this.filePath;
|
|
76
|
+
const componentName = fileName.replace(/\.svelte$/, '');
|
|
77
|
+
const id = (0, tree_sitter_helpers_1.generateNodeId)(this.filePath, 'component', componentName, 1);
|
|
78
|
+
const node = {
|
|
79
|
+
id,
|
|
80
|
+
kind: 'component',
|
|
81
|
+
name: componentName,
|
|
82
|
+
qualifiedName: `${this.filePath}::${componentName}`,
|
|
83
|
+
filePath: this.filePath,
|
|
84
|
+
language: 'svelte',
|
|
85
|
+
startLine: 1,
|
|
86
|
+
endLine: lines.length,
|
|
87
|
+
startColumn: 0,
|
|
88
|
+
endColumn: lines[lines.length - 1]?.length || 0,
|
|
89
|
+
isExported: true, // Svelte components are always importable
|
|
90
|
+
updatedAt: Date.now(),
|
|
91
|
+
};
|
|
92
|
+
this.nodes.push(node);
|
|
93
|
+
return node;
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Extract <script> blocks from the Svelte source
|
|
97
|
+
*/
|
|
98
|
+
extractScriptBlocks() {
|
|
99
|
+
const blocks = [];
|
|
100
|
+
const scriptRegex = /<script(\s[^>]*)?>(?<content>[\s\S]*?)<\/script>/g;
|
|
101
|
+
let match;
|
|
102
|
+
while ((match = scriptRegex.exec(this.source)) !== null) {
|
|
103
|
+
const attrs = match[1] || '';
|
|
104
|
+
const content = match.groups?.content || match[2] || '';
|
|
105
|
+
// Detect TypeScript from lang attribute
|
|
106
|
+
const isTypeScript = /lang\s*=\s*["'](ts|typescript)["']/.test(attrs);
|
|
107
|
+
// Detect module script
|
|
108
|
+
const isModule = /context\s*=\s*["']module["']/.test(attrs);
|
|
109
|
+
// Calculate start line of the script content (line after <script>)
|
|
110
|
+
const beforeScript = this.source.substring(0, match.index);
|
|
111
|
+
const scriptTagLine = (beforeScript.match(/\n/g) || []).length;
|
|
112
|
+
// The content starts on the line after the opening <script> tag
|
|
113
|
+
const openingTag = match[0].substring(0, match[0].indexOf('>') + 1);
|
|
114
|
+
const openingTagLines = (openingTag.match(/\n/g) || []).length;
|
|
115
|
+
const contentStartLine = scriptTagLine + openingTagLines + 1; // 0-indexed line
|
|
116
|
+
blocks.push({
|
|
117
|
+
content,
|
|
118
|
+
startLine: contentStartLine,
|
|
119
|
+
isModule,
|
|
120
|
+
isTypeScript,
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
return blocks;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Process a script block by delegating to TreeSitterExtractor
|
|
127
|
+
*/
|
|
128
|
+
processScriptBlock(block, componentNodeId) {
|
|
129
|
+
const scriptLanguage = block.isTypeScript ? 'typescript' : 'javascript';
|
|
130
|
+
// Check if the script language parser is available
|
|
131
|
+
if (!(0, grammars_1.isLanguageSupported)(scriptLanguage)) {
|
|
132
|
+
this.errors.push({
|
|
133
|
+
message: `Parser for ${scriptLanguage} not available, cannot parse Svelte script block`,
|
|
134
|
+
severity: 'warning',
|
|
135
|
+
});
|
|
136
|
+
return;
|
|
137
|
+
}
|
|
138
|
+
// Delegate to TreeSitterExtractor
|
|
139
|
+
const extractor = new tree_sitter_1.TreeSitterExtractor(this.filePath, block.content, scriptLanguage);
|
|
140
|
+
const result = extractor.extract();
|
|
141
|
+
// Offset line numbers from script block back to .svelte file positions
|
|
142
|
+
for (const node of result.nodes) {
|
|
143
|
+
node.startLine += block.startLine;
|
|
144
|
+
node.endLine += block.startLine;
|
|
145
|
+
node.language = 'svelte'; // Mark as svelte, not TS/JS
|
|
146
|
+
this.nodes.push(node);
|
|
147
|
+
// Add containment edge from component to this node
|
|
148
|
+
this.edges.push({
|
|
149
|
+
source: componentNodeId,
|
|
150
|
+
target: node.id,
|
|
151
|
+
kind: 'contains',
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
// Offset edges (they reference line numbers)
|
|
155
|
+
for (const edge of result.edges) {
|
|
156
|
+
if (edge.line) {
|
|
157
|
+
edge.line += block.startLine;
|
|
158
|
+
}
|
|
159
|
+
this.edges.push(edge);
|
|
160
|
+
}
|
|
161
|
+
// Offset unresolved references
|
|
162
|
+
for (const ref of result.unresolvedReferences) {
|
|
163
|
+
ref.line += block.startLine;
|
|
164
|
+
ref.filePath = this.filePath;
|
|
165
|
+
ref.language = 'svelte';
|
|
166
|
+
this.unresolvedReferences.push(ref);
|
|
167
|
+
}
|
|
168
|
+
// Carry over errors
|
|
169
|
+
for (const error of result.errors) {
|
|
170
|
+
if (error.line) {
|
|
171
|
+
error.line += block.startLine;
|
|
172
|
+
}
|
|
173
|
+
this.errors.push(error);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Extract function calls from Svelte template expressions.
|
|
178
|
+
*
|
|
179
|
+
* In Svelte, many function calls happen in markup (e.g., `class={cn(...)}`),
|
|
180
|
+
* not inside `<script>` blocks. We scan the template portion for `{expression}`
|
|
181
|
+
* blocks and extract call patterns from them.
|
|
182
|
+
*/
|
|
183
|
+
extractTemplateCalls(componentNodeId, _scriptBlocks) {
|
|
184
|
+
// Build a set of line ranges covered by <script> and <style> blocks so we skip them
|
|
185
|
+
const coveredRanges = [];
|
|
186
|
+
// Find all <script>...</script> and <style>...</style> ranges
|
|
187
|
+
const tagRegex = /<(script|style)(\s[^>]*)?>[\s\S]*?<\/\1>/g;
|
|
188
|
+
let tagMatch;
|
|
189
|
+
while ((tagMatch = tagRegex.exec(this.source)) !== null) {
|
|
190
|
+
const startLine = (this.source.substring(0, tagMatch.index).match(/\n/g) || []).length;
|
|
191
|
+
const endLine = startLine + (tagMatch[0].match(/\n/g) || []).length;
|
|
192
|
+
coveredRanges.push([startLine, endLine]);
|
|
193
|
+
}
|
|
194
|
+
// Find template expressions: {...} outside of script/style blocks
|
|
195
|
+
// Matches curly-brace expressions, excluding Svelte block syntax ({#if}, {:else}, {/if}, {@html}, {@render})
|
|
196
|
+
const lines = this.source.split('\n');
|
|
197
|
+
const exprRegex = /\{([^}#/:@][^}]*)\}/g;
|
|
198
|
+
for (let lineIdx = 0; lineIdx < lines.length; lineIdx++) {
|
|
199
|
+
// Skip lines inside script/style blocks
|
|
200
|
+
if (coveredRanges.some(([start, end]) => lineIdx >= start && lineIdx <= end))
|
|
201
|
+
continue;
|
|
202
|
+
const line = lines[lineIdx];
|
|
203
|
+
let exprMatch;
|
|
204
|
+
while ((exprMatch = exprRegex.exec(line)) !== null) {
|
|
205
|
+
const expr = exprMatch[1];
|
|
206
|
+
// Extract function calls: identifiers followed by (
|
|
207
|
+
// Matches: cn(...), buttonVariants(...), obj.method(...)
|
|
208
|
+
const callRegex = /\b([a-zA-Z_$][\w$.]*)\s*\(/g;
|
|
209
|
+
let callMatch;
|
|
210
|
+
while ((callMatch = callRegex.exec(expr)) !== null) {
|
|
211
|
+
const calleeName = callMatch[1];
|
|
212
|
+
// Skip Svelte runes, control flow keywords, and common non-function patterns
|
|
213
|
+
if (SVELTE_RUNES.has(calleeName))
|
|
214
|
+
continue;
|
|
215
|
+
if (calleeName === 'if' || calleeName === 'else' || calleeName === 'each' || calleeName === 'await')
|
|
216
|
+
continue;
|
|
217
|
+
this.unresolvedReferences.push({
|
|
218
|
+
fromNodeId: componentNodeId,
|
|
219
|
+
referenceName: calleeName,
|
|
220
|
+
referenceKind: 'calls',
|
|
221
|
+
line: lineIdx + 1, // 1-indexed
|
|
222
|
+
column: exprMatch.index + callMatch.index,
|
|
223
|
+
filePath: this.filePath,
|
|
224
|
+
language: 'svelte',
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Extract component usages from the Svelte template.
|
|
232
|
+
*
|
|
233
|
+
* PascalCase tags like <Modal>, <Button />, <DevServerPreview> represent
|
|
234
|
+
* component instantiations — analogous to function calls in imperative code.
|
|
235
|
+
* Capturing these creates graph edges from parent to child components and
|
|
236
|
+
* gives codegraph_explore anchor points in the template markup.
|
|
237
|
+
*/
|
|
238
|
+
extractTemplateComponents(componentNodeId) {
|
|
239
|
+
// Build ranges covered by <script> and <style> blocks to skip them
|
|
240
|
+
const coveredRanges = [];
|
|
241
|
+
const tagRegex = /<(script|style)(\s[^>]*)?>[\s\S]*?<\/\1>/g;
|
|
242
|
+
let tagMatch;
|
|
243
|
+
while ((tagMatch = tagRegex.exec(this.source)) !== null) {
|
|
244
|
+
const startLine = (this.source.substring(0, tagMatch.index).match(/\n/g) || []).length;
|
|
245
|
+
const endLine = startLine + (tagMatch[0].match(/\n/g) || []).length;
|
|
246
|
+
coveredRanges.push([startLine, endLine]);
|
|
247
|
+
}
|
|
248
|
+
const lines = this.source.split('\n');
|
|
249
|
+
// Match PascalCase opening/self-closing tags (closing tags </Foo> start with </ so won't match)
|
|
250
|
+
const componentTagRegex = /<([A-Z][a-zA-Z0-9_$]*)\b/g;
|
|
251
|
+
for (let lineIdx = 0; lineIdx < lines.length; lineIdx++) {
|
|
252
|
+
if (coveredRanges.some(([start, end]) => lineIdx >= start && lineIdx <= end))
|
|
253
|
+
continue;
|
|
254
|
+
const line = lines[lineIdx];
|
|
255
|
+
let match;
|
|
256
|
+
while ((match = componentTagRegex.exec(line)) !== null) {
|
|
257
|
+
const componentName = match[1];
|
|
258
|
+
this.unresolvedReferences.push({
|
|
259
|
+
fromNodeId: componentNodeId,
|
|
260
|
+
referenceName: componentName,
|
|
261
|
+
referenceKind: 'references',
|
|
262
|
+
line: lineIdx + 1, // 1-indexed
|
|
263
|
+
column: match.index + 1,
|
|
264
|
+
filePath: this.filePath,
|
|
265
|
+
language: 'svelte',
|
|
266
|
+
});
|
|
267
|
+
}
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
}
|
|
271
|
+
exports.SvelteExtractor = SvelteExtractor;
|
|
272
|
+
//# sourceMappingURL=svelte-extractor.js.map
|