purecontext-mcp 1.0.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 +207 -0
- package/dist/adapters/actix-web.d.ts +28 -0
- package/dist/adapters/actix-web.d.ts.map +1 -0
- package/dist/adapters/actix-web.js +362 -0
- package/dist/adapters/actix-web.js.map +1 -0
- package/dist/adapters/adapter-registry.d.ts +34 -0
- package/dist/adapters/adapter-registry.d.ts.map +1 -0
- package/dist/adapters/adapter-registry.js +92 -0
- package/dist/adapters/adapter-registry.js.map +1 -0
- package/dist/adapters/angular.d.ts +13 -0
- package/dist/adapters/angular.d.ts.map +1 -0
- package/dist/adapters/angular.js +348 -0
- package/dist/adapters/angular.js.map +1 -0
- package/dist/adapters/axum.d.ts +16 -0
- package/dist/adapters/axum.d.ts.map +1 -0
- package/dist/adapters/axum.js +299 -0
- package/dist/adapters/axum.js.map +1 -0
- package/dist/adapters/django-orm.d.ts +28 -0
- package/dist/adapters/django-orm.d.ts.map +1 -0
- package/dist/adapters/django-orm.js +464 -0
- package/dist/adapters/django-orm.js.map +1 -0
- package/dist/adapters/django.d.ts +16 -0
- package/dist/adapters/django.d.ts.map +1 -0
- package/dist/adapters/django.js +257 -0
- package/dist/adapters/django.js.map +1 -0
- package/dist/adapters/echo.d.ts +15 -0
- package/dist/adapters/echo.d.ts.map +1 -0
- package/dist/adapters/echo.js +142 -0
- package/dist/adapters/echo.js.map +1 -0
- package/dist/adapters/express.d.ts +15 -0
- package/dist/adapters/express.d.ts.map +1 -0
- package/dist/adapters/express.js +126 -0
- package/dist/adapters/express.js.map +1 -0
- package/dist/adapters/fastapi.d.ts +16 -0
- package/dist/adapters/fastapi.d.ts.map +1 -0
- package/dist/adapters/fastapi.js +113 -0
- package/dist/adapters/fastapi.js.map +1 -0
- package/dist/adapters/fastify.d.ts +14 -0
- package/dist/adapters/fastify.d.ts.map +1 -0
- package/dist/adapters/fastify.js +124 -0
- package/dist/adapters/fastify.js.map +1 -0
- package/dist/adapters/fiber.d.ts +15 -0
- package/dist/adapters/fiber.d.ts.map +1 -0
- package/dist/adapters/fiber.js +147 -0
- package/dist/adapters/fiber.js.map +1 -0
- package/dist/adapters/flask.d.ts +18 -0
- package/dist/adapters/flask.d.ts.map +1 -0
- package/dist/adapters/flask.js +175 -0
- package/dist/adapters/flask.js.map +1 -0
- package/dist/adapters/flutter.d.ts +19 -0
- package/dist/adapters/flutter.d.ts.map +1 -0
- package/dist/adapters/flutter.js +251 -0
- package/dist/adapters/flutter.js.map +1 -0
- package/dist/adapters/gin.d.ts +16 -0
- package/dist/adapters/gin.d.ts.map +1 -0
- package/dist/adapters/gin.js +159 -0
- package/dist/adapters/gin.js.map +1 -0
- package/dist/adapters/hibernate.d.ts +24 -0
- package/dist/adapters/hibernate.d.ts.map +1 -0
- package/dist/adapters/hibernate.js +448 -0
- package/dist/adapters/hibernate.js.map +1 -0
- package/dist/adapters/ktor.d.ts +18 -0
- package/dist/adapters/ktor.d.ts.map +1 -0
- package/dist/adapters/ktor.js +219 -0
- package/dist/adapters/ktor.js.map +1 -0
- package/dist/adapters/laravel.d.ts +19 -0
- package/dist/adapters/laravel.d.ts.map +1 -0
- package/dist/adapters/laravel.js +370 -0
- package/dist/adapters/laravel.js.map +1 -0
- package/dist/adapters/micronaut.d.ts +21 -0
- package/dist/adapters/micronaut.d.ts.map +1 -0
- package/dist/adapters/micronaut.js +435 -0
- package/dist/adapters/micronaut.js.map +1 -0
- package/dist/adapters/nestjs.d.ts +12 -0
- package/dist/adapters/nestjs.d.ts.map +1 -0
- package/dist/adapters/nestjs.js +401 -0
- package/dist/adapters/nestjs.js.map +1 -0
- package/dist/adapters/nextjs.d.ts +49 -0
- package/dist/adapters/nextjs.d.ts.map +1 -0
- package/dist/adapters/nextjs.js +412 -0
- package/dist/adapters/nextjs.js.map +1 -0
- package/dist/adapters/nuxt.d.ts +44 -0
- package/dist/adapters/nuxt.d.ts.map +1 -0
- package/dist/adapters/nuxt.js +243 -0
- package/dist/adapters/nuxt.js.map +1 -0
- package/dist/adapters/quarkus.d.ts +21 -0
- package/dist/adapters/quarkus.d.ts.map +1 -0
- package/dist/adapters/quarkus.js +395 -0
- package/dist/adapters/quarkus.js.map +1 -0
- package/dist/adapters/rails.d.ts +18 -0
- package/dist/adapters/rails.d.ts.map +1 -0
- package/dist/adapters/rails.js +363 -0
- package/dist/adapters/rails.js.map +1 -0
- package/dist/adapters/react.d.ts +18 -0
- package/dist/adapters/react.d.ts.map +1 -0
- package/dist/adapters/react.js +95 -0
- package/dist/adapters/react.js.map +1 -0
- package/dist/adapters/rocket.d.ts +19 -0
- package/dist/adapters/rocket.d.ts.map +1 -0
- package/dist/adapters/rocket.js +271 -0
- package/dist/adapters/rocket.js.map +1 -0
- package/dist/adapters/sinatra.d.ts +16 -0
- package/dist/adapters/sinatra.d.ts.map +1 -0
- package/dist/adapters/sinatra.js +114 -0
- package/dist/adapters/sinatra.js.map +1 -0
- package/dist/adapters/spring-boot.d.ts +24 -0
- package/dist/adapters/spring-boot.d.ts.map +1 -0
- package/dist/adapters/spring-boot.js +399 -0
- package/dist/adapters/spring-boot.js.map +1 -0
- package/dist/adapters/spring-kotlin.d.ts +19 -0
- package/dist/adapters/spring-kotlin.d.ts.map +1 -0
- package/dist/adapters/spring-kotlin.js +297 -0
- package/dist/adapters/spring-kotlin.js.map +1 -0
- package/dist/adapters/sqlalchemy.d.ts +28 -0
- package/dist/adapters/sqlalchemy.d.ts.map +1 -0
- package/dist/adapters/sqlalchemy.js +435 -0
- package/dist/adapters/sqlalchemy.js.map +1 -0
- package/dist/adapters/symfony.d.ts +16 -0
- package/dist/adapters/symfony.d.ts.map +1 -0
- package/dist/adapters/symfony.js +242 -0
- package/dist/adapters/symfony.js.map +1 -0
- package/dist/adapters/vapor.d.ts +21 -0
- package/dist/adapters/vapor.d.ts.map +1 -0
- package/dist/adapters/vapor.js +269 -0
- package/dist/adapters/vapor.js.map +1 -0
- package/dist/adapters/vue-preprocessor.d.ts +26 -0
- package/dist/adapters/vue-preprocessor.d.ts.map +1 -0
- package/dist/adapters/vue-preprocessor.js +82 -0
- package/dist/adapters/vue-preprocessor.js.map +1 -0
- package/dist/adapters/vue.d.ts +13 -0
- package/dist/adapters/vue.d.ts.map +1 -0
- package/dist/adapters/vue.js +134 -0
- package/dist/adapters/vue.js.map +1 -0
- package/dist/config/cli.d.ts +26 -0
- package/dist/config/cli.d.ts.map +1 -0
- package/dist/config/cli.js +291 -0
- package/dist/config/cli.js.map +1 -0
- package/dist/config/config-loader.d.ts +26 -0
- package/dist/config/config-loader.d.ts.map +1 -0
- package/dist/config/config-loader.js +168 -0
- package/dist/config/config-loader.js.map +1 -0
- package/dist/config/config-schema.d.ts +228 -0
- package/dist/config/config-schema.d.ts.map +1 -0
- package/dist/config/config-schema.js +400 -0
- package/dist/config/config-schema.js.map +1 -0
- package/dist/config/keys-cli.d.ts +37 -0
- package/dist/config/keys-cli.d.ts.map +1 -0
- package/dist/config/keys-cli.js +179 -0
- package/dist/config/keys-cli.js.map +1 -0
- package/dist/config/workspaces-cli.d.ts +2 -0
- package/dist/config/workspaces-cli.d.ts.map +1 -0
- package/dist/config/workspaces-cli.js +84 -0
- package/dist/config/workspaces-cli.js.map +1 -0
- package/dist/core/db/api-keys.d.ts +95 -0
- package/dist/core/db/api-keys.d.ts.map +1 -0
- package/dist/core/db/api-keys.js +293 -0
- package/dist/core/db/api-keys.js.map +1 -0
- package/dist/core/db/dep-store.d.ts +18 -0
- package/dist/core/db/dep-store.d.ts.map +1 -0
- package/dist/core/db/dep-store.js +155 -0
- package/dist/core/db/dep-store.js.map +1 -0
- package/dist/core/db/embedding-store.d.ts +40 -0
- package/dist/core/db/embedding-store.d.ts.map +1 -0
- package/dist/core/db/embedding-store.js +120 -0
- package/dist/core/db/embedding-store.js.map +1 -0
- package/dist/core/db/file-store.d.ts +27 -0
- package/dist/core/db/file-store.d.ts.map +1 -0
- package/dist/core/db/file-store.js +101 -0
- package/dist/core/db/file-store.js.map +1 -0
- package/dist/core/db/request-log.d.ts +40 -0
- package/dist/core/db/request-log.d.ts.map +1 -0
- package/dist/core/db/request-log.js +90 -0
- package/dist/core/db/request-log.js.map +1 -0
- package/dist/core/db/savings-store.d.ts +9 -0
- package/dist/core/db/savings-store.d.ts.map +1 -0
- package/dist/core/db/savings-store.js +64 -0
- package/dist/core/db/savings-store.js.map +1 -0
- package/dist/core/db/schema.d.ts +14 -0
- package/dist/core/db/schema.d.ts.map +1 -0
- package/dist/core/db/schema.js +235 -0
- package/dist/core/db/schema.js.map +1 -0
- package/dist/core/db/symbol-store.d.ts +64 -0
- package/dist/core/db/symbol-store.d.ts.map +1 -0
- package/dist/core/db/symbol-store.js +243 -0
- package/dist/core/db/symbol-store.js.map +1 -0
- package/dist/core/db/tenants.d.ts +91 -0
- package/dist/core/db/tenants.d.ts.map +1 -0
- package/dist/core/db/tenants.js +219 -0
- package/dist/core/db/tenants.js.map +1 -0
- package/dist/core/errors.d.ts +72 -0
- package/dist/core/errors.d.ts.map +1 -0
- package/dist/core/errors.js +140 -0
- package/dist/core/errors.js.map +1 -0
- package/dist/core/file-discovery.d.ts +17 -0
- package/dist/core/file-discovery.d.ts.map +1 -0
- package/dist/core/file-discovery.js +136 -0
- package/dist/core/file-discovery.js.map +1 -0
- package/dist/core/file-processor.d.ts +21 -0
- package/dist/core/file-processor.d.ts.map +1 -0
- package/dist/core/file-processor.js +110 -0
- package/dist/core/file-processor.js.map +1 -0
- package/dist/core/hash-cache.d.ts +18 -0
- package/dist/core/hash-cache.d.ts.map +1 -0
- package/dist/core/hash-cache.js +35 -0
- package/dist/core/hash-cache.js.map +1 -0
- package/dist/core/index-manager.d.ts +18 -0
- package/dist/core/index-manager.d.ts.map +1 -0
- package/dist/core/index-manager.js +461 -0
- package/dist/core/index-manager.js.map +1 -0
- package/dist/core/indexing-worker.d.ts +60 -0
- package/dist/core/indexing-worker.d.ts.map +1 -0
- package/dist/core/indexing-worker.js +128 -0
- package/dist/core/indexing-worker.js.map +1 -0
- package/dist/core/logger.d.ts +10 -0
- package/dist/core/logger.d.ts.map +1 -0
- package/dist/core/logger.js +40 -0
- package/dist/core/logger.js.map +1 -0
- package/dist/core/parse-dispatcher.d.ts +18 -0
- package/dist/core/parse-dispatcher.d.ts.map +1 -0
- package/dist/core/parse-dispatcher.js +74 -0
- package/dist/core/parse-dispatcher.js.map +1 -0
- package/dist/core/search/query-preprocessor.d.ts +22 -0
- package/dist/core/search/query-preprocessor.d.ts.map +1 -0
- package/dist/core/search/query-preprocessor.js +77 -0
- package/dist/core/search/query-preprocessor.js.map +1 -0
- package/dist/core/search/relevance-ranker.d.ts +34 -0
- package/dist/core/search/relevance-ranker.d.ts.map +1 -0
- package/dist/core/search/relevance-ranker.js +132 -0
- package/dist/core/search/relevance-ranker.js.map +1 -0
- package/dist/core/security.d.ts +40 -0
- package/dist/core/security.d.ts.map +1 -0
- package/dist/core/security.js +133 -0
- package/dist/core/security.js.map +1 -0
- package/dist/core/telemetry.d.ts +19 -0
- package/dist/core/telemetry.d.ts.map +1 -0
- package/dist/core/telemetry.js +101 -0
- package/dist/core/telemetry.js.map +1 -0
- package/dist/core/tenant-context.d.ts +22 -0
- package/dist/core/tenant-context.d.ts.map +1 -0
- package/dist/core/tenant-context.js +16 -0
- package/dist/core/tenant-context.js.map +1 -0
- package/dist/core/token-tracker.d.ts +39 -0
- package/dist/core/token-tracker.d.ts.map +1 -0
- package/dist/core/token-tracker.js +153 -0
- package/dist/core/token-tracker.js.map +1 -0
- package/dist/core/types.d.ts +145 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +2 -0
- package/dist/core/types.js.map +1 -0
- package/dist/core/watcher/file-watcher.d.ts +18 -0
- package/dist/core/watcher/file-watcher.d.ts.map +1 -0
- package/dist/core/watcher/file-watcher.js +123 -0
- package/dist/core/watcher/file-watcher.js.map +1 -0
- package/dist/core/worker-pool.d.ts +24 -0
- package/dist/core/worker-pool.d.ts.map +1 -0
- package/dist/core/worker-pool.js +92 -0
- package/dist/core/worker-pool.js.map +1 -0
- package/dist/graph/graph-builder.d.ts +16 -0
- package/dist/graph/graph-builder.d.ts.map +1 -0
- package/dist/graph/graph-builder.js +51 -0
- package/dist/graph/graph-builder.js.map +1 -0
- package/dist/graph/graph-traversal.d.ts +57 -0
- package/dist/graph/graph-traversal.d.ts.map +1 -0
- package/dist/graph/graph-traversal.js +144 -0
- package/dist/graph/graph-traversal.js.map +1 -0
- package/dist/graph/path-resolver.d.ts +13 -0
- package/dist/graph/path-resolver.d.ts.map +1 -0
- package/dist/graph/path-resolver.js +161 -0
- package/dist/graph/path-resolver.js.map +1 -0
- package/dist/handlers/c.d.ts +3 -0
- package/dist/handlers/c.d.ts.map +1 -0
- package/dist/handlers/c.js +473 -0
- package/dist/handlers/c.js.map +1 -0
- package/dist/handlers/cpp.d.ts +3 -0
- package/dist/handlers/cpp.d.ts.map +1 -0
- package/dist/handlers/cpp.js +682 -0
- package/dist/handlers/cpp.js.map +1 -0
- package/dist/handlers/csharp.d.ts +3 -0
- package/dist/handlers/csharp.d.ts.map +1 -0
- package/dist/handlers/csharp.js +369 -0
- package/dist/handlers/csharp.js.map +1 -0
- package/dist/handlers/dart.d.ts +3 -0
- package/dist/handlers/dart.d.ts.map +1 -0
- package/dist/handlers/dart.js +596 -0
- package/dist/handlers/dart.js.map +1 -0
- package/dist/handlers/elixir.d.ts +8 -0
- package/dist/handlers/elixir.d.ts.map +1 -0
- package/dist/handlers/elixir.js +412 -0
- package/dist/handlers/elixir.js.map +1 -0
- package/dist/handlers/go.d.ts +3 -0
- package/dist/handlers/go.d.ts.map +1 -0
- package/dist/handlers/go.js +262 -0
- package/dist/handlers/go.js.map +1 -0
- package/dist/handlers/handler-registry.d.ts +20 -0
- package/dist/handlers/handler-registry.d.ts.map +1 -0
- package/dist/handlers/handler-registry.js +69 -0
- package/dist/handlers/handler-registry.js.map +1 -0
- package/dist/handlers/haskell.d.ts +17 -0
- package/dist/handlers/haskell.d.ts.map +1 -0
- package/dist/handlers/haskell.js +356 -0
- package/dist/handlers/haskell.js.map +1 -0
- package/dist/handlers/java.d.ts +3 -0
- package/dist/handlers/java.d.ts.map +1 -0
- package/dist/handlers/java.js +350 -0
- package/dist/handlers/java.js.map +1 -0
- package/dist/handlers/javascript.d.ts +3 -0
- package/dist/handlers/javascript.d.ts.map +1 -0
- package/dist/handlers/javascript.js +232 -0
- package/dist/handlers/javascript.js.map +1 -0
- package/dist/handlers/kotlin.d.ts +3 -0
- package/dist/handlers/kotlin.d.ts.map +1 -0
- package/dist/handlers/kotlin.js +317 -0
- package/dist/handlers/kotlin.js.map +1 -0
- package/dist/handlers/lua.d.ts +3 -0
- package/dist/handlers/lua.d.ts.map +1 -0
- package/dist/handlers/lua.js +328 -0
- package/dist/handlers/lua.js.map +1 -0
- package/dist/handlers/php.d.ts +3 -0
- package/dist/handlers/php.d.ts.map +1 -0
- package/dist/handlers/php.js +343 -0
- package/dist/handlers/php.js.map +1 -0
- package/dist/handlers/python.d.ts +3 -0
- package/dist/handlers/python.d.ts.map +1 -0
- package/dist/handlers/python.js +343 -0
- package/dist/handlers/python.js.map +1 -0
- package/dist/handlers/r.d.ts +9 -0
- package/dist/handlers/r.d.ts.map +1 -0
- package/dist/handlers/r.js +452 -0
- package/dist/handlers/r.js.map +1 -0
- package/dist/handlers/ruby.d.ts +8 -0
- package/dist/handlers/ruby.d.ts.map +1 -0
- package/dist/handlers/ruby.js +271 -0
- package/dist/handlers/ruby.js.map +1 -0
- package/dist/handlers/rust.d.ts +3 -0
- package/dist/handlers/rust.d.ts.map +1 -0
- package/dist/handlers/rust.js +420 -0
- package/dist/handlers/rust.js.map +1 -0
- package/dist/handlers/scala.d.ts +9 -0
- package/dist/handlers/scala.d.ts.map +1 -0
- package/dist/handlers/scala.js +480 -0
- package/dist/handlers/scala.js.map +1 -0
- package/dist/handlers/swift.d.ts +3 -0
- package/dist/handlers/swift.d.ts.map +1 -0
- package/dist/handlers/swift.js +553 -0
- package/dist/handlers/swift.js.map +1 -0
- package/dist/handlers/typescript.d.ts +4 -0
- package/dist/handlers/typescript.d.ts.map +1 -0
- package/dist/handlers/typescript.js +325 -0
- package/dist/handlers/typescript.js.map +1 -0
- package/dist/index.d.ts +44 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +266 -0
- package/dist/index.js.map +1 -0
- package/dist/semantic/embedding-provider.d.ts +66 -0
- package/dist/semantic/embedding-provider.d.ts.map +1 -0
- package/dist/semantic/embedding-provider.js +176 -0
- package/dist/semantic/embedding-provider.js.map +1 -0
- package/dist/semantic/hnsw-index.d.ts +96 -0
- package/dist/semantic/hnsw-index.d.ts.map +1 -0
- package/dist/semantic/hnsw-index.js +364 -0
- package/dist/semantic/hnsw-index.js.map +1 -0
- package/dist/semantic/hybrid-search.d.ts +46 -0
- package/dist/semantic/hybrid-search.d.ts.map +1 -0
- package/dist/semantic/hybrid-search.js +164 -0
- package/dist/semantic/hybrid-search.js.map +1 -0
- package/dist/semantic/query-expansion.d.ts +25 -0
- package/dist/semantic/query-expansion.d.ts.map +1 -0
- package/dist/semantic/query-expansion.js +150 -0
- package/dist/semantic/query-expansion.js.map +1 -0
- package/dist/semantic/semantic-indexer.d.ts +64 -0
- package/dist/semantic/semantic-indexer.d.ts.map +1 -0
- package/dist/semantic/semantic-indexer.js +162 -0
- package/dist/semantic/semantic-indexer.js.map +1 -0
- package/dist/semantic/text-preparation.d.ts +23 -0
- package/dist/semantic/text-preparation.d.ts.map +1 -0
- package/dist/semantic/text-preparation.js +56 -0
- package/dist/semantic/text-preparation.js.map +1 -0
- package/dist/semantic/vector-store.d.ts +81 -0
- package/dist/semantic/vector-store.d.ts.map +1 -0
- package/dist/semantic/vector-store.js +157 -0
- package/dist/semantic/vector-store.js.map +1 -0
- package/dist/server/admin-api.d.ts +88 -0
- package/dist/server/admin-api.d.ts.map +1 -0
- package/dist/server/admin-api.js +661 -0
- package/dist/server/admin-api.js.map +1 -0
- package/dist/server/auth/api-key.d.ts +105 -0
- package/dist/server/auth/api-key.d.ts.map +1 -0
- package/dist/server/auth/api-key.js +276 -0
- package/dist/server/auth/api-key.js.map +1 -0
- package/dist/server/http-server.d.ts +100 -0
- package/dist/server/http-server.d.ts.map +1 -0
- package/dist/server/http-server.js +823 -0
- package/dist/server/http-server.js.map +1 -0
- package/dist/server/mcp-server.d.ts +23 -0
- package/dist/server/mcp-server.d.ts.map +1 -0
- package/dist/server/mcp-server.js +214 -0
- package/dist/server/mcp-server.js.map +1 -0
- package/dist/server/rate-limit-store.d.ts +25 -0
- package/dist/server/rate-limit-store.d.ts.map +1 -0
- package/dist/server/rate-limit-store.js +46 -0
- package/dist/server/rate-limit-store.js.map +1 -0
- package/dist/server/rate-limiter.d.ts +59 -0
- package/dist/server/rate-limiter.d.ts.map +1 -0
- package/dist/server/rate-limiter.js +85 -0
- package/dist/server/rate-limiter.js.map +1 -0
- package/dist/server/tools/_meta.d.ts +24 -0
- package/dist/server/tools/_meta.d.ts.map +1 -0
- package/dist/server/tools/_meta.js +35 -0
- package/dist/server/tools/_meta.js.map +1 -0
- package/dist/server/tools/find-dead-code.d.ts +11 -0
- package/dist/server/tools/find-dead-code.d.ts.map +1 -0
- package/dist/server/tools/find-dead-code.js +45 -0
- package/dist/server/tools/find-dead-code.js.map +1 -0
- package/dist/server/tools/find-importers.d.ts +13 -0
- package/dist/server/tools/find-importers.d.ts.map +1 -0
- package/dist/server/tools/find-importers.js +46 -0
- package/dist/server/tools/find-importers.js.map +1 -0
- package/dist/server/tools/get-blast-radius.d.ts +15 -0
- package/dist/server/tools/get-blast-radius.d.ts.map +1 -0
- package/dist/server/tools/get-blast-radius.js +51 -0
- package/dist/server/tools/get-blast-radius.js.map +1 -0
- package/dist/server/tools/get-context-bundle.d.ts +15 -0
- package/dist/server/tools/get-context-bundle.d.ts.map +1 -0
- package/dist/server/tools/get-context-bundle.js +53 -0
- package/dist/server/tools/get-context-bundle.js.map +1 -0
- package/dist/server/tools/get-file-outline.d.ts +13 -0
- package/dist/server/tools/get-file-outline.d.ts.map +1 -0
- package/dist/server/tools/get-file-outline.js +42 -0
- package/dist/server/tools/get-file-outline.js.map +1 -0
- package/dist/server/tools/get-file-tree.d.ts +11 -0
- package/dist/server/tools/get-file-tree.d.ts.map +1 -0
- package/dist/server/tools/get-file-tree.js +63 -0
- package/dist/server/tools/get-file-tree.js.map +1 -0
- package/dist/server/tools/get-graph.d.ts +46 -0
- package/dist/server/tools/get-graph.d.ts.map +1 -0
- package/dist/server/tools/get-graph.js +168 -0
- package/dist/server/tools/get-graph.js.map +1 -0
- package/dist/server/tools/get-layer-violations.d.ts +37 -0
- package/dist/server/tools/get-layer-violations.d.ts.map +1 -0
- package/dist/server/tools/get-layer-violations.js +138 -0
- package/dist/server/tools/get-layer-violations.js.map +1 -0
- package/dist/server/tools/get-repo-outline.d.ts +13 -0
- package/dist/server/tools/get-repo-outline.d.ts.map +1 -0
- package/dist/server/tools/get-repo-outline.js +72 -0
- package/dist/server/tools/get-repo-outline.js.map +1 -0
- package/dist/server/tools/get-savings-stats.d.ts +11 -0
- package/dist/server/tools/get-savings-stats.d.ts.map +1 -0
- package/dist/server/tools/get-savings-stats.js +56 -0
- package/dist/server/tools/get-savings-stats.js.map +1 -0
- package/dist/server/tools/get-symbol-source.d.ts +13 -0
- package/dist/server/tools/get-symbol-source.d.ts.map +1 -0
- package/dist/server/tools/get-symbol-source.js +93 -0
- package/dist/server/tools/get-symbol-source.js.map +1 -0
- package/dist/server/tools/index-folder.d.ts +15 -0
- package/dist/server/tools/index-folder.d.ts.map +1 -0
- package/dist/server/tools/index-folder.js +45 -0
- package/dist/server/tools/index-folder.js.map +1 -0
- package/dist/server/tools/index-repo.d.ts +26 -0
- package/dist/server/tools/index-repo.d.ts.map +1 -0
- package/dist/server/tools/index-repo.js +164 -0
- package/dist/server/tools/index-repo.js.map +1 -0
- package/dist/server/tools/list-repos.d.ts +11 -0
- package/dist/server/tools/list-repos.d.ts.map +1 -0
- package/dist/server/tools/list-repos.js +60 -0
- package/dist/server/tools/list-repos.js.map +1 -0
- package/dist/server/tools/resolve-repo.d.ts +11 -0
- package/dist/server/tools/resolve-repo.d.ts.map +1 -0
- package/dist/server/tools/resolve-repo.js +44 -0
- package/dist/server/tools/resolve-repo.js.map +1 -0
- package/dist/server/tools/search-semantic.d.ts +56 -0
- package/dist/server/tools/search-semantic.d.ts.map +1 -0
- package/dist/server/tools/search-semantic.js +187 -0
- package/dist/server/tools/search-semantic.js.map +1 -0
- package/dist/server/tools/search-symbols.d.ts +43 -0
- package/dist/server/tools/search-symbols.d.ts.map +1 -0
- package/dist/server/tools/search-symbols.js +197 -0
- package/dist/server/tools/search-symbols.js.map +1 -0
- package/dist/server/tools/search-text.d.ts +21 -0
- package/dist/server/tools/search-text.d.ts.map +1 -0
- package/dist/server/tools/search-text.js +131 -0
- package/dist/server/tools/search-text.js.map +1 -0
- package/dist/server/transport.d.ts +59 -0
- package/dist/server/transport.d.ts.map +1 -0
- package/dist/server/transport.js +92 -0
- package/dist/server/transport.js.map +1 -0
- package/dist/summarizer/ai-summarizer.d.ts +71 -0
- package/dist/summarizer/ai-summarizer.d.ts.map +1 -0
- package/dist/summarizer/ai-summarizer.js +228 -0
- package/dist/summarizer/ai-summarizer.js.map +1 -0
- package/dist/summarizer/docstring-extractor.d.ts +9 -0
- package/dist/summarizer/docstring-extractor.d.ts.map +1 -0
- package/dist/summarizer/docstring-extractor.js +89 -0
- package/dist/summarizer/docstring-extractor.js.map +1 -0
- package/dist/summarizer/embeddings.d.ts +29 -0
- package/dist/summarizer/embeddings.d.ts.map +1 -0
- package/dist/summarizer/embeddings.js +133 -0
- package/dist/summarizer/embeddings.js.map +1 -0
- package/dist/summarizer/summarizer.d.ts +22 -0
- package/dist/summarizer/summarizer.d.ts.map +1 -0
- package/dist/summarizer/summarizer.js +86 -0
- package/dist/summarizer/summarizer.js.map +1 -0
- package/dist/ui/assets/BlastRadius-ccQ3ktbv.js +1 -0
- package/dist/ui/assets/DependencyGraph-BZV40eAE.css +1 -0
- package/dist/ui/assets/DependencyGraph-Ca84q89b.js +27 -0
- package/dist/ui/assets/NotFound-C1wVKP-6.js +1 -0
- package/dist/ui/assets/RepoDetail-B_8qid2Y.js +1 -0
- package/dist/ui/assets/RepoList-BuPu-ODM.js +1 -0
- package/dist/ui/assets/Search-BzZ9Og8E.js +1 -0
- package/dist/ui/assets/SymbolView-FdpKlzql.js +14 -0
- package/dist/ui/assets/client-BANW_tIp.js +1 -0
- package/dist/ui/assets/index-CnwwQi_S.js +61 -0
- package/dist/ui/assets/index-SS2IXr8I.css +1 -0
- package/dist/ui/assets/repoStore-SbGR6YI6.js +1 -0
- package/dist/ui/assets/useSearch-DHyve22h.js +1 -0
- package/dist/ui/index.html +13 -0
- package/dist/version.d.ts +2 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +2 -0
- package/dist/version.js.map +1 -0
- package/grammars/tree-sitter-c.wasm +0 -0
- package/grammars/tree-sitter-cpp.wasm +0 -0
- package/grammars/tree-sitter-csharp.wasm +0 -0
- package/grammars/tree-sitter-dart.wasm +0 -0
- package/grammars/tree-sitter-elixir.wasm +0 -0
- package/grammars/tree-sitter-go.wasm +0 -0
- package/grammars/tree-sitter-haskell.wasm +0 -0
- package/grammars/tree-sitter-java.wasm +0 -0
- package/grammars/tree-sitter-javascript.wasm +0 -0
- package/grammars/tree-sitter-kotlin.wasm +0 -0
- package/grammars/tree-sitter-lua.wasm +0 -0
- package/grammars/tree-sitter-php.wasm +0 -0
- package/grammars/tree-sitter-python.wasm +0 -0
- package/grammars/tree-sitter-r.wasm +0 -0
- package/grammars/tree-sitter-ruby.wasm +0 -0
- package/grammars/tree-sitter-rust.wasm +0 -0
- package/grammars/tree-sitter-scala.wasm +0 -0
- package/grammars/tree-sitter-swift.wasm +0 -0
- package/grammars/tree-sitter-tsx.wasm +0 -0
- package/grammars/tree-sitter-typescript.wasm +0 -0
- package/package.json +104 -0
- package/scripts/check-sqlite.js +41 -0
|
@@ -0,0 +1,364 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Pure TypeScript HNSW (Hierarchical Navigable Small World) index.
|
|
3
|
+
*
|
|
4
|
+
* Implements approximate nearest-neighbor search with O(log n) average-case
|
|
5
|
+
* complexity via a layered proximity graph.
|
|
6
|
+
*
|
|
7
|
+
* Reference: Malkov & Yashunin, 2018
|
|
8
|
+
* "Efficient and robust approximate nearest neighbor search using
|
|
9
|
+
* Hierarchical Navigable Small World graphs"
|
|
10
|
+
*
|
|
11
|
+
* Design notes:
|
|
12
|
+
* - No native addon or WASM dependency — works everywhere Node.js runs.
|
|
13
|
+
* - Cosine distance metric (L2-normalized input vectors recommended).
|
|
14
|
+
* - String IDs mapped to integer labels internally for graph adjacency lists.
|
|
15
|
+
* - Serializes to JSON for persistence (readable, portable).
|
|
16
|
+
*/
|
|
17
|
+
import { readFileSync, writeFileSync, mkdirSync } from 'fs';
|
|
18
|
+
import { dirname } from 'path';
|
|
19
|
+
import { PureContextError } from '../core/errors.js';
|
|
20
|
+
import { logger } from '../core/logger.js';
|
|
21
|
+
function heapPush(heap, entry) {
|
|
22
|
+
heap.push(entry);
|
|
23
|
+
let i = heap.length - 1;
|
|
24
|
+
while (i > 0) {
|
|
25
|
+
const parent = (i - 1) >> 1;
|
|
26
|
+
if (heap[parent].dist <= heap[i].dist)
|
|
27
|
+
break;
|
|
28
|
+
[heap[parent], heap[i]] = [heap[i], heap[parent]];
|
|
29
|
+
i = parent;
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
function heapPop(heap) {
|
|
33
|
+
const top = heap[0];
|
|
34
|
+
const last = heap.pop();
|
|
35
|
+
if (heap.length > 0) {
|
|
36
|
+
heap[0] = last;
|
|
37
|
+
let i = 0;
|
|
38
|
+
for (;;) {
|
|
39
|
+
const l = 2 * i + 1;
|
|
40
|
+
const r = 2 * i + 2;
|
|
41
|
+
let smallest = i;
|
|
42
|
+
if (l < heap.length && heap[l].dist < heap[smallest].dist)
|
|
43
|
+
smallest = l;
|
|
44
|
+
if (r < heap.length && heap[r].dist < heap[smallest].dist)
|
|
45
|
+
smallest = r;
|
|
46
|
+
if (smallest === i)
|
|
47
|
+
break;
|
|
48
|
+
[heap[i], heap[smallest]] = [heap[smallest], heap[i]];
|
|
49
|
+
i = smallest;
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
return top;
|
|
53
|
+
}
|
|
54
|
+
/** Max-heap: largest distance at top — used for the W (working set). */
|
|
55
|
+
function maxHeapPush(heap, entry) {
|
|
56
|
+
heap.push(entry);
|
|
57
|
+
let i = heap.length - 1;
|
|
58
|
+
while (i > 0) {
|
|
59
|
+
const parent = (i - 1) >> 1;
|
|
60
|
+
if (heap[parent].dist >= heap[i].dist)
|
|
61
|
+
break;
|
|
62
|
+
[heap[parent], heap[i]] = [heap[i], heap[parent]];
|
|
63
|
+
i = parent;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
function maxHeapPop(heap) {
|
|
67
|
+
const top = heap[0];
|
|
68
|
+
const last = heap.pop();
|
|
69
|
+
if (heap.length > 0) {
|
|
70
|
+
heap[0] = last;
|
|
71
|
+
let i = 0;
|
|
72
|
+
for (;;) {
|
|
73
|
+
const l = 2 * i + 1;
|
|
74
|
+
const r = 2 * i + 2;
|
|
75
|
+
let largest = i;
|
|
76
|
+
if (l < heap.length && heap[l].dist > heap[largest].dist)
|
|
77
|
+
largest = l;
|
|
78
|
+
if (r < heap.length && heap[r].dist > heap[largest].dist)
|
|
79
|
+
largest = r;
|
|
80
|
+
if (largest === i)
|
|
81
|
+
break;
|
|
82
|
+
[heap[i], heap[largest]] = [heap[largest], heap[i]];
|
|
83
|
+
i = largest;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
return top;
|
|
87
|
+
}
|
|
88
|
+
// ─── HNSWIndex ────────────────────────────────────────────────────────────────
|
|
89
|
+
/**
|
|
90
|
+
* HNSW approximate nearest-neighbor index.
|
|
91
|
+
*
|
|
92
|
+
* Usage:
|
|
93
|
+
* ```typescript
|
|
94
|
+
* const index = new HNSWIndex(1024, 100_000);
|
|
95
|
+
* index.add(['id1', 'id2'], [vec1, vec2]);
|
|
96
|
+
* const results = index.search(queryVec, 10);
|
|
97
|
+
* index.save('/path/to/hnsw.idx');
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
export class HNSWIndex {
|
|
101
|
+
dimension;
|
|
102
|
+
_maxElements;
|
|
103
|
+
M;
|
|
104
|
+
/** Max connections at layer 0: 2×M per the paper. */
|
|
105
|
+
Mmax0;
|
|
106
|
+
efConstruction;
|
|
107
|
+
efSearch;
|
|
108
|
+
nodes = [];
|
|
109
|
+
idToLabel = new Map();
|
|
110
|
+
deletedLabels = new Set();
|
|
111
|
+
entryPoint = null;
|
|
112
|
+
maxLayer = -1;
|
|
113
|
+
/** Reciprocal of ln(M) — used for random level generation. */
|
|
114
|
+
mL;
|
|
115
|
+
constructor(dimension, _maxElements, M = 16, efConstruction = 200, efSearch = 100) {
|
|
116
|
+
this.dimension = dimension;
|
|
117
|
+
this._maxElements = _maxElements;
|
|
118
|
+
this.M = M;
|
|
119
|
+
this.Mmax0 = 2 * M;
|
|
120
|
+
this.efConstruction = efConstruction;
|
|
121
|
+
this.efSearch = efSearch;
|
|
122
|
+
this.mL = 1 / Math.log(M);
|
|
123
|
+
}
|
|
124
|
+
// ─── Distance ──────────────────────────────────────────────────────────────
|
|
125
|
+
/**
|
|
126
|
+
* Cosine distance = 1 - cosine_similarity.
|
|
127
|
+
* For L2-normalized vectors, this equals the inner product distance.
|
|
128
|
+
* Range: [0, 2]. Identical vectors → 0. Opposite vectors → 2.
|
|
129
|
+
*/
|
|
130
|
+
dist(a, b) {
|
|
131
|
+
let dot = 0;
|
|
132
|
+
const len = a.length;
|
|
133
|
+
// Unrolled by 4 for minor speed gain
|
|
134
|
+
let i = 0;
|
|
135
|
+
for (; i + 3 < len; i += 4) {
|
|
136
|
+
dot += a[i] * b[i] + a[i + 1] * b[i + 1] + a[i + 2] * b[i + 2] + a[i + 3] * b[i + 3];
|
|
137
|
+
}
|
|
138
|
+
for (; i < len; i++)
|
|
139
|
+
dot += a[i] * b[i];
|
|
140
|
+
return 1 - dot;
|
|
141
|
+
}
|
|
142
|
+
// ─── Level generation ──────────────────────────────────────────────────────
|
|
143
|
+
/** Geometric distribution — same formula as the original HNSW paper. */
|
|
144
|
+
randomLevel() {
|
|
145
|
+
return Math.floor(-Math.log(Math.random() + Number.EPSILON) * this.mL);
|
|
146
|
+
}
|
|
147
|
+
// ─── Core search at a single layer ────────────────────────────────────────
|
|
148
|
+
/**
|
|
149
|
+
* Search layer `level` starting from `entryLabel`.
|
|
150
|
+
* Returns up to `ef` nearest labels, sorted nearest-first.
|
|
151
|
+
*/
|
|
152
|
+
searchLayer(query, entryLabel, ef, level) {
|
|
153
|
+
const visited = new Set([entryLabel]);
|
|
154
|
+
const entryDist = this.dist(query, this.nodes[entryLabel].vector);
|
|
155
|
+
// C: candidate min-heap (closest at top)
|
|
156
|
+
const C = [];
|
|
157
|
+
heapPush(C, { label: entryLabel, dist: entryDist });
|
|
158
|
+
// W: result max-heap — keeps ef nearest found so far (farthest at top for easy pruning)
|
|
159
|
+
const W = [];
|
|
160
|
+
maxHeapPush(W, { label: entryLabel, dist: entryDist });
|
|
161
|
+
while (C.length > 0) {
|
|
162
|
+
const c = heapPop(C);
|
|
163
|
+
// If closest candidate is farther than the farthest in W, we're done
|
|
164
|
+
if (W.length >= ef && c.dist > W[0].dist)
|
|
165
|
+
break;
|
|
166
|
+
const neighbors = this.nodes[c.label].neighbors[level] ?? [];
|
|
167
|
+
for (const n of neighbors) {
|
|
168
|
+
if (visited.has(n))
|
|
169
|
+
continue;
|
|
170
|
+
visited.add(n);
|
|
171
|
+
const nDist = this.dist(query, this.nodes[n].vector);
|
|
172
|
+
const farthestInW = W[0]?.dist ?? Infinity;
|
|
173
|
+
if (W.length < ef || nDist < farthestInW) {
|
|
174
|
+
heapPush(C, { label: n, dist: nDist });
|
|
175
|
+
maxHeapPush(W, { label: n, dist: nDist });
|
|
176
|
+
if (W.length > ef) {
|
|
177
|
+
maxHeapPop(W);
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
// Sort W nearest-first and return labels
|
|
183
|
+
return W
|
|
184
|
+
.sort((a, b) => a.dist - b.dist)
|
|
185
|
+
.map((e) => e.label);
|
|
186
|
+
}
|
|
187
|
+
// ─── Neighbor selection ────────────────────────────────────────────────────
|
|
188
|
+
/**
|
|
189
|
+
* Select M neighbors from sorted candidates (nearest-first).
|
|
190
|
+
* Simple heuristic: take the M closest.
|
|
191
|
+
*/
|
|
192
|
+
selectNeighbors(candidates, M) {
|
|
193
|
+
return candidates.slice(0, M);
|
|
194
|
+
}
|
|
195
|
+
// ─── Insertion ─────────────────────────────────────────────────────────────
|
|
196
|
+
insertOne(id, vector) {
|
|
197
|
+
if (this.idToLabel.has(id)) {
|
|
198
|
+
logger.debug('HNSWIndex: skipping already-indexed id', { id });
|
|
199
|
+
return;
|
|
200
|
+
}
|
|
201
|
+
const label = this.nodes.length;
|
|
202
|
+
const level = this.randomLevel();
|
|
203
|
+
const node = {
|
|
204
|
+
id,
|
|
205
|
+
vector,
|
|
206
|
+
neighbors: Array.from({ length: level + 1 }, () => []),
|
|
207
|
+
};
|
|
208
|
+
this.nodes.push(node);
|
|
209
|
+
this.idToLabel.set(id, label);
|
|
210
|
+
if (this.entryPoint === null) {
|
|
211
|
+
this.entryPoint = label;
|
|
212
|
+
this.maxLayer = level;
|
|
213
|
+
return;
|
|
214
|
+
}
|
|
215
|
+
let ep = this.entryPoint;
|
|
216
|
+
// Phase 1: greedy traversal from top layer to level+1 (ef=1)
|
|
217
|
+
for (let lc = this.maxLayer; lc > level; lc--) {
|
|
218
|
+
const results = this.searchLayer(vector, ep, 1, lc);
|
|
219
|
+
ep = results[0] ?? ep;
|
|
220
|
+
}
|
|
221
|
+
// Phase 2: search and connect from min(level, maxLayer) down to 0
|
|
222
|
+
for (let lc = Math.min(level, this.maxLayer); lc >= 0; lc--) {
|
|
223
|
+
const candidates = this.searchLayer(vector, ep, this.efConstruction, lc);
|
|
224
|
+
const Mmax = lc === 0 ? this.Mmax0 : this.M;
|
|
225
|
+
const newNeighbors = this.selectNeighbors(candidates, Mmax).filter((n) => n !== label);
|
|
226
|
+
node.neighbors[lc] = newNeighbors;
|
|
227
|
+
// Bidirectional connection + prune if needed
|
|
228
|
+
for (const n of newNeighbors) {
|
|
229
|
+
if (!this.nodes[n].neighbors[lc])
|
|
230
|
+
this.nodes[n].neighbors[lc] = [];
|
|
231
|
+
this.nodes[n].neighbors[lc].push(label);
|
|
232
|
+
if (this.nodes[n].neighbors[lc].length > Mmax) {
|
|
233
|
+
// Prune: keep Mmax closest to n
|
|
234
|
+
const nVec = this.nodes[n].vector;
|
|
235
|
+
this.nodes[n].neighbors[lc] = this.nodes[n].neighbors[lc]
|
|
236
|
+
.map((nb) => ({ nb, d: this.dist(nVec, this.nodes[nb].vector) }))
|
|
237
|
+
.sort((a, b) => a.d - b.d)
|
|
238
|
+
.slice(0, Mmax)
|
|
239
|
+
.map((x) => x.nb);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
ep = candidates[0] ?? ep;
|
|
243
|
+
}
|
|
244
|
+
if (level > this.maxLayer) {
|
|
245
|
+
this.maxLayer = level;
|
|
246
|
+
this.entryPoint = label;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
// ─── Public API ────────────────────────────────────────────────────────────
|
|
250
|
+
/**
|
|
251
|
+
* Insert vectors into the index.
|
|
252
|
+
* `ids` and `vectors` must be the same length.
|
|
253
|
+
*/
|
|
254
|
+
add(ids, vectors) {
|
|
255
|
+
if (ids.length !== vectors.length) {
|
|
256
|
+
throw new PureContextError(`HNSWIndex.add: ids.length (${ids.length}) !== vectors.length (${vectors.length})`);
|
|
257
|
+
}
|
|
258
|
+
for (let i = 0; i < ids.length; i++) {
|
|
259
|
+
this.insertOne(ids[i], vectors[i]);
|
|
260
|
+
}
|
|
261
|
+
logger.debug('HNSWIndex: added vectors', { count: ids.length, total: this.size() });
|
|
262
|
+
}
|
|
263
|
+
/**
|
|
264
|
+
* Search for the `k` nearest neighbors of `query`.
|
|
265
|
+
* Returns results sorted by ascending distance (nearest first).
|
|
266
|
+
* Deleted vectors are excluded from results.
|
|
267
|
+
*/
|
|
268
|
+
search(query, k) {
|
|
269
|
+
if (this.entryPoint === null || this.nodes.length === 0)
|
|
270
|
+
return [];
|
|
271
|
+
if (k <= 0)
|
|
272
|
+
return [];
|
|
273
|
+
let ep = this.entryPoint;
|
|
274
|
+
// Greedy descent to layer 1
|
|
275
|
+
for (let lc = this.maxLayer; lc > 0; lc--) {
|
|
276
|
+
const results = this.searchLayer(query, ep, 1, lc);
|
|
277
|
+
ep = results[0] ?? ep;
|
|
278
|
+
}
|
|
279
|
+
// Search at layer 0
|
|
280
|
+
const ef = Math.max(k, this.efSearch);
|
|
281
|
+
const candidates = this.searchLayer(query, ep, ef, 0);
|
|
282
|
+
const out = [];
|
|
283
|
+
for (const label of candidates) {
|
|
284
|
+
if (this.deletedLabels.has(label))
|
|
285
|
+
continue;
|
|
286
|
+
out.push({ id: this.nodes[label].id, distance: this.dist(query, this.nodes[label].vector) });
|
|
287
|
+
if (out.length >= k)
|
|
288
|
+
break;
|
|
289
|
+
}
|
|
290
|
+
return out;
|
|
291
|
+
}
|
|
292
|
+
/**
|
|
293
|
+
* Mark vectors as deleted. Deleted vectors are excluded from search results.
|
|
294
|
+
* Actual storage is reclaimed on `rebuild()`.
|
|
295
|
+
*/
|
|
296
|
+
remove(ids) {
|
|
297
|
+
for (const id of ids) {
|
|
298
|
+
const label = this.idToLabel.get(id);
|
|
299
|
+
if (label !== undefined) {
|
|
300
|
+
this.deletedLabels.add(label);
|
|
301
|
+
logger.debug('HNSWIndex: marked deleted', { id, label });
|
|
302
|
+
}
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
/** Number of live (non-deleted) vectors in the index. */
|
|
306
|
+
size() {
|
|
307
|
+
return this.nodes.length - this.deletedLabels.size;
|
|
308
|
+
}
|
|
309
|
+
/**
|
|
310
|
+
* Persist the index to disk as JSON.
|
|
311
|
+
* Path: typically `~/.purecontext/indexes/{repoId}/hnsw.idx`
|
|
312
|
+
*/
|
|
313
|
+
save(path) {
|
|
314
|
+
mkdirSync(dirname(path), { recursive: true });
|
|
315
|
+
const data = {
|
|
316
|
+
version: 1,
|
|
317
|
+
dimension: this.dimension,
|
|
318
|
+
M: this.M,
|
|
319
|
+
Mmax0: this.Mmax0,
|
|
320
|
+
efConstruction: this.efConstruction,
|
|
321
|
+
efSearch: this.efSearch,
|
|
322
|
+
entryPoint: this.entryPoint,
|
|
323
|
+
maxLayer: this.maxLayer,
|
|
324
|
+
deletedLabels: [...this.deletedLabels],
|
|
325
|
+
nodes: this.nodes.map((n) => ({
|
|
326
|
+
id: n.id,
|
|
327
|
+
vector: Array.from(n.vector),
|
|
328
|
+
neighbors: n.neighbors,
|
|
329
|
+
})),
|
|
330
|
+
};
|
|
331
|
+
writeFileSync(path, JSON.stringify(data), 'utf8');
|
|
332
|
+
logger.debug('HNSWIndex: saved to disk', { path, nodes: this.nodes.length });
|
|
333
|
+
}
|
|
334
|
+
/**
|
|
335
|
+
* Load a previously saved index from disk.
|
|
336
|
+
* Replaces all current state.
|
|
337
|
+
*/
|
|
338
|
+
load(path) {
|
|
339
|
+
const raw = readFileSync(path, 'utf8');
|
|
340
|
+
const data = JSON.parse(raw);
|
|
341
|
+
if (data.version !== 1) {
|
|
342
|
+
throw new PureContextError(`HNSWIndex: unsupported index version ${data.version}`);
|
|
343
|
+
}
|
|
344
|
+
if (data.dimension !== this.dimension) {
|
|
345
|
+
throw new PureContextError(`HNSWIndex: dimension mismatch — index has ${data.dimension}, this instance expects ${this.dimension}`);
|
|
346
|
+
}
|
|
347
|
+
this.entryPoint = data.entryPoint;
|
|
348
|
+
this.maxLayer = data.maxLayer;
|
|
349
|
+
this.deletedLabels.clear();
|
|
350
|
+
for (const l of data.deletedLabels)
|
|
351
|
+
this.deletedLabels.add(l);
|
|
352
|
+
this.nodes = data.nodes.map((n) => ({
|
|
353
|
+
id: n.id,
|
|
354
|
+
vector: new Float32Array(n.vector),
|
|
355
|
+
neighbors: n.neighbors,
|
|
356
|
+
}));
|
|
357
|
+
this.idToLabel.clear();
|
|
358
|
+
for (let label = 0; label < this.nodes.length; label++) {
|
|
359
|
+
this.idToLabel.set(this.nodes[label].id, label);
|
|
360
|
+
}
|
|
361
|
+
logger.debug('HNSWIndex: loaded from disk', { path, nodes: this.nodes.length });
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
//# sourceMappingURL=hnsw-index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hnsw-index.js","sourceRoot":"","sources":["../../src/semantic/hnsw-index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HybridSearcher — combines FTS5 keyword search with HNSW semantic search
|
|
3
|
+
* using Reciprocal Rank Fusion (RRF).
|
|
4
|
+
*
|
|
5
|
+
* Algorithm:
|
|
6
|
+
* 1. Run FTS5 → get top-N keyword-ranked symbols
|
|
7
|
+
* 2. Run semantic (HNSW) → get top-N vector-ranked symbols
|
|
8
|
+
* 3. Merge via RRF: score = kw_weight * 1/(k+kwRank) + sem_weight * 1/(k+semRank)
|
|
9
|
+
* 4. Sort descending by combined score; return top maxResults
|
|
10
|
+
*
|
|
11
|
+
* When no semantic index exists (VectorStore.size === 0), the searcher falls
|
|
12
|
+
* back to keyword-only mode silently.
|
|
13
|
+
*/
|
|
14
|
+
import type Database from 'better-sqlite3';
|
|
15
|
+
import type { SymbolRecord } from '../core/types.js';
|
|
16
|
+
import type { VectorStore } from './vector-store.js';
|
|
17
|
+
export interface SearchOptions {
|
|
18
|
+
/** Maximum results to return (default: 10). */
|
|
19
|
+
maxResults?: number;
|
|
20
|
+
/** Weight given to keyword rank in RRF (default: 0.5). */
|
|
21
|
+
keywordWeight?: number;
|
|
22
|
+
/** Weight given to semantic rank in RRF (default: 0.5). */
|
|
23
|
+
semanticWeight?: number;
|
|
24
|
+
/** Minimum combined RRF score to include in results (default: 0). */
|
|
25
|
+
threshold?: number;
|
|
26
|
+
/** Filter by symbol kind. */
|
|
27
|
+
kind?: string;
|
|
28
|
+
/** Filter by file path prefix. */
|
|
29
|
+
filePattern?: string;
|
|
30
|
+
/** Use query expansion to improve recall (default: true). */
|
|
31
|
+
expandQuery?: boolean;
|
|
32
|
+
}
|
|
33
|
+
export interface HybridSearchResult {
|
|
34
|
+
symbol: SymbolRecord;
|
|
35
|
+
keywordScore: number;
|
|
36
|
+
semanticScore: number;
|
|
37
|
+
combinedScore: number;
|
|
38
|
+
}
|
|
39
|
+
export declare class HybridSearcher {
|
|
40
|
+
private readonly repoId;
|
|
41
|
+
private readonly vectorStore;
|
|
42
|
+
private readonly db;
|
|
43
|
+
constructor(repoId: string, vectorStore: VectorStore, db: Database.Database);
|
|
44
|
+
search(query: string, options?: SearchOptions): Promise<HybridSearchResult[]>;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=hybrid-search.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hybrid-search.d.ts","sourceRoot":"","sources":["../../src/semantic/hybrid-search.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAE3C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAErD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAKrD,MAAM,WAAW,aAAa;IAC5B,+CAA+C;IAC/C,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,0DAA0D;IAC1D,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,2DAA2D;IAC3D,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,qEAAqE;IACrE,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,6BAA6B;IAC7B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,6DAA6D;IAC7D,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,YAAY,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;CACvB;AASD,qBAAa,cAAc;IACzB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAS;IAChC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAc;IAC1C,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAoB;gBAE3B,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,WAAW,EAAE,EAAE,EAAE,QAAQ,CAAC,QAAQ;IAQrE,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,GAAE,aAAkB,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;CAmHxF"}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HybridSearcher — combines FTS5 keyword search with HNSW semantic search
|
|
3
|
+
* using Reciprocal Rank Fusion (RRF).
|
|
4
|
+
*
|
|
5
|
+
* Algorithm:
|
|
6
|
+
* 1. Run FTS5 → get top-N keyword-ranked symbols
|
|
7
|
+
* 2. Run semantic (HNSW) → get top-N vector-ranked symbols
|
|
8
|
+
* 3. Merge via RRF: score = kw_weight * 1/(k+kwRank) + sem_weight * 1/(k+semRank)
|
|
9
|
+
* 4. Sort descending by combined score; return top maxResults
|
|
10
|
+
*
|
|
11
|
+
* When no semantic index exists (VectorStore.size === 0), the searcher falls
|
|
12
|
+
* back to keyword-only mode silently.
|
|
13
|
+
*/
|
|
14
|
+
import { ftsSearchSymbols } from '../core/db/symbol-store.js';
|
|
15
|
+
import { logger } from '../core/logger.js';
|
|
16
|
+
import { expandQuery } from './query-expansion.js';
|
|
17
|
+
// ─── RRF constant ─────────────────────────────────────────────────────────────
|
|
18
|
+
/** Standard RRF k constant — smoothes rank differences. */
|
|
19
|
+
const RRF_K = 60;
|
|
20
|
+
// ─── HybridSearcher ───────────────────────────────────────────────────────────
|
|
21
|
+
export class HybridSearcher {
|
|
22
|
+
repoId;
|
|
23
|
+
vectorStore;
|
|
24
|
+
db;
|
|
25
|
+
constructor(repoId, vectorStore, db) {
|
|
26
|
+
this.repoId = repoId;
|
|
27
|
+
this.vectorStore = vectorStore;
|
|
28
|
+
this.db = db;
|
|
29
|
+
}
|
|
30
|
+
// ─── Public API ────────────────────────────────────────────────────────────
|
|
31
|
+
async search(query, options = {}) {
|
|
32
|
+
const { maxResults = 10, keywordWeight = 0.5, semanticWeight = 0.5, threshold = 0, kind, filePattern, expandQuery: doExpand = true, } = options;
|
|
33
|
+
const hasSemanticIndex = this.vectorStore.size > 0;
|
|
34
|
+
// Determine effective mode
|
|
35
|
+
const useKeyword = keywordWeight > 0;
|
|
36
|
+
const useSemantic = semanticWeight > 0 && hasSemanticIndex;
|
|
37
|
+
const candidateCount = Math.max(maxResults * 4, 40); // over-fetch for merging
|
|
38
|
+
// ── Step 1: FTS keyword search ────────────────────────────────────────────
|
|
39
|
+
const keywordResults = [];
|
|
40
|
+
if (useKeyword) {
|
|
41
|
+
const ftsQuery = buildFtsQuery(query);
|
|
42
|
+
try {
|
|
43
|
+
const rows = ftsSearchSymbols(this.db, this.repoId, ftsQuery, { limit: candidateCount });
|
|
44
|
+
keywordResults.push(...rows);
|
|
45
|
+
}
|
|
46
|
+
catch {
|
|
47
|
+
// FTS query can fail on special characters — fall back to empty
|
|
48
|
+
logger.debug('HybridSearcher: FTS query failed, continuing without keyword results', { query });
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
// ── Step 2: Semantic vector search ────────────────────────────────────────
|
|
52
|
+
const semanticIdsByRank = [];
|
|
53
|
+
if (useSemantic) {
|
|
54
|
+
const queries = doExpand ? expandQuery(query) : [query];
|
|
55
|
+
// Collect semantic hits across all query variations; de-dup by ID, preserve first rank
|
|
56
|
+
const seenSemantic = new Set();
|
|
57
|
+
for (const q of queries) {
|
|
58
|
+
const hits = await this.vectorStore.searchSimilar(q, candidateCount);
|
|
59
|
+
for (const hit of hits) {
|
|
60
|
+
if (!seenSemantic.has(hit.id)) {
|
|
61
|
+
seenSemantic.add(hit.id);
|
|
62
|
+
semanticIdsByRank.push(hit.id);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
if (semanticIdsByRank.length >= candidateCount)
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
// ── Step 3: Build ranked maps ─────────────────────────────────────────────
|
|
70
|
+
const kwRankOf = new Map(); // symbolId → 1-based rank
|
|
71
|
+
for (let i = 0; i < keywordResults.length; i++) {
|
|
72
|
+
kwRankOf.set(keywordResults[i].id, i + 1);
|
|
73
|
+
}
|
|
74
|
+
const semRankOf = new Map(); // symbolId → 1-based rank
|
|
75
|
+
for (let i = 0; i < semanticIdsByRank.length; i++) {
|
|
76
|
+
semRankOf.set(semanticIdsByRank[i], i + 1);
|
|
77
|
+
}
|
|
78
|
+
// ── Step 4: Collect all candidate symbol IDs ──────────────────────────────
|
|
79
|
+
const allIds = new Set([
|
|
80
|
+
...keywordResults.map((s) => s.id),
|
|
81
|
+
...semanticIdsByRank,
|
|
82
|
+
]);
|
|
83
|
+
// ── Step 5: Build symbol map (keyword results already fetched; semantic IDs
|
|
84
|
+
// need lookup from DB for symbols not in keyword results) ────────
|
|
85
|
+
const symbolById = new Map();
|
|
86
|
+
for (const sym of keywordResults) {
|
|
87
|
+
symbolById.set(sym.id, sym);
|
|
88
|
+
}
|
|
89
|
+
// Fetch semantic-only symbols from DB in one query
|
|
90
|
+
const missingIds = [...allIds].filter((id) => !symbolById.has(id));
|
|
91
|
+
if (missingIds.length > 0) {
|
|
92
|
+
const fetched = fetchSymbolsByIds(this.db, this.repoId, missingIds);
|
|
93
|
+
for (const sym of fetched) {
|
|
94
|
+
symbolById.set(sym.id, sym);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
// ── Step 6: RRF scoring ───────────────────────────────────────────────────
|
|
98
|
+
const scored = [];
|
|
99
|
+
for (const id of allIds) {
|
|
100
|
+
const symbol = symbolById.get(id);
|
|
101
|
+
if (!symbol)
|
|
102
|
+
continue;
|
|
103
|
+
// Apply filters
|
|
104
|
+
if (kind && symbol.kind !== kind)
|
|
105
|
+
continue;
|
|
106
|
+
if (filePattern && !symbol.filePath.includes(filePattern))
|
|
107
|
+
continue;
|
|
108
|
+
const kwRank = kwRankOf.get(id);
|
|
109
|
+
const semRank = semRankOf.get(id);
|
|
110
|
+
const keywordScore = kwRank !== undefined && useKeyword
|
|
111
|
+
? keywordWeight * (1 / (RRF_K + kwRank))
|
|
112
|
+
: 0;
|
|
113
|
+
const semanticScore = semRank !== undefined && useSemantic
|
|
114
|
+
? semanticWeight * (1 / (RRF_K + semRank))
|
|
115
|
+
: 0;
|
|
116
|
+
const combinedScore = keywordScore + semanticScore;
|
|
117
|
+
if (combinedScore < threshold)
|
|
118
|
+
continue;
|
|
119
|
+
scored.push({ symbol, keywordScore, semanticScore, combinedScore });
|
|
120
|
+
}
|
|
121
|
+
// ── Step 7: Sort and return ───────────────────────────────────────────────
|
|
122
|
+
scored.sort((a, b) => b.combinedScore - a.combinedScore);
|
|
123
|
+
return scored.slice(0, maxResults);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
// ─── Helpers ──────────────────────────────────────────────────────────────────
|
|
127
|
+
/**
|
|
128
|
+
* Convert a plain search query to a safe FTS5 query string.
|
|
129
|
+
* Wraps terms in quotes to handle special characters; falls back to
|
|
130
|
+
* prefix matching for single words.
|
|
131
|
+
*/
|
|
132
|
+
function buildFtsQuery(query) {
|
|
133
|
+
const words = query.trim().split(/\s+/).filter(Boolean);
|
|
134
|
+
if (words.length === 0)
|
|
135
|
+
return '""';
|
|
136
|
+
// Use prefix matching on each token: `auth*`
|
|
137
|
+
return words.map((w) => `"${w.replace(/"/g, '""')}"*`).join(' ');
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* Bulk-fetch SymbolRecords by ID for a given repo.
|
|
141
|
+
* Uses a single SQL query with placeholders.
|
|
142
|
+
*/
|
|
143
|
+
function fetchSymbolsByIds(db, repoId, ids) {
|
|
144
|
+
if (ids.length === 0)
|
|
145
|
+
return [];
|
|
146
|
+
const placeholders = ids.map(() => '?').join(',');
|
|
147
|
+
const rows = db
|
|
148
|
+
.prepare(`SELECT * FROM symbols WHERE repo_id = ? AND id IN (${placeholders})`)
|
|
149
|
+
.all(repoId, ...ids);
|
|
150
|
+
return rows.map((r) => ({
|
|
151
|
+
id: r.id,
|
|
152
|
+
name: r.name,
|
|
153
|
+
kind: r.kind,
|
|
154
|
+
filePath: r.file_path,
|
|
155
|
+
startByte: r.start_byte,
|
|
156
|
+
endByte: r.end_byte,
|
|
157
|
+
signature: r.signature,
|
|
158
|
+
summary: r.summary,
|
|
159
|
+
frameworkMeta: r.framework_meta
|
|
160
|
+
? JSON.parse(r.framework_meta)
|
|
161
|
+
: undefined,
|
|
162
|
+
}));
|
|
163
|
+
}
|
|
164
|
+
//# sourceMappingURL=hybrid-search.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hybrid-search.js","sourceRoot":"","sources":["../../src/semantic/hybrid-search.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Query expansion — generates lightweight variations of a search query to
|
|
3
|
+
* improve recall without requiring API calls.
|
|
4
|
+
*
|
|
5
|
+
* Techniques:
|
|
6
|
+
* - Abbreviation expansion: "auth" → ["authentication", "authorization"]
|
|
7
|
+
* - Camel/snake splitting: "getUserById" → ["get", "user", "by", "id"]
|
|
8
|
+
* - Common synonym expansion for programming terms
|
|
9
|
+
*/
|
|
10
|
+
/**
|
|
11
|
+
* Generate query variations for better semantic search coverage.
|
|
12
|
+
*
|
|
13
|
+
* The returned array always includes the original query as the first element.
|
|
14
|
+
* Duplicates are removed. The result is limited to 8 variations to keep
|
|
15
|
+
* embedding costs bounded.
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* expandQuery('auth')
|
|
19
|
+
* // → ['auth', 'authentication', 'authorization', 'authenticate', 'authorize']
|
|
20
|
+
*
|
|
21
|
+
* expandQuery('getUserById')
|
|
22
|
+
* // → ['getUserById', 'get user by id', 'getuser', 'by', 'id']
|
|
23
|
+
*/
|
|
24
|
+
export declare function expandQuery(query: string): string[];
|
|
25
|
+
//# sourceMappingURL=query-expansion.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"query-expansion.d.ts","sourceRoot":"","sources":["../../src/semantic/query-expansion.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAkGH;;;;;;;;;;;;;GAaG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,EAAE,CA2CnD"}
|