codevault 1.6.0 → 1.7.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.
- package/dist/chunking/file-grouper.d.ts +39 -0
- package/dist/chunking/file-grouper.d.ts.map +1 -0
- package/dist/chunking/file-grouper.js +164 -0
- package/dist/chunking/file-grouper.js.map +1 -0
- package/dist/chunking/semantic-chunker.d.ts +37 -0
- package/dist/chunking/semantic-chunker.d.ts.map +1 -0
- package/dist/chunking/semantic-chunker.js +157 -0
- package/dist/chunking/semantic-chunker.js.map +1 -0
- package/dist/chunking/token-counter.d.ts +28 -0
- package/dist/chunking/token-counter.d.ts.map +1 -0
- package/dist/chunking/token-counter.js +178 -0
- package/dist/chunking/token-counter.js.map +1 -0
- package/dist/cli/commands/ask-cmd.d.ts +3 -0
- package/dist/cli/commands/ask-cmd.d.ts.map +1 -0
- package/dist/cli/commands/ask-cmd.js +130 -0
- package/dist/cli/commands/ask-cmd.js.map +1 -0
- package/dist/cli/commands/chat-cmd.d.ts +3 -0
- package/dist/cli/commands/chat-cmd.d.ts.map +1 -0
- package/dist/cli/commands/chat-cmd.js +194 -0
- package/dist/cli/commands/chat-cmd.js.map +1 -0
- package/dist/cli/commands/config-cmd.d.ts +3 -0
- package/dist/cli/commands/config-cmd.d.ts.map +1 -0
- package/dist/cli/commands/config-cmd.js +245 -0
- package/dist/cli/commands/config-cmd.js.map +1 -0
- package/dist/cli/commands/context.d.ts +3 -0
- package/dist/cli/commands/context.d.ts.map +1 -0
- package/dist/cli/commands/context.js +98 -0
- package/dist/cli/commands/context.js.map +1 -0
- package/dist/cli/commands/interactive-config.d.ts +2 -0
- package/dist/cli/commands/interactive-config.d.ts.map +1 -0
- package/dist/cli/commands/interactive-config.js +274 -0
- package/dist/cli/commands/interactive-config.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +401 -0
- package/dist/cli.js.map +1 -0
- package/dist/codemap/io.d.ts +6 -0
- package/dist/codemap/io.d.ts.map +1 -0
- package/dist/codemap/io.js +46 -0
- package/dist/codemap/io.js.map +1 -0
- package/dist/config/apply-env.d.ts +23 -0
- package/dist/config/apply-env.d.ts.map +1 -0
- package/dist/config/apply-env.js +89 -0
- package/dist/config/apply-env.js.map +1 -0
- package/dist/config/constants.d.ts +326 -0
- package/dist/config/constants.d.ts.map +1 -0
- package/dist/config/constants.js +214 -0
- package/dist/config/constants.js.map +1 -0
- package/dist/config/loader.d.ts +57 -0
- package/dist/config/loader.d.ts.map +1 -0
- package/dist/config/loader.js +287 -0
- package/dist/config/loader.js.map +1 -0
- package/dist/config/resolver.d.ts +30 -0
- package/dist/config/resolver.d.ts.map +1 -0
- package/dist/config/resolver.js +29 -0
- package/dist/config/resolver.js.map +1 -0
- package/dist/config/types.d.ts +46 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +2 -0
- package/dist/config/types.js.map +1 -0
- package/dist/context/packs.d.ts +33 -0
- package/dist/context/packs.d.ts.map +1 -0
- package/dist/context/packs.js +180 -0
- package/dist/context/packs.js.map +1 -0
- package/dist/core/IndexerEngine.d.ts +24 -0
- package/dist/core/IndexerEngine.d.ts.map +1 -0
- package/dist/core/IndexerEngine.js +372 -0
- package/dist/core/IndexerEngine.js.map +1 -0
- package/dist/core/SearchService.d.ts +25 -0
- package/dist/core/SearchService.d.ts.map +1 -0
- package/dist/core/SearchService.js +455 -0
- package/dist/core/SearchService.js.map +1 -0
- package/dist/core/batch-indexer.d.ts +56 -0
- package/dist/core/batch-indexer.d.ts.map +1 -0
- package/dist/core/batch-indexer.js +192 -0
- package/dist/core/batch-indexer.js.map +1 -0
- package/dist/core/indexer.d.ts +3 -0
- package/dist/core/indexer.d.ts.map +1 -0
- package/dist/core/indexer.js +6 -0
- package/dist/core/indexer.js.map +1 -0
- package/dist/core/indexing/chunk-pipeline.d.ts +39 -0
- package/dist/core/indexing/chunk-pipeline.d.ts.map +1 -0
- package/dist/core/indexing/chunk-pipeline.js +210 -0
- package/dist/core/indexing/chunk-pipeline.js.map +1 -0
- package/dist/core/indexing/file-scanner.d.ts +11 -0
- package/dist/core/indexing/file-scanner.d.ts.map +1 -0
- package/dist/core/indexing/file-scanner.js +49 -0
- package/dist/core/indexing/file-scanner.js.map +1 -0
- package/dist/core/metadata.d.ts +19 -0
- package/dist/core/metadata.d.ts.map +1 -0
- package/dist/core/metadata.js +161 -0
- package/dist/core/metadata.js.map +1 -0
- package/dist/core/search.d.ts +7 -0
- package/dist/core/search.d.ts.map +1 -0
- package/dist/core/search.js +16 -0
- package/dist/core/search.js.map +1 -0
- package/dist/core/symbol-extractor.d.ts +3 -0
- package/dist/core/symbol-extractor.d.ts.map +1 -0
- package/dist/core/symbol-extractor.js +78 -0
- package/dist/core/symbol-extractor.js.map +1 -0
- package/dist/core/types.d.ts +104 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +2 -0
- package/dist/core/types.js.map +1 -0
- package/dist/database/db.d.ts +101 -0
- package/dist/database/db.d.ts.map +1 -0
- package/dist/database/db.js +326 -0
- package/dist/database/db.js.map +1 -0
- package/dist/indexer/merkle.d.ts +13 -0
- package/dist/indexer/merkle.d.ts.map +1 -0
- package/dist/indexer/merkle.js +86 -0
- package/dist/indexer/merkle.js.map +1 -0
- package/dist/indexer/update.d.ts +19 -0
- package/dist/indexer/update.d.ts.map +1 -0
- package/dist/indexer/update.js +40 -0
- package/dist/indexer/update.js.map +1 -0
- package/dist/indexer/watch.d.ts +21 -0
- package/dist/indexer/watch.d.ts.map +1 -0
- package/dist/indexer/watch.js +224 -0
- package/dist/indexer/watch.js.map +1 -0
- package/dist/languages/rules.d.ts +11 -0
- package/dist/languages/rules.d.ts.map +1 -0
- package/dist/languages/rules.js +371 -0
- package/dist/languages/rules.js.map +1 -0
- package/dist/languages/tree-sitter-loader.d.ts +27 -0
- package/dist/languages/tree-sitter-loader.d.ts.map +1 -0
- package/dist/languages/tree-sitter-loader.js +76 -0
- package/dist/languages/tree-sitter-loader.js.map +1 -0
- package/dist/mcp/handlers/context.d.ts +15 -0
- package/dist/mcp/handlers/context.d.ts.map +1 -0
- package/dist/mcp/handlers/context.js +31 -0
- package/dist/mcp/handlers/context.js.map +1 -0
- package/dist/mcp/handlers/index.d.ts +5 -0
- package/dist/mcp/handlers/index.d.ts.map +1 -0
- package/dist/mcp/handlers/index.js +5 -0
- package/dist/mcp/handlers/index.js.map +1 -0
- package/dist/mcp/handlers/project.d.ts +41 -0
- package/dist/mcp/handlers/project.d.ts.map +1 -0
- package/dist/mcp/handlers/project.js +76 -0
- package/dist/mcp/handlers/project.js.map +1 -0
- package/dist/mcp/handlers/search.d.ts +27 -0
- package/dist/mcp/handlers/search.d.ts.map +1 -0
- package/dist/mcp/handlers/search.js +108 -0
- package/dist/mcp/handlers/search.js.map +1 -0
- package/dist/mcp/handlers/synthesis.d.ts +15 -0
- package/dist/mcp/handlers/synthesis.d.ts.map +1 -0
- package/dist/mcp/handlers/synthesis.js +58 -0
- package/dist/mcp/handlers/synthesis.js.map +1 -0
- package/dist/mcp/schemas.d.ts +166 -0
- package/dist/mcp/schemas.d.ts.map +1 -0
- package/dist/mcp/schemas.js +159 -0
- package/dist/mcp/schemas.js.map +1 -0
- package/dist/mcp/tools/ask-codebase.d.ts +85 -0
- package/dist/mcp/tools/ask-codebase.d.ts.map +1 -0
- package/dist/mcp/tools/ask-codebase.js +125 -0
- package/dist/mcp/tools/ask-codebase.js.map +1 -0
- package/dist/mcp/tools/use-context-pack.d.ts +57 -0
- package/dist/mcp/tools/use-context-pack.d.ts.map +1 -0
- package/dist/mcp/tools/use-context-pack.js +91 -0
- package/dist/mcp/tools/use-context-pack.js.map +1 -0
- package/dist/mcp-server.d.ts +13 -0
- package/dist/mcp-server.d.ts.map +1 -0
- package/dist/mcp-server.js +263 -0
- package/dist/mcp-server.js.map +1 -0
- package/dist/providers/base.d.ts +39 -0
- package/dist/providers/base.d.ts.map +1 -0
- package/dist/providers/base.js +198 -0
- package/dist/providers/base.js.map +1 -0
- package/dist/providers/chat-llm.d.ts +35 -0
- package/dist/providers/chat-llm.d.ts.map +1 -0
- package/dist/providers/chat-llm.js +98 -0
- package/dist/providers/chat-llm.js.map +1 -0
- package/dist/providers/index.d.ts +6 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +12 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/openai.d.ts +18 -0
- package/dist/providers/openai.d.ts.map +1 -0
- package/dist/providers/openai.js +132 -0
- package/dist/providers/openai.js.map +1 -0
- package/dist/providers/token-counter.d.ts +2 -0
- package/dist/providers/token-counter.d.ts.map +1 -0
- package/dist/providers/token-counter.js +18 -0
- package/dist/providers/token-counter.js.map +1 -0
- package/dist/ranking/api-reranker.d.ts +18 -0
- package/dist/ranking/api-reranker.d.ts.map +1 -0
- package/dist/ranking/api-reranker.js +137 -0
- package/dist/ranking/api-reranker.js.map +1 -0
- package/dist/ranking/symbol-boost.d.ts +15 -0
- package/dist/ranking/symbol-boost.d.ts.map +1 -0
- package/dist/ranking/symbol-boost.js +175 -0
- package/dist/ranking/symbol-boost.js.map +1 -0
- package/dist/search/bm25.d.ts +17 -0
- package/dist/search/bm25.d.ts.map +1 -0
- package/dist/search/bm25.js +56 -0
- package/dist/search/bm25.js.map +1 -0
- package/dist/search/hybrid.d.ts +21 -0
- package/dist/search/hybrid.d.ts.map +1 -0
- package/dist/search/hybrid.js +50 -0
- package/dist/search/hybrid.js.map +1 -0
- package/dist/search/scope.d.ts +5 -0
- package/dist/search/scope.d.ts.map +1 -0
- package/dist/search/scope.js +107 -0
- package/dist/search/scope.js.map +1 -0
- package/dist/storage/encrypted-chunks.d.ts +40 -0
- package/dist/storage/encrypted-chunks.d.ts.map +1 -0
- package/dist/storage/encrypted-chunks.js +238 -0
- package/dist/storage/encrypted-chunks.js.map +1 -0
- package/dist/symbols/extract.d.ts +15 -0
- package/dist/symbols/extract.d.ts.map +1 -0
- package/dist/symbols/extract.js +208 -0
- package/dist/symbols/extract.js.map +1 -0
- package/dist/symbols/graph.d.ts +3 -0
- package/dist/symbols/graph.d.ts.map +1 -0
- package/dist/symbols/graph.js +89 -0
- package/dist/symbols/graph.js.map +1 -0
- package/dist/synthesis/conversational-synthesizer.d.ts +61 -0
- package/dist/synthesis/conversational-synthesizer.d.ts.map +1 -0
- package/dist/synthesis/conversational-synthesizer.js +289 -0
- package/dist/synthesis/conversational-synthesizer.js.map +1 -0
- package/dist/synthesis/markdown-formatter.d.ts +13 -0
- package/dist/synthesis/markdown-formatter.d.ts.map +1 -0
- package/dist/synthesis/markdown-formatter.js +104 -0
- package/dist/synthesis/markdown-formatter.js.map +1 -0
- package/dist/synthesis/prompt-builder.d.ts +21 -0
- package/dist/synthesis/prompt-builder.d.ts.map +1 -0
- package/dist/synthesis/prompt-builder.js +129 -0
- package/dist/synthesis/prompt-builder.js.map +1 -0
- package/dist/synthesis/synthesizer.d.ts +30 -0
- package/dist/synthesis/synthesizer.d.ts.map +1 -0
- package/dist/synthesis/synthesizer.js +213 -0
- package/dist/synthesis/synthesizer.js.map +1 -0
- package/dist/tests/rate-limiter.test.d.ts +2 -0
- package/dist/tests/rate-limiter.test.d.ts.map +1 -0
- package/dist/tests/rate-limiter.test.js +11 -0
- package/dist/tests/rate-limiter.test.js.map +1 -0
- package/dist/tests/search-normalization.test.d.ts +2 -0
- package/dist/tests/search-normalization.test.d.ts.map +1 -0
- package/dist/tests/search-normalization.test.js +9 -0
- package/dist/tests/search-normalization.test.js.map +1 -0
- package/dist/tests/semantic-chunker.test.d.ts +2 -0
- package/dist/tests/semantic-chunker.test.d.ts.map +1 -0
- package/dist/tests/semantic-chunker.test.js +48 -0
- package/dist/tests/semantic-chunker.test.js.map +1 -0
- package/dist/tests/simple-lru.test.d.ts +2 -0
- package/dist/tests/simple-lru.test.d.ts.map +1 -0
- package/dist/tests/simple-lru.test.js +21 -0
- package/dist/tests/simple-lru.test.js.map +1 -0
- package/dist/tests/symbol-boost.test.d.ts +2 -0
- package/dist/tests/symbol-boost.test.d.ts.map +1 -0
- package/dist/tests/symbol-boost.test.js +21 -0
- package/dist/tests/symbol-boost.test.js.map +1 -0
- package/dist/types/ast.d.ts +3 -0
- package/dist/types/ast.d.ts.map +1 -0
- package/dist/types/ast.js +2 -0
- package/dist/types/ast.js.map +1 -0
- package/dist/types/codemap.d.ts +58 -0
- package/dist/types/codemap.d.ts.map +1 -0
- package/dist/types/codemap.js +224 -0
- package/dist/types/codemap.js.map +1 -0
- package/dist/types/context-pack.d.ts +47 -0
- package/dist/types/context-pack.d.ts.map +1 -0
- package/dist/types/context-pack.js +44 -0
- package/dist/types/context-pack.js.map +1 -0
- package/dist/types/search.d.ts +15 -0
- package/dist/types/search.d.ts.map +1 -0
- package/dist/types/search.js +11 -0
- package/dist/types/search.js.map +1 -0
- package/dist/utils/cli-ui.d.ts +44 -0
- package/dist/utils/cli-ui.d.ts.map +1 -0
- package/dist/utils/cli-ui.js +139 -0
- package/dist/utils/cli-ui.js.map +1 -0
- package/dist/utils/indexer-with-progress.d.ts +10 -0
- package/dist/utils/indexer-with-progress.d.ts.map +1 -0
- package/dist/utils/indexer-with-progress.js +43 -0
- package/dist/utils/indexer-with-progress.js.map +1 -0
- package/dist/utils/logger.d.ts +55 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +121 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/mutex.d.ts +63 -0
- package/dist/utils/mutex.d.ts.map +1 -0
- package/dist/utils/mutex.js +123 -0
- package/dist/utils/mutex.js.map +1 -0
- package/dist/utils/path-helpers.d.ts +27 -0
- package/dist/utils/path-helpers.d.ts.map +1 -0
- package/dist/utils/path-helpers.js +55 -0
- package/dist/utils/path-helpers.js.map +1 -0
- package/dist/utils/rate-limiter.d.ts +34 -0
- package/dist/utils/rate-limiter.d.ts.map +1 -0
- package/dist/utils/rate-limiter.js +178 -0
- package/dist/utils/rate-limiter.js.map +1 -0
- package/dist/utils/scan-patterns.d.ts +5 -0
- package/dist/utils/scan-patterns.d.ts.map +1 -0
- package/dist/utils/scan-patterns.js +29 -0
- package/dist/utils/scan-patterns.js.map +1 -0
- package/dist/utils/simple-lru.d.ts +10 -0
- package/dist/utils/simple-lru.d.ts.map +1 -0
- package/dist/utils/simple-lru.js +38 -0
- package/dist/utils/simple-lru.js.map +1 -0
- package/package.json +3 -2
|
@@ -0,0 +1,455 @@
|
|
|
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 { readCodemapAsync } 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 { logger } from '../utils/logger.js';
|
|
12
|
+
import { SimpleLRU } from '../utils/simple-lru.js';
|
|
13
|
+
import { readChunkFromDisk } from '../storage/encrypted-chunks.js';
|
|
14
|
+
import { RRF_K, DOC_BOOST, CACHE_CONSTANTS, DOC_BOOST_CONSTANTS, SEARCH_CONSTANTS } from '../config/constants.js';
|
|
15
|
+
import { resolveProviderContext } from '../config/resolver.js';
|
|
16
|
+
export class SearchService {
|
|
17
|
+
bm25Cache;
|
|
18
|
+
chunkCache;
|
|
19
|
+
constructor() {
|
|
20
|
+
this.bm25Cache = new SimpleLRU(CACHE_CONSTANTS.MAX_BM25_CACHE_SIZE);
|
|
21
|
+
this.chunkCache = new SimpleLRU(CACHE_CONSTANTS.MAX_CHUNK_TEXT_CACHE_SIZE);
|
|
22
|
+
}
|
|
23
|
+
clearCaches() {
|
|
24
|
+
logger.debug('Clearing search caches explicitly.');
|
|
25
|
+
this.bm25Cache.clear();
|
|
26
|
+
this.chunkCache.clear();
|
|
27
|
+
}
|
|
28
|
+
async search(query, limit = SEARCH_CONSTANTS.DEFAULT_SEARCH_LIMIT, provider = 'auto', workingPath = '.', scopeOptions = {}) {
|
|
29
|
+
const basePath = path.resolve(workingPath);
|
|
30
|
+
const dbPath = path.join(basePath, '.codevault/codevault.db');
|
|
31
|
+
const chunkDir = path.join(basePath, '.codevault/chunks');
|
|
32
|
+
const codemapPath = path.join(basePath, 'codevault.codemap.json');
|
|
33
|
+
const normalizedQuery = this.normalizeQuery(query);
|
|
34
|
+
const providerContext = resolveProviderContext(basePath);
|
|
35
|
+
if (!normalizedQuery) {
|
|
36
|
+
return this.getOverview(limit, workingPath);
|
|
37
|
+
}
|
|
38
|
+
const normalizedScope = normalizeScopeFilters(scopeOptions);
|
|
39
|
+
const effectiveProvider = normalizedScope.provider || provider;
|
|
40
|
+
const hybridEnabled = normalizedScope.hybrid !== false;
|
|
41
|
+
const bm25Enabled = normalizedScope.bm25 !== false;
|
|
42
|
+
const symbolBoostEnabled = normalizedScope.symbol_boost !== false;
|
|
43
|
+
const embeddingProvider = createEmbeddingProvider(effectiveProvider, providerContext.embedding);
|
|
44
|
+
let db = null;
|
|
45
|
+
try {
|
|
46
|
+
if (!fs.existsSync(dbPath)) {
|
|
47
|
+
return this.createErrorResult('database_not_found', `Database not found at ${dbPath}`, embeddingProvider.getName(), normalizedScope, hybridEnabled, bm25Enabled, symbolBoostEnabled);
|
|
48
|
+
}
|
|
49
|
+
db = new Database(dbPath);
|
|
50
|
+
const chunks = await db.getChunks(embeddingProvider.getName(), embeddingProvider.getDimensions());
|
|
51
|
+
if (chunks.length === 0) {
|
|
52
|
+
return this.createErrorResult('no_chunks_found', `No indexed chunks found`, embeddingProvider.getName(), normalizedScope, hybridEnabled, bm25Enabled, symbolBoostEnabled);
|
|
53
|
+
}
|
|
54
|
+
const codemapData = await readCodemapAsync(codemapPath);
|
|
55
|
+
const scopedChunks = applyScope(chunks, normalizedScope);
|
|
56
|
+
const { chunkInfoById, vectorPool } = await this.buildVectorPool(scopedChunks, embeddingProvider, normalizedQuery);
|
|
57
|
+
if (symbolBoostEnabled) {
|
|
58
|
+
try {
|
|
59
|
+
applySymbolBoost(vectorPool, { query: normalizedQuery, codemap: codemapData });
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
// Silent fail
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
const selectionBudget = Math.max(limit, RRF_K);
|
|
66
|
+
const { fusedResults, bm25Fused, bm25CandidateCount } = this.tryHybridFusion({
|
|
67
|
+
hybridEnabled,
|
|
68
|
+
bm25Enabled,
|
|
69
|
+
selectionBudget,
|
|
70
|
+
normalizedQuery,
|
|
71
|
+
embeddingProvider,
|
|
72
|
+
chunkDir,
|
|
73
|
+
basePath,
|
|
74
|
+
scopedChunks,
|
|
75
|
+
chunkInfoById,
|
|
76
|
+
vectorPool
|
|
77
|
+
});
|
|
78
|
+
let vectorResults = fusedResults.length > 0 ? fusedResults : vectorPool.slice(0, selectionBudget);
|
|
79
|
+
vectorResults = this.sortWithSymbolBoost(vectorResults, symbolBoostEnabled);
|
|
80
|
+
vectorResults = vectorResults.slice(0, limit);
|
|
81
|
+
if (vectorResults.length > 1 && normalizedScope.reranker === 'api') {
|
|
82
|
+
vectorResults = await this.applyReranker(normalizedQuery, vectorResults, chunkDir, basePath, providerContext);
|
|
83
|
+
}
|
|
84
|
+
// Enforce score bounds after boosts/reranking
|
|
85
|
+
vectorResults = vectorResults.map(candidate => ({
|
|
86
|
+
...candidate,
|
|
87
|
+
score: Math.min(1, Math.max(candidate.score ?? 0, 0))
|
|
88
|
+
}));
|
|
89
|
+
const combinedResults = this.mapResults(vectorResults, bm25Fused ? 'hybrid' : 'vector');
|
|
90
|
+
combinedResults.sort((a, b) => {
|
|
91
|
+
if (typeof a.meta?.rerankerScore === 'number' && typeof b.meta?.rerankerScore === 'number') {
|
|
92
|
+
return b.meta.rerankerScore - a.meta.rerankerScore;
|
|
93
|
+
}
|
|
94
|
+
return (b.meta?.score ?? 0) - (a.meta?.score ?? 0);
|
|
95
|
+
});
|
|
96
|
+
if (combinedResults.length === 0) {
|
|
97
|
+
return this.createErrorResult('no_relevant_matches', `No relevant matches found for "${query}"`, embeddingProvider.getName(), normalizedScope, hybridEnabled, bm25Enabled, symbolBoostEnabled);
|
|
98
|
+
}
|
|
99
|
+
if (symbolBoostEnabled && combinedResults.length > 0 && combinedResults[0].meta.score > 0.8) {
|
|
100
|
+
await db.recordIntention(normalizedQuery, query, combinedResults[0].sha, combinedResults[0].meta.score);
|
|
101
|
+
}
|
|
102
|
+
const pattern = normalizedQuery
|
|
103
|
+
.replace(/\b[\w-]+Session\b/gi, '[SESSION]')
|
|
104
|
+
.replace(/\bstripe\b/gi, '[PAYMENT_PROVIDER]')
|
|
105
|
+
.replace(/\b\w+Service\b/gi, '[SERVICE]')
|
|
106
|
+
.replace(/\b\w+Controller\b/gi, '[CONTROLLER]')
|
|
107
|
+
.trim();
|
|
108
|
+
await db.recordQueryPattern(pattern);
|
|
109
|
+
return {
|
|
110
|
+
success: true,
|
|
111
|
+
query,
|
|
112
|
+
searchType: bm25Fused ? 'hybrid' : 'vector',
|
|
113
|
+
vectorResults: vectorResults.length,
|
|
114
|
+
provider: embeddingProvider.getName(),
|
|
115
|
+
scope: normalizedScope,
|
|
116
|
+
reranker: normalizedScope.reranker,
|
|
117
|
+
hybrid: {
|
|
118
|
+
enabled: hybridEnabled,
|
|
119
|
+
bm25Enabled,
|
|
120
|
+
fused: bm25Fused,
|
|
121
|
+
bm25Candidates: bm25CandidateCount
|
|
122
|
+
},
|
|
123
|
+
symbolBoost: {
|
|
124
|
+
enabled: symbolBoostEnabled,
|
|
125
|
+
boosted: symbolBoostEnabled && vectorResults.some((result) => typeof result.symbolBoost === 'number' && result.symbolBoost > 0)
|
|
126
|
+
},
|
|
127
|
+
results: combinedResults
|
|
128
|
+
};
|
|
129
|
+
}
|
|
130
|
+
catch (error) {
|
|
131
|
+
logger.error('Error in searchCode', error);
|
|
132
|
+
return this.createErrorResult('search_error', error.message, embeddingProvider.getName(), normalizedScope, hybridEnabled, bm25Enabled, symbolBoostEnabled);
|
|
133
|
+
}
|
|
134
|
+
finally {
|
|
135
|
+
if (db) {
|
|
136
|
+
try {
|
|
137
|
+
db.close();
|
|
138
|
+
}
|
|
139
|
+
catch { }
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
async getOverview(limit = 20, workingPath = '.') {
|
|
144
|
+
const basePath = path.resolve(workingPath);
|
|
145
|
+
const dbPath = path.join(basePath, '.codevault/codevault.db');
|
|
146
|
+
try {
|
|
147
|
+
if (!fs.existsSync(dbPath)) {
|
|
148
|
+
return { success: false, error: 'database_not_found', message: 'Database not found', provider: 'overview', results: [] };
|
|
149
|
+
}
|
|
150
|
+
const db = new Database(dbPath);
|
|
151
|
+
const chunks = await db.getOverviewChunks(limit);
|
|
152
|
+
db.close();
|
|
153
|
+
const results = chunks.map(chunk => ({
|
|
154
|
+
type: 'code',
|
|
155
|
+
lang: chunk.lang,
|
|
156
|
+
path: chunk.file_path,
|
|
157
|
+
sha: chunk.sha,
|
|
158
|
+
data: null,
|
|
159
|
+
meta: { id: chunk.id, symbol: chunk.symbol, score: 1.0 }
|
|
160
|
+
}));
|
|
161
|
+
return { success: true, provider: 'overview', results };
|
|
162
|
+
}
|
|
163
|
+
catch (error) {
|
|
164
|
+
return { success: false, error: 'overview_error', message: error.message, provider: 'overview', results: [] };
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
async getChunk(sha, workingPath = '.') {
|
|
168
|
+
const basePath = path.resolve(workingPath);
|
|
169
|
+
const chunkDir = path.join(basePath, '.codevault/chunks');
|
|
170
|
+
try {
|
|
171
|
+
const result = readChunkFromDisk({ chunkDir, sha });
|
|
172
|
+
if (!result) {
|
|
173
|
+
return { success: false, error: 'Chunk not found' };
|
|
174
|
+
}
|
|
175
|
+
return { success: true, code: result.code };
|
|
176
|
+
}
|
|
177
|
+
catch (error) {
|
|
178
|
+
if (error && error.code === 'ENCRYPTION_KEY_REQUIRED') {
|
|
179
|
+
return { success: false, error: 'Chunk is encrypted. Configure CODEVAULT_ENCRYPTION_KEY.' };
|
|
180
|
+
}
|
|
181
|
+
return { success: false, error: error.message };
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
// Helpers
|
|
185
|
+
createErrorResult(error, message, provider, scope, hybrid, bm25, symbolBoost) {
|
|
186
|
+
return {
|
|
187
|
+
success: false,
|
|
188
|
+
error,
|
|
189
|
+
message,
|
|
190
|
+
provider,
|
|
191
|
+
scope,
|
|
192
|
+
hybrid: { enabled: hybrid, bm25Enabled: bm25 },
|
|
193
|
+
symbolBoost: { enabled: symbolBoost, boosted: false },
|
|
194
|
+
reranker: scope.reranker,
|
|
195
|
+
results: []
|
|
196
|
+
};
|
|
197
|
+
}
|
|
198
|
+
normalizeQuery(query) {
|
|
199
|
+
return query.toLowerCase().trim().replace(/[¿?]/g, '').replace(/\s+/g, ' ');
|
|
200
|
+
}
|
|
201
|
+
async buildVectorPool(scopedChunks, embeddingProvider, normalizedQuery) {
|
|
202
|
+
const chunkInfoById = new Map();
|
|
203
|
+
const results = [];
|
|
204
|
+
let queryEmbedding = null;
|
|
205
|
+
if (scopedChunks.length > 0) {
|
|
206
|
+
if (embeddingProvider.init) {
|
|
207
|
+
await embeddingProvider.init();
|
|
208
|
+
}
|
|
209
|
+
queryEmbedding = await embeddingProvider.generateEmbedding(normalizedQuery);
|
|
210
|
+
}
|
|
211
|
+
for (const chunk of scopedChunks) {
|
|
212
|
+
const embedding = JSON.parse(chunk.embedding.toString());
|
|
213
|
+
const vectorSimilarity = queryEmbedding ? this.cosineSimilarity(queryEmbedding, embedding) : 0;
|
|
214
|
+
let boostScore = 0;
|
|
215
|
+
if (chunk.codevault_intent && normalizedQuery.includes(chunk.codevault_intent.toLowerCase())) {
|
|
216
|
+
boostScore += DOC_BOOST_CONSTANTS.INTENT_MATCH_BOOST;
|
|
217
|
+
}
|
|
218
|
+
if (chunk.codevault_tags) {
|
|
219
|
+
try {
|
|
220
|
+
const tags = JSON.parse(chunk.codevault_tags || '[]');
|
|
221
|
+
tags.forEach((tag) => {
|
|
222
|
+
if (typeof tag === 'string' && normalizedQuery.includes(tag.toLowerCase())) {
|
|
223
|
+
boostScore += DOC_BOOST_CONSTANTS.TAG_MATCH_BOOST;
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
catch (error) {
|
|
228
|
+
logger.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(1, Math.max(0, vectorSimilarity + boostScore + docBoost));
|
|
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
|
+
// Highest vector scores first
|
|
259
|
+
results.sort((a, b) => b.score - a.score);
|
|
260
|
+
return { chunkInfoById, vectorPool: results };
|
|
261
|
+
}
|
|
262
|
+
tryHybridFusion(params) {
|
|
263
|
+
const { hybridEnabled, bm25Enabled, selectionBudget, normalizedQuery, embeddingProvider, chunkDir, basePath, scopedChunks, chunkInfoById, vectorPool } = params;
|
|
264
|
+
let vectorResults = [];
|
|
265
|
+
let bm25Fused = false;
|
|
266
|
+
let bm25CandidateCount = 0;
|
|
267
|
+
if (hybridEnabled && bm25Enabled) {
|
|
268
|
+
const bm25Index = this.ensureBm25IndexForChunks(basePath, chunkDir, embeddingProvider.getName(), embeddingProvider.getDimensions(), scopedChunks);
|
|
269
|
+
if (bm25Index) {
|
|
270
|
+
const allowedIds = new Set(scopedChunks.map((chunk) => chunk.id));
|
|
271
|
+
const bm25RawResults = bm25Index.search(normalizedQuery, selectionBudget);
|
|
272
|
+
const bm25Results = bm25RawResults.filter(result => allowedIds.has(result.id));
|
|
273
|
+
bm25CandidateCount = bm25Results.length;
|
|
274
|
+
if (bm25Results.length > 0) {
|
|
275
|
+
const fused = reciprocalRankFusion({
|
|
276
|
+
vectorResults: vectorPool.slice(0, selectionBudget).map((item) => ({ id: item.id, score: item.score })),
|
|
277
|
+
bm25Results: bm25Results.map(item => ({ id: item.id, score: item.score })),
|
|
278
|
+
limit: selectionBudget,
|
|
279
|
+
k: RRF_K
|
|
280
|
+
});
|
|
281
|
+
if (fused.length > 0) {
|
|
282
|
+
bm25Fused = true;
|
|
283
|
+
vectorResults = fused
|
|
284
|
+
.map(entry => {
|
|
285
|
+
const info = chunkInfoById.get(entry.id);
|
|
286
|
+
if (!info)
|
|
287
|
+
return null;
|
|
288
|
+
info.hybridScore = entry.score;
|
|
289
|
+
info.bm25Score = entry.bm25Score;
|
|
290
|
+
info.bm25Rank = entry.bm25Rank;
|
|
291
|
+
info.vectorRank = entry.vectorRank;
|
|
292
|
+
return info;
|
|
293
|
+
})
|
|
294
|
+
.filter((item) => item !== null);
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
return { fusedResults: vectorResults, bm25Fused, bm25CandidateCount };
|
|
300
|
+
}
|
|
301
|
+
sortWithSymbolBoost(results, symbolBoostEnabled) {
|
|
302
|
+
const hasSymbolBoost = symbolBoostEnabled && results.some((candidate) => typeof candidate.symbolBoost === 'number' && candidate.symbolBoost > 0);
|
|
303
|
+
if (hasSymbolBoost && results.length > 1) {
|
|
304
|
+
return [...results].sort((a, b) => {
|
|
305
|
+
const scoreA = typeof a.score === 'number' ? a.score : 0;
|
|
306
|
+
const scoreB = typeof b.score === 'number' ? b.score : 0;
|
|
307
|
+
if (scoreB !== scoreA)
|
|
308
|
+
return scoreB - scoreA;
|
|
309
|
+
const boostA = typeof a.symbolBoost === 'number' ? a.symbolBoost : 0;
|
|
310
|
+
const boostB = typeof b.symbolBoost === 'number' ? b.symbolBoost : 0;
|
|
311
|
+
if (boostB !== boostA)
|
|
312
|
+
return boostB - boostA;
|
|
313
|
+
const hybridA = typeof a.hybridScore === 'number' ? a.hybridScore : Number.NEGATIVE_INFINITY;
|
|
314
|
+
const hybridB = typeof b.hybridScore === 'number' ? b.hybridScore : Number.NEGATIVE_INFINITY;
|
|
315
|
+
return hybridB - hybridA;
|
|
316
|
+
});
|
|
317
|
+
}
|
|
318
|
+
return results;
|
|
319
|
+
}
|
|
320
|
+
async applyReranker(normalizedQuery, vectorResults, chunkDir, basePath, providerContext) {
|
|
321
|
+
try {
|
|
322
|
+
const reranked = await rerankWithAPI(normalizedQuery, vectorResults, {
|
|
323
|
+
max: Math.min(SEARCH_CONSTANTS.RERANKER_MAX_CANDIDATES, vectorResults.length),
|
|
324
|
+
getText: (candidate) => {
|
|
325
|
+
const codeText = this.readChunkTextCached(candidate.sha, chunkDir, basePath) || '';
|
|
326
|
+
return this.buildBm25Document(candidate, codeText);
|
|
327
|
+
},
|
|
328
|
+
apiUrl: providerContext.reranker.apiUrl,
|
|
329
|
+
apiKey: providerContext.reranker.apiKey,
|
|
330
|
+
model: providerContext.reranker.model,
|
|
331
|
+
maxTokens: providerContext.reranker.maxTokens
|
|
332
|
+
});
|
|
333
|
+
if (Array.isArray(reranked) && reranked.length === vectorResults.length) {
|
|
334
|
+
return reranked;
|
|
335
|
+
}
|
|
336
|
+
}
|
|
337
|
+
catch (error) {
|
|
338
|
+
// Silent fallback
|
|
339
|
+
}
|
|
340
|
+
return vectorResults;
|
|
341
|
+
}
|
|
342
|
+
mapResults(vectorResults, searchType) {
|
|
343
|
+
return vectorResults.map((result) => {
|
|
344
|
+
const meta = {
|
|
345
|
+
id: result.id,
|
|
346
|
+
symbol: result.symbol,
|
|
347
|
+
score: Math.min(1, Math.max(result.score || 0, 0)),
|
|
348
|
+
intent: result.codevault_intent,
|
|
349
|
+
description: result.codevault_description,
|
|
350
|
+
searchType: searchType,
|
|
351
|
+
vectorScore: result.vectorScore
|
|
352
|
+
};
|
|
353
|
+
if (typeof result.hybridScore === 'number')
|
|
354
|
+
meta.hybridScore = result.hybridScore;
|
|
355
|
+
if (typeof result.bm25Score === 'number')
|
|
356
|
+
meta.bm25Score = result.bm25Score;
|
|
357
|
+
if (typeof result.bm25Rank === 'number')
|
|
358
|
+
meta.bm25Rank = result.bm25Rank;
|
|
359
|
+
if (typeof result.vectorRank === 'number')
|
|
360
|
+
meta.vectorRank = result.vectorRank;
|
|
361
|
+
if (typeof result.rerankerScore === 'number')
|
|
362
|
+
meta.rerankerScore = result.rerankerScore;
|
|
363
|
+
if (typeof result.rerankerRank === 'number')
|
|
364
|
+
meta.rerankerRank = result.rerankerRank;
|
|
365
|
+
if (typeof result.symbolBoost === 'number' && result.symbolBoost > 0) {
|
|
366
|
+
meta.symbolBoost = result.symbolBoost;
|
|
367
|
+
if (Array.isArray(result.symbolBoostSources))
|
|
368
|
+
meta.symbolBoostSources = result.symbolBoostSources;
|
|
369
|
+
}
|
|
370
|
+
if (typeof result.score === 'number' && result.score > 1)
|
|
371
|
+
meta.scoreRaw = result.score;
|
|
372
|
+
return {
|
|
373
|
+
type: 'code',
|
|
374
|
+
lang: result.lang,
|
|
375
|
+
path: result.file_path,
|
|
376
|
+
sha: result.sha,
|
|
377
|
+
data: null,
|
|
378
|
+
meta
|
|
379
|
+
};
|
|
380
|
+
});
|
|
381
|
+
}
|
|
382
|
+
cosineSimilarity(a, b) {
|
|
383
|
+
if (a.length !== b.length)
|
|
384
|
+
return 0;
|
|
385
|
+
let dotProduct = 0, normA = 0, normB = 0;
|
|
386
|
+
for (let i = 0; i < a.length; i++) {
|
|
387
|
+
dotProduct += a[i] * b[i];
|
|
388
|
+
normA += a[i] * a[i];
|
|
389
|
+
normB += b[i] * b[i];
|
|
390
|
+
}
|
|
391
|
+
return dotProduct / (Math.sqrt(normA) * Math.sqrt(normB));
|
|
392
|
+
}
|
|
393
|
+
getBm25CacheKey(basePath, providerName, dimensions) {
|
|
394
|
+
return `${basePath}::${providerName}::${dimensions}`;
|
|
395
|
+
}
|
|
396
|
+
getChunkCacheKey(basePath, sha) {
|
|
397
|
+
return `${basePath}::${sha}`;
|
|
398
|
+
}
|
|
399
|
+
readChunkTextCached(sha, chunkDir, basePath) {
|
|
400
|
+
if (!sha)
|
|
401
|
+
return null;
|
|
402
|
+
const cacheKey = this.getChunkCacheKey(basePath, sha);
|
|
403
|
+
const cached = this.chunkCache.get(cacheKey);
|
|
404
|
+
if (cached !== undefined)
|
|
405
|
+
return cached;
|
|
406
|
+
try {
|
|
407
|
+
const result = readChunkFromDisk({ chunkDir, sha });
|
|
408
|
+
const code = result ? result.code : null;
|
|
409
|
+
this.chunkCache.set(cacheKey, code);
|
|
410
|
+
return code;
|
|
411
|
+
}
|
|
412
|
+
catch {
|
|
413
|
+
this.chunkCache.set(cacheKey, null);
|
|
414
|
+
return null;
|
|
415
|
+
}
|
|
416
|
+
}
|
|
417
|
+
buildBm25Document(chunk, codeText) {
|
|
418
|
+
if (!chunk)
|
|
419
|
+
return '';
|
|
420
|
+
const parts = [
|
|
421
|
+
chunk.symbol,
|
|
422
|
+
chunk.file_path,
|
|
423
|
+
chunk.codevault_description,
|
|
424
|
+
chunk.codevault_intent,
|
|
425
|
+
codeText
|
|
426
|
+
].filter(value => typeof value === 'string' && value.trim().length > 0);
|
|
427
|
+
return parts.join('\n');
|
|
428
|
+
}
|
|
429
|
+
ensureBm25IndexForChunks(basePath, chunkDir, providerName, dimensions, chunks) {
|
|
430
|
+
if (!Array.isArray(chunks) || chunks.length === 0)
|
|
431
|
+
return null;
|
|
432
|
+
const key = this.getBm25CacheKey(basePath, providerName, dimensions);
|
|
433
|
+
let entry = this.bm25Cache.get(key);
|
|
434
|
+
if (!entry) {
|
|
435
|
+
entry = { index: new BM25Index(), added: new Set() };
|
|
436
|
+
this.bm25Cache.set(key, entry);
|
|
437
|
+
}
|
|
438
|
+
const toAdd = [];
|
|
439
|
+
for (const chunk of chunks) {
|
|
440
|
+
if (!chunk || !chunk.id || entry.added.has(chunk.id))
|
|
441
|
+
continue;
|
|
442
|
+
const codeText = this.readChunkTextCached(chunk.sha, chunkDir, basePath);
|
|
443
|
+
const docText = this.buildBm25Document(chunk, codeText);
|
|
444
|
+
if (docText && docText.trim().length > 0) {
|
|
445
|
+
toAdd.push({ id: chunk.id, text: docText });
|
|
446
|
+
}
|
|
447
|
+
entry.added.add(chunk.id);
|
|
448
|
+
}
|
|
449
|
+
if (toAdd.length > 0)
|
|
450
|
+
entry.index.addDocuments(toAdd);
|
|
451
|
+
entry.index.consolidate();
|
|
452
|
+
return entry.index;
|
|
453
|
+
}
|
|
454
|
+
}
|
|
455
|
+
//# sourceMappingURL=SearchService.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchService.js","sourceRoot":"","sources":["../../src/core/SearchService.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import type { EmbeddingProvider } from '../providers/base.js';
|
|
2
|
+
import type { Database } from '../database/db.js';
|
|
3
|
+
interface ChunkToEmbed {
|
|
4
|
+
chunkId: string;
|
|
5
|
+
enhancedEmbeddingText: string;
|
|
6
|
+
params: {
|
|
7
|
+
code: string;
|
|
8
|
+
sha: string;
|
|
9
|
+
lang: string;
|
|
10
|
+
rel: string;
|
|
11
|
+
symbol: string;
|
|
12
|
+
chunkType: string;
|
|
13
|
+
codevaultMetadata: any;
|
|
14
|
+
importantVariables: any[];
|
|
15
|
+
docComments: string | null;
|
|
16
|
+
contextInfo: any;
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
export declare class BatchEmbeddingProcessor {
|
|
20
|
+
private embeddingProvider;
|
|
21
|
+
private db;
|
|
22
|
+
private batch;
|
|
23
|
+
private batchSize;
|
|
24
|
+
private mutex;
|
|
25
|
+
constructor(embeddingProvider: EmbeddingProvider, db: Database, batchSize?: number);
|
|
26
|
+
/**
|
|
27
|
+
* Add a chunk to the batch queue
|
|
28
|
+
*/
|
|
29
|
+
addChunk(chunk: ChunkToEmbed): Promise<void>;
|
|
30
|
+
/**
|
|
31
|
+
* Process any remaining chunks in the batch
|
|
32
|
+
*/
|
|
33
|
+
flush(): Promise<void>;
|
|
34
|
+
/**
|
|
35
|
+
* Process the current batch (with mutex protection)
|
|
36
|
+
*/
|
|
37
|
+
private processBatch;
|
|
38
|
+
/**
|
|
39
|
+
* Process a batch with smart error handling and retry logic
|
|
40
|
+
*/
|
|
41
|
+
private processBatchWithRetry;
|
|
42
|
+
/**
|
|
43
|
+
* Internal batch processing implementation with database transactions
|
|
44
|
+
*/
|
|
45
|
+
private processBatchInternal;
|
|
46
|
+
/**
|
|
47
|
+
* Fall back to processing chunks individually
|
|
48
|
+
*/
|
|
49
|
+
private fallbackToIndividualProcessing;
|
|
50
|
+
/**
|
|
51
|
+
* Get current batch size for monitoring
|
|
52
|
+
*/
|
|
53
|
+
getBatchCount(): number;
|
|
54
|
+
}
|
|
55
|
+
export {};
|
|
56
|
+
//# sourceMappingURL=batch-indexer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"batch-indexer.d.ts","sourceRoot":"","sources":["../../src/core/batch-indexer.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAC;AAC9D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAC;AA8BlD,UAAU,YAAY;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,MAAM,EAAE;QACN,IAAI,EAAE,MAAM,CAAC;QACb,GAAG,EAAE,MAAM,CAAC;QACZ,IAAI,EAAE,MAAM,CAAC;QACb,GAAG,EAAE,MAAM,CAAC;QACZ,MAAM,EAAE,MAAM,CAAC;QACf,SAAS,EAAE,MAAM,CAAC;QAClB,iBAAiB,EAAE,GAAG,CAAC;QACvB,kBAAkB,EAAE,GAAG,EAAE,CAAC;QAC1B,WAAW,EAAE,MAAM,GAAG,IAAI,CAAC;QAC3B,WAAW,EAAE,GAAG,CAAC;KAClB,CAAC;CACH;AAED,qBAAa,uBAAuB;IAMhC,OAAO,CAAC,iBAAiB;IACzB,OAAO,CAAC,EAAE;IANZ,OAAO,CAAC,KAAK,CAAsB;IACnC,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,KAAK,CAAe;gBAGlB,iBAAiB,EAAE,iBAAiB,EACpC,EAAE,EAAE,QAAQ,EACpB,SAAS,GAAE,MAAmB;IAKhC;;OAEG;IACG,QAAQ,CAAC,KAAK,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;IASlD;;OAEG;IACG,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAS5B;;OAEG;YACW,YAAY;IAS1B;;OAEG;YACW,qBAAqB;IAkCnC;;OAEG;YACW,oBAAoB;IA4ClC;;OAEG;YACW,8BAA8B;IA4C5C;;OAEG;IACH,aAAa,IAAI,MAAM;CAGxB"}
|