codevault 1.6.0 → 1.6.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.
Files changed (237) hide show
  1. package/dist/chunking/file-grouper.d.ts +39 -0
  2. package/dist/chunking/file-grouper.d.ts.map +1 -0
  3. package/dist/chunking/file-grouper.js +164 -0
  4. package/dist/chunking/file-grouper.js.map +1 -0
  5. package/dist/chunking/semantic-chunker.d.ts +37 -0
  6. package/dist/chunking/semantic-chunker.d.ts.map +1 -0
  7. package/dist/chunking/semantic-chunker.js +157 -0
  8. package/dist/chunking/semantic-chunker.js.map +1 -0
  9. package/dist/chunking/token-counter.d.ts +28 -0
  10. package/dist/chunking/token-counter.d.ts.map +1 -0
  11. package/dist/chunking/token-counter.js +207 -0
  12. package/dist/chunking/token-counter.js.map +1 -0
  13. package/dist/cli/commands/ask-cmd.d.ts +3 -0
  14. package/dist/cli/commands/ask-cmd.d.ts.map +1 -0
  15. package/dist/cli/commands/ask-cmd.js +130 -0
  16. package/dist/cli/commands/ask-cmd.js.map +1 -0
  17. package/dist/cli/commands/chat-cmd.d.ts +3 -0
  18. package/dist/cli/commands/chat-cmd.d.ts.map +1 -0
  19. package/dist/cli/commands/chat-cmd.js +194 -0
  20. package/dist/cli/commands/chat-cmd.js.map +1 -0
  21. package/dist/cli/commands/config-cmd.d.ts +3 -0
  22. package/dist/cli/commands/config-cmd.d.ts.map +1 -0
  23. package/dist/cli/commands/config-cmd.js +245 -0
  24. package/dist/cli/commands/config-cmd.js.map +1 -0
  25. package/dist/cli/commands/context.d.ts +3 -0
  26. package/dist/cli/commands/context.d.ts.map +1 -0
  27. package/dist/cli/commands/context.js +98 -0
  28. package/dist/cli/commands/context.js.map +1 -0
  29. package/dist/cli/commands/interactive-config.d.ts +2 -0
  30. package/dist/cli/commands/interactive-config.d.ts.map +1 -0
  31. package/dist/cli/commands/interactive-config.js +274 -0
  32. package/dist/cli/commands/interactive-config.js.map +1 -0
  33. package/dist/cli.d.ts +3 -0
  34. package/dist/cli.d.ts.map +1 -0
  35. package/dist/cli.js +403 -0
  36. package/dist/cli.js.map +1 -0
  37. package/dist/codemap/io.d.ts +5 -0
  38. package/dist/codemap/io.d.ts.map +1 -0
  39. package/dist/codemap/io.js +30 -0
  40. package/dist/codemap/io.js.map +1 -0
  41. package/dist/config/apply-env.d.ts +15 -0
  42. package/dist/config/apply-env.d.ts.map +1 -0
  43. package/dist/config/apply-env.js +91 -0
  44. package/dist/config/apply-env.js.map +1 -0
  45. package/dist/config/constants.d.ts +326 -0
  46. package/dist/config/constants.d.ts.map +1 -0
  47. package/dist/config/constants.js +214 -0
  48. package/dist/config/constants.js.map +1 -0
  49. package/dist/config/loader.d.ts +57 -0
  50. package/dist/config/loader.d.ts.map +1 -0
  51. package/dist/config/loader.js +287 -0
  52. package/dist/config/loader.js.map +1 -0
  53. package/dist/config/types.d.ts +46 -0
  54. package/dist/config/types.d.ts.map +1 -0
  55. package/dist/config/types.js +2 -0
  56. package/dist/config/types.js.map +1 -0
  57. package/dist/context/packs.d.ts +33 -0
  58. package/dist/context/packs.d.ts.map +1 -0
  59. package/dist/context/packs.js +180 -0
  60. package/dist/context/packs.js.map +1 -0
  61. package/dist/core/batch-indexer.d.ts +56 -0
  62. package/dist/core/batch-indexer.d.ts.map +1 -0
  63. package/dist/core/batch-indexer.js +189 -0
  64. package/dist/core/batch-indexer.js.map +1 -0
  65. package/dist/core/indexer.d.ts +3 -0
  66. package/dist/core/indexer.d.ts.map +1 -0
  67. package/dist/core/indexer.js +600 -0
  68. package/dist/core/indexer.js.map +1 -0
  69. package/dist/core/metadata.d.ts +19 -0
  70. package/dist/core/metadata.d.ts.map +1 -0
  71. package/dist/core/metadata.js +161 -0
  72. package/dist/core/metadata.js.map +1 -0
  73. package/dist/core/search.d.ts +7 -0
  74. package/dist/core/search.d.ts.map +1 -0
  75. package/dist/core/search.js +545 -0
  76. package/dist/core/search.js.map +1 -0
  77. package/dist/core/symbol-extractor.d.ts +3 -0
  78. package/dist/core/symbol-extractor.d.ts.map +1 -0
  79. package/dist/core/symbol-extractor.js +78 -0
  80. package/dist/core/symbol-extractor.js.map +1 -0
  81. package/dist/core/types.d.ts +104 -0
  82. package/dist/core/types.d.ts.map +1 -0
  83. package/dist/core/types.js +2 -0
  84. package/dist/core/types.js.map +1 -0
  85. package/dist/database/db.d.ts +102 -0
  86. package/dist/database/db.d.ts.map +1 -0
  87. package/dist/database/db.js +366 -0
  88. package/dist/database/db.js.map +1 -0
  89. package/dist/indexer/merkle.d.ts +13 -0
  90. package/dist/indexer/merkle.d.ts.map +1 -0
  91. package/dist/indexer/merkle.js +86 -0
  92. package/dist/indexer/merkle.js.map +1 -0
  93. package/dist/indexer/update.d.ts +19 -0
  94. package/dist/indexer/update.d.ts.map +1 -0
  95. package/dist/indexer/update.js +40 -0
  96. package/dist/indexer/update.js.map +1 -0
  97. package/dist/indexer/watch.d.ts +21 -0
  98. package/dist/indexer/watch.d.ts.map +1 -0
  99. package/dist/indexer/watch.js +222 -0
  100. package/dist/indexer/watch.js.map +1 -0
  101. package/dist/languages/rules.d.ts +11 -0
  102. package/dist/languages/rules.d.ts.map +1 -0
  103. package/dist/languages/rules.js +371 -0
  104. package/dist/languages/rules.js.map +1 -0
  105. package/dist/languages/tree-sitter-loader.d.ts +27 -0
  106. package/dist/languages/tree-sitter-loader.d.ts.map +1 -0
  107. package/dist/languages/tree-sitter-loader.js +76 -0
  108. package/dist/languages/tree-sitter-loader.js.map +1 -0
  109. package/dist/mcp/schemas.d.ts +166 -0
  110. package/dist/mcp/schemas.d.ts.map +1 -0
  111. package/dist/mcp/schemas.js +159 -0
  112. package/dist/mcp/schemas.js.map +1 -0
  113. package/dist/mcp/tools/ask-codebase.d.ts +85 -0
  114. package/dist/mcp/tools/ask-codebase.d.ts.map +1 -0
  115. package/dist/mcp/tools/ask-codebase.js +125 -0
  116. package/dist/mcp/tools/ask-codebase.js.map +1 -0
  117. package/dist/mcp/tools/use-context-pack.d.ts +57 -0
  118. package/dist/mcp/tools/use-context-pack.d.ts.map +1 -0
  119. package/dist/mcp/tools/use-context-pack.js +91 -0
  120. package/dist/mcp/tools/use-context-pack.js.map +1 -0
  121. package/dist/mcp-server.d.ts +3 -0
  122. package/dist/mcp-server.d.ts.map +1 -0
  123. package/dist/mcp-server.js +511 -0
  124. package/dist/mcp-server.js.map +1 -0
  125. package/dist/providers/base.d.ts +39 -0
  126. package/dist/providers/base.d.ts.map +1 -0
  127. package/dist/providers/base.js +198 -0
  128. package/dist/providers/base.js.map +1 -0
  129. package/dist/providers/chat-llm.d.ts +30 -0
  130. package/dist/providers/chat-llm.d.ts.map +1 -0
  131. package/dist/providers/chat-llm.js +85 -0
  132. package/dist/providers/chat-llm.js.map +1 -0
  133. package/dist/providers/index.d.ts +5 -0
  134. package/dist/providers/index.d.ts.map +1 -0
  135. package/dist/providers/index.js +12 -0
  136. package/dist/providers/index.js.map +1 -0
  137. package/dist/providers/openai.d.ts +14 -0
  138. package/dist/providers/openai.d.ts.map +1 -0
  139. package/dist/providers/openai.js +122 -0
  140. package/dist/providers/openai.js.map +1 -0
  141. package/dist/providers/token-counter.d.ts +2 -0
  142. package/dist/providers/token-counter.d.ts.map +1 -0
  143. package/dist/providers/token-counter.js +18 -0
  144. package/dist/providers/token-counter.js.map +1 -0
  145. package/dist/ranking/api-reranker.d.ts +18 -0
  146. package/dist/ranking/api-reranker.d.ts.map +1 -0
  147. package/dist/ranking/api-reranker.js +134 -0
  148. package/dist/ranking/api-reranker.js.map +1 -0
  149. package/dist/ranking/symbol-boost.d.ts +15 -0
  150. package/dist/ranking/symbol-boost.d.ts.map +1 -0
  151. package/dist/ranking/symbol-boost.js +175 -0
  152. package/dist/ranking/symbol-boost.js.map +1 -0
  153. package/dist/search/bm25.d.ts +17 -0
  154. package/dist/search/bm25.d.ts.map +1 -0
  155. package/dist/search/bm25.js +56 -0
  156. package/dist/search/bm25.js.map +1 -0
  157. package/dist/search/hybrid.d.ts +21 -0
  158. package/dist/search/hybrid.d.ts.map +1 -0
  159. package/dist/search/hybrid.js +50 -0
  160. package/dist/search/hybrid.js.map +1 -0
  161. package/dist/search/scope.d.ts +5 -0
  162. package/dist/search/scope.d.ts.map +1 -0
  163. package/dist/search/scope.js +107 -0
  164. package/dist/search/scope.js.map +1 -0
  165. package/dist/storage/encrypted-chunks.d.ts +40 -0
  166. package/dist/storage/encrypted-chunks.d.ts.map +1 -0
  167. package/dist/storage/encrypted-chunks.js +238 -0
  168. package/dist/storage/encrypted-chunks.js.map +1 -0
  169. package/dist/symbols/extract.d.ts +15 -0
  170. package/dist/symbols/extract.d.ts.map +1 -0
  171. package/dist/symbols/extract.js +208 -0
  172. package/dist/symbols/extract.js.map +1 -0
  173. package/dist/symbols/graph.d.ts +3 -0
  174. package/dist/symbols/graph.d.ts.map +1 -0
  175. package/dist/symbols/graph.js +89 -0
  176. package/dist/symbols/graph.js.map +1 -0
  177. package/dist/synthesis/conversational-synthesizer.d.ts +61 -0
  178. package/dist/synthesis/conversational-synthesizer.d.ts.map +1 -0
  179. package/dist/synthesis/conversational-synthesizer.js +286 -0
  180. package/dist/synthesis/conversational-synthesizer.js.map +1 -0
  181. package/dist/synthesis/markdown-formatter.d.ts +13 -0
  182. package/dist/synthesis/markdown-formatter.d.ts.map +1 -0
  183. package/dist/synthesis/markdown-formatter.js +104 -0
  184. package/dist/synthesis/markdown-formatter.js.map +1 -0
  185. package/dist/synthesis/prompt-builder.d.ts +21 -0
  186. package/dist/synthesis/prompt-builder.d.ts.map +1 -0
  187. package/dist/synthesis/prompt-builder.js +129 -0
  188. package/dist/synthesis/prompt-builder.js.map +1 -0
  189. package/dist/synthesis/synthesizer.d.ts +30 -0
  190. package/dist/synthesis/synthesizer.d.ts.map +1 -0
  191. package/dist/synthesis/synthesizer.js +210 -0
  192. package/dist/synthesis/synthesizer.js.map +1 -0
  193. package/dist/types/ast.d.ts +3 -0
  194. package/dist/types/ast.d.ts.map +1 -0
  195. package/dist/types/ast.js +2 -0
  196. package/dist/types/ast.js.map +1 -0
  197. package/dist/types/codemap.d.ts +58 -0
  198. package/dist/types/codemap.d.ts.map +1 -0
  199. package/dist/types/codemap.js +224 -0
  200. package/dist/types/codemap.js.map +1 -0
  201. package/dist/types/context-pack.d.ts +47 -0
  202. package/dist/types/context-pack.d.ts.map +1 -0
  203. package/dist/types/context-pack.js +44 -0
  204. package/dist/types/context-pack.js.map +1 -0
  205. package/dist/types/search.d.ts +15 -0
  206. package/dist/types/search.d.ts.map +1 -0
  207. package/dist/types/search.js +11 -0
  208. package/dist/types/search.js.map +1 -0
  209. package/dist/utils/cli-ui.d.ts +44 -0
  210. package/dist/utils/cli-ui.d.ts.map +1 -0
  211. package/dist/utils/cli-ui.js +139 -0
  212. package/dist/utils/cli-ui.js.map +1 -0
  213. package/dist/utils/indexer-with-progress.d.ts +10 -0
  214. package/dist/utils/indexer-with-progress.d.ts.map +1 -0
  215. package/dist/utils/indexer-with-progress.js +43 -0
  216. package/dist/utils/indexer-with-progress.js.map +1 -0
  217. package/dist/utils/logger.d.ts +55 -0
  218. package/dist/utils/logger.d.ts.map +1 -0
  219. package/dist/utils/logger.js +121 -0
  220. package/dist/utils/logger.js.map +1 -0
  221. package/dist/utils/mutex.d.ts +63 -0
  222. package/dist/utils/mutex.d.ts.map +1 -0
  223. package/dist/utils/mutex.js +123 -0
  224. package/dist/utils/mutex.js.map +1 -0
  225. package/dist/utils/path-helpers.d.ts +27 -0
  226. package/dist/utils/path-helpers.d.ts.map +1 -0
  227. package/dist/utils/path-helpers.js +55 -0
  228. package/dist/utils/path-helpers.js.map +1 -0
  229. package/dist/utils/rate-limiter.d.ts +34 -0
  230. package/dist/utils/rate-limiter.d.ts.map +1 -0
  231. package/dist/utils/rate-limiter.js +178 -0
  232. package/dist/utils/rate-limiter.js.map +1 -0
  233. package/dist/utils/scan-patterns.d.ts +5 -0
  234. package/dist/utils/scan-patterns.d.ts.map +1 -0
  235. package/dist/utils/scan-patterns.js +29 -0
  236. package/dist/utils/scan-patterns.js.map +1 -0
  237. package/package.json +1 -1
@@ -0,0 +1,545 @@
1
+ import fs from 'fs';
2
+ import path from 'path';
3
+ import { createEmbeddingProvider } from '../providers/index.js';
4
+ import { Database } from '../database/db.js';
5
+ import { readCodemap } from '../codemap/io.js';
6
+ import { normalizeScopeFilters, applyScope } from '../search/scope.js';
7
+ import { BM25Index } from '../search/bm25.js';
8
+ import { reciprocalRankFusion } from '../search/hybrid.js';
9
+ import { rerankWithAPI } from '../ranking/api-reranker.js';
10
+ import { applySymbolBoost } from '../ranking/symbol-boost.js';
11
+ import { log } from '../utils/logger.js';
12
+ import { readChunkFromDisk } from '../storage/encrypted-chunks.js';
13
+ import { RRF_K, DOC_BOOST } from '../config/constants.js';
14
+ // FIX: Add cache size limits to prevent memory leaks in long-running processes
15
+ const MAX_BM25_CACHE_SIZE = Number.parseInt(process.env.CODEVAULT_MAX_BM25_CACHE || '10', 10);
16
+ const MAX_CHUNK_TEXT_CACHE_SIZE = Number.parseInt(process.env.CODEVAULT_MAX_CHUNK_CACHE || '1000', 10);
17
+ const bm25IndexCache = new Map();
18
+ const chunkTextCache = new Map();
19
+ const RERANKER_MAX_CANDIDATES = Number.parseInt(process.env.CODEVAULT_RERANKER_MAX || '50', 10);
20
+ // Cache eviction helper for BM25 index cache (LRU)
21
+ function evictOldestBm25Index() {
22
+ if (bm25IndexCache.size >= MAX_BM25_CACHE_SIZE) {
23
+ let oldestKey = null;
24
+ let oldestTime = Infinity;
25
+ for (const [key, value] of bm25IndexCache.entries()) {
26
+ if (value.lastAccess < oldestTime) {
27
+ oldestTime = value.lastAccess;
28
+ oldestKey = key;
29
+ }
30
+ }
31
+ if (oldestKey) {
32
+ bm25IndexCache.delete(oldestKey);
33
+ }
34
+ }
35
+ }
36
+ // Cache eviction helper for chunk text cache (LRU)
37
+ function evictOldestChunkText() {
38
+ if (chunkTextCache.size >= MAX_CHUNK_TEXT_CACHE_SIZE) {
39
+ let oldestKey = null;
40
+ let oldestTime = Infinity;
41
+ for (const [key, value] of chunkTextCache.entries()) {
42
+ if (value.lastAccess < oldestTime) {
43
+ oldestTime = value.lastAccess;
44
+ oldestKey = key;
45
+ }
46
+ }
47
+ if (oldestKey) {
48
+ chunkTextCache.delete(oldestKey);
49
+ }
50
+ }
51
+ }
52
+ // Public function to clear caches (useful for long-running processes)
53
+ export function clearSearchCaches() {
54
+ bm25IndexCache.clear();
55
+ chunkTextCache.clear();
56
+ }
57
+ function normalizeQuery(query) {
58
+ return query
59
+ .toLowerCase()
60
+ .trim()
61
+ .replace(/[¿?]/g, '')
62
+ .replace(/\s+/g, ' ');
63
+ }
64
+ function cosineSimilarity(a, b) {
65
+ if (a.length !== b.length)
66
+ return 0;
67
+ let dotProduct = 0;
68
+ let normA = 0;
69
+ let normB = 0;
70
+ for (let i = 0; i < a.length; i++) {
71
+ dotProduct += a[i] * b[i];
72
+ normA += a[i] * a[i];
73
+ normB += b[i] * b[i];
74
+ }
75
+ return dotProduct / (Math.sqrt(normA) * Math.sqrt(normB));
76
+ }
77
+ function getBm25CacheKey(basePath, providerName, dimensions) {
78
+ return `${basePath}::${providerName}::${dimensions}`;
79
+ }
80
+ function getChunkCacheKey(basePath, sha) {
81
+ return `${basePath}::${sha}`;
82
+ }
83
+ function readChunkTextCached(sha, chunkDir, basePath) {
84
+ if (!sha) {
85
+ return null;
86
+ }
87
+ const cacheKey = getChunkCacheKey(basePath, sha);
88
+ const cached = chunkTextCache.get(cacheKey);
89
+ if (cached) {
90
+ // Update access time for LRU
91
+ cached.lastAccess = Date.now();
92
+ return cached.text;
93
+ }
94
+ try {
95
+ const result = readChunkFromDisk({ chunkDir, sha });
96
+ const code = result ? result.code : null;
97
+ evictOldestChunkText();
98
+ chunkTextCache.set(cacheKey, { text: code, lastAccess: Date.now() });
99
+ return code;
100
+ }
101
+ catch (error) {
102
+ evictOldestChunkText();
103
+ chunkTextCache.set(cacheKey, { text: null, lastAccess: Date.now() });
104
+ return null;
105
+ }
106
+ }
107
+ function buildBm25Document(chunk, codeText) {
108
+ if (!chunk) {
109
+ return '';
110
+ }
111
+ const parts = [
112
+ chunk.symbol,
113
+ chunk.file_path,
114
+ chunk.codevault_description,
115
+ chunk.codevault_intent,
116
+ codeText
117
+ ].filter(value => typeof value === 'string' && value.trim().length > 0);
118
+ return parts.join('\n');
119
+ }
120
+ function ensureBm25IndexForChunks(basePath, chunkDir, providerName, dimensions, chunks) {
121
+ if (!Array.isArray(chunks) || chunks.length === 0) {
122
+ return null;
123
+ }
124
+ const key = getBm25CacheKey(basePath, providerName, dimensions);
125
+ let entry = bm25IndexCache.get(key);
126
+ if (!entry) {
127
+ evictOldestBm25Index();
128
+ entry = { index: new BM25Index(), added: new Set(), lastAccess: Date.now() };
129
+ bm25IndexCache.set(key, entry);
130
+ }
131
+ else {
132
+ // Update access time for LRU
133
+ entry.lastAccess = Date.now();
134
+ }
135
+ const toAdd = [];
136
+ for (const chunk of chunks) {
137
+ if (!chunk || !chunk.id || entry.added.has(chunk.id)) {
138
+ continue;
139
+ }
140
+ const codeText = readChunkTextCached(chunk.sha, chunkDir, basePath);
141
+ const docText = buildBm25Document(chunk, codeText);
142
+ if (docText && docText.trim().length > 0) {
143
+ toAdd.push({ id: chunk.id, text: docText });
144
+ }
145
+ entry.added.add(chunk.id);
146
+ }
147
+ if (toAdd.length > 0) {
148
+ entry.index.addDocuments(toAdd);
149
+ }
150
+ entry.index.consolidate();
151
+ return entry.index;
152
+ }
153
+ export async function searchCode(query, limit = 10, provider = 'auto', workingPath = '.', scopeOptions = {}) {
154
+ const basePath = path.resolve(workingPath);
155
+ const dbPath = path.join(basePath, '.codevault/codevault.db');
156
+ const chunkDir = path.join(basePath, '.codevault/chunks');
157
+ const codemapPath = path.join(basePath, 'codevault.codemap.json');
158
+ if (!query || !query.trim()) {
159
+ return getOverview(limit, workingPath);
160
+ }
161
+ const normalizedScope = normalizeScopeFilters(scopeOptions);
162
+ const effectiveProvider = normalizedScope.provider || provider;
163
+ const hybridEnabled = normalizedScope.hybrid !== false;
164
+ const bm25Enabled = normalizedScope.bm25 !== false;
165
+ const symbolBoostEnabled = normalizedScope.symbol_boost !== false;
166
+ const embeddingProvider = createEmbeddingProvider(effectiveProvider);
167
+ // FIX: Ensure database is always closed, even on error paths
168
+ let db = null;
169
+ try {
170
+ if (!fs.existsSync(dbPath)) {
171
+ return {
172
+ success: false,
173
+ error: 'database_not_found',
174
+ message: `Database not found at ${dbPath}. Project needs to be indexed first.`,
175
+ suggestion: `Run index_project on directory: ${workingPath}`,
176
+ provider: embeddingProvider.getName(),
177
+ scope: normalizedScope,
178
+ hybrid: { enabled: hybridEnabled, bm25Enabled },
179
+ symbolBoost: { enabled: symbolBoostEnabled, boosted: false },
180
+ reranker: normalizedScope.reranker,
181
+ results: []
182
+ };
183
+ }
184
+ db = new Database(dbPath);
185
+ const chunks = await db.getChunks(embeddingProvider.getName(), embeddingProvider.getDimensions());
186
+ const codemapData = readCodemap(codemapPath);
187
+ if (chunks.length === 0) {
188
+ return {
189
+ success: false,
190
+ error: 'no_chunks_found',
191
+ message: `No indexed chunks found with ${embeddingProvider.getName()} in ${basePath}`,
192
+ suggestion: `Run: codevault index --provider ${effectiveProvider} from ${basePath}`,
193
+ provider: embeddingProvider.getName(),
194
+ scope: normalizedScope,
195
+ hybrid: { enabled: hybridEnabled, bm25Enabled },
196
+ reranker: normalizedScope.reranker,
197
+ results: []
198
+ };
199
+ }
200
+ const scopedChunks = applyScope(chunks, normalizedScope);
201
+ const chunkInfoById = new Map();
202
+ const results = [];
203
+ let queryEmbedding = null;
204
+ if (scopedChunks.length > 0) {
205
+ if (embeddingProvider.init) {
206
+ await embeddingProvider.init();
207
+ }
208
+ queryEmbedding = await embeddingProvider.generateEmbedding(query);
209
+ }
210
+ for (const chunk of scopedChunks) {
211
+ const embedding = JSON.parse(chunk.embedding.toString());
212
+ const vectorSimilarity = queryEmbedding ? cosineSimilarity(queryEmbedding, embedding) : 0;
213
+ let boostScore = 0;
214
+ if (chunk.codevault_intent && query.toLowerCase().includes(chunk.codevault_intent.toLowerCase())) {
215
+ boostScore += 0.2;
216
+ }
217
+ if (chunk.codevault_tags) {
218
+ try {
219
+ const tags = JSON.parse(chunk.codevault_tags || '[]');
220
+ const queryLower = query.toLowerCase();
221
+ tags.forEach((tag) => {
222
+ if (typeof tag === 'string' && queryLower.includes(tag.toLowerCase())) {
223
+ boostScore += 0.1;
224
+ }
225
+ });
226
+ }
227
+ catch (error) {
228
+ log.warn('Failed to parse codevault_tags for chunk', { chunkId: chunk.id, error });
229
+ }
230
+ }
231
+ let docBoost = 0;
232
+ const filePath = chunk.file_path.toLowerCase();
233
+ if (filePath.includes('readme') ||
234
+ filePath.includes('/docs/') ||
235
+ filePath.startsWith('docs/') ||
236
+ filePath.includes('changelog') ||
237
+ filePath.includes('contributing') ||
238
+ filePath.endsWith('.md')) {
239
+ docBoost = DOC_BOOST;
240
+ }
241
+ const finalScore = Math.min(vectorSimilarity + boostScore + docBoost, 1.0);
242
+ const info = {
243
+ id: chunk.id,
244
+ file_path: chunk.file_path,
245
+ symbol: chunk.symbol,
246
+ sha: chunk.sha,
247
+ lang: chunk.lang,
248
+ chunk_type: chunk.chunk_type,
249
+ codevault_intent: chunk.codevault_intent,
250
+ codevault_description: chunk.codevault_description,
251
+ score: finalScore,
252
+ vectorScore: vectorSimilarity,
253
+ boostScore: boostScore
254
+ };
255
+ chunkInfoById.set(chunk.id, info);
256
+ results.push(info);
257
+ }
258
+ if (symbolBoostEnabled) {
259
+ try {
260
+ applySymbolBoost(results, { query, codemap: codemapData });
261
+ }
262
+ catch (error) {
263
+ // Symbol boost fails silently
264
+ }
265
+ }
266
+ const sortedResults = results.sort((a, b) => b.score - a.score);
267
+ const remainingSlots = limit;
268
+ let vectorResults = [];
269
+ let bm25Fused = false;
270
+ let bm25CandidateCount = 0;
271
+ if (remainingSlots > 0) {
272
+ const selectionBudget = Math.max(remainingSlots, RRF_K);
273
+ const vectorPool = sortedResults.slice(0, selectionBudget);
274
+ if (hybridEnabled && bm25Enabled) {
275
+ const bm25Index = ensureBm25IndexForChunks(basePath, chunkDir, embeddingProvider.getName(), embeddingProvider.getDimensions(), scopedChunks);
276
+ if (bm25Index) {
277
+ const allowedIds = new Set(scopedChunks.map((chunk) => chunk.id));
278
+ const bm25RawResults = bm25Index.search(query, selectionBudget);
279
+ const bm25Results = bm25RawResults.filter(result => allowedIds.has(result.id));
280
+ bm25CandidateCount = bm25Results.length;
281
+ if (bm25Results.length > 0) {
282
+ const fused = reciprocalRankFusion({
283
+ vectorResults: vectorPool.map((item) => ({ id: item.id, score: item.score })),
284
+ bm25Results: bm25Results.map(item => ({ id: item.id, score: item.score })),
285
+ limit: selectionBudget,
286
+ k: RRF_K
287
+ });
288
+ if (fused.length > 0) {
289
+ bm25Fused = true;
290
+ vectorResults = fused
291
+ .map(entry => {
292
+ const info = chunkInfoById.get(entry.id);
293
+ if (!info) {
294
+ return null;
295
+ }
296
+ info.hybridScore = entry.score;
297
+ info.bm25Score = entry.bm25Score;
298
+ info.bm25Rank = entry.bm25Rank;
299
+ info.vectorRank = entry.vectorRank;
300
+ return info;
301
+ })
302
+ .filter((item) => item !== null);
303
+ }
304
+ }
305
+ }
306
+ }
307
+ if (vectorResults.length === 0) {
308
+ vectorResults = vectorPool;
309
+ }
310
+ const hasSymbolBoost = symbolBoostEnabled && vectorResults.some((candidate) => typeof candidate.symbolBoost === 'number' && candidate.symbolBoost > 0);
311
+ if (hasSymbolBoost && vectorResults.length > 1) {
312
+ vectorResults.sort((a, b) => {
313
+ const scoreA = typeof a.score === 'number' ? a.score : 0;
314
+ const scoreB = typeof b.score === 'number' ? b.score : 0;
315
+ if (scoreB !== scoreA) {
316
+ return scoreB - scoreA;
317
+ }
318
+ const boostA = typeof a.symbolBoost === 'number' ? a.symbolBoost : 0;
319
+ const boostB = typeof b.symbolBoost === 'number' ? b.symbolBoost : 0;
320
+ if (boostB !== boostA) {
321
+ return boostB - boostA;
322
+ }
323
+ const hybridA = typeof a.hybridScore === 'number' ? a.hybridScore : Number.NEGATIVE_INFINITY;
324
+ const hybridB = typeof b.hybridScore === 'number' ? b.hybridScore : Number.NEGATIVE_INFINITY;
325
+ return hybridB - hybridA;
326
+ });
327
+ }
328
+ vectorResults = vectorResults.slice(0, remainingSlots);
329
+ if (vectorResults.length > 1 && normalizedScope.reranker === 'api') {
330
+ try {
331
+ const reranked = await rerankWithAPI(query, vectorResults, {
332
+ max: Math.min(RERANKER_MAX_CANDIDATES, vectorResults.length),
333
+ getText: (candidate) => {
334
+ const codeText = readChunkTextCached(candidate.sha, chunkDir, basePath) || '';
335
+ return buildBm25Document(candidate, codeText);
336
+ }
337
+ });
338
+ if (Array.isArray(reranked) && reranked.length === vectorResults.length) {
339
+ // Reranker preserves input objects and adds rerankerScore/rerankerRank
340
+ vectorResults = reranked;
341
+ }
342
+ }
343
+ catch (error) {
344
+ // Silent fallback when reranker is unavailable
345
+ }
346
+ }
347
+ }
348
+ const vectorSearchType = bm25Fused ? 'hybrid' : 'vector';
349
+ const combinedResults = vectorResults.map((result) => {
350
+ const rawScore = typeof result.score === 'number' ? result.score : 0;
351
+ const meta = {
352
+ id: result.id,
353
+ symbol: result.symbol,
354
+ score: Math.min(1, rawScore),
355
+ intent: result.codevault_intent,
356
+ description: result.codevault_description,
357
+ searchType: vectorSearchType,
358
+ vectorScore: result.vectorScore
359
+ };
360
+ if (typeof result.hybridScore === 'number') {
361
+ meta.hybridScore = result.hybridScore;
362
+ }
363
+ if (typeof result.bm25Score === 'number') {
364
+ meta.bm25Score = result.bm25Score;
365
+ }
366
+ if (typeof result.bm25Rank === 'number') {
367
+ meta.bm25Rank = result.bm25Rank;
368
+ }
369
+ if (typeof result.vectorRank === 'number') {
370
+ meta.vectorRank = result.vectorRank;
371
+ }
372
+ if (typeof result.rerankerScore === 'number') {
373
+ meta.rerankerScore = result.rerankerScore;
374
+ }
375
+ if (typeof result.rerankerRank === 'number') {
376
+ meta.rerankerRank = result.rerankerRank;
377
+ }
378
+ if (typeof result.symbolBoost === 'number' && result.symbolBoost > 0) {
379
+ meta.symbolBoost = result.symbolBoost;
380
+ if (Array.isArray(result.symbolBoostSources) && result.symbolBoostSources.length > 0) {
381
+ meta.symbolBoostSources = result.symbolBoostSources;
382
+ }
383
+ }
384
+ if (typeof rawScore === 'number' && rawScore > 1) {
385
+ meta.scoreRaw = rawScore;
386
+ }
387
+ return {
388
+ type: 'code',
389
+ lang: result.lang,
390
+ path: result.file_path,
391
+ sha: result.sha,
392
+ data: null,
393
+ meta
394
+ };
395
+ });
396
+ combinedResults.sort((a, b) => {
397
+ const hasRerankerA = typeof a.meta?.rerankerScore === 'number';
398
+ const hasRerankerB = typeof b.meta?.rerankerScore === 'number';
399
+ if (hasRerankerA && hasRerankerB) {
400
+ return b.meta.rerankerScore - a.meta.rerankerScore;
401
+ }
402
+ const scoreA = a.meta?.score ?? 0;
403
+ const scoreB = b.meta?.score ?? 0;
404
+ return scoreB - scoreA;
405
+ });
406
+ if (combinedResults.length === 0) {
407
+ return {
408
+ success: false,
409
+ error: 'no_relevant_matches',
410
+ message: `No relevant matches found for "${query}"`,
411
+ suggestion: 'Try broader search terms or check if the project is properly indexed',
412
+ provider: embeddingProvider.getName(),
413
+ scope: normalizedScope,
414
+ hybrid: { enabled: hybridEnabled, bm25Enabled },
415
+ symbolBoost: { enabled: symbolBoostEnabled, boosted: false },
416
+ reranker: normalizedScope.reranker,
417
+ results: []
418
+ };
419
+ }
420
+ if (symbolBoostEnabled && combinedResults.length > 0 && combinedResults[0].meta.score > 0.8) {
421
+ await db.recordIntention(normalizeQuery(query), query, combinedResults[0].sha, combinedResults[0].meta.score);
422
+ }
423
+ const pattern = query
424
+ .toLowerCase()
425
+ .replace(/\b[\w-]+Session\b/gi, '[SESSION]')
426
+ .replace(/\bstripe\b/gi, '[PAYMENT_PROVIDER]')
427
+ .replace(/\b\w+Service\b/gi, '[SERVICE]')
428
+ .replace(/\b\w+Controller\b/gi, '[CONTROLLER]')
429
+ .trim();
430
+ await db.recordQueryPattern(pattern);
431
+ return {
432
+ success: true,
433
+ query,
434
+ searchType: bm25Fused ? 'hybrid' : 'vector',
435
+ vectorResults: vectorResults.length,
436
+ provider: embeddingProvider.getName(),
437
+ scope: normalizedScope,
438
+ reranker: normalizedScope.reranker,
439
+ hybrid: {
440
+ enabled: hybridEnabled,
441
+ bm25Enabled,
442
+ fused: bm25Fused,
443
+ bm25Candidates: bm25CandidateCount
444
+ },
445
+ symbolBoost: {
446
+ enabled: symbolBoostEnabled,
447
+ boosted: symbolBoostEnabled && vectorResults.some((result) => typeof result.symbolBoost === 'number' && result.symbolBoost > 0)
448
+ },
449
+ results: combinedResults
450
+ };
451
+ }
452
+ catch (error) {
453
+ console.error('Error in searchCode:', error);
454
+ return {
455
+ success: false,
456
+ error: 'search_error',
457
+ message: error.message,
458
+ provider: embeddingProvider.getName(),
459
+ scope: normalizedScope,
460
+ hybrid: { enabled: hybridEnabled, bm25Enabled },
461
+ symbolBoost: { enabled: symbolBoostEnabled, boosted: false },
462
+ reranker: normalizedScope.reranker,
463
+ results: []
464
+ };
465
+ }
466
+ finally {
467
+ // FIX: Always close database connection in finally block
468
+ if (db) {
469
+ try {
470
+ db.close();
471
+ }
472
+ catch (closeError) {
473
+ // Ignore close errors during cleanup
474
+ }
475
+ }
476
+ }
477
+ }
478
+ export async function getOverview(limit = 20, workingPath = '.') {
479
+ const basePath = path.resolve(workingPath);
480
+ const dbPath = path.join(basePath, '.codevault/codevault.db');
481
+ try {
482
+ if (!fs.existsSync(dbPath)) {
483
+ return {
484
+ success: false,
485
+ error: 'database_not_found',
486
+ message: `Database not found at ${dbPath}. Project needs to be indexed first.`,
487
+ suggestion: `Run index_project on directory: ${workingPath}`,
488
+ provider: 'unknown',
489
+ results: []
490
+ };
491
+ }
492
+ const db = new Database(dbPath);
493
+ const chunks = await db.getOverviewChunks(limit);
494
+ db.close();
495
+ const results = chunks.map(chunk => ({
496
+ type: 'code',
497
+ lang: chunk.lang,
498
+ path: chunk.file_path,
499
+ sha: chunk.sha,
500
+ data: null,
501
+ meta: {
502
+ id: chunk.id,
503
+ symbol: chunk.symbol,
504
+ score: 1.0
505
+ }
506
+ }));
507
+ return {
508
+ success: true,
509
+ provider: 'overview',
510
+ results
511
+ };
512
+ }
513
+ catch (error) {
514
+ return {
515
+ success: false,
516
+ error: 'overview_error',
517
+ message: error.message,
518
+ provider: 'overview',
519
+ results: []
520
+ };
521
+ }
522
+ }
523
+ export async function getChunk(sha, workingPath = '.') {
524
+ const basePath = path.resolve(workingPath);
525
+ const chunkDir = path.join(basePath, '.codevault/chunks');
526
+ try {
527
+ const result = readChunkFromDisk({ chunkDir, sha });
528
+ if (!result) {
529
+ const plainPath = path.join(chunkDir, `${sha}.gz`);
530
+ const encryptedPath = path.join(chunkDir, `${sha}.gz.enc`);
531
+ throw new Error(`Chunk ${sha} not found at ${plainPath} or ${encryptedPath}`);
532
+ }
533
+ return { success: true, code: result.code };
534
+ }
535
+ catch (error) {
536
+ if (error && error.code === 'ENCRYPTION_KEY_REQUIRED') {
537
+ return {
538
+ success: false,
539
+ error: `Chunk ${sha} is encrypted. Configure CODEVAULT_ENCRYPTION_KEY to decrypt.`
540
+ };
541
+ }
542
+ return { success: false, error: error.message };
543
+ }
544
+ }
545
+ //# sourceMappingURL=search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.js","sourceRoot":"","sources":["../../src/core/search.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { TreeSitterNode } from '../types/ast.js';
2
+ export declare function extractSymbolName(node: TreeSitterNode, source: string): string | null;
3
+ //# sourceMappingURL=symbol-extractor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"symbol-extractor.d.ts","sourceRoot":"","sources":["../../src/core/symbol-extractor.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAEtD,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAiFrF"}
@@ -0,0 +1,78 @@
1
+ export function extractSymbolName(node, source) {
2
+ if (node.type === 'function_declaration' || node.type === 'function_definition') {
3
+ for (let i = 0; i < node.childCount; i++) {
4
+ const child = node.child(i);
5
+ if (child && child.type === 'identifier') {
6
+ return source.slice(child.startIndex, child.endIndex);
7
+ }
8
+ }
9
+ }
10
+ if (node.type === 'method_declaration' || node.type === 'method_definition') {
11
+ function findMethodName(n) {
12
+ if (n.type === 'name' || n.type === 'identifier' || n.type === 'property_identifier') {
13
+ const text = source.slice(n.startIndex, n.endIndex);
14
+ if (!['public', 'private', 'protected', 'static', 'function', 'abstract', 'final'].includes(text)) {
15
+ return text;
16
+ }
17
+ }
18
+ for (let i = 0; i < n.childCount; i++) {
19
+ const child = n.child(i);
20
+ if (child) {
21
+ const result = findMethodName(child);
22
+ if (result)
23
+ return result;
24
+ }
25
+ }
26
+ return null;
27
+ }
28
+ const methodName = findMethodName(node);
29
+ if (methodName)
30
+ return methodName;
31
+ }
32
+ if (node.type === 'class_declaration') {
33
+ for (let i = 0; i < node.childCount; i++) {
34
+ const child = node.child(i);
35
+ if (child && (child.type === 'identifier' || child.type === 'type_identifier' || child.type === 'name')) {
36
+ const text = source.slice(child.startIndex, child.endIndex);
37
+ if (text !== 'class') {
38
+ return text;
39
+ }
40
+ }
41
+ }
42
+ }
43
+ function findAnyIdentifier(n) {
44
+ if (n.type === 'identifier' || n.type === 'name' || n.type === 'property_identifier') {
45
+ const text = source.slice(n.startIndex, n.endIndex);
46
+ if (!['public', 'private', 'protected', 'static', 'function', 'class', 'abstract', 'final', 'const', 'var', 'let'].includes(text)) {
47
+ return text;
48
+ }
49
+ }
50
+ for (let i = 0; i < n.childCount; i++) {
51
+ const child = n.child(i);
52
+ if (child) {
53
+ const result = findAnyIdentifier(child);
54
+ if (result)
55
+ return result;
56
+ }
57
+ }
58
+ return null;
59
+ }
60
+ const anyIdentifier = findAnyIdentifier(node);
61
+ if (anyIdentifier)
62
+ return anyIdentifier;
63
+ const code = source.slice(node.startIndex, node.endIndex);
64
+ const phpMethodMatch = code.match(/(?:public|private|protected)?\s*(?:static)?\s*function\s+([a-zA-Z_][a-zA-Z0-9_]*)/);
65
+ if (phpMethodMatch)
66
+ return phpMethodMatch[1];
67
+ const jsFunctionMatch = code.match(/function\s+([a-zA-Z_][a-zA-Z0-9_]*)/);
68
+ if (jsFunctionMatch)
69
+ return jsFunctionMatch[1];
70
+ const jsMethodMatch = code.match(/([a-zA-Z_][a-zA-Z0-9_]*)\s*\([^)]*\)\s*\{/);
71
+ if (jsMethodMatch)
72
+ return jsMethodMatch[1];
73
+ const classMatch = code.match(/class\s+([a-zA-Z_][a-zA-Z0-9_]*)/);
74
+ if (classMatch)
75
+ return classMatch[1];
76
+ return `${node.type}_${node.startIndex}`;
77
+ }
78
+ //# sourceMappingURL=symbol-extractor.js.map