agentic-qe 2.5.9 → 2.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (336) hide show
  1. package/.claude/agents/qe-code-intelligence.md +359 -0
  2. package/CHANGELOG.md +136 -0
  3. package/README.md +4 -3
  4. package/dist/agents/BaseAgent.d.ts +167 -0
  5. package/dist/agents/BaseAgent.d.ts.map +1 -1
  6. package/dist/agents/BaseAgent.js +414 -0
  7. package/dist/agents/BaseAgent.js.map +1 -1
  8. package/dist/agents/CodeIntelligenceAgent.d.ts +133 -0
  9. package/dist/agents/CodeIntelligenceAgent.d.ts.map +1 -0
  10. package/dist/agents/CodeIntelligenceAgent.js +473 -0
  11. package/dist/agents/CodeIntelligenceAgent.js.map +1 -0
  12. package/dist/agents/FlakyTestHunterAgent.d.ts +15 -0
  13. package/dist/agents/FlakyTestHunterAgent.d.ts.map +1 -1
  14. package/dist/agents/FlakyTestHunterAgent.js +93 -0
  15. package/dist/agents/FlakyTestHunterAgent.js.map +1 -1
  16. package/dist/agents/SecurityScannerAgent.d.ts +19 -0
  17. package/dist/agents/SecurityScannerAgent.d.ts.map +1 -1
  18. package/dist/agents/SecurityScannerAgent.js +137 -0
  19. package/dist/agents/SecurityScannerAgent.js.map +1 -1
  20. package/dist/agents/context/ContextCache.d.ts +105 -0
  21. package/dist/agents/context/ContextCache.d.ts.map +1 -0
  22. package/dist/agents/context/ContextCache.js +235 -0
  23. package/dist/agents/context/ContextCache.js.map +1 -0
  24. package/dist/agents/context/ContextFormatter.d.ts +92 -0
  25. package/dist/agents/context/ContextFormatter.d.ts.map +1 -0
  26. package/dist/agents/context/ContextFormatter.js +338 -0
  27. package/dist/agents/context/ContextFormatter.js.map +1 -0
  28. package/dist/agents/context/GraphExpander.d.ts +87 -0
  29. package/dist/agents/context/GraphExpander.d.ts.map +1 -0
  30. package/dist/agents/context/GraphExpander.js +215 -0
  31. package/dist/agents/context/GraphExpander.js.map +1 -0
  32. package/dist/agents/context/KnowledgeGraphContextBuilder.d.ts +160 -0
  33. package/dist/agents/context/KnowledgeGraphContextBuilder.d.ts.map +1 -0
  34. package/dist/agents/context/KnowledgeGraphContextBuilder.js +300 -0
  35. package/dist/agents/context/KnowledgeGraphContextBuilder.js.map +1 -0
  36. package/dist/agents/context/index.d.ts +15 -0
  37. package/dist/agents/context/index.d.ts.map +1 -0
  38. package/dist/agents/context/index.js +18 -0
  39. package/dist/agents/context/index.js.map +1 -0
  40. package/dist/agents/index.d.ts +1 -0
  41. package/dist/agents/index.d.ts.map +1 -1
  42. package/dist/agents/index.js +67 -3
  43. package/dist/agents/index.js.map +1 -1
  44. package/dist/cli/commands/knowledge-graph.d.ts +112 -0
  45. package/dist/cli/commands/knowledge-graph.d.ts.map +1 -0
  46. package/dist/cli/commands/knowledge-graph.js +466 -0
  47. package/dist/cli/commands/knowledge-graph.js.map +1 -0
  48. package/dist/cli/commands/ruvector/index.d.ts +13 -0
  49. package/dist/cli/commands/ruvector/index.d.ts.map +1 -0
  50. package/dist/cli/commands/ruvector/index.js +308 -0
  51. package/dist/cli/commands/ruvector/index.js.map +1 -0
  52. package/dist/cli/formatters/KGOutputFormatter.d.ts +50 -0
  53. package/dist/cli/formatters/KGOutputFormatter.d.ts.map +1 -0
  54. package/dist/cli/formatters/KGOutputFormatter.js +237 -0
  55. package/dist/cli/formatters/KGOutputFormatter.js.map +1 -0
  56. package/dist/cli/index-working.js +138 -0
  57. package/dist/cli/index-working.js.map +1 -1
  58. package/dist/cli/index.js +5 -0
  59. package/dist/cli/index.js.map +1 -1
  60. package/dist/cli/init/claude-config.d.ts +13 -1
  61. package/dist/cli/init/claude-config.d.ts.map +1 -1
  62. package/dist/cli/init/claude-config.js +70 -8
  63. package/dist/cli/init/claude-config.js.map +1 -1
  64. package/dist/cli/init/code-intelligence-init.d.ts +52 -0
  65. package/dist/cli/init/code-intelligence-init.d.ts.map +1 -0
  66. package/dist/cli/init/code-intelligence-init.js +250 -0
  67. package/dist/cli/init/code-intelligence-init.js.map +1 -0
  68. package/dist/cli/init/index.d.ts +2 -2
  69. package/dist/cli/init/index.d.ts.map +1 -1
  70. package/dist/cli/init/index.js +21 -1
  71. package/dist/cli/init/index.js.map +1 -1
  72. package/dist/code-intelligence/chunking/ASTChunker.d.ts +64 -0
  73. package/dist/code-intelligence/chunking/ASTChunker.d.ts.map +1 -0
  74. package/dist/code-intelligence/chunking/ASTChunker.js +344 -0
  75. package/dist/code-intelligence/chunking/ASTChunker.js.map +1 -0
  76. package/dist/code-intelligence/chunking/ChunkSplitter.d.ts +48 -0
  77. package/dist/code-intelligence/chunking/ChunkSplitter.d.ts.map +1 -0
  78. package/dist/code-intelligence/chunking/ChunkSplitter.js +278 -0
  79. package/dist/code-intelligence/chunking/ChunkSplitter.js.map +1 -0
  80. package/dist/code-intelligence/chunking/index.d.ts +8 -0
  81. package/dist/code-intelligence/chunking/index.d.ts.map +1 -0
  82. package/dist/code-intelligence/chunking/index.js +13 -0
  83. package/dist/code-intelligence/chunking/index.js.map +1 -0
  84. package/dist/code-intelligence/chunking/types.d.ts +52 -0
  85. package/dist/code-intelligence/chunking/types.d.ts.map +1 -0
  86. package/dist/code-intelligence/chunking/types.js +6 -0
  87. package/dist/code-intelligence/chunking/types.js.map +1 -0
  88. package/dist/code-intelligence/config/database-schema.d.ts +245 -0
  89. package/dist/code-intelligence/config/database-schema.d.ts.map +1 -0
  90. package/dist/code-intelligence/config/database-schema.js +110 -0
  91. package/dist/code-intelligence/config/database-schema.js.map +1 -0
  92. package/dist/code-intelligence/config/environment.d.ts +53 -0
  93. package/dist/code-intelligence/config/environment.d.ts.map +1 -0
  94. package/dist/code-intelligence/config/environment.js +86 -0
  95. package/dist/code-intelligence/config/environment.js.map +1 -0
  96. package/dist/code-intelligence/config/index.d.ts +10 -0
  97. package/dist/code-intelligence/config/index.d.ts.map +1 -0
  98. package/dist/code-intelligence/config/index.js +36 -0
  99. package/dist/code-intelligence/config/index.js.map +1 -0
  100. package/dist/code-intelligence/embeddings/EmbeddingCache.d.ts +81 -0
  101. package/dist/code-intelligence/embeddings/EmbeddingCache.d.ts.map +1 -0
  102. package/dist/code-intelligence/embeddings/EmbeddingCache.js +168 -0
  103. package/dist/code-intelligence/embeddings/EmbeddingCache.js.map +1 -0
  104. package/dist/code-intelligence/embeddings/NomicEmbedder.d.ts +82 -0
  105. package/dist/code-intelligence/embeddings/NomicEmbedder.d.ts.map +1 -0
  106. package/dist/code-intelligence/embeddings/NomicEmbedder.js +233 -0
  107. package/dist/code-intelligence/embeddings/NomicEmbedder.js.map +1 -0
  108. package/dist/code-intelligence/embeddings/OllamaClient.d.ts +42 -0
  109. package/dist/code-intelligence/embeddings/OllamaClient.d.ts.map +1 -0
  110. package/dist/code-intelligence/embeddings/OllamaClient.js +142 -0
  111. package/dist/code-intelligence/embeddings/OllamaClient.js.map +1 -0
  112. package/dist/code-intelligence/embeddings/index.d.ts +33 -0
  113. package/dist/code-intelligence/embeddings/index.d.ts.map +1 -0
  114. package/dist/code-intelligence/embeddings/index.js +39 -0
  115. package/dist/code-intelligence/embeddings/index.js.map +1 -0
  116. package/dist/code-intelligence/embeddings/types.d.ts +84 -0
  117. package/dist/code-intelligence/embeddings/types.d.ts.map +1 -0
  118. package/dist/code-intelligence/embeddings/types.js +19 -0
  119. package/dist/code-intelligence/embeddings/types.js.map +1 -0
  120. package/dist/code-intelligence/graph/GraphBuilder.d.ts +126 -0
  121. package/dist/code-intelligence/graph/GraphBuilder.d.ts.map +1 -0
  122. package/dist/code-intelligence/graph/GraphBuilder.js +416 -0
  123. package/dist/code-intelligence/graph/GraphBuilder.js.map +1 -0
  124. package/dist/code-intelligence/graph/ImportParser.d.ts +72 -0
  125. package/dist/code-intelligence/graph/ImportParser.d.ts.map +1 -0
  126. package/dist/code-intelligence/graph/ImportParser.js +422 -0
  127. package/dist/code-intelligence/graph/ImportParser.js.map +1 -0
  128. package/dist/code-intelligence/graph/RelationshipExtractor.d.ts +74 -0
  129. package/dist/code-intelligence/graph/RelationshipExtractor.d.ts.map +1 -0
  130. package/dist/code-intelligence/graph/RelationshipExtractor.js +310 -0
  131. package/dist/code-intelligence/graph/RelationshipExtractor.js.map +1 -0
  132. package/dist/code-intelligence/graph/TestMapper.d.ts +99 -0
  133. package/dist/code-intelligence/graph/TestMapper.d.ts.map +1 -0
  134. package/dist/code-intelligence/graph/TestMapper.js +335 -0
  135. package/dist/code-intelligence/graph/TestMapper.js.map +1 -0
  136. package/dist/code-intelligence/graph/index.d.ts +14 -0
  137. package/dist/code-intelligence/graph/index.d.ts.map +1 -0
  138. package/dist/code-intelligence/graph/index.js +19 -0
  139. package/dist/code-intelligence/graph/index.js.map +1 -0
  140. package/dist/code-intelligence/graph/types.d.ts +141 -0
  141. package/dist/code-intelligence/graph/types.d.ts.map +1 -0
  142. package/dist/code-intelligence/graph/types.js +18 -0
  143. package/dist/code-intelligence/graph/types.js.map +1 -0
  144. package/dist/code-intelligence/indexing/FileWatcher.d.ts +90 -0
  145. package/dist/code-intelligence/indexing/FileWatcher.d.ts.map +1 -0
  146. package/dist/code-intelligence/indexing/FileWatcher.js +304 -0
  147. package/dist/code-intelligence/indexing/FileWatcher.js.map +1 -0
  148. package/dist/code-intelligence/indexing/GitChangeDetector.d.ts +76 -0
  149. package/dist/code-intelligence/indexing/GitChangeDetector.d.ts.map +1 -0
  150. package/dist/code-intelligence/indexing/GitChangeDetector.js +347 -0
  151. package/dist/code-intelligence/indexing/GitChangeDetector.js.map +1 -0
  152. package/dist/code-intelligence/indexing/IncrementalIndexer.d.ts +108 -0
  153. package/dist/code-intelligence/indexing/IncrementalIndexer.d.ts.map +1 -0
  154. package/dist/code-intelligence/indexing/IncrementalIndexer.js +269 -0
  155. package/dist/code-intelligence/indexing/IncrementalIndexer.js.map +1 -0
  156. package/dist/code-intelligence/indexing/index.d.ts +11 -0
  157. package/dist/code-intelligence/indexing/index.d.ts.map +1 -0
  158. package/dist/code-intelligence/indexing/index.js +18 -0
  159. package/dist/code-intelligence/indexing/index.js.map +1 -0
  160. package/dist/code-intelligence/indexing/types.d.ts +133 -0
  161. package/dist/code-intelligence/indexing/types.d.ts.map +1 -0
  162. package/dist/code-intelligence/indexing/types.js +27 -0
  163. package/dist/code-intelligence/indexing/types.js.map +1 -0
  164. package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.d.ts +150 -0
  165. package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.d.ts.map +1 -0
  166. package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.js +806 -0
  167. package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.js.map +1 -0
  168. package/dist/code-intelligence/orchestrator/index.d.ts +8 -0
  169. package/dist/code-intelligence/orchestrator/index.d.ts.map +1 -0
  170. package/dist/code-intelligence/orchestrator/index.js +24 -0
  171. package/dist/code-intelligence/orchestrator/index.js.map +1 -0
  172. package/dist/code-intelligence/orchestrator/types.d.ts +164 -0
  173. package/dist/code-intelligence/orchestrator/types.d.ts.map +1 -0
  174. package/dist/code-intelligence/orchestrator/types.js +18 -0
  175. package/dist/code-intelligence/orchestrator/types.js.map +1 -0
  176. package/dist/code-intelligence/parser/LanguageRegistry.d.ts +13 -0
  177. package/dist/code-intelligence/parser/LanguageRegistry.d.ts.map +1 -0
  178. package/dist/code-intelligence/parser/LanguageRegistry.js +150 -0
  179. package/dist/code-intelligence/parser/LanguageRegistry.js.map +1 -0
  180. package/dist/code-intelligence/parser/TreeSitterParser.d.ts +98 -0
  181. package/dist/code-intelligence/parser/TreeSitterParser.d.ts.map +1 -0
  182. package/dist/code-intelligence/parser/TreeSitterParser.js +530 -0
  183. package/dist/code-intelligence/parser/TreeSitterParser.js.map +1 -0
  184. package/dist/code-intelligence/parser/extractors/BaseExtractor.d.ts +36 -0
  185. package/dist/code-intelligence/parser/extractors/BaseExtractor.d.ts.map +1 -0
  186. package/dist/code-intelligence/parser/extractors/BaseExtractor.js +31 -0
  187. package/dist/code-intelligence/parser/extractors/BaseExtractor.js.map +1 -0
  188. package/dist/code-intelligence/parser/extractors/GoExtractor.d.ts +21 -0
  189. package/dist/code-intelligence/parser/extractors/GoExtractor.d.ts.map +1 -0
  190. package/dist/code-intelligence/parser/extractors/GoExtractor.js +249 -0
  191. package/dist/code-intelligence/parser/extractors/GoExtractor.js.map +1 -0
  192. package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.d.ts +21 -0
  193. package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.d.ts.map +1 -0
  194. package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.js +217 -0
  195. package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.js.map +1 -0
  196. package/dist/code-intelligence/parser/extractors/PythonExtractor.d.ts +20 -0
  197. package/dist/code-intelligence/parser/extractors/PythonExtractor.d.ts.map +1 -0
  198. package/dist/code-intelligence/parser/extractors/PythonExtractor.js +237 -0
  199. package/dist/code-intelligence/parser/extractors/PythonExtractor.js.map +1 -0
  200. package/dist/code-intelligence/parser/extractors/RustExtractor.d.ts +21 -0
  201. package/dist/code-intelligence/parser/extractors/RustExtractor.d.ts.map +1 -0
  202. package/dist/code-intelligence/parser/extractors/RustExtractor.js +234 -0
  203. package/dist/code-intelligence/parser/extractors/RustExtractor.js.map +1 -0
  204. package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.d.ts +23 -0
  205. package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.d.ts.map +1 -0
  206. package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.js +247 -0
  207. package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.js.map +1 -0
  208. package/dist/code-intelligence/parser/extractors/index.d.ts +7 -0
  209. package/dist/code-intelligence/parser/extractors/index.d.ts.map +1 -0
  210. package/dist/code-intelligence/parser/extractors/index.js +16 -0
  211. package/dist/code-intelligence/parser/extractors/index.js.map +1 -0
  212. package/dist/code-intelligence/parser/index.d.ts +8 -0
  213. package/dist/code-intelligence/parser/index.d.ts.map +1 -0
  214. package/dist/code-intelligence/parser/index.js +12 -0
  215. package/dist/code-intelligence/parser/index.js.map +1 -0
  216. package/dist/code-intelligence/parser/types.d.ts +60 -0
  217. package/dist/code-intelligence/parser/types.d.ts.map +1 -0
  218. package/dist/code-intelligence/parser/types.js +6 -0
  219. package/dist/code-intelligence/parser/types.js.map +1 -0
  220. package/dist/code-intelligence/rag/ContextBuilder.d.ts +82 -0
  221. package/dist/code-intelligence/rag/ContextBuilder.d.ts.map +1 -0
  222. package/dist/code-intelligence/rag/ContextBuilder.js +242 -0
  223. package/dist/code-intelligence/rag/ContextBuilder.js.map +1 -0
  224. package/dist/code-intelligence/rag/GraphExpander.d.ts +95 -0
  225. package/dist/code-intelligence/rag/GraphExpander.d.ts.map +1 -0
  226. package/dist/code-intelligence/rag/GraphExpander.js +250 -0
  227. package/dist/code-intelligence/rag/GraphExpander.js.map +1 -0
  228. package/dist/code-intelligence/rag/index.d.ts +9 -0
  229. package/dist/code-intelligence/rag/index.d.ts.map +1 -0
  230. package/dist/code-intelligence/rag/index.js +25 -0
  231. package/dist/code-intelligence/rag/index.js.map +1 -0
  232. package/dist/code-intelligence/rag/types.d.ts +121 -0
  233. package/dist/code-intelligence/rag/types.d.ts.map +1 -0
  234. package/dist/code-intelligence/rag/types.js +50 -0
  235. package/dist/code-intelligence/rag/types.js.map +1 -0
  236. package/dist/code-intelligence/retrieval/SemanticRetriever.d.ts +62 -0
  237. package/dist/code-intelligence/retrieval/SemanticRetriever.d.ts.map +1 -0
  238. package/dist/code-intelligence/retrieval/SemanticRetriever.js +174 -0
  239. package/dist/code-intelligence/retrieval/SemanticRetriever.js.map +1 -0
  240. package/dist/code-intelligence/retrieval/index.d.ts +9 -0
  241. package/dist/code-intelligence/retrieval/index.d.ts.map +1 -0
  242. package/dist/code-intelligence/retrieval/index.js +16 -0
  243. package/dist/code-intelligence/retrieval/index.js.map +1 -0
  244. package/dist/code-intelligence/retrieval/types.d.ts +118 -0
  245. package/dist/code-intelligence/retrieval/types.d.ts.map +1 -0
  246. package/dist/code-intelligence/retrieval/types.js +46 -0
  247. package/dist/code-intelligence/retrieval/types.js.map +1 -0
  248. package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.d.ts +167 -0
  249. package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.d.ts.map +1 -0
  250. package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.js +365 -0
  251. package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.js.map +1 -0
  252. package/dist/code-intelligence/router/index.d.ts +7 -0
  253. package/dist/code-intelligence/router/index.d.ts.map +1 -0
  254. package/dist/code-intelligence/router/index.js +14 -0
  255. package/dist/code-intelligence/router/index.js.map +1 -0
  256. package/dist/code-intelligence/search/BM25Search.d.ts +74 -0
  257. package/dist/code-intelligence/search/BM25Search.d.ts.map +1 -0
  258. package/dist/code-intelligence/search/BM25Search.js +233 -0
  259. package/dist/code-intelligence/search/BM25Search.js.map +1 -0
  260. package/dist/code-intelligence/search/HybridSearchEngine.d.ts +94 -0
  261. package/dist/code-intelligence/search/HybridSearchEngine.d.ts.map +1 -0
  262. package/dist/code-intelligence/search/HybridSearchEngine.js +168 -0
  263. package/dist/code-intelligence/search/HybridSearchEngine.js.map +1 -0
  264. package/dist/code-intelligence/search/RRFFusion.d.ts +46 -0
  265. package/dist/code-intelligence/search/RRFFusion.d.ts.map +1 -0
  266. package/dist/code-intelligence/search/RRFFusion.js +223 -0
  267. package/dist/code-intelligence/search/RRFFusion.js.map +1 -0
  268. package/dist/code-intelligence/search/VectorSearch.d.ts +157 -0
  269. package/dist/code-intelligence/search/VectorSearch.d.ts.map +1 -0
  270. package/dist/code-intelligence/search/VectorSearch.js +301 -0
  271. package/dist/code-intelligence/search/VectorSearch.js.map +1 -0
  272. package/dist/code-intelligence/search/index.d.ts +14 -0
  273. package/dist/code-intelligence/search/index.d.ts.map +1 -0
  274. package/dist/code-intelligence/search/index.js +23 -0
  275. package/dist/code-intelligence/search/index.js.map +1 -0
  276. package/dist/code-intelligence/search/types.d.ts +201 -0
  277. package/dist/code-intelligence/search/types.d.ts.map +1 -0
  278. package/dist/code-intelligence/search/types.js +35 -0
  279. package/dist/code-intelligence/search/types.js.map +1 -0
  280. package/dist/code-intelligence/service/CodeIntelligenceService.d.ts +171 -0
  281. package/dist/code-intelligence/service/CodeIntelligenceService.d.ts.map +1 -0
  282. package/dist/code-intelligence/service/CodeIntelligenceService.js +325 -0
  283. package/dist/code-intelligence/service/CodeIntelligenceService.js.map +1 -0
  284. package/dist/code-intelligence/service/index.d.ts +7 -0
  285. package/dist/code-intelligence/service/index.d.ts.map +1 -0
  286. package/dist/code-intelligence/service/index.js +14 -0
  287. package/dist/code-intelligence/service/index.js.map +1 -0
  288. package/dist/code-intelligence/storage/CodeChunkStore.d.ts +213 -0
  289. package/dist/code-intelligence/storage/CodeChunkStore.d.ts.map +1 -0
  290. package/dist/code-intelligence/storage/CodeChunkStore.js +542 -0
  291. package/dist/code-intelligence/storage/CodeChunkStore.js.map +1 -0
  292. package/dist/code-intelligence/storage/index.d.ts +7 -0
  293. package/dist/code-intelligence/storage/index.d.ts.map +1 -0
  294. package/dist/code-intelligence/storage/index.js +13 -0
  295. package/dist/code-intelligence/storage/index.js.map +1 -0
  296. package/dist/code-intelligence/visualization/ClassDiagramBuilder.d.ts +51 -0
  297. package/dist/code-intelligence/visualization/ClassDiagramBuilder.d.ts.map +1 -0
  298. package/dist/code-intelligence/visualization/ClassDiagramBuilder.js +180 -0
  299. package/dist/code-intelligence/visualization/ClassDiagramBuilder.js.map +1 -0
  300. package/dist/code-intelligence/visualization/DependencyGraphBuilder.d.ts +66 -0
  301. package/dist/code-intelligence/visualization/DependencyGraphBuilder.d.ts.map +1 -0
  302. package/dist/code-intelligence/visualization/DependencyGraphBuilder.js +203 -0
  303. package/dist/code-intelligence/visualization/DependencyGraphBuilder.js.map +1 -0
  304. package/dist/code-intelligence/visualization/MermaidGenerator.d.ts +76 -0
  305. package/dist/code-intelligence/visualization/MermaidGenerator.d.ts.map +1 -0
  306. package/dist/code-intelligence/visualization/MermaidGenerator.js +368 -0
  307. package/dist/code-intelligence/visualization/MermaidGenerator.js.map +1 -0
  308. package/dist/code-intelligence/visualization/index.d.ts +9 -0
  309. package/dist/code-intelligence/visualization/index.d.ts.map +1 -0
  310. package/dist/code-intelligence/visualization/index.js +15 -0
  311. package/dist/code-intelligence/visualization/index.js.map +1 -0
  312. package/dist/core/FleetManager.d.ts +27 -0
  313. package/dist/core/FleetManager.d.ts.map +1 -1
  314. package/dist/core/FleetManager.js +84 -0
  315. package/dist/core/FleetManager.js.map +1 -1
  316. package/dist/core/memory/HNSWVectorMemory.js +1 -1
  317. package/dist/mcp/server-instructions.d.ts +1 -1
  318. package/dist/mcp/server-instructions.js +1 -1
  319. package/dist/memory/RuVectorPatternStore.d.ts +258 -0
  320. package/dist/memory/RuVectorPatternStore.d.ts.map +1 -0
  321. package/dist/memory/RuVectorPatternStore.js +525 -0
  322. package/dist/memory/RuVectorPatternStore.js.map +1 -0
  323. package/dist/providers/RuVectorPostgresAdapter.d.ts +134 -0
  324. package/dist/providers/RuVectorPostgresAdapter.d.ts.map +1 -0
  325. package/dist/providers/RuVectorPostgresAdapter.js +504 -0
  326. package/dist/providers/RuVectorPostgresAdapter.js.map +1 -0
  327. package/dist/providers/index.d.ts +2 -0
  328. package/dist/providers/index.d.ts.map +1 -1
  329. package/dist/providers/index.js +7 -1
  330. package/dist/providers/index.js.map +1 -1
  331. package/dist/types/index.d.ts +2 -1
  332. package/dist/types/index.d.ts.map +1 -1
  333. package/dist/types/index.js +2 -0
  334. package/dist/types/index.js.map +1 -1
  335. package/docs/reference/agents.md +44 -1
  336. package/package.json +15 -2
@@ -0,0 +1,233 @@
1
+ "use strict";
2
+ /**
3
+ * BM25 Search Engine
4
+ *
5
+ * Implements Best Matching 25 algorithm for keyword-based
6
+ * code search with:
7
+ * - Term frequency saturation
8
+ * - Document length normalization
9
+ * - Inverse document frequency weighting
10
+ */
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.BM25Search = void 0;
13
+ const types_js_1 = require("./types.js");
14
+ class BM25Search {
15
+ constructor(config = {}) {
16
+ this.config = { ...types_js_1.DEFAULT_BM25_CONFIG, ...config };
17
+ this.index = this.createEmptyIndex();
18
+ }
19
+ /**
20
+ * Add a document to the index.
21
+ */
22
+ addDocument(doc) {
23
+ const terms = this.tokenize(doc.content);
24
+ const document = { ...doc, terms };
25
+ // Store document
26
+ this.index.documents.set(doc.id, document);
27
+ this.index.documentLengths.set(doc.id, terms.length);
28
+ // Update term frequencies for this document
29
+ const termFreqs = new Map();
30
+ for (const term of terms) {
31
+ termFreqs.set(term, (termFreqs.get(term) || 0) + 1);
32
+ }
33
+ this.index.termFrequencies.set(doc.id, termFreqs);
34
+ // Update document frequencies
35
+ const uniqueTerms = new Set(terms);
36
+ for (const term of uniqueTerms) {
37
+ this.index.documentFrequency.set(term, (this.index.documentFrequency.get(term) || 0) + 1);
38
+ }
39
+ // Update stats
40
+ this.index.docCount++;
41
+ this.updateAvgDocLength();
42
+ }
43
+ /**
44
+ * Add multiple documents.
45
+ */
46
+ addDocuments(docs) {
47
+ for (const doc of docs) {
48
+ this.addDocument(doc);
49
+ }
50
+ }
51
+ /**
52
+ * Remove a document from the index.
53
+ */
54
+ removeDocument(docId) {
55
+ const doc = this.index.documents.get(docId);
56
+ if (!doc)
57
+ return false;
58
+ // Update document frequencies
59
+ const termFreqs = this.index.termFrequencies.get(docId);
60
+ if (termFreqs) {
61
+ for (const term of termFreqs.keys()) {
62
+ const df = this.index.documentFrequency.get(term) || 0;
63
+ if (df <= 1) {
64
+ this.index.documentFrequency.delete(term);
65
+ }
66
+ else {
67
+ this.index.documentFrequency.set(term, df - 1);
68
+ }
69
+ }
70
+ }
71
+ // Remove from index
72
+ this.index.documents.delete(docId);
73
+ this.index.documentLengths.delete(docId);
74
+ this.index.termFrequencies.delete(docId);
75
+ // Update stats
76
+ this.index.docCount--;
77
+ this.updateAvgDocLength();
78
+ return true;
79
+ }
80
+ /**
81
+ * Search for documents matching a query.
82
+ */
83
+ search(query, topK = 10) {
84
+ const queryTerms = this.tokenize(query);
85
+ // Filter query terms by document frequency
86
+ const filteredTerms = queryTerms.filter(term => {
87
+ const df = this.index.documentFrequency.get(term) || 0;
88
+ if (df < this.config.minDocFreq)
89
+ return false;
90
+ if (this.index.docCount > 0 && df / this.index.docCount > this.config.maxDocFreqRatio) {
91
+ return false;
92
+ }
93
+ return true;
94
+ });
95
+ if (filteredTerms.length === 0) {
96
+ return [];
97
+ }
98
+ // Calculate BM25 scores for all documents
99
+ const scores = [];
100
+ for (const [docId, termFreqs] of this.index.termFrequencies) {
101
+ const docLength = this.index.documentLengths.get(docId) || 0;
102
+ let score = 0;
103
+ for (const term of filteredTerms) {
104
+ const tf = termFreqs.get(term) || 0;
105
+ if (tf === 0)
106
+ continue;
107
+ const df = this.index.documentFrequency.get(term) || 0;
108
+ const idf = this.calculateIDF(df);
109
+ const tfNorm = this.calculateTF(tf, docLength);
110
+ score += idf * tfNorm;
111
+ }
112
+ if (score > 0) {
113
+ scores.push({ docId, score });
114
+ }
115
+ }
116
+ // Sort by score
117
+ scores.sort((a, b) => b.score - a.score);
118
+ // Convert to results
119
+ return scores.slice(0, topK).map(({ docId, score }) => {
120
+ const doc = this.index.documents.get(docId);
121
+ return {
122
+ id: doc.id,
123
+ filePath: doc.filePath,
124
+ content: doc.content,
125
+ startLine: doc.startLine,
126
+ endLine: doc.endLine,
127
+ score,
128
+ bm25Score: score,
129
+ entityType: doc.entityType,
130
+ entityName: doc.entityName,
131
+ highlights: this.getHighlights(doc.content, filteredTerms),
132
+ };
133
+ });
134
+ }
135
+ /**
136
+ * Get term matches in content for highlighting.
137
+ */
138
+ getHighlights(content, queryTerms) {
139
+ const highlights = [];
140
+ const lines = content.split('\n');
141
+ for (const line of lines) {
142
+ const lineTokens = this.tokenize(line);
143
+ const hasMatch = queryTerms.some(term => lineTokens.includes(term));
144
+ if (hasMatch) {
145
+ highlights.push(line.trim());
146
+ }
147
+ }
148
+ return highlights.slice(0, 3); // Max 3 highlights
149
+ }
150
+ /**
151
+ * Get index statistics.
152
+ */
153
+ getStats() {
154
+ return {
155
+ docCount: this.index.docCount,
156
+ avgDocLength: this.index.avgDocLength,
157
+ uniqueTerms: this.index.documentFrequency.size,
158
+ };
159
+ }
160
+ /**
161
+ * Clear the index.
162
+ */
163
+ clear() {
164
+ this.index = this.createEmptyIndex();
165
+ }
166
+ /**
167
+ * Get configuration.
168
+ */
169
+ getConfig() {
170
+ return { ...this.config };
171
+ }
172
+ /**
173
+ * Calculate Inverse Document Frequency.
174
+ * IDF = ln((N - df + 0.5) / (df + 0.5))
175
+ */
176
+ calculateIDF(df) {
177
+ const N = this.index.docCount;
178
+ return Math.log((N - df + 0.5) / (df + 0.5) + 1);
179
+ }
180
+ /**
181
+ * Calculate normalized term frequency.
182
+ * TF = (tf * (k1 + 1)) / (tf + k1 * (1 - b + b * dl/avgdl))
183
+ */
184
+ calculateTF(tf, docLength) {
185
+ const { k1, b } = this.config;
186
+ const avgDl = this.index.avgDocLength || 1;
187
+ const numerator = tf * (k1 + 1);
188
+ const denominator = tf + k1 * (1 - b + b * (docLength / avgDl));
189
+ return numerator / denominator;
190
+ }
191
+ /**
192
+ * Tokenize text into terms.
193
+ */
194
+ tokenize(text) {
195
+ // Split on non-alphanumeric, handle camelCase and snake_case
196
+ const expanded = text
197
+ .replace(/([a-z])([A-Z])/g, '$1 $2') // camelCase
198
+ .replace(/_/g, ' ') // snake_case
199
+ .toLowerCase();
200
+ return expanded
201
+ .split(/[^a-z0-9]+/)
202
+ .filter(token => token.length >= 2); // Min 2 chars
203
+ }
204
+ /**
205
+ * Update average document length.
206
+ */
207
+ updateAvgDocLength() {
208
+ if (this.index.docCount === 0) {
209
+ this.index.avgDocLength = 0;
210
+ return;
211
+ }
212
+ let totalLength = 0;
213
+ for (const length of this.index.documentLengths.values()) {
214
+ totalLength += length;
215
+ }
216
+ this.index.avgDocLength = totalLength / this.index.docCount;
217
+ }
218
+ /**
219
+ * Create empty index structure.
220
+ */
221
+ createEmptyIndex() {
222
+ return {
223
+ docCount: 0,
224
+ avgDocLength: 0,
225
+ documentFrequency: new Map(),
226
+ termFrequencies: new Map(),
227
+ documentLengths: new Map(),
228
+ documents: new Map(),
229
+ };
230
+ }
231
+ }
232
+ exports.BM25Search = BM25Search;
233
+ //# sourceMappingURL=BM25Search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BM25Search.js","sourceRoot":"","sources":["../../../src/code-intelligence/search/BM25Search.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,94 @@
1
+ /**
2
+ * Hybrid Search Engine
3
+ *
4
+ * Combines BM25 keyword search with vector similarity search
5
+ * using Reciprocal Rank Fusion (RRF) for optimal results.
6
+ *
7
+ * Benefits:
8
+ * - BM25 excels at exact keyword matches and rare terms
9
+ * - Vector search excels at semantic similarity
10
+ * - RRF combines both without manual tuning
11
+ */
12
+ import { HybridSearchConfig, SearchResult, SearchResponse } from './types.js';
13
+ export interface VectorSearchProvider {
14
+ search(query: string, topK: number): Promise<SearchResult[]>;
15
+ }
16
+ export declare class HybridSearchEngine {
17
+ private config;
18
+ private bm25;
19
+ private rrfFusion;
20
+ private vectorProvider?;
21
+ constructor(config?: Partial<HybridSearchConfig>, vectorProvider?: VectorSearchProvider);
22
+ /**
23
+ * Add a document to the search index.
24
+ */
25
+ addDocument(doc: {
26
+ id: string;
27
+ filePath: string;
28
+ content: string;
29
+ startLine: number;
30
+ endLine: number;
31
+ entityType?: string;
32
+ entityName?: string;
33
+ }): void;
34
+ /**
35
+ * Add multiple documents.
36
+ */
37
+ addDocuments(docs: Array<{
38
+ id: string;
39
+ filePath: string;
40
+ content: string;
41
+ startLine: number;
42
+ endLine: number;
43
+ entityType?: string;
44
+ entityName?: string;
45
+ }>): void;
46
+ /**
47
+ * Remove a document.
48
+ */
49
+ removeDocument(docId: string): boolean;
50
+ /**
51
+ * Set the vector search provider.
52
+ */
53
+ setVectorProvider(provider: VectorSearchProvider): void;
54
+ /**
55
+ * Perform hybrid search.
56
+ */
57
+ search(query: string, configOverride?: Partial<HybridSearchConfig>): Promise<SearchResponse>;
58
+ /**
59
+ * BM25-only search (no vector).
60
+ */
61
+ searchKeyword(query: string, topK?: number): SearchResult[];
62
+ /**
63
+ * Vector-only search.
64
+ */
65
+ searchSemantic(query: string, topK?: number): Promise<SearchResult[]>;
66
+ /**
67
+ * Get index statistics.
68
+ */
69
+ getStats(): {
70
+ bm25: {
71
+ docCount: number;
72
+ avgDocLength: number;
73
+ uniqueTerms: number;
74
+ };
75
+ hasVectorProvider: boolean;
76
+ };
77
+ /**
78
+ * Clear all indexes.
79
+ */
80
+ clear(): void;
81
+ /**
82
+ * Get configuration.
83
+ */
84
+ getConfig(): HybridSearchConfig;
85
+ /**
86
+ * Update configuration.
87
+ */
88
+ updateConfig(config: Partial<HybridSearchConfig>): void;
89
+ /**
90
+ * Simple tokenization for highlighting.
91
+ */
92
+ private tokenize;
93
+ }
94
+ //# sourceMappingURL=HybridSearchEngine.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HybridSearchEngine.d.ts","sourceRoot":"","sources":["../../../src/code-intelligence/search/HybridSearchEngine.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAIH,OAAO,EACL,kBAAkB,EAClB,YAAY,EACZ,cAAc,EAGf,MAAM,YAAY,CAAC;AAEpB,MAAM,WAAW,oBAAoB;IACnC,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;CAC9D;AAED,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,MAAM,CAAqB;IACnC,OAAO,CAAC,IAAI,CAAa;IACzB,OAAO,CAAC,SAAS,CAAY;IAC7B,OAAO,CAAC,cAAc,CAAC,CAAuB;gBAG5C,MAAM,GAAE,OAAO,CAAC,kBAAkB,CAAM,EACxC,cAAc,CAAC,EAAE,oBAAoB;IAQvC;;OAEG;IACH,WAAW,CAAC,GAAG,EAAE;QACf,EAAE,EAAE,MAAM,CAAC;QACX,QAAQ,EAAE,MAAM,CAAC;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,GAAG,IAAI;IAIR;;OAEG;IACH,YAAY,CAAC,IAAI,EAAE,KAAK,CAAC;QACvB,EAAE,EAAE,MAAM,CAAC;QACX,QAAQ,EAAE,MAAM,CAAC;QACjB,OAAO,EAAE,MAAM,CAAC;QAChB,SAAS,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC;QAChB,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,UAAU,CAAC,EAAE,MAAM,CAAC;KACrB,CAAC,GAAG,IAAI;IAIT;;OAEG;IACH,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO;IAItC;;OAEG;IACH,iBAAiB,CAAC,QAAQ,EAAE,oBAAoB,GAAG,IAAI;IAIvD;;OAEG;IACG,MAAM,CACV,KAAK,EAAE,MAAM,EACb,cAAc,CAAC,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAC3C,OAAO,CAAC,cAAc,CAAC;IA8E1B;;OAEG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,YAAY,EAAE;IAI3D;;OAEG;IACG,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IAO3E;;OAEG;IACH,QAAQ,IAAI;QACV,IAAI,EAAE;YAAE,QAAQ,EAAE,MAAM,CAAC;YAAC,YAAY,EAAE,MAAM,CAAC;YAAC,WAAW,EAAE,MAAM,CAAA;SAAE,CAAC;QACtE,iBAAiB,EAAE,OAAO,CAAC;KAC5B;IAOD;;OAEG;IACH,KAAK,IAAI,IAAI;IAIb;;OAEG;IACH,SAAS,IAAI,kBAAkB;IAI/B;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,kBAAkB,CAAC,GAAG,IAAI;IAKvD;;OAEG;IACH,OAAO,CAAC,QAAQ;CAQjB"}
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+ /**
3
+ * Hybrid Search Engine
4
+ *
5
+ * Combines BM25 keyword search with vector similarity search
6
+ * using Reciprocal Rank Fusion (RRF) for optimal results.
7
+ *
8
+ * Benefits:
9
+ * - BM25 excels at exact keyword matches and rare terms
10
+ * - Vector search excels at semantic similarity
11
+ * - RRF combines both without manual tuning
12
+ */
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ exports.HybridSearchEngine = void 0;
15
+ const BM25Search_js_1 = require("./BM25Search.js");
16
+ const RRFFusion_js_1 = require("./RRFFusion.js");
17
+ const types_js_1 = require("./types.js");
18
+ class HybridSearchEngine {
19
+ constructor(config = {}, vectorProvider) {
20
+ this.config = { ...types_js_1.DEFAULT_HYBRID_SEARCH_CONFIG, ...config };
21
+ this.bm25 = new BM25Search_js_1.BM25Search();
22
+ this.rrfFusion = new RRFFusion_js_1.RRFFusion({ k: this.config.rrfK });
23
+ this.vectorProvider = vectorProvider;
24
+ }
25
+ /**
26
+ * Add a document to the search index.
27
+ */
28
+ addDocument(doc) {
29
+ this.bm25.addDocument(doc);
30
+ }
31
+ /**
32
+ * Add multiple documents.
33
+ */
34
+ addDocuments(docs) {
35
+ this.bm25.addDocuments(docs);
36
+ }
37
+ /**
38
+ * Remove a document.
39
+ */
40
+ removeDocument(docId) {
41
+ return this.bm25.removeDocument(docId);
42
+ }
43
+ /**
44
+ * Set the vector search provider.
45
+ */
46
+ setVectorProvider(provider) {
47
+ this.vectorProvider = provider;
48
+ }
49
+ /**
50
+ * Perform hybrid search.
51
+ */
52
+ async search(query, configOverride) {
53
+ const config = { ...this.config, ...configOverride };
54
+ const startTime = Date.now();
55
+ const candidateCount = config.topK * config.candidateMultiplier;
56
+ let bm25TimeMs = 0;
57
+ let vectorTimeMs = 0;
58
+ let fusionTimeMs = 0;
59
+ // BM25 search
60
+ const bm25Start = Date.now();
61
+ const bm25Results = this.bm25.search(query, candidateCount);
62
+ bm25TimeMs = Date.now() - bm25Start;
63
+ // Vector search (if provider available)
64
+ let vectorResults = [];
65
+ if (this.vectorProvider) {
66
+ const vectorStart = Date.now();
67
+ vectorResults = await this.vectorProvider.search(query, candidateCount);
68
+ vectorTimeMs = Date.now() - vectorStart;
69
+ }
70
+ // Fusion
71
+ const fusionStart = Date.now();
72
+ let results;
73
+ if (vectorResults.length === 0) {
74
+ // BM25 only
75
+ results = bm25Results.slice(0, config.topK);
76
+ }
77
+ else if (config.useRRF) {
78
+ // RRF fusion
79
+ results = this.rrfFusion.fuse([bm25Results, vectorResults], config.topK);
80
+ }
81
+ else {
82
+ // Weighted score fusion
83
+ results = this.rrfFusion.fuseScores([bm25Results, vectorResults], [config.bm25Weight, config.vectorWeight], config.topK);
84
+ }
85
+ fusionTimeMs = Date.now() - fusionStart;
86
+ // Filter by minimum score
87
+ results = results.filter(r => r.score >= config.minScore);
88
+ // Add highlights if enabled
89
+ if (config.includeHighlights) {
90
+ for (const result of results) {
91
+ if (!result.highlights || result.highlights.length === 0) {
92
+ result.highlights = this.bm25.getHighlights(result.content, this.tokenize(query));
93
+ }
94
+ }
95
+ }
96
+ const stats = {
97
+ bm25Candidates: bm25Results.length,
98
+ vectorCandidates: vectorResults.length,
99
+ fusedResults: results.length,
100
+ bm25TimeMs,
101
+ vectorTimeMs,
102
+ fusionTimeMs,
103
+ };
104
+ return {
105
+ results,
106
+ query,
107
+ totalMatches: bm25Results.length + vectorResults.length,
108
+ searchTimeMs: Date.now() - startTime,
109
+ stats,
110
+ };
111
+ }
112
+ /**
113
+ * BM25-only search (no vector).
114
+ */
115
+ searchKeyword(query, topK) {
116
+ return this.bm25.search(query, topK || this.config.topK);
117
+ }
118
+ /**
119
+ * Vector-only search.
120
+ */
121
+ async searchSemantic(query, topK) {
122
+ if (!this.vectorProvider) {
123
+ throw new Error('Vector provider not configured');
124
+ }
125
+ return this.vectorProvider.search(query, topK || this.config.topK);
126
+ }
127
+ /**
128
+ * Get index statistics.
129
+ */
130
+ getStats() {
131
+ return {
132
+ bm25: this.bm25.getStats(),
133
+ hasVectorProvider: !!this.vectorProvider,
134
+ };
135
+ }
136
+ /**
137
+ * Clear all indexes.
138
+ */
139
+ clear() {
140
+ this.bm25.clear();
141
+ }
142
+ /**
143
+ * Get configuration.
144
+ */
145
+ getConfig() {
146
+ return { ...this.config };
147
+ }
148
+ /**
149
+ * Update configuration.
150
+ */
151
+ updateConfig(config) {
152
+ this.config = { ...this.config, ...config };
153
+ this.rrfFusion.updateConfig({ k: this.config.rrfK });
154
+ }
155
+ /**
156
+ * Simple tokenization for highlighting.
157
+ */
158
+ tokenize(text) {
159
+ return text
160
+ .replace(/([a-z])([A-Z])/g, '$1 $2')
161
+ .replace(/_/g, ' ')
162
+ .toLowerCase()
163
+ .split(/[^a-z0-9]+/)
164
+ .filter(token => token.length >= 2);
165
+ }
166
+ }
167
+ exports.HybridSearchEngine = HybridSearchEngine;
168
+ //# sourceMappingURL=HybridSearchEngine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"HybridSearchEngine.js","sourceRoot":"","sources":["../../../src/code-intelligence/search/HybridSearchEngine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,46 @@
1
+ /**
2
+ * Reciprocal Rank Fusion (RRF)
3
+ *
4
+ * Combines rankings from multiple search methods
5
+ * using the RRF formula:
6
+ * score(d) = Σ 1 / (k + rank_i(d))
7
+ *
8
+ * Where k is a constant (typically 60) that determines
9
+ * how much weight is given to lower-ranked results.
10
+ */
11
+ import { RRFConfig, SearchResult } from './types.js';
12
+ export declare class RRFFusion {
13
+ private config;
14
+ constructor(config?: Partial<RRFConfig>);
15
+ /**
16
+ * Fuse multiple ranked lists using RRF.
17
+ *
18
+ * @param rankedLists - Array of search result lists, each ordered by relevance
19
+ * @param topK - Number of results to return
20
+ * @returns Fused results ordered by RRF score
21
+ */
22
+ fuse(rankedLists: SearchResult[][], topK?: number): SearchResult[];
23
+ /**
24
+ * Fuse with weighted RRF.
25
+ * Allows different weights for each source.
26
+ */
27
+ fuseWeighted(rankedLists: SearchResult[][], weights: number[], topK?: number): SearchResult[];
28
+ /**
29
+ * Simple weighted score fusion (alternative to RRF).
30
+ * Combines normalized scores directly.
31
+ */
32
+ fuseScores(rankedLists: SearchResult[][], weights: number[], topK?: number): SearchResult[];
33
+ /**
34
+ * Calculate RRF score from ranks.
35
+ */
36
+ private calculateRRFScore;
37
+ /**
38
+ * Get configuration.
39
+ */
40
+ getConfig(): RRFConfig;
41
+ /**
42
+ * Update configuration.
43
+ */
44
+ updateConfig(config: Partial<RRFConfig>): void;
45
+ }
46
+ //# sourceMappingURL=RRFFusion.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RRFFusion.d.ts","sourceRoot":"","sources":["../../../src/code-intelligence/search/RRFFusion.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,EACL,SAAS,EAET,YAAY,EAEb,MAAM,YAAY,CAAC;AAEpB,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAY;gBAEd,MAAM,GAAE,OAAO,CAAC,SAAS,CAAM;IAI3C;;;;;;OAMG;IACH,IAAI,CAAC,WAAW,EAAE,YAAY,EAAE,EAAE,EAAE,IAAI,GAAE,MAAW,GAAG,YAAY,EAAE;IAoEtE;;;OAGG;IACH,YAAY,CACV,WAAW,EAAE,YAAY,EAAE,EAAE,EAC7B,OAAO,EAAE,MAAM,EAAE,EACjB,IAAI,GAAE,MAAW,GAChB,YAAY,EAAE;IAsEjB;;;OAGG;IACH,UAAU,CACR,WAAW,EAAE,YAAY,EAAE,EAAE,EAC7B,OAAO,EAAE,MAAM,EAAE,EACjB,IAAI,GAAE,MAAW,GAChB,YAAY,EAAE;IA2DjB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAUzB;;OAEG;IACH,SAAS,IAAI,SAAS;IAItB;;OAEG;IACH,YAAY,CAAC,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC,GAAG,IAAI;CAG/C"}