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