grepmind-core 0.1.0-alpha
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 +190 -0
- package/dist/config/types.d.ts +174 -0
- package/dist/config/types.d.ts.map +1 -0
- package/dist/config/types.js +137 -0
- package/dist/config/types.js.map +1 -0
- package/dist/git.d.ts +98 -0
- package/dist/git.d.ts.map +1 -0
- package/dist/git.js +298 -0
- package/dist/git.js.map +1 -0
- package/dist/git.test.d.ts +7 -0
- package/dist/git.test.d.ts.map +1 -0
- package/dist/git.test.js +242 -0
- package/dist/git.test.js.map +1 -0
- package/dist/index.d.ts +44 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +67 -0
- package/dist/index.js.map +1 -0
- package/dist/indexer/branch.d.ts +121 -0
- package/dist/indexer/branch.d.ts.map +1 -0
- package/dist/indexer/branch.js +451 -0
- package/dist/indexer/branch.js.map +1 -0
- package/dist/indexer/chunker.d.ts +9 -0
- package/dist/indexer/chunker.d.ts.map +1 -0
- package/dist/indexer/chunker.js +70 -0
- package/dist/indexer/chunker.js.map +1 -0
- package/dist/indexer/chunker.test.d.ts +2 -0
- package/dist/indexer/chunker.test.d.ts.map +1 -0
- package/dist/indexer/chunker.test.js +180 -0
- package/dist/indexer/chunker.test.js.map +1 -0
- package/dist/indexer/code/branch.d.ts +155 -0
- package/dist/indexer/code/branch.d.ts.map +1 -0
- package/dist/indexer/code/branch.js +550 -0
- package/dist/indexer/code/branch.js.map +1 -0
- package/dist/indexer/code/branch.test.d.ts +7 -0
- package/dist/indexer/code/branch.test.d.ts.map +1 -0
- package/dist/indexer/code/branch.test.js +241 -0
- package/dist/indexer/code/branch.test.js.map +1 -0
- package/dist/indexer/code/chunker.d.ts +61 -0
- package/dist/indexer/code/chunker.d.ts.map +1 -0
- package/dist/indexer/code/chunker.js +311 -0
- package/dist/indexer/code/chunker.js.map +1 -0
- package/dist/indexer/code/chunker.test.d.ts +2 -0
- package/dist/indexer/code/chunker.test.d.ts.map +1 -0
- package/dist/indexer/code/chunker.test.js +552 -0
- package/dist/indexer/code/chunker.test.js.map +1 -0
- package/dist/indexer/code/fts.test.d.ts +2 -0
- package/dist/indexer/code/fts.test.d.ts.map +1 -0
- package/dist/indexer/code/fts.test.js +14 -0
- package/dist/indexer/code/fts.test.js.map +1 -0
- package/dist/indexer/code/graph/embedded.d.ts +11 -0
- package/dist/indexer/code/graph/embedded.d.ts.map +1 -0
- package/dist/indexer/code/graph/embedded.js +152 -0
- package/dist/indexer/code/graph/embedded.js.map +1 -0
- package/dist/indexer/code/graph/embedded.test.d.ts +2 -0
- package/dist/indexer/code/graph/embedded.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/embedded.test.js +105 -0
- package/dist/indexer/code/graph/embedded.test.js.map +1 -0
- package/dist/indexer/code/graph/facts.d.ts +11 -0
- package/dist/indexer/code/graph/facts.d.ts.map +1 -0
- package/dist/indexer/code/graph/facts.js +456 -0
- package/dist/indexer/code/graph/facts.js.map +1 -0
- package/dist/indexer/code/graph/facts.test.d.ts +2 -0
- package/dist/indexer/code/graph/facts.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/facts.test.js +181 -0
- package/dist/indexer/code/graph/facts.test.js.map +1 -0
- package/dist/indexer/code/graph/id.d.ts +14 -0
- package/dist/indexer/code/graph/id.d.ts.map +1 -0
- package/dist/indexer/code/graph/id.js +40 -0
- package/dist/indexer/code/graph/id.js.map +1 -0
- package/dist/indexer/code/graph/id.test.d.ts +2 -0
- package/dist/indexer/code/graph/id.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/id.test.js +86 -0
- package/dist/indexer/code/graph/id.test.js.map +1 -0
- package/dist/indexer/code/graph/index.d.ts +133 -0
- package/dist/indexer/code/graph/index.d.ts.map +1 -0
- package/dist/indexer/code/graph/index.js +1876 -0
- package/dist/indexer/code/graph/index.js.map +1 -0
- package/dist/indexer/code/graph/index.test.d.ts +2 -0
- package/dist/indexer/code/graph/index.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/index.test.js +210 -0
- package/dist/indexer/code/graph/index.test.js.map +1 -0
- package/dist/indexer/code/graph/queries.d.ts +22 -0
- package/dist/indexer/code/graph/queries.d.ts.map +1 -0
- package/dist/indexer/code/graph/queries.js +79 -0
- package/dist/indexer/code/graph/queries.js.map +1 -0
- package/dist/indexer/code/graph/queries.test.d.ts +2 -0
- package/dist/indexer/code/graph/queries.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/queries.test.js +108 -0
- package/dist/indexer/code/graph/queries.test.js.map +1 -0
- package/dist/indexer/code/graph/resolver.d.ts +136 -0
- package/dist/indexer/code/graph/resolver.d.ts.map +1 -0
- package/dist/indexer/code/graph/resolver.js +839 -0
- package/dist/indexer/code/graph/resolver.js.map +1 -0
- package/dist/indexer/code/graph/resolver.test.d.ts +2 -0
- package/dist/indexer/code/graph/resolver.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/resolver.test.js +482 -0
- package/dist/indexer/code/graph/resolver.test.js.map +1 -0
- package/dist/indexer/code/graph/semantic.d.ts +33 -0
- package/dist/indexer/code/graph/semantic.d.ts.map +1 -0
- package/dist/indexer/code/graph/semantic.js +279 -0
- package/dist/indexer/code/graph/semantic.js.map +1 -0
- package/dist/indexer/code/graph/semantic.test.d.ts +2 -0
- package/dist/indexer/code/graph/semantic.test.d.ts.map +1 -0
- package/dist/indexer/code/graph/semantic.test.js +127 -0
- package/dist/indexer/code/graph/semantic.test.js.map +1 -0
- package/dist/indexer/code/index.d.ts +404 -0
- package/dist/indexer/code/index.d.ts.map +1 -0
- package/dist/indexer/code/index.js +2070 -0
- package/dist/indexer/code/index.js.map +1 -0
- package/dist/indexer/code/languages/bash.d.ts +14 -0
- package/dist/indexer/code/languages/bash.d.ts.map +1 -0
- package/dist/indexer/code/languages/bash.js +125 -0
- package/dist/indexer/code/languages/bash.js.map +1 -0
- package/dist/indexer/code/languages/css.d.ts +16 -0
- package/dist/indexer/code/languages/css.d.ts.map +1 -0
- package/dist/indexer/code/languages/css.js +204 -0
- package/dist/indexer/code/languages/css.js.map +1 -0
- package/dist/indexer/code/languages/generic.d.ts +61 -0
- package/dist/indexer/code/languages/generic.d.ts.map +1 -0
- package/dist/indexer/code/languages/generic.js +150 -0
- package/dist/indexer/code/languages/generic.js.map +1 -0
- package/dist/indexer/code/languages/graphql.d.ts +13 -0
- package/dist/indexer/code/languages/graphql.d.ts.map +1 -0
- package/dist/indexer/code/languages/graphql.js +180 -0
- package/dist/indexer/code/languages/graphql.js.map +1 -0
- package/dist/indexer/code/languages/html.d.ts +16 -0
- package/dist/indexer/code/languages/html.d.ts.map +1 -0
- package/dist/indexer/code/languages/html.js +138 -0
- package/dist/indexer/code/languages/html.js.map +1 -0
- package/dist/indexer/code/languages/index.d.ts +9 -0
- package/dist/indexer/code/languages/index.d.ts.map +1 -0
- package/dist/indexer/code/languages/index.js +12 -0
- package/dist/indexer/code/languages/index.js.map +1 -0
- package/dist/indexer/code/languages/json.d.ts +12 -0
- package/dist/indexer/code/languages/json.d.ts.map +1 -0
- package/dist/indexer/code/languages/json.js +66 -0
- package/dist/indexer/code/languages/json.js.map +1 -0
- package/dist/indexer/code/languages/registry.d.ts +78 -0
- package/dist/indexer/code/languages/registry.d.ts.map +1 -0
- package/dist/indexer/code/languages/registry.js +72 -0
- package/dist/indexer/code/languages/registry.js.map +1 -0
- package/dist/indexer/code/languages/typescript.d.ts +39 -0
- package/dist/indexer/code/languages/typescript.d.ts.map +1 -0
- package/dist/indexer/code/languages/typescript.js +300 -0
- package/dist/indexer/code/languages/typescript.js.map +1 -0
- package/dist/indexer/code/languages/yaml.d.ts +13 -0
- package/dist/indexer/code/languages/yaml.d.ts.map +1 -0
- package/dist/indexer/code/languages/yaml.js +90 -0
- package/dist/indexer/code/languages/yaml.js.map +1 -0
- package/dist/indexer/code/parser.d.ts +26 -0
- package/dist/indexer/code/parser.d.ts.map +1 -0
- package/dist/indexer/code/parser.js +332 -0
- package/dist/indexer/code/parser.js.map +1 -0
- package/dist/indexer/code/retry.d.ts +58 -0
- package/dist/indexer/code/retry.d.ts.map +1 -0
- package/dist/indexer/code/retry.js +192 -0
- package/dist/indexer/code/retry.js.map +1 -0
- package/dist/indexer/code/tree/builder.d.ts +30 -0
- package/dist/indexer/code/tree/builder.d.ts.map +1 -0
- package/dist/indexer/code/tree/builder.js +132 -0
- package/dist/indexer/code/tree/builder.js.map +1 -0
- package/dist/indexer/code/tree/builder.test.d.ts +2 -0
- package/dist/indexer/code/tree/builder.test.d.ts.map +1 -0
- package/dist/indexer/code/tree/builder.test.js +31 -0
- package/dist/indexer/code/tree/builder.test.js.map +1 -0
- package/dist/indexer/code/tree/cache.d.ts +22 -0
- package/dist/indexer/code/tree/cache.d.ts.map +1 -0
- package/dist/indexer/code/tree/cache.js +85 -0
- package/dist/indexer/code/tree/cache.js.map +1 -0
- package/dist/indexer/code/tree/context.d.ts +32 -0
- package/dist/indexer/code/tree/context.d.ts.map +1 -0
- package/dist/indexer/code/tree/context.js +78 -0
- package/dist/indexer/code/tree/context.js.map +1 -0
- package/dist/indexer/code/tree/embedding.d.ts +9 -0
- package/dist/indexer/code/tree/embedding.d.ts.map +1 -0
- package/dist/indexer/code/tree/embedding.js +53 -0
- package/dist/indexer/code/tree/embedding.js.map +1 -0
- package/dist/indexer/code/tree/embedding.test.d.ts +2 -0
- package/dist/indexer/code/tree/embedding.test.d.ts.map +1 -0
- package/dist/indexer/code/tree/embedding.test.js +57 -0
- package/dist/indexer/code/tree/embedding.test.js.map +1 -0
- package/dist/indexer/code/tree/id.d.ts +3 -0
- package/dist/indexer/code/tree/id.d.ts.map +1 -0
- package/dist/indexer/code/tree/id.js +8 -0
- package/dist/indexer/code/tree/id.js.map +1 -0
- package/dist/indexer/code/tree/index.d.ts +113 -0
- package/dist/indexer/code/tree/index.d.ts.map +1 -0
- package/dist/indexer/code/tree/index.js +1146 -0
- package/dist/indexer/code/tree/index.js.map +1 -0
- package/dist/indexer/code/tree/rename.d.ts +13 -0
- package/dist/indexer/code/tree/rename.d.ts.map +1 -0
- package/dist/indexer/code/tree/rename.js +46 -0
- package/dist/indexer/code/tree/rename.js.map +1 -0
- package/dist/indexer/code/tree/repomap.d.ts +29 -0
- package/dist/indexer/code/tree/repomap.d.ts.map +1 -0
- package/dist/indexer/code/tree/repomap.js +95 -0
- package/dist/indexer/code/tree/repomap.js.map +1 -0
- package/dist/indexer/code/tree/repomap.test.d.ts +2 -0
- package/dist/indexer/code/tree/repomap.test.d.ts.map +1 -0
- package/dist/indexer/code/tree/repomap.test.js +93 -0
- package/dist/indexer/code/tree/repomap.test.js.map +1 -0
- package/dist/indexer/code/tree/stats.d.ts +26 -0
- package/dist/indexer/code/tree/stats.d.ts.map +1 -0
- package/dist/indexer/code/tree/stats.js +49 -0
- package/dist/indexer/code/tree/stats.js.map +1 -0
- package/dist/indexer/code/tree/types.d.ts +186 -0
- package/dist/indexer/code/tree/types.d.ts.map +1 -0
- package/dist/indexer/code/tree/types.js +10 -0
- package/dist/indexer/code/tree/types.js.map +1 -0
- package/dist/indexer/code/wal.d.ts +144 -0
- package/dist/indexer/code/wal.d.ts.map +1 -0
- package/dist/indexer/code/wal.js +283 -0
- package/dist/indexer/code/wal.js.map +1 -0
- package/dist/indexer/embeddings.d.ts +113 -0
- package/dist/indexer/embeddings.d.ts.map +1 -0
- package/dist/indexer/embeddings.js +477 -0
- package/dist/indexer/embeddings.js.map +1 -0
- package/dist/indexer/git-sync.d.ts +117 -0
- package/dist/indexer/git-sync.d.ts.map +1 -0
- package/dist/indexer/git-sync.js +398 -0
- package/dist/indexer/git-sync.js.map +1 -0
- package/dist/indexer/index.d.ts +175 -0
- package/dist/indexer/index.d.ts.map +1 -0
- package/dist/indexer/index.js +1096 -0
- package/dist/indexer/index.js.map +1 -0
- package/dist/indexer/mocks/mock-reranker.d.ts +12 -0
- package/dist/indexer/mocks/mock-reranker.d.ts.map +1 -0
- package/dist/indexer/mocks/mock-reranker.js +26 -0
- package/dist/indexer/mocks/mock-reranker.js.map +1 -0
- package/dist/indexer/parser.d.ts +8 -0
- package/dist/indexer/parser.d.ts.map +1 -0
- package/dist/indexer/parser.js +44 -0
- package/dist/indexer/parser.js.map +1 -0
- package/dist/indexer/parser.test.d.ts +2 -0
- package/dist/indexer/parser.test.d.ts.map +1 -0
- package/dist/indexer/parser.test.js +197 -0
- package/dist/indexer/parser.test.js.map +1 -0
- package/dist/indexer/reranking.d.ts +71 -0
- package/dist/indexer/reranking.d.ts.map +1 -0
- package/dist/indexer/reranking.integration.test.d.ts +2 -0
- package/dist/indexer/reranking.integration.test.d.ts.map +1 -0
- package/dist/indexer/reranking.integration.test.js +104 -0
- package/dist/indexer/reranking.integration.test.js.map +1 -0
- package/dist/indexer/reranking.js +256 -0
- package/dist/indexer/reranking.js.map +1 -0
- package/dist/indexer/reranking.test.d.ts +2 -0
- package/dist/indexer/reranking.test.d.ts.map +1 -0
- package/dist/indexer/reranking.test.js +130 -0
- package/dist/indexer/reranking.test.js.map +1 -0
- package/dist/indexer/wal/file-storage.d.ts +60 -0
- package/dist/indexer/wal/file-storage.d.ts.map +1 -0
- package/dist/indexer/wal/file-storage.js +277 -0
- package/dist/indexer/wal/file-storage.js.map +1 -0
- package/dist/indexer/wal/file-storage.test.d.ts +8 -0
- package/dist/indexer/wal/file-storage.test.d.ts.map +1 -0
- package/dist/indexer/wal/file-storage.test.js +444 -0
- package/dist/indexer/wal/file-storage.test.js.map +1 -0
- package/dist/indexer/wal/index.d.ts +41 -0
- package/dist/indexer/wal/index.d.ts.map +1 -0
- package/dist/indexer/wal/index.js +61 -0
- package/dist/indexer/wal/index.js.map +1 -0
- package/dist/indexer/wal/integration.test.d.ts +11 -0
- package/dist/indexer/wal/integration.test.d.ts.map +1 -0
- package/dist/indexer/wal/integration.test.js +378 -0
- package/dist/indexer/wal/integration.test.js.map +1 -0
- package/dist/indexer/wal/lancedb-storage.d.ts +72 -0
- package/dist/indexer/wal/lancedb-storage.d.ts.map +1 -0
- package/dist/indexer/wal/lancedb-storage.js +462 -0
- package/dist/indexer/wal/lancedb-storage.js.map +1 -0
- package/dist/indexer/wal/lancedb-storage.test.d.ts +8 -0
- package/dist/indexer/wal/lancedb-storage.test.d.ts.map +1 -0
- package/dist/indexer/wal/lancedb-storage.test.js +415 -0
- package/dist/indexer/wal/lancedb-storage.test.js.map +1 -0
- package/dist/indexer/wal/sync-wal.d.ts +144 -0
- package/dist/indexer/wal/sync-wal.d.ts.map +1 -0
- package/dist/indexer/wal/sync-wal.js +863 -0
- package/dist/indexer/wal/sync-wal.js.map +1 -0
- package/dist/indexer/wal/sync-wal.test.d.ts +8 -0
- package/dist/indexer/wal/sync-wal.test.d.ts.map +1 -0
- package/dist/indexer/wal/sync-wal.test.js +752 -0
- package/dist/indexer/wal/sync-wal.test.js.map +1 -0
- package/dist/indexer/wal/types.d.ts +167 -0
- package/dist/indexer/wal/types.d.ts.map +1 -0
- package/dist/indexer/wal/types.js +12 -0
- package/dist/indexer/wal/types.js.map +1 -0
- package/dist/indexer/watcher.d.ts +36 -0
- package/dist/indexer/watcher.d.ts.map +1 -0
- package/dist/indexer/watcher.js +110 -0
- package/dist/indexer/watcher.js.map +1 -0
- package/dist/search/explore.d.ts +62 -0
- package/dist/search/explore.d.ts.map +1 -0
- package/dist/search/explore.js +111 -0
- package/dist/search/explore.js.map +1 -0
- package/dist/search/fts.d.ts +23 -0
- package/dist/search/fts.d.ts.map +1 -0
- package/dist/search/fts.js +64 -0
- package/dist/search/fts.js.map +1 -0
- package/dist/search/fts.test.d.ts +2 -0
- package/dist/search/fts.test.d.ts.map +1 -0
- package/dist/search/fts.test.js +27 -0
- package/dist/search/fts.test.js.map +1 -0
- package/dist/search/grep.d.ts +75 -0
- package/dist/search/grep.d.ts.map +1 -0
- package/dist/search/grep.js +96 -0
- package/dist/search/grep.js.map +1 -0
- package/dist/search/grep.test.d.ts +2 -0
- package/dist/search/grep.test.d.ts.map +1 -0
- package/dist/search/grep.test.js +178 -0
- package/dist/search/grep.test.js.map +1 -0
- package/dist/search/hybrid-grep.d.ts +43 -0
- package/dist/search/hybrid-grep.d.ts.map +1 -0
- package/dist/search/hybrid-grep.js +130 -0
- package/dist/search/hybrid-grep.js.map +1 -0
- package/dist/search/hybrid-grep.test.d.ts +2 -0
- package/dist/search/hybrid-grep.test.d.ts.map +1 -0
- package/dist/search/hybrid-grep.test.js +133 -0
- package/dist/search/hybrid-grep.test.js.map +1 -0
- package/dist/search/rg-executor.d.ts +63 -0
- package/dist/search/rg-executor.d.ts.map +1 -0
- package/dist/search/rg-executor.js +146 -0
- package/dist/search/rg-executor.js.map +1 -0
- package/dist/search/rg-executor.test.d.ts +2 -0
- package/dist/search/rg-executor.test.d.ts.map +1 -0
- package/dist/search/rg-executor.test.js +104 -0
- package/dist/search/rg-executor.test.js.map +1 -0
- package/dist/search/rg-parser/extractor.d.ts +14 -0
- package/dist/search/rg-parser/extractor.d.ts.map +1 -0
- package/dist/search/rg-parser/extractor.js +82 -0
- package/dist/search/rg-parser/extractor.js.map +1 -0
- package/dist/search/rg-parser/extractor.test.d.ts +2 -0
- package/dist/search/rg-parser/extractor.test.d.ts.map +1 -0
- package/dist/search/rg-parser/extractor.test.js +35 -0
- package/dist/search/rg-parser/extractor.test.js.map +1 -0
- package/dist/search/rg-parser/fts-builder.d.ts +7 -0
- package/dist/search/rg-parser/fts-builder.d.ts.map +1 -0
- package/dist/search/rg-parser/fts-builder.js +18 -0
- package/dist/search/rg-parser/fts-builder.js.map +1 -0
- package/dist/search/rg-parser/fts-builder.test.d.ts +2 -0
- package/dist/search/rg-parser/fts-builder.test.d.ts.map +1 -0
- package/dist/search/rg-parser/fts-builder.test.js +26 -0
- package/dist/search/rg-parser/fts-builder.test.js.map +1 -0
- package/dist/search/rg-parser/index.d.ts +36 -0
- package/dist/search/rg-parser/index.d.ts.map +1 -0
- package/dist/search/rg-parser/index.js +83 -0
- package/dist/search/rg-parser/index.js.map +1 -0
- package/dist/search/rg-parser/index.test.d.ts +2 -0
- package/dist/search/rg-parser/index.test.d.ts.map +1 -0
- package/dist/search/rg-parser/index.test.js +34 -0
- package/dist/search/rg-parser/index.test.js.map +1 -0
- package/dist/search/rg-parser/strategy.d.ts +14 -0
- package/dist/search/rg-parser/strategy.d.ts.map +1 -0
- package/dist/search/rg-parser/strategy.js +31 -0
- package/dist/search/rg-parser/strategy.js.map +1 -0
- package/dist/search/rg-parser/strategy.test.d.ts +2 -0
- package/dist/search/rg-parser/strategy.test.d.ts.map +1 -0
- package/dist/search/rg-parser/strategy.test.js +29 -0
- package/dist/search/rg-parser/strategy.test.js.map +1 -0
- package/dist/types.d.ts +345 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +7 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/vault.d.ts +84 -0
- package/dist/utils/vault.d.ts.map +1 -0
- package/dist/utils/vault.js +138 -0
- package/dist/utils/vault.js.map +1 -0
- package/dist/utils/vault.test.d.ts +2 -0
- package/dist/utils/vault.test.d.ts.map +1 -0
- package/dist/utils/vault.test.js +153 -0
- package/dist/utils/vault.test.js.map +1 -0
- package/package.json +69 -0
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import * as regexpTree from 'regexp-tree';
|
|
2
|
+
const MIN_LITERAL_LENGTH = 3;
|
|
3
|
+
const FALLBACK_LITERAL_RE = /[A-Za-z_][A-Za-z0-9_]{2,}/g;
|
|
4
|
+
function dedupe(values) {
|
|
5
|
+
return [...new Set(values)];
|
|
6
|
+
}
|
|
7
|
+
function finalizeExtraction(literals, hasComplexPatterns) {
|
|
8
|
+
const unique = dedupe(literals);
|
|
9
|
+
return {
|
|
10
|
+
literals: unique,
|
|
11
|
+
hasComplexPatterns,
|
|
12
|
+
complexity: hasComplexPatterns
|
|
13
|
+
? (unique.length > 0 ? 'medium' : 'complex')
|
|
14
|
+
: 'simple',
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
function pushLiteral(literals, value) {
|
|
18
|
+
if (value.length >= MIN_LITERAL_LENGTH) {
|
|
19
|
+
literals.push(value);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
function extractAlternativeLiterals(node, literals) {
|
|
23
|
+
let current = '';
|
|
24
|
+
for (const expr of node.expressions || []) {
|
|
25
|
+
if (expr.type === 'Char' && expr.kind === 'simple') {
|
|
26
|
+
current += expr.value;
|
|
27
|
+
continue;
|
|
28
|
+
}
|
|
29
|
+
pushLiteral(literals, current);
|
|
30
|
+
current = '';
|
|
31
|
+
}
|
|
32
|
+
pushLiteral(literals, current);
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Extracts recall-safe literal hints from a grep pattern.
|
|
36
|
+
*
|
|
37
|
+
* For regex patterns we use regexp-tree AST traversal to find contiguous
|
|
38
|
+
* Char(simple) sequences that can be used to narrow candidate files via FTS.
|
|
39
|
+
*/
|
|
40
|
+
export function extractLiterals(pattern, isRegex) {
|
|
41
|
+
if (!isRegex) {
|
|
42
|
+
return finalizeExtraction(pattern ? [pattern] : [], false);
|
|
43
|
+
}
|
|
44
|
+
const literals = [];
|
|
45
|
+
let hasComplexPatterns = false;
|
|
46
|
+
try {
|
|
47
|
+
const safeLiteral = `/${pattern.replaceAll('/', '\\/')}/`;
|
|
48
|
+
const ast = regexpTree.parse(safeLiteral);
|
|
49
|
+
regexpTree.traverse(ast, {
|
|
50
|
+
Alternative(node) {
|
|
51
|
+
extractAlternativeLiterals(node, literals);
|
|
52
|
+
},
|
|
53
|
+
Disjunction() {
|
|
54
|
+
hasComplexPatterns = true;
|
|
55
|
+
},
|
|
56
|
+
Repetition() {
|
|
57
|
+
hasComplexPatterns = true;
|
|
58
|
+
},
|
|
59
|
+
CharacterClass() {
|
|
60
|
+
hasComplexPatterns = true;
|
|
61
|
+
},
|
|
62
|
+
Group() {
|
|
63
|
+
hasComplexPatterns = true;
|
|
64
|
+
},
|
|
65
|
+
Backreference() {
|
|
66
|
+
hasComplexPatterns = true;
|
|
67
|
+
},
|
|
68
|
+
Assertion() {
|
|
69
|
+
hasComplexPatterns = true;
|
|
70
|
+
},
|
|
71
|
+
}, { asNodes: true });
|
|
72
|
+
}
|
|
73
|
+
catch {
|
|
74
|
+
const terms = pattern.match(FALLBACK_LITERAL_RE);
|
|
75
|
+
if (terms) {
|
|
76
|
+
literals.push(...terms);
|
|
77
|
+
}
|
|
78
|
+
hasComplexPatterns = true;
|
|
79
|
+
}
|
|
80
|
+
return finalizeExtraction(literals, hasComplexPatterns);
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=extractor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor.js","sourceRoot":"","sources":["../../../src/search/rg-parser/extractor.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor.test.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/extractor.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { extractLiterals } from './extractor.js';
|
|
3
|
+
describe('extractLiterals', () => {
|
|
4
|
+
it('uses full input for fixed string mode', () => {
|
|
5
|
+
expect(extractLiterals('kubernetes', false)).toEqual({
|
|
6
|
+
literals: ['kubernetes'],
|
|
7
|
+
hasComplexPatterns: false,
|
|
8
|
+
complexity: 'simple',
|
|
9
|
+
});
|
|
10
|
+
});
|
|
11
|
+
it('extracts literals from grouped alternations', () => {
|
|
12
|
+
const result = extractLiterals('(foo|bar)baz', true);
|
|
13
|
+
expect(result.literals).toEqual(expect.arrayContaining(['foo', 'bar', 'baz']));
|
|
14
|
+
expect(result.hasComplexPatterns).toBe(true);
|
|
15
|
+
expect(result.complexity).toBe('medium');
|
|
16
|
+
});
|
|
17
|
+
it('returns complex when regex has no literal hints', () => {
|
|
18
|
+
expect(extractLiterals('\\d{3,5}', true)).toEqual({
|
|
19
|
+
literals: [],
|
|
20
|
+
hasComplexPatterns: true,
|
|
21
|
+
complexity: 'complex',
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
it('falls back to alphanumeric term extraction for invalid regex', () => {
|
|
25
|
+
const result = extractLiterals('foo[bar', true);
|
|
26
|
+
expect(result.literals).toEqual(expect.arrayContaining(['foo', 'bar']));
|
|
27
|
+
expect(result.hasComplexPatterns).toBe(true);
|
|
28
|
+
expect(result.complexity).toBe('medium');
|
|
29
|
+
});
|
|
30
|
+
it('deduplicates extracted literals', () => {
|
|
31
|
+
const result = extractLiterals('(alpha|alpha)beta', true);
|
|
32
|
+
expect(result.literals.filter((item) => item === 'alpha')).toHaveLength(1);
|
|
33
|
+
});
|
|
34
|
+
});
|
|
35
|
+
//# sourceMappingURL=extractor.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"extractor.test.js","sourceRoot":"","sources":["../../../src/search/rg-parser/extractor.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAEjD,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,uCAAuC,EAAE,GAAG,EAAE;QAC/C,MAAM,CAAC,eAAe,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YACnD,QAAQ,EAAE,CAAC,YAAY,CAAC;YACxB,kBAAkB,EAAE,KAAK;YACzB,UAAU,EAAE,QAAQ;SACrB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,eAAe,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC;QAErD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QAC/E,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iDAAiD,EAAE,GAAG,EAAE;QACzD,MAAM,CAAC,eAAe,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;YAChD,QAAQ,EAAE,EAAE;YACZ,kBAAkB,EAAE,IAAI;YACxB,UAAU,EAAE,SAAS;SACtB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8DAA8D,EAAE,GAAG,EAAE;QACtE,MAAM,MAAM,GAAG,eAAe,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAEhD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC;QACxE,MAAM,CAAC,MAAM,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG,eAAe,CAAC,mBAAmB,EAAE,IAAI,CAAC,CAAC;QAE1D,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC7E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export interface FtsQueryOptions {
|
|
2
|
+
maxTerms?: number;
|
|
3
|
+
operator?: 'OR' | 'AND';
|
|
4
|
+
}
|
|
5
|
+
export declare function escapeTantivyTerm(term: string): string;
|
|
6
|
+
export declare function buildFtsQuery(literals: string[], options?: FtsQueryOptions): string | null;
|
|
7
|
+
//# sourceMappingURL=fts-builder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fts-builder.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/fts-builder.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,eAAe;IAC9B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,IAAI,GAAG,KAAK,CAAC;CACzB;AAED,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,MAAM,GAAG,MAAM,CAKtD;AAED,wBAAgB,aAAa,CAC3B,QAAQ,EAAE,MAAM,EAAE,EAClB,OAAO,GAAE,eAAoB,GAC5B,MAAM,GAAG,IAAI,CAYf"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export function escapeTantivyTerm(term) {
|
|
2
|
+
return term
|
|
3
|
+
.replace(/\\/g, '\\\\')
|
|
4
|
+
.replace(/"/g, '\\"')
|
|
5
|
+
.replace(/([+\-!(){}\[\]^~*?:/])/g, '\\$1');
|
|
6
|
+
}
|
|
7
|
+
export function buildFtsQuery(literals, options = {}) {
|
|
8
|
+
const cleaned = [...new Set(literals.map((item) => item.trim()).filter(Boolean))];
|
|
9
|
+
if (cleaned.length === 0) {
|
|
10
|
+
return null;
|
|
11
|
+
}
|
|
12
|
+
const maxTerms = options.maxTerms ?? 8;
|
|
13
|
+
const operator = options.operator ?? 'OR';
|
|
14
|
+
const selected = cleaned.slice(0, maxTerms);
|
|
15
|
+
const tokens = selected.map((term) => `"${escapeTantivyTerm(term)}"`);
|
|
16
|
+
return tokens.join(` ${operator} `);
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=fts-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fts-builder.js","sourceRoot":"","sources":["../../../src/search/rg-parser/fts-builder.ts"],"names":[],"mappings":"AAKA,MAAM,UAAU,iBAAiB,CAAC,IAAY;IAC5C,OAAO,IAAI;SACR,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC;SACtB,OAAO,CAAC,IAAI,EAAE,KAAK,CAAC;SACpB,OAAO,CAAC,yBAAyB,EAAE,MAAM,CAAC,CAAC;AAChD,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,QAAkB,EAClB,UAA2B,EAAE;IAE7B,MAAM,OAAO,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAClF,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;IACvC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,IAAI,IAAI,CAAC;IAC1C,MAAM,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IAC5C,MAAM,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,iBAAiB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEtE,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,QAAQ,GAAG,CAAC,CAAC;AACtC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fts-builder.test.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/fts-builder.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { buildFtsQuery, escapeTantivyTerm } from './fts-builder.js';
|
|
3
|
+
describe('escapeTantivyTerm', () => {
|
|
4
|
+
it('escapes tantivy reserved syntax', () => {
|
|
5
|
+
expect(escapeTantivyTerm('foo+bar:(baz)')).toBe('foo\\+bar\\:\\(baz\\)');
|
|
6
|
+
});
|
|
7
|
+
});
|
|
8
|
+
describe('buildFtsQuery', () => {
|
|
9
|
+
it('returns null for empty input', () => {
|
|
10
|
+
expect(buildFtsQuery([])).toBeNull();
|
|
11
|
+
expect(buildFtsQuery([' '])).toBeNull();
|
|
12
|
+
});
|
|
13
|
+
it('builds quoted OR query by default', () => {
|
|
14
|
+
expect(buildFtsQuery(['error', 'warning'])).toBe('"error" OR "warning"');
|
|
15
|
+
});
|
|
16
|
+
it('deduplicates and trims values', () => {
|
|
17
|
+
expect(buildFtsQuery([' error ', 'error', 'warning '])).toBe('"error" OR "warning"');
|
|
18
|
+
});
|
|
19
|
+
it('respects maxTerms and operator', () => {
|
|
20
|
+
expect(buildFtsQuery(['a', 'b', 'c'], { maxTerms: 2, operator: 'AND' })).toBe('"a" AND "b"');
|
|
21
|
+
});
|
|
22
|
+
it('escapes terms so they stay literal', () => {
|
|
23
|
+
expect(buildFtsQuery(['a+b'])).toBe('"a\\+b"');
|
|
24
|
+
});
|
|
25
|
+
});
|
|
26
|
+
//# sourceMappingURL=fts-builder.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"fts-builder.test.js","sourceRoot":"","sources":["../../../src/search/rg-parser/fts-builder.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAEpE,QAAQ,CAAC,mBAAmB,EAAE,GAAG,EAAE;IACjC,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,CAAC,iBAAiB,CAAC,eAAe,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,eAAe,EAAE,GAAG,EAAE;IAC7B,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;QACrC,MAAM,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,CAAC;IAC3C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,CAAC,aAAa,CAAC,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC3E,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+BAA+B,EAAE,GAAG,EAAE;QACvC,MAAM,CAAC,aAAa,CAAC,CAAC,SAAS,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IACvF,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,MAAM,CAAC,aAAa,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;IAC/F,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,oCAAoC,EAAE,GAAG,EAAE;QAC5C,MAAM,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { type RgSearchStrategy } from './strategy.js';
|
|
2
|
+
export interface ParseRgQueryOptions {
|
|
3
|
+
regex?: boolean;
|
|
4
|
+
fixedStrings?: boolean;
|
|
5
|
+
ignoreCase?: boolean;
|
|
6
|
+
caseSensitive?: boolean;
|
|
7
|
+
smartCase?: boolean;
|
|
8
|
+
pcre2?: boolean;
|
|
9
|
+
wordRegexp?: boolean;
|
|
10
|
+
lineRegexp?: boolean;
|
|
11
|
+
invertMatch?: boolean;
|
|
12
|
+
contextBefore?: number;
|
|
13
|
+
contextAfter?: number;
|
|
14
|
+
}
|
|
15
|
+
export interface ParsedRgQuery {
|
|
16
|
+
ftsQuery: string | null;
|
|
17
|
+
hintTerms: string[];
|
|
18
|
+
originalPattern: string;
|
|
19
|
+
options: {
|
|
20
|
+
fixedStrings: boolean;
|
|
21
|
+
ignoreCase: boolean;
|
|
22
|
+
caseSensitive: boolean;
|
|
23
|
+
smartCase: boolean;
|
|
24
|
+
pcre2: boolean;
|
|
25
|
+
wordRegexp: boolean;
|
|
26
|
+
lineRegexp: boolean;
|
|
27
|
+
invertMatch: boolean;
|
|
28
|
+
contextBefore: number;
|
|
29
|
+
contextAfter: number;
|
|
30
|
+
};
|
|
31
|
+
strategy: RgSearchStrategy;
|
|
32
|
+
strategyReason: string;
|
|
33
|
+
}
|
|
34
|
+
export declare function resolveRegexMode(pattern: string, options: ParseRgQueryOptions): boolean;
|
|
35
|
+
export declare function parseRgQuery(pattern: string, additionalPatterns?: string[], input?: ParseRgQueryOptions): ParsedRgQuery;
|
|
36
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/index.ts"],"names":[],"mappings":"AAEA,OAAO,EAAkB,KAAK,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAEtE,MAAM,WAAW,mBAAmB;IAClC,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,SAAS,EAAE,MAAM,EAAE,CAAC;IACpB,eAAe,EAAE,MAAM,CAAC;IACxB,OAAO,EAAE;QACP,YAAY,EAAE,OAAO,CAAC;QACtB,UAAU,EAAE,OAAO,CAAC;QACpB,aAAa,EAAE,OAAO,CAAC;QACvB,SAAS,EAAE,OAAO,CAAC;QACnB,KAAK,EAAE,OAAO,CAAC;QACf,UAAU,EAAE,OAAO,CAAC;QACpB,UAAU,EAAE,OAAO,CAAC;QACpB,WAAW,EAAE,OAAO,CAAC;QACrB,aAAa,EAAE,MAAM,CAAC;QACtB,YAAY,EAAE,MAAM,CAAC;KACtB,CAAC;IACF,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,cAAc,EAAE,MAAM,CAAC;CACxB;AAwBD,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,mBAAmB,GAAG,OAAO,CAUvF;AAED,wBAAgB,YAAY,CAC1B,OAAO,EAAE,MAAM,EACf,kBAAkB,GAAE,MAAM,EAAO,EACjC,KAAK,GAAE,mBAAwB,GAC9B,aAAa,CAqDf"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { extractLiterals } from './extractor.js';
|
|
2
|
+
import { buildFtsQuery } from './fts-builder.js';
|
|
3
|
+
import { decideStrategy } from './strategy.js';
|
|
4
|
+
function normalizeContext(value) {
|
|
5
|
+
if (typeof value !== 'number' || Number.isNaN(value)) {
|
|
6
|
+
return 0;
|
|
7
|
+
}
|
|
8
|
+
return Math.max(0, Math.floor(value));
|
|
9
|
+
}
|
|
10
|
+
function hasRegexSyntax(pattern) {
|
|
11
|
+
if (!pattern) {
|
|
12
|
+
return false;
|
|
13
|
+
}
|
|
14
|
+
if (/\\[AbBdDsSwWfnrtvxuU0pP]/.test(pattern))
|
|
15
|
+
return true;
|
|
16
|
+
if (/(^|[^\\])[|()[\]{}]/.test(pattern))
|
|
17
|
+
return true;
|
|
18
|
+
if (/(^|[^\\])(\*|\+|\?|\{\d+(,\d*)?\})/.test(pattern))
|
|
19
|
+
return true;
|
|
20
|
+
if (/(^|[^\\])(\^|\$)/.test(pattern))
|
|
21
|
+
return true;
|
|
22
|
+
if (/\.\*/.test(pattern) || /\.\+/.test(pattern) || /\.\?/.test(pattern))
|
|
23
|
+
return true;
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
export function resolveRegexMode(pattern, options) {
|
|
27
|
+
if (options.fixedStrings) {
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
if (typeof options.regex === 'boolean') {
|
|
31
|
+
return options.regex;
|
|
32
|
+
}
|
|
33
|
+
return hasRegexSyntax(pattern);
|
|
34
|
+
}
|
|
35
|
+
export function parseRgQuery(pattern, additionalPatterns = [], input = {}) {
|
|
36
|
+
const fixedStrings = input.fixedStrings ?? false;
|
|
37
|
+
const isRegex = resolveRegexMode(pattern, input);
|
|
38
|
+
const base = extractLiterals(pattern, isRegex);
|
|
39
|
+
const extras = additionalPatterns
|
|
40
|
+
.filter(Boolean)
|
|
41
|
+
.map((extra) => extractLiterals(extra, isRegex));
|
|
42
|
+
const hintTerms = [...new Set([
|
|
43
|
+
...base.literals,
|
|
44
|
+
...extras.flatMap((item) => item.literals),
|
|
45
|
+
])];
|
|
46
|
+
const hasComplexPatterns = base.hasComplexPatterns || extras.some((item) => item.hasComplexPatterns);
|
|
47
|
+
const extraction = {
|
|
48
|
+
literals: hintTerms,
|
|
49
|
+
hasComplexPatterns,
|
|
50
|
+
complexity: hasComplexPatterns
|
|
51
|
+
? (hintTerms.length > 0 ? 'medium' : 'complex')
|
|
52
|
+
: 'simple',
|
|
53
|
+
};
|
|
54
|
+
const strategyDecision = decideStrategy(extraction, {
|
|
55
|
+
additionalPatterns,
|
|
56
|
+
invertMatch: input.invertMatch,
|
|
57
|
+
wordRegexp: input.wordRegexp,
|
|
58
|
+
lineRegexp: input.lineRegexp,
|
|
59
|
+
});
|
|
60
|
+
const ftsQuery = strategyDecision.strategy === 'fts-narrow-then-rg'
|
|
61
|
+
? buildFtsQuery(hintTerms)
|
|
62
|
+
: null;
|
|
63
|
+
return {
|
|
64
|
+
ftsQuery,
|
|
65
|
+
hintTerms,
|
|
66
|
+
originalPattern: pattern,
|
|
67
|
+
options: {
|
|
68
|
+
fixedStrings,
|
|
69
|
+
ignoreCase: input.ignoreCase ?? false,
|
|
70
|
+
caseSensitive: input.caseSensitive ?? false,
|
|
71
|
+
smartCase: input.smartCase ?? false,
|
|
72
|
+
pcre2: input.pcre2 ?? false,
|
|
73
|
+
wordRegexp: input.wordRegexp ?? false,
|
|
74
|
+
lineRegexp: input.lineRegexp ?? false,
|
|
75
|
+
invertMatch: input.invertMatch ?? false,
|
|
76
|
+
contextBefore: normalizeContext(input.contextBefore),
|
|
77
|
+
contextAfter: normalizeContext(input.contextAfter),
|
|
78
|
+
},
|
|
79
|
+
strategy: strategyDecision.strategy,
|
|
80
|
+
strategyReason: strategyDecision.reason,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/search/rg-parser/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/index.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { parseRgQuery, resolveRegexMode } from './index.js';
|
|
3
|
+
describe('resolveRegexMode', () => {
|
|
4
|
+
it('honors fixedStrings over auto detection', () => {
|
|
5
|
+
expect(resolveRegexMode('a.*b', { fixedStrings: true })).toBe(false);
|
|
6
|
+
});
|
|
7
|
+
it('honors explicit regex option', () => {
|
|
8
|
+
expect(resolveRegexMode('plain text', { regex: true })).toBe(true);
|
|
9
|
+
expect(resolveRegexMode('a.*b', { regex: false })).toBe(false);
|
|
10
|
+
});
|
|
11
|
+
it('auto-detects obvious regex syntax', () => {
|
|
12
|
+
expect(resolveRegexMode('foo|bar', {})).toBe(true);
|
|
13
|
+
expect(resolveRegexMode('file.txt', {})).toBe(false);
|
|
14
|
+
});
|
|
15
|
+
});
|
|
16
|
+
describe('parseRgQuery', () => {
|
|
17
|
+
it('builds FTS query for narrowable patterns', () => {
|
|
18
|
+
const parsed = parseRgQuery('kubernetes', [], {});
|
|
19
|
+
expect(parsed.strategy).toBe('fts-narrow-then-rg');
|
|
20
|
+
expect(parsed.ftsQuery).toBe('"kubernetes"');
|
|
21
|
+
expect(parsed.hintTerms).toEqual(['kubernetes']);
|
|
22
|
+
});
|
|
23
|
+
it('forces rg-only for multiple -e patterns', () => {
|
|
24
|
+
const parsed = parseRgQuery('error', ['warning'], {});
|
|
25
|
+
expect(parsed.strategy).toBe('rg-only');
|
|
26
|
+
expect(parsed.ftsQuery).toBeNull();
|
|
27
|
+
});
|
|
28
|
+
it('normalizes context to non-negative integers', () => {
|
|
29
|
+
const parsed = parseRgQuery('error', [], { contextBefore: 1.8, contextAfter: -2 });
|
|
30
|
+
expect(parsed.options.contextBefore).toBe(1);
|
|
31
|
+
expect(parsed.options.contextAfter).toBe(0);
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
//# sourceMappingURL=index.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.test.js","sourceRoot":"","sources":["../../../src/search/rg-parser/index.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAE5D,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,EAAE,YAAY,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACtC,MAAM,CAAC,gBAAgB,CAAC,YAAY,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnE,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACjE,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,mCAAmC,EAAE,GAAG,EAAE;QAC3C,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,MAAM,CAAC,gBAAgB,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACvD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,cAAc,EAAE,GAAG,EAAE;IAC5B,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,MAAM,GAAG,YAAY,CAAC,YAAY,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAElD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACnD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC;IACnD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,MAAM,GAAG,YAAY,CAAC,OAAO,EAAE,CAAC,SAAS,CAAC,EAAE,EAAE,CAAC,CAAC;QAEtD,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,YAAY,CAAC,OAAO,EAAE,EAAE,EAAE,EAAE,aAAa,EAAE,GAAG,EAAE,YAAY,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;QAEnF,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC7C,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { ExtractionResult } from './extractor.js';
|
|
2
|
+
export type RgSearchStrategy = 'fts-narrow-then-rg' | 'rg-only';
|
|
3
|
+
export interface StrategyOptions {
|
|
4
|
+
additionalPatterns?: string[];
|
|
5
|
+
invertMatch?: boolean;
|
|
6
|
+
wordRegexp?: boolean;
|
|
7
|
+
lineRegexp?: boolean;
|
|
8
|
+
}
|
|
9
|
+
export interface StrategyDecision {
|
|
10
|
+
strategy: RgSearchStrategy;
|
|
11
|
+
reason: string;
|
|
12
|
+
}
|
|
13
|
+
export declare function decideStrategy(extraction: ExtractionResult, options: StrategyOptions): StrategyDecision;
|
|
14
|
+
//# sourceMappingURL=strategy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvD,MAAM,MAAM,gBAAgB,GAAG,oBAAoB,GAAG,SAAS,CAAC;AAEhE,MAAM,WAAW,eAAe;IAC9B,kBAAkB,CAAC,EAAE,MAAM,EAAE,CAAC;IAC9B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,gBAAgB;IAC/B,QAAQ,EAAE,gBAAgB,CAAC;IAC3B,MAAM,EAAE,MAAM,CAAC;CAChB;AAED,wBAAgB,cAAc,CAC5B,UAAU,EAAE,gBAAgB,EAC5B,OAAO,EAAE,eAAe,GACvB,gBAAgB,CAiClB"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
export function decideStrategy(extraction, options) {
|
|
2
|
+
if (options.invertMatch) {
|
|
3
|
+
return {
|
|
4
|
+
strategy: 'rg-only',
|
|
5
|
+
reason: 'Invert match requires full file set to avoid false negatives',
|
|
6
|
+
};
|
|
7
|
+
}
|
|
8
|
+
if ((options.additionalPatterns?.length ?? 0) > 0) {
|
|
9
|
+
return {
|
|
10
|
+
strategy: 'rg-only',
|
|
11
|
+
reason: 'Multiple -e patterns use OR semantics; avoid partial narrowing false negatives',
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
if (extraction.literals.length === 0) {
|
|
15
|
+
return {
|
|
16
|
+
strategy: 'rg-only',
|
|
17
|
+
reason: 'No literal terms to narrow search',
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
if (!extraction.hasComplexPatterns && !options.wordRegexp && !options.lineRegexp) {
|
|
21
|
+
return {
|
|
22
|
+
strategy: 'fts-narrow-then-rg',
|
|
23
|
+
reason: 'Simple pattern, use FTS narrowing then verify with rg',
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
return {
|
|
27
|
+
strategy: 'fts-narrow-then-rg',
|
|
28
|
+
reason: `Narrowing with ${extraction.literals.length} hint terms`,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=strategy.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.js","sourceRoot":"","sources":["../../../src/search/rg-parser/strategy.ts"],"names":[],"mappings":"AAgBA,MAAM,UAAU,cAAc,CAC5B,UAA4B,EAC5B,OAAwB;IAExB,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;QACxB,OAAO;YACL,QAAQ,EAAE,SAAS;YACnB,MAAM,EAAE,8DAA8D;SACvE,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,OAAO,CAAC,kBAAkB,EAAE,MAAM,IAAI,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC;QAClD,OAAO;YACL,QAAQ,EAAE,SAAS;YACnB,MAAM,EAAE,gFAAgF;SACzF,CAAC;IACJ,CAAC;IAED,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACrC,OAAO;YACL,QAAQ,EAAE,SAAS;YACnB,MAAM,EAAE,mCAAmC;SAC5C,CAAC;IACJ,CAAC;IAED,IAAI,CAAC,UAAU,CAAC,kBAAkB,IAAI,CAAC,OAAO,CAAC,UAAU,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC;QACjF,OAAO;YACL,QAAQ,EAAE,oBAAoB;YAC9B,MAAM,EAAE,uDAAuD;SAChE,CAAC;IACJ,CAAC;IAED,OAAO;QACL,QAAQ,EAAE,oBAAoB;QAC9B,MAAM,EAAE,kBAAkB,UAAU,CAAC,QAAQ,CAAC,MAAM,aAAa;KAClE,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.test.d.ts","sourceRoot":"","sources":["../../../src/search/rg-parser/strategy.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { decideStrategy } from './strategy.js';
|
|
3
|
+
describe('decideStrategy', () => {
|
|
4
|
+
it('forces rg-only for invert match', () => {
|
|
5
|
+
const result = decideStrategy({ literals: ['error'], hasComplexPatterns: false, complexity: 'simple' }, { invertMatch: true });
|
|
6
|
+
expect(result.strategy).toBe('rg-only');
|
|
7
|
+
expect(result.reason).toContain('Invert match');
|
|
8
|
+
});
|
|
9
|
+
it('forces rg-only for multiple -e patterns', () => {
|
|
10
|
+
const result = decideStrategy({ literals: ['error'], hasComplexPatterns: false, complexity: 'simple' }, { additionalPatterns: ['warning'] });
|
|
11
|
+
expect(result.strategy).toBe('rg-only');
|
|
12
|
+
expect(result.reason).toContain('Multiple -e patterns');
|
|
13
|
+
});
|
|
14
|
+
it('uses rg-only when no literals are extractable', () => {
|
|
15
|
+
const result = decideStrategy({ literals: [], hasComplexPatterns: true, complexity: 'complex' }, {});
|
|
16
|
+
expect(result.strategy).toBe('rg-only');
|
|
17
|
+
});
|
|
18
|
+
it('uses fts-narrow-then-rg for simple literals', () => {
|
|
19
|
+
const result = decideStrategy({ literals: ['kubernetes'], hasComplexPatterns: false, complexity: 'simple' }, {});
|
|
20
|
+
expect(result.strategy).toBe('fts-narrow-then-rg');
|
|
21
|
+
expect(result.reason).toContain('Simple pattern');
|
|
22
|
+
});
|
|
23
|
+
it('uses fts-narrow-then-rg for complex regex with hints', () => {
|
|
24
|
+
const result = decideStrategy({ literals: ['handleRequest', 'timeout'], hasComplexPatterns: true, complexity: 'medium' }, { wordRegexp: true });
|
|
25
|
+
expect(result.strategy).toBe('fts-narrow-then-rg');
|
|
26
|
+
expect(result.reason).toContain('hint terms');
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
//# sourceMappingURL=strategy.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"strategy.test.js","sourceRoot":"","sources":["../../../src/search/rg-parser/strategy.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAE/C,QAAQ,CAAC,gBAAgB,EAAE,GAAG,EAAE;IAC9B,EAAE,CAAC,iCAAiC,EAAE,GAAG,EAAE;QACzC,MAAM,MAAM,GAAG,cAAc,CAC3B,EAAE,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,kBAAkB,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,EACxE,EAAE,WAAW,EAAE,IAAI,EAAE,CACtB,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,cAAc,CAAC,CAAC;IAClD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,yCAAyC,EAAE,GAAG,EAAE;QACjD,MAAM,MAAM,GAAG,cAAc,CAC3B,EAAE,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,kBAAkB,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,EACxE,EAAE,kBAAkB,EAAE,CAAC,SAAS,CAAC,EAAE,CACpC,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACxC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,sBAAsB,CAAC,CAAC;IAC1D,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,+CAA+C,EAAE,GAAG,EAAE;QACvD,MAAM,MAAM,GAAG,cAAc,CAC3B,EAAE,QAAQ,EAAE,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,EACjE,EAAE,CACH,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC1C,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,6CAA6C,EAAE,GAAG,EAAE;QACrD,MAAM,MAAM,GAAG,cAAc,CAC3B,EAAE,QAAQ,EAAE,CAAC,YAAY,CAAC,EAAE,kBAAkB,EAAE,KAAK,EAAE,UAAU,EAAE,QAAQ,EAAE,EAC7E,EAAE,CACH,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACnD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;IACpD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,sDAAsD,EAAE,GAAG,EAAE;QAC9D,MAAM,MAAM,GAAG,cAAc,CAC3B,EAAE,QAAQ,EAAE,CAAC,eAAe,EAAE,SAAS,CAAC,EAAE,kBAAkB,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE,EAC1F,EAAE,UAAU,EAAE,IAAI,EAAE,CACrB,CAAC;QAEF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACnD,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,SAAS,CAAC,YAAY,CAAC,CAAC;IAChD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|