@danielsimonjr/memoryjs 1.0.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/LICENSE +22 -0
- package/README.md +266 -0
- package/dist/core/EntityManager.d.ts +268 -0
- package/dist/core/EntityManager.d.ts.map +1 -0
- package/dist/core/EntityManager.js +512 -0
- package/dist/core/EntityManager.js.map +1 -0
- package/dist/core/GraphEventEmitter.d.ts +202 -0
- package/dist/core/GraphEventEmitter.d.ts.map +1 -0
- package/dist/core/GraphEventEmitter.js +347 -0
- package/dist/core/GraphEventEmitter.js.map +1 -0
- package/dist/core/GraphStorage.d.ts +395 -0
- package/dist/core/GraphStorage.d.ts.map +1 -0
- package/dist/core/GraphStorage.js +786 -0
- package/dist/core/GraphStorage.js.map +1 -0
- package/dist/core/GraphTraversal.d.ts +141 -0
- package/dist/core/GraphTraversal.d.ts.map +1 -0
- package/dist/core/GraphTraversal.js +574 -0
- package/dist/core/GraphTraversal.js.map +1 -0
- package/dist/core/HierarchyManager.d.ts +111 -0
- package/dist/core/HierarchyManager.d.ts.map +1 -0
- package/dist/core/HierarchyManager.js +225 -0
- package/dist/core/HierarchyManager.js.map +1 -0
- package/dist/core/ManagerContext.d.ts +76 -0
- package/dist/core/ManagerContext.d.ts.map +1 -0
- package/dist/core/ManagerContext.js +129 -0
- package/dist/core/ManagerContext.js.map +1 -0
- package/dist/core/ObservationManager.d.ts +85 -0
- package/dist/core/ObservationManager.d.ts.map +1 -0
- package/dist/core/ObservationManager.js +124 -0
- package/dist/core/ObservationManager.js.map +1 -0
- package/dist/core/RelationManager.d.ts +131 -0
- package/dist/core/RelationManager.d.ts.map +1 -0
- package/dist/core/RelationManager.js +212 -0
- package/dist/core/RelationManager.js.map +1 -0
- package/dist/core/SQLiteStorage.d.ts +354 -0
- package/dist/core/SQLiteStorage.d.ts.map +1 -0
- package/dist/core/SQLiteStorage.js +919 -0
- package/dist/core/SQLiteStorage.js.map +1 -0
- package/dist/core/StorageFactory.d.ts +45 -0
- package/dist/core/StorageFactory.d.ts.map +1 -0
- package/dist/core/StorageFactory.js +65 -0
- package/dist/core/StorageFactory.js.map +1 -0
- package/dist/core/TransactionManager.d.ts +464 -0
- package/dist/core/TransactionManager.d.ts.map +1 -0
- package/dist/core/TransactionManager.js +869 -0
- package/dist/core/TransactionManager.js.map +1 -0
- package/dist/core/index.d.ts +17 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +20 -0
- package/dist/core/index.js.map +1 -0
- package/dist/features/AnalyticsManager.d.ts +44 -0
- package/dist/features/AnalyticsManager.d.ts.map +1 -0
- package/dist/features/AnalyticsManager.js +224 -0
- package/dist/features/AnalyticsManager.js.map +1 -0
- package/dist/features/ArchiveManager.d.ts +133 -0
- package/dist/features/ArchiveManager.d.ts.map +1 -0
- package/dist/features/ArchiveManager.js +282 -0
- package/dist/features/ArchiveManager.js.map +1 -0
- package/dist/features/CompressionManager.d.ts +119 -0
- package/dist/features/CompressionManager.d.ts.map +1 -0
- package/dist/features/CompressionManager.js +470 -0
- package/dist/features/CompressionManager.js.map +1 -0
- package/dist/features/IOManager.d.ts +225 -0
- package/dist/features/IOManager.d.ts.map +1 -0
- package/dist/features/IOManager.js +1093 -0
- package/dist/features/IOManager.js.map +1 -0
- package/dist/features/KeywordExtractor.d.ts +61 -0
- package/dist/features/KeywordExtractor.d.ts.map +1 -0
- package/dist/features/KeywordExtractor.js +127 -0
- package/dist/features/KeywordExtractor.js.map +1 -0
- package/dist/features/ObservationNormalizer.d.ts +90 -0
- package/dist/features/ObservationNormalizer.d.ts.map +1 -0
- package/dist/features/ObservationNormalizer.js +194 -0
- package/dist/features/ObservationNormalizer.js.map +1 -0
- package/dist/features/StreamingExporter.d.ts +128 -0
- package/dist/features/StreamingExporter.d.ts.map +1 -0
- package/dist/features/StreamingExporter.js +212 -0
- package/dist/features/StreamingExporter.js.map +1 -0
- package/dist/features/TagManager.d.ts +147 -0
- package/dist/features/TagManager.d.ts.map +1 -0
- package/dist/features/TagManager.js +211 -0
- package/dist/features/TagManager.js.map +1 -0
- package/dist/features/index.d.ts +14 -0
- package/dist/features/index.d.ts.map +1 -0
- package/dist/features/index.js +15 -0
- package/dist/features/index.js.map +1 -0
- package/dist/index.d.ts +15 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/index.js.map +1 -0
- package/dist/search/BM25Search.d.ts +148 -0
- package/dist/search/BM25Search.d.ts.map +1 -0
- package/dist/search/BM25Search.js +340 -0
- package/dist/search/BM25Search.js.map +1 -0
- package/dist/search/BasicSearch.d.ts +51 -0
- package/dist/search/BasicSearch.d.ts.map +1 -0
- package/dist/search/BasicSearch.js +138 -0
- package/dist/search/BasicSearch.js.map +1 -0
- package/dist/search/BooleanSearch.d.ts +98 -0
- package/dist/search/BooleanSearch.d.ts.map +1 -0
- package/dist/search/BooleanSearch.js +431 -0
- package/dist/search/BooleanSearch.js.map +1 -0
- package/dist/search/EarlyTerminationManager.d.ts +140 -0
- package/dist/search/EarlyTerminationManager.d.ts.map +1 -0
- package/dist/search/EarlyTerminationManager.js +280 -0
- package/dist/search/EarlyTerminationManager.js.map +1 -0
- package/dist/search/EmbeddingCache.d.ts +175 -0
- package/dist/search/EmbeddingCache.d.ts.map +1 -0
- package/dist/search/EmbeddingCache.js +247 -0
- package/dist/search/EmbeddingCache.js.map +1 -0
- package/dist/search/EmbeddingService.d.ts +277 -0
- package/dist/search/EmbeddingService.d.ts.map +1 -0
- package/dist/search/EmbeddingService.js +531 -0
- package/dist/search/EmbeddingService.js.map +1 -0
- package/dist/search/FuzzySearch.d.ts +118 -0
- package/dist/search/FuzzySearch.d.ts.map +1 -0
- package/dist/search/FuzzySearch.js +313 -0
- package/dist/search/FuzzySearch.js.map +1 -0
- package/dist/search/HybridScorer.d.ts +181 -0
- package/dist/search/HybridScorer.d.ts.map +1 -0
- package/dist/search/HybridScorer.js +258 -0
- package/dist/search/HybridScorer.js.map +1 -0
- package/dist/search/HybridSearchManager.d.ts +80 -0
- package/dist/search/HybridSearchManager.d.ts.map +1 -0
- package/dist/search/HybridSearchManager.js +188 -0
- package/dist/search/HybridSearchManager.js.map +1 -0
- package/dist/search/IncrementalIndexer.d.ts +201 -0
- package/dist/search/IncrementalIndexer.d.ts.map +1 -0
- package/dist/search/IncrementalIndexer.js +343 -0
- package/dist/search/IncrementalIndexer.js.map +1 -0
- package/dist/search/OptimizedInvertedIndex.d.ts +163 -0
- package/dist/search/OptimizedInvertedIndex.d.ts.map +1 -0
- package/dist/search/OptimizedInvertedIndex.js +359 -0
- package/dist/search/OptimizedInvertedIndex.js.map +1 -0
- package/dist/search/ParallelSearchExecutor.d.ts +172 -0
- package/dist/search/ParallelSearchExecutor.d.ts.map +1 -0
- package/dist/search/ParallelSearchExecutor.js +310 -0
- package/dist/search/ParallelSearchExecutor.js.map +1 -0
- package/dist/search/QuantizedVectorStore.d.ts +171 -0
- package/dist/search/QuantizedVectorStore.d.ts.map +1 -0
- package/dist/search/QuantizedVectorStore.js +308 -0
- package/dist/search/QuantizedVectorStore.js.map +1 -0
- package/dist/search/QueryAnalyzer.d.ts +76 -0
- package/dist/search/QueryAnalyzer.d.ts.map +1 -0
- package/dist/search/QueryAnalyzer.js +228 -0
- package/dist/search/QueryAnalyzer.js.map +1 -0
- package/dist/search/QueryCostEstimator.d.ts +244 -0
- package/dist/search/QueryCostEstimator.d.ts.map +1 -0
- package/dist/search/QueryCostEstimator.js +653 -0
- package/dist/search/QueryCostEstimator.js.map +1 -0
- package/dist/search/QueryPlanCache.d.ts +220 -0
- package/dist/search/QueryPlanCache.d.ts.map +1 -0
- package/dist/search/QueryPlanCache.js +380 -0
- package/dist/search/QueryPlanCache.js.map +1 -0
- package/dist/search/QueryPlanner.d.ts +58 -0
- package/dist/search/QueryPlanner.d.ts.map +1 -0
- package/dist/search/QueryPlanner.js +138 -0
- package/dist/search/QueryPlanner.js.map +1 -0
- package/dist/search/RankedSearch.d.ts +71 -0
- package/dist/search/RankedSearch.d.ts.map +1 -0
- package/dist/search/RankedSearch.js +239 -0
- package/dist/search/RankedSearch.js.map +1 -0
- package/dist/search/ReflectionManager.d.ts +120 -0
- package/dist/search/ReflectionManager.d.ts.map +1 -0
- package/dist/search/ReflectionManager.js +232 -0
- package/dist/search/ReflectionManager.js.map +1 -0
- package/dist/search/SavedSearchManager.d.ts +79 -0
- package/dist/search/SavedSearchManager.d.ts.map +1 -0
- package/dist/search/SavedSearchManager.js +147 -0
- package/dist/search/SavedSearchManager.js.map +1 -0
- package/dist/search/SearchFilterChain.d.ts +120 -0
- package/dist/search/SearchFilterChain.d.ts.map +1 -0
- package/dist/search/SearchFilterChain.js +186 -0
- package/dist/search/SearchFilterChain.js.map +1 -0
- package/dist/search/SearchManager.d.ts +326 -0
- package/dist/search/SearchManager.d.ts.map +1 -0
- package/dist/search/SearchManager.js +454 -0
- package/dist/search/SearchManager.js.map +1 -0
- package/dist/search/SearchSuggestions.d.ts +27 -0
- package/dist/search/SearchSuggestions.d.ts.map +1 -0
- package/dist/search/SearchSuggestions.js +58 -0
- package/dist/search/SearchSuggestions.js.map +1 -0
- package/dist/search/SemanticSearch.d.ts +149 -0
- package/dist/search/SemanticSearch.d.ts.map +1 -0
- package/dist/search/SemanticSearch.js +324 -0
- package/dist/search/SemanticSearch.js.map +1 -0
- package/dist/search/SymbolicSearch.d.ts +61 -0
- package/dist/search/SymbolicSearch.d.ts.map +1 -0
- package/dist/search/SymbolicSearch.js +164 -0
- package/dist/search/SymbolicSearch.js.map +1 -0
- package/dist/search/TFIDFEventSync.d.ts +85 -0
- package/dist/search/TFIDFEventSync.d.ts.map +1 -0
- package/dist/search/TFIDFEventSync.js +134 -0
- package/dist/search/TFIDFEventSync.js.map +1 -0
- package/dist/search/TFIDFIndexManager.d.ts +151 -0
- package/dist/search/TFIDFIndexManager.d.ts.map +1 -0
- package/dist/search/TFIDFIndexManager.js +433 -0
- package/dist/search/TFIDFIndexManager.js.map +1 -0
- package/dist/search/VectorStore.d.ts +235 -0
- package/dist/search/VectorStore.d.ts.map +1 -0
- package/dist/search/VectorStore.js +312 -0
- package/dist/search/VectorStore.js.map +1 -0
- package/dist/search/index.d.ts +35 -0
- package/dist/search/index.d.ts.map +1 -0
- package/dist/search/index.js +53 -0
- package/dist/search/index.js.map +1 -0
- package/dist/types/index.d.ts +13 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +13 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/types.d.ts +1811 -0
- package/dist/types/types.d.ts.map +1 -0
- package/dist/types/types.js +10 -0
- package/dist/types/types.js.map +1 -0
- package/dist/utils/BatchProcessor.d.ts +271 -0
- package/dist/utils/BatchProcessor.d.ts.map +1 -0
- package/dist/utils/BatchProcessor.js +377 -0
- package/dist/utils/BatchProcessor.js.map +1 -0
- package/dist/utils/MemoryMonitor.d.ts +176 -0
- package/dist/utils/MemoryMonitor.d.ts.map +1 -0
- package/dist/utils/MemoryMonitor.js +306 -0
- package/dist/utils/MemoryMonitor.js.map +1 -0
- package/dist/utils/WorkerPoolManager.d.ts +233 -0
- package/dist/utils/WorkerPoolManager.d.ts.map +1 -0
- package/dist/utils/WorkerPoolManager.js +421 -0
- package/dist/utils/WorkerPoolManager.js.map +1 -0
- package/dist/utils/compressedCache.d.ts +221 -0
- package/dist/utils/compressedCache.d.ts.map +1 -0
- package/dist/utils/compressedCache.js +349 -0
- package/dist/utils/compressedCache.js.map +1 -0
- package/dist/utils/compressionUtil.d.ts +214 -0
- package/dist/utils/compressionUtil.d.ts.map +1 -0
- package/dist/utils/compressionUtil.js +248 -0
- package/dist/utils/compressionUtil.js.map +1 -0
- package/dist/utils/constants.d.ts +245 -0
- package/dist/utils/constants.d.ts.map +1 -0
- package/dist/utils/constants.js +253 -0
- package/dist/utils/constants.js.map +1 -0
- package/dist/utils/entityUtils.d.ts +379 -0
- package/dist/utils/entityUtils.d.ts.map +1 -0
- package/dist/utils/entityUtils.js +649 -0
- package/dist/utils/entityUtils.js.map +1 -0
- package/dist/utils/errors.d.ts +95 -0
- package/dist/utils/errors.d.ts.map +1 -0
- package/dist/utils/errors.js +146 -0
- package/dist/utils/errors.js.map +1 -0
- package/dist/utils/formatters.d.ts +145 -0
- package/dist/utils/formatters.d.ts.map +1 -0
- package/dist/utils/formatters.js +133 -0
- package/dist/utils/formatters.js.map +1 -0
- package/dist/utils/index.d.ts +26 -0
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +88 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/indexes.d.ts +270 -0
- package/dist/utils/indexes.d.ts.map +1 -0
- package/dist/utils/indexes.js +527 -0
- package/dist/utils/indexes.js.map +1 -0
- package/dist/utils/logger.d.ts +31 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +41 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/operationUtils.d.ts +124 -0
- package/dist/utils/operationUtils.d.ts.map +1 -0
- package/dist/utils/operationUtils.js +176 -0
- package/dist/utils/operationUtils.js.map +1 -0
- package/dist/utils/parallelUtils.d.ts +76 -0
- package/dist/utils/parallelUtils.d.ts.map +1 -0
- package/dist/utils/parallelUtils.js +192 -0
- package/dist/utils/parallelUtils.js.map +1 -0
- package/dist/utils/schemas.d.ts +556 -0
- package/dist/utils/schemas.d.ts.map +1 -0
- package/dist/utils/schemas.js +485 -0
- package/dist/utils/schemas.js.map +1 -0
- package/dist/utils/searchAlgorithms.d.ts +99 -0
- package/dist/utils/searchAlgorithms.d.ts.map +1 -0
- package/dist/utils/searchAlgorithms.js +168 -0
- package/dist/utils/searchAlgorithms.js.map +1 -0
- package/dist/utils/searchCache.d.ts +108 -0
- package/dist/utils/searchCache.d.ts.map +1 -0
- package/dist/utils/searchCache.js +210 -0
- package/dist/utils/searchCache.js.map +1 -0
- package/dist/utils/taskScheduler.d.ts +294 -0
- package/dist/utils/taskScheduler.d.ts.map +1 -0
- package/dist/utils/taskScheduler.js +487 -0
- package/dist/utils/taskScheduler.js.map +1 -0
- package/dist/workers/index.d.ts +12 -0
- package/dist/workers/index.d.ts.map +1 -0
- package/dist/workers/index.js +10 -0
- package/dist/workers/index.js.map +1 -0
- package/dist/workers/levenshteinWorker.d.ts +60 -0
- package/dist/workers/levenshteinWorker.d.ts.map +1 -0
- package/dist/workers/levenshteinWorker.js +99 -0
- package/dist/workers/levenshteinWorker.js.map +1 -0
- package/package.json +69 -0
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tag Manager
|
|
3
|
+
*
|
|
4
|
+
* Manages tag aliases and canonical tag resolution.
|
|
5
|
+
*
|
|
6
|
+
* @module features/TagManager
|
|
7
|
+
*/
|
|
8
|
+
import * as fs from 'fs/promises';
|
|
9
|
+
/**
|
|
10
|
+
* Manages tag alias system for synonym mapping.
|
|
11
|
+
*/
|
|
12
|
+
export class TagManager {
|
|
13
|
+
tagAliasesFilePath;
|
|
14
|
+
constructor(tagAliasesFilePath) {
|
|
15
|
+
this.tagAliasesFilePath = tagAliasesFilePath;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* Load all tag aliases from JSONL file.
|
|
19
|
+
*
|
|
20
|
+
* @returns Array of tag aliases
|
|
21
|
+
*/
|
|
22
|
+
async loadTagAliases() {
|
|
23
|
+
try {
|
|
24
|
+
const data = await fs.readFile(this.tagAliasesFilePath, 'utf-8');
|
|
25
|
+
const lines = data.split('\n').filter((line) => line.trim() !== '');
|
|
26
|
+
return lines.map((line) => JSON.parse(line));
|
|
27
|
+
}
|
|
28
|
+
catch (error) {
|
|
29
|
+
if (error instanceof Error && 'code' in error && error.code === 'ENOENT') {
|
|
30
|
+
return [];
|
|
31
|
+
}
|
|
32
|
+
throw error;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Save tag aliases to JSONL file.
|
|
37
|
+
*
|
|
38
|
+
* @param aliases - Array of tag aliases
|
|
39
|
+
*/
|
|
40
|
+
async saveTagAliases(aliases) {
|
|
41
|
+
const lines = aliases.map(a => JSON.stringify(a));
|
|
42
|
+
await fs.writeFile(this.tagAliasesFilePath, lines.join('\n'));
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Resolve a tag through aliases to get its canonical form.
|
|
46
|
+
*
|
|
47
|
+
* This method follows the alias chain to find the canonical (main) tag name.
|
|
48
|
+
* All tags are normalized to lowercase for consistency.
|
|
49
|
+
* If the tag has no alias, it returns the tag itself as canonical.
|
|
50
|
+
*
|
|
51
|
+
* @param tag - Tag to resolve (can be alias or canonical)
|
|
52
|
+
* @returns Canonical tag name (lowercase)
|
|
53
|
+
*
|
|
54
|
+
* @example
|
|
55
|
+
* ```typescript
|
|
56
|
+
* const manager = new TagManager(tagAliasesPath);
|
|
57
|
+
*
|
|
58
|
+
* // Set up: assume "js" is aliased to "javascript"
|
|
59
|
+
* await manager.addTagAlias('js', 'javascript');
|
|
60
|
+
*
|
|
61
|
+
* // Resolve alias to canonical
|
|
62
|
+
* const canonical = await manager.resolveTag('js');
|
|
63
|
+
* console.log(canonical); // "javascript"
|
|
64
|
+
*
|
|
65
|
+
* // Resolve canonical tag (returns as-is)
|
|
66
|
+
* const unchanged = await manager.resolveTag('javascript');
|
|
67
|
+
* console.log(unchanged); // "javascript"
|
|
68
|
+
*
|
|
69
|
+
* // Resolve unknown tag (returns normalized)
|
|
70
|
+
* const unknown = await manager.resolveTag('PYTHON');
|
|
71
|
+
* console.log(unknown); // "python"
|
|
72
|
+
* ```
|
|
73
|
+
*/
|
|
74
|
+
async resolveTag(tag) {
|
|
75
|
+
const aliases = await this.loadTagAliases();
|
|
76
|
+
const normalized = tag.toLowerCase();
|
|
77
|
+
// Check if this tag is an alias
|
|
78
|
+
const alias = aliases.find(a => a.alias === normalized);
|
|
79
|
+
if (alias) {
|
|
80
|
+
return alias.canonical;
|
|
81
|
+
}
|
|
82
|
+
// Return as-is (might be canonical or unaliased tag)
|
|
83
|
+
return normalized;
|
|
84
|
+
}
|
|
85
|
+
/**
|
|
86
|
+
* Add a tag alias (synonym mapping).
|
|
87
|
+
*
|
|
88
|
+
* Creates a mapping from an alias (synonym) to a canonical (main) tag.
|
|
89
|
+
* This enables flexible tagging where users can use different terms
|
|
90
|
+
* that all resolve to the same canonical tag.
|
|
91
|
+
*
|
|
92
|
+
* Validation rules:
|
|
93
|
+
* - Prevents duplicate aliases (same alias can't map to different canonicals)
|
|
94
|
+
* - Prevents chained aliases (alias must point to canonical, not another alias)
|
|
95
|
+
* - All tags are normalized to lowercase
|
|
96
|
+
*
|
|
97
|
+
* @param alias - The alias/synonym (will be normalized to lowercase)
|
|
98
|
+
* @param canonical - The canonical (main) tag name (will be normalized to lowercase)
|
|
99
|
+
* @param description - Optional description explaining the alias relationship
|
|
100
|
+
* @returns Newly created TagAlias object with metadata
|
|
101
|
+
* @throws {Error} If alias already exists or would create chained aliases
|
|
102
|
+
*
|
|
103
|
+
* @example
|
|
104
|
+
* ```typescript
|
|
105
|
+
* const manager = new TagManager(tagAliasesPath);
|
|
106
|
+
*
|
|
107
|
+
* // Create simple alias
|
|
108
|
+
* await manager.addTagAlias('js', 'javascript', 'Common abbreviation');
|
|
109
|
+
*
|
|
110
|
+
* // Create multiple aliases for same canonical
|
|
111
|
+
* await manager.addTagAlias('py', 'python');
|
|
112
|
+
* await manager.addTagAlias('py3', 'python', 'Python 3.x');
|
|
113
|
+
*
|
|
114
|
+
* // Error: duplicate alias
|
|
115
|
+
* try {
|
|
116
|
+
* await manager.addTagAlias('js', 'ecmascript'); // Fails - 'js' already aliased
|
|
117
|
+
* } catch (error) {
|
|
118
|
+
* console.error('Alias already exists');
|
|
119
|
+
* }
|
|
120
|
+
*
|
|
121
|
+
* // Error: chained alias
|
|
122
|
+
* await manager.addTagAlias('js', 'javascript');
|
|
123
|
+
* try {
|
|
124
|
+
* await manager.addTagAlias('javascript', 'ecmascript'); // Fails - can't alias canonical
|
|
125
|
+
* } catch (error) {
|
|
126
|
+
* console.error('Cannot create chained aliases');
|
|
127
|
+
* }
|
|
128
|
+
* ```
|
|
129
|
+
*/
|
|
130
|
+
async addTagAlias(alias, canonical, description) {
|
|
131
|
+
const aliases = await this.loadTagAliases();
|
|
132
|
+
const normalizedAlias = alias.toLowerCase();
|
|
133
|
+
const normalizedCanonical = canonical.toLowerCase();
|
|
134
|
+
// Check if alias already exists
|
|
135
|
+
if (aliases.some(a => a.alias === normalizedAlias)) {
|
|
136
|
+
throw new Error(`Tag alias "${alias}" already exists`);
|
|
137
|
+
}
|
|
138
|
+
// Prevent aliasing to another alias (aliases should point to canonical tags)
|
|
139
|
+
if (aliases.some(a => a.canonical === normalizedAlias)) {
|
|
140
|
+
throw new Error(`Cannot create alias to "${alias}" because it is a canonical tag with existing aliases`);
|
|
141
|
+
}
|
|
142
|
+
const newAlias = {
|
|
143
|
+
alias: normalizedAlias,
|
|
144
|
+
canonical: normalizedCanonical,
|
|
145
|
+
description,
|
|
146
|
+
createdAt: new Date().toISOString(),
|
|
147
|
+
};
|
|
148
|
+
aliases.push(newAlias);
|
|
149
|
+
await this.saveTagAliases(aliases);
|
|
150
|
+
return newAlias;
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* List all tag aliases.
|
|
154
|
+
*
|
|
155
|
+
* @returns Array of all tag aliases
|
|
156
|
+
*/
|
|
157
|
+
async listTagAliases() {
|
|
158
|
+
return await this.loadTagAliases();
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Remove a tag alias.
|
|
162
|
+
*
|
|
163
|
+
* @param alias - Alias to remove
|
|
164
|
+
* @returns True if removed, false if not found
|
|
165
|
+
*/
|
|
166
|
+
async removeTagAlias(alias) {
|
|
167
|
+
const aliases = await this.loadTagAliases();
|
|
168
|
+
const normalizedAlias = alias.toLowerCase();
|
|
169
|
+
const initialLength = aliases.length;
|
|
170
|
+
const filtered = aliases.filter(a => a.alias !== normalizedAlias);
|
|
171
|
+
if (filtered.length === initialLength) {
|
|
172
|
+
return false; // Alias not found
|
|
173
|
+
}
|
|
174
|
+
await this.saveTagAliases(filtered);
|
|
175
|
+
return true;
|
|
176
|
+
}
|
|
177
|
+
/**
|
|
178
|
+
* Get all aliases (synonyms) for a canonical tag.
|
|
179
|
+
*
|
|
180
|
+
* Returns all alias names that resolve to the specified canonical tag.
|
|
181
|
+
* Useful for discovering alternative names users might use for a tag.
|
|
182
|
+
* The canonical tag name is normalized to lowercase.
|
|
183
|
+
*
|
|
184
|
+
* @param canonicalTag - Canonical tag name (will be normalized to lowercase)
|
|
185
|
+
* @returns Array of alias names (all lowercase)
|
|
186
|
+
*
|
|
187
|
+
* @example
|
|
188
|
+
* ```typescript
|
|
189
|
+
* const manager = new TagManager(tagAliasesPath);
|
|
190
|
+
*
|
|
191
|
+
* // Set up some aliases
|
|
192
|
+
* await manager.addTagAlias('js', 'javascript');
|
|
193
|
+
* await manager.addTagAlias('ecmascript', 'javascript');
|
|
194
|
+
* await manager.addTagAlias('es6', 'javascript');
|
|
195
|
+
*
|
|
196
|
+
* // Get all aliases for canonical tag
|
|
197
|
+
* const aliases = await manager.getAliasesForTag('javascript');
|
|
198
|
+
* console.log(aliases); // ['js', 'ecmascript', 'es6']
|
|
199
|
+
*
|
|
200
|
+
* // Empty array if no aliases
|
|
201
|
+
* const noAliases = await manager.getAliasesForTag('python');
|
|
202
|
+
* console.log(noAliases); // []
|
|
203
|
+
* ```
|
|
204
|
+
*/
|
|
205
|
+
async getAliasesForTag(canonicalTag) {
|
|
206
|
+
const aliases = await this.loadTagAliases();
|
|
207
|
+
const normalized = canonicalTag.toLowerCase();
|
|
208
|
+
return aliases.filter(a => a.canonical === normalized).map(a => a.alias);
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
//# sourceMappingURL=TagManager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TagManager.js","sourceRoot":"","sources":["../../src/features/TagManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Features Module Barrel Export
|
|
3
|
+
* Phase 4: Re-extracted specialized managers for single responsibility
|
|
4
|
+
* Phase 7: Added streaming export utilities
|
|
5
|
+
*/
|
|
6
|
+
export { TagManager } from './TagManager.js';
|
|
7
|
+
export { IOManager, type ExportFormat, type ImportFormat, type MergeStrategy, type BackupMetadata, type BackupInfo, } from './IOManager.js';
|
|
8
|
+
export { AnalyticsManager } from './AnalyticsManager.js';
|
|
9
|
+
export { CompressionManager } from './CompressionManager.js';
|
|
10
|
+
export { ArchiveManager, type ArchiveCriteria, type ArchiveOptions, type ArchiveResult, } from './ArchiveManager.js';
|
|
11
|
+
export { StreamingExporter, type StreamResult } from './StreamingExporter.js';
|
|
12
|
+
export { ObservationNormalizer, type NormalizationOptions, type NormalizationResult, } from './ObservationNormalizer.js';
|
|
13
|
+
export { KeywordExtractor, type ScoredKeyword, } from './KeywordExtractor.js';
|
|
14
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/features/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,SAAS,EACT,KAAK,YAAY,EACjB,KAAK,YAAY,EACjB,KAAK,aAAa,EAClB,KAAK,cAAc,EACnB,KAAK,UAAU,GAChB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EACL,cAAc,EACd,KAAK,eAAe,EACpB,KAAK,cAAc,EACnB,KAAK,aAAa,GACnB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,iBAAiB,EAAE,KAAK,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAG9E,OAAO,EACL,qBAAqB,EACrB,KAAK,oBAAoB,EACzB,KAAK,mBAAmB,GACzB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACL,gBAAgB,EAChB,KAAK,aAAa,GACnB,MAAM,uBAAuB,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Features Module Barrel Export
|
|
3
|
+
* Phase 4: Re-extracted specialized managers for single responsibility
|
|
4
|
+
* Phase 7: Added streaming export utilities
|
|
5
|
+
*/
|
|
6
|
+
export { TagManager } from './TagManager.js';
|
|
7
|
+
export { IOManager, } from './IOManager.js';
|
|
8
|
+
export { AnalyticsManager } from './AnalyticsManager.js';
|
|
9
|
+
export { CompressionManager } from './CompressionManager.js';
|
|
10
|
+
export { ArchiveManager, } from './ArchiveManager.js';
|
|
11
|
+
export { StreamingExporter } from './StreamingExporter.js';
|
|
12
|
+
// Phase 11 Sprint 5: Semantic Compression
|
|
13
|
+
export { ObservationNormalizer, } from './ObservationNormalizer.js';
|
|
14
|
+
export { KeywordExtractor, } from './KeywordExtractor.js';
|
|
15
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/features/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EACL,SAAS,GAMV,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EACL,cAAc,GAIf,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,iBAAiB,EAAqB,MAAM,wBAAwB,CAAC;AAE9E,0CAA0C;AAC1C,OAAO,EACL,qBAAqB,GAGtB,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACL,gBAAgB,GAEjB,MAAM,uBAAuB,CAAC"}
|
package/dist/index.d.ts
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MemoryJS - Knowledge Graph Storage Library
|
|
3
|
+
*
|
|
4
|
+
* A high-performance TypeScript library for knowledge graph storage
|
|
5
|
+
* with hierarchical organization, advanced search, and event-driven architecture.
|
|
6
|
+
*
|
|
7
|
+
* @packageDocumentation
|
|
8
|
+
* @module @danielsimonjr/memoryjs
|
|
9
|
+
*/
|
|
10
|
+
export * from './types/index.js';
|
|
11
|
+
export * from './utils/index.js';
|
|
12
|
+
export * from './core/index.js';
|
|
13
|
+
export * from './features/index.js';
|
|
14
|
+
export * from './search/index.js';
|
|
15
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,cAAc,kBAAkB,CAAC;AAGjC,cAAc,kBAAkB,CAAC;AAGjC,cAAc,iBAAiB,CAAC;AAGhC,cAAc,qBAAqB,CAAC;AAGpC,cAAc,mBAAmB,CAAC"}
|
package/dist/index.js
ADDED
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* MemoryJS - Knowledge Graph Storage Library
|
|
3
|
+
*
|
|
4
|
+
* A high-performance TypeScript library for knowledge graph storage
|
|
5
|
+
* with hierarchical organization, advanced search, and event-driven architecture.
|
|
6
|
+
*
|
|
7
|
+
* @packageDocumentation
|
|
8
|
+
* @module @danielsimonjr/memoryjs
|
|
9
|
+
*/
|
|
10
|
+
// Export all types
|
|
11
|
+
export * from './types/index.js';
|
|
12
|
+
// Export all utilities
|
|
13
|
+
export * from './utils/index.js';
|
|
14
|
+
// Export core infrastructure
|
|
15
|
+
export * from './core/index.js';
|
|
16
|
+
// Export feature managers
|
|
17
|
+
export * from './features/index.js';
|
|
18
|
+
// Export search system
|
|
19
|
+
export * from './search/index.js';
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,mBAAmB;AACnB,cAAc,kBAAkB,CAAC;AAEjC,uBAAuB;AACvB,cAAc,kBAAkB,CAAC;AAEjC,6BAA6B;AAC7B,cAAc,iBAAiB,CAAC;AAEhC,0BAA0B;AAC1B,cAAc,qBAAqB,CAAC;AAEpC,uBAAuB;AACvB,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* BM25 Search
|
|
3
|
+
*
|
|
4
|
+
* BM25 (Best Matching 25) relevance scoring algorithm for lexical search.
|
|
5
|
+
* Provides improved ranking over TF-IDF by incorporating document length normalization.
|
|
6
|
+
*
|
|
7
|
+
* Phase 12 Sprint 3: Search Algorithm Optimization
|
|
8
|
+
*
|
|
9
|
+
* @module search/BM25Search
|
|
10
|
+
*/
|
|
11
|
+
import type { SearchResult } from '../types/index.js';
|
|
12
|
+
import type { GraphStorage } from '../core/GraphStorage.js';
|
|
13
|
+
/**
|
|
14
|
+
* Common English stopwords to filter from queries and documents.
|
|
15
|
+
* These words are too common to provide meaningful ranking signal.
|
|
16
|
+
*/
|
|
17
|
+
export declare const STOPWORDS: Set<string>;
|
|
18
|
+
/**
|
|
19
|
+
* BM25 index entry for a single document.
|
|
20
|
+
*/
|
|
21
|
+
export interface BM25DocumentEntry {
|
|
22
|
+
/** Entity name */
|
|
23
|
+
entityName: string;
|
|
24
|
+
/** Term frequencies in this document */
|
|
25
|
+
termFreqs: Map<string, number>;
|
|
26
|
+
/** Total number of tokens in document */
|
|
27
|
+
docLength: number;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* BM25 index structure.
|
|
31
|
+
*/
|
|
32
|
+
export interface BM25Index {
|
|
33
|
+
/** Document entries keyed by entity name */
|
|
34
|
+
documents: Map<string, BM25DocumentEntry>;
|
|
35
|
+
/** Document frequency for each term (number of docs containing term) */
|
|
36
|
+
documentFrequency: Map<string, number>;
|
|
37
|
+
/** Average document length */
|
|
38
|
+
avgDocLength: number;
|
|
39
|
+
/** Total number of documents */
|
|
40
|
+
totalDocs: number;
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* BM25 configuration parameters.
|
|
44
|
+
*/
|
|
45
|
+
export interface BM25Config {
|
|
46
|
+
/** Term frequency saturation parameter (default: 1.2) */
|
|
47
|
+
k1: number;
|
|
48
|
+
/** Length normalization parameter (default: 0.75) */
|
|
49
|
+
b: number;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Default BM25 parameters based on research recommendations.
|
|
53
|
+
*/
|
|
54
|
+
export declare const DEFAULT_BM25_CONFIG: BM25Config;
|
|
55
|
+
/**
|
|
56
|
+
* BM25 Search implementation.
|
|
57
|
+
*
|
|
58
|
+
* BM25 improves over TF-IDF by:
|
|
59
|
+
* 1. Saturating term frequency - prevents long documents from dominating
|
|
60
|
+
* 2. Document length normalization - accounts for varying document sizes
|
|
61
|
+
*
|
|
62
|
+
* Formula:
|
|
63
|
+
* score(D,Q) = sum_i( IDF(qi) * (f(qi,D) * (k1 + 1)) / (f(qi,D) + k1 * (1 - b + b * |D|/avgdl)) )
|
|
64
|
+
*
|
|
65
|
+
* Where:
|
|
66
|
+
* - f(qi,D) is the term frequency of qi in document D
|
|
67
|
+
* - |D| is the length of document D
|
|
68
|
+
* - avgdl is the average document length
|
|
69
|
+
* - k1 and b are free parameters
|
|
70
|
+
*
|
|
71
|
+
* @example
|
|
72
|
+
* ```typescript
|
|
73
|
+
* const bm25 = new BM25Search(storage);
|
|
74
|
+
* await bm25.buildIndex();
|
|
75
|
+
* const results = await bm25.search('machine learning');
|
|
76
|
+
* ```
|
|
77
|
+
*/
|
|
78
|
+
export declare class BM25Search {
|
|
79
|
+
private storage;
|
|
80
|
+
private index;
|
|
81
|
+
private config;
|
|
82
|
+
constructor(storage: GraphStorage, config?: Partial<BM25Config>);
|
|
83
|
+
/**
|
|
84
|
+
* Get the current configuration.
|
|
85
|
+
*/
|
|
86
|
+
getConfig(): BM25Config;
|
|
87
|
+
/**
|
|
88
|
+
* Update configuration parameters.
|
|
89
|
+
*
|
|
90
|
+
* @param config - New configuration values
|
|
91
|
+
*/
|
|
92
|
+
setConfig(config: Partial<BM25Config>): void;
|
|
93
|
+
/**
|
|
94
|
+
* Tokenize text into lowercase terms with stopword filtering.
|
|
95
|
+
*
|
|
96
|
+
* @param text - Text to tokenize
|
|
97
|
+
* @param filterStopwords - Whether to filter stopwords (default: true)
|
|
98
|
+
* @returns Array of lowercase tokens
|
|
99
|
+
*/
|
|
100
|
+
tokenize(text: string, filterStopwords?: boolean): string[];
|
|
101
|
+
/**
|
|
102
|
+
* Build the BM25 index from the current graph.
|
|
103
|
+
*
|
|
104
|
+
* Should be called after significant graph changes.
|
|
105
|
+
*/
|
|
106
|
+
buildIndex(): Promise<void>;
|
|
107
|
+
/**
|
|
108
|
+
* Search using the BM25 algorithm.
|
|
109
|
+
*
|
|
110
|
+
* @param query - Search query
|
|
111
|
+
* @param limit - Maximum results to return
|
|
112
|
+
* @returns Array of search results sorted by BM25 score
|
|
113
|
+
*/
|
|
114
|
+
search(query: string, limit?: number): Promise<SearchResult[]>;
|
|
115
|
+
/**
|
|
116
|
+
* Update the index for changed entities.
|
|
117
|
+
*
|
|
118
|
+
* @param changedEntityNames - Names of entities that changed
|
|
119
|
+
*/
|
|
120
|
+
update(changedEntityNames: Set<string>): Promise<void>;
|
|
121
|
+
/**
|
|
122
|
+
* Remove an entity from the index.
|
|
123
|
+
*
|
|
124
|
+
* @param entityName - Name of entity to remove
|
|
125
|
+
*/
|
|
126
|
+
remove(entityName: string): boolean;
|
|
127
|
+
/**
|
|
128
|
+
* Clear the index.
|
|
129
|
+
*/
|
|
130
|
+
clearIndex(): void;
|
|
131
|
+
/**
|
|
132
|
+
* Check if the index is built.
|
|
133
|
+
*/
|
|
134
|
+
isIndexed(): boolean;
|
|
135
|
+
/**
|
|
136
|
+
* Get index statistics.
|
|
137
|
+
*/
|
|
138
|
+
getIndexStats(): {
|
|
139
|
+
documents: number;
|
|
140
|
+
terms: number;
|
|
141
|
+
avgDocLength: number;
|
|
142
|
+
} | null;
|
|
143
|
+
/**
|
|
144
|
+
* Convert an entity to searchable text.
|
|
145
|
+
*/
|
|
146
|
+
private entityToText;
|
|
147
|
+
}
|
|
148
|
+
//# sourceMappingURL=BM25Search.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"BM25Search.d.ts","sourceRoot":"","sources":["../../src/search/BM25Search.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAK,EAAU,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAG5D;;;GAGG;AACH,eAAO,MAAM,SAAS,aAWpB,CAAC;AAEH;;GAEG;AACH,MAAM,WAAW,iBAAiB;IAChC,kBAAkB;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,wCAAwC;IACxC,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC/B,yCAAyC;IACzC,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,4CAA4C;IAC5C,SAAS,EAAE,GAAG,CAAC,MAAM,EAAE,iBAAiB,CAAC,CAAC;IAC1C,wEAAwE;IACxE,iBAAiB,EAAE,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACvC,8BAA8B;IAC9B,YAAY,EAAE,MAAM,CAAC;IACrB,gCAAgC;IAChC,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,yDAAyD;IACzD,EAAE,EAAE,MAAM,CAAC;IACX,qDAAqD;IACrD,CAAC,EAAE,MAAM,CAAC;CACX;AAED;;GAEG;AACH,eAAO,MAAM,mBAAmB,EAAE,UAGjC,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,qBAAa,UAAU;IAKnB,OAAO,CAAC,OAAO;IAJjB,OAAO,CAAC,KAAK,CAA0B;IACvC,OAAO,CAAC,MAAM,CAAa;gBAGjB,OAAO,EAAE,YAAY,EAC7B,MAAM,GAAE,OAAO,CAAC,UAAU,CAAM;IAKlC;;OAEG;IACH,SAAS,IAAI,UAAU;IAIvB;;;;OAIG;IACH,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,UAAU,CAAC,GAAG,IAAI;IAI5C;;;;;;OAMG;IACH,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,eAAe,GAAE,OAAc,GAAG,MAAM,EAAE;IAajE;;;;OAIG;IACG,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAgDjC;;;;;;OAMG;IACG,MAAM,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,GAAE,MAA8B,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC;IA8E3F;;;;OAIG;IACG,MAAM,CAAC,kBAAkB,EAAE,GAAG,CAAC,MAAM,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAkE5D;;;;OAIG;IACH,MAAM,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;IAmCnC;;OAEG;IACH,UAAU,IAAI,IAAI;IAIlB;;OAEG;IACH,SAAS,IAAI,OAAO;IAIpB;;OAEG;IACH,aAAa,IAAI;QAAE,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IAWlF;;OAEG;IACH,OAAO,CAAC,YAAY;CAGrB"}
|