raggrep 0.8.4 → 0.9.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.
@@ -4,27 +4,27 @@
4
4
  "sourcesContent": [
5
5
  "/**\n * Transformers.js Embedding Adapter\n *\n * Implements the EmbeddingProvider port using Transformers.js for local embeddings.\n * Models are automatically downloaded and cached on first use.\n */\n\nimport {\n pipeline,\n env,\n type FeatureExtractionPipeline,\n} from \"@xenova/transformers\";\nimport * as path from \"path\";\nimport * as os from \"os\";\nimport type {\n EmbeddingProvider,\n EmbeddingConfig,\n EmbeddingModelName,\n Logger,\n} from \"../../domain/ports\";\n\n// ============================================================================\n// Configuration\n// ============================================================================\n\n/** Cache directory for models */\nconst CACHE_DIR = path.join(os.homedir(), \".cache\", \"raggrep\", \"models\");\n\n// Set the cache directory for transformers.js\nenv.cacheDir = CACHE_DIR;\nenv.allowLocalModels = true;\n\n/** Available embedding models and their Hugging Face IDs */\nexport const EMBEDDING_MODELS: Record<EmbeddingModelName, string> = {\n \"all-MiniLM-L6-v2\": \"Xenova/all-MiniLM-L6-v2\",\n \"all-MiniLM-L12-v2\": \"Xenova/all-MiniLM-L12-v2\",\n \"bge-small-en-v1.5\": \"Xenova/bge-small-en-v1.5\",\n \"paraphrase-MiniLM-L3-v2\": \"Xenova/paraphrase-MiniLM-L3-v2\",\n \"nomic-embed-text-v1.5\": \"nomic-ai/nomic-embed-text-v1.5\",\n};\n\n/** Embedding dimensions per model */\nexport const EMBEDDING_DIMENSIONS: Record<EmbeddingModelName, number> = {\n \"all-MiniLM-L6-v2\": 384,\n \"all-MiniLM-L12-v2\": 384,\n \"bge-small-en-v1.5\": 384,\n \"paraphrase-MiniLM-L3-v2\": 384,\n \"nomic-embed-text-v1.5\": 768,\n};\n\n/** Maximum texts per batch */\nconst BATCH_SIZE = 32;\n\n// ============================================================================\n// Transformers.js Embedding Provider\n// ============================================================================\n\n/**\n * Embedding provider using Transformers.js (local inference).\n */\nexport class TransformersEmbeddingProvider implements EmbeddingProvider {\n private pipeline: FeatureExtractionPipeline | null = null;\n private config: EmbeddingConfig;\n private isInitializing = false;\n private initPromise: Promise<void> | null = null;\n\n constructor(config?: Partial<EmbeddingConfig>) {\n this.config = {\n model: config?.model ?? \"bge-small-en-v1.5\",\n showProgress: config?.showProgress ?? false, // Silent by default\n logger: config?.logger,\n };\n }\n\n async initialize(config?: EmbeddingConfig): Promise<void> {\n if (config) {\n // If model changed, reset pipeline\n if (config.model !== this.config.model) {\n this.pipeline = null;\n }\n this.config = { ...this.config, ...config };\n }\n\n await this.ensurePipeline();\n }\n\n private async ensurePipeline(): Promise<void> {\n if (this.pipeline) {\n return;\n }\n\n // Prevent multiple simultaneous initializations\n if (this.isInitializing && this.initPromise) {\n return this.initPromise;\n }\n\n this.isInitializing = true;\n\n this.initPromise = (async () => {\n const modelId = EMBEDDING_MODELS[this.config.model];\n const logger = this.config.logger;\n const showProgress = this.config.showProgress || !!logger;\n\n // Check if model is already cached to avoid logging progress when using cached model\n const isCached = await isModelCached(this.config.model);\n\n // Track if we've seen any actual downloads (only log if actually downloading)\n let hasDownloads = false;\n\n try {\n this.pipeline = await pipeline(\"feature-extraction\", modelId, {\n // Only show progress if we want progress AND the model isn't already cached\n progress_callback:\n showProgress && !isCached\n ? (progress: {\n status: string;\n file?: string;\n progress?: number;\n }) => {\n if (progress.status === \"progress\" && progress.file) {\n // Only start logging once we confirm there's a download happening\n if (!hasDownloads) {\n hasDownloads = true;\n if (logger) {\n logger.info(\n `Downloading embedding model: ${this.config.model}`\n );\n } else {\n console.log(\n `\\n Loading embedding model: ${this.config.model}`\n );\n console.log(` Cache: ${CACHE_DIR}`);\n }\n }\n const pct = progress.progress\n ? Math.round(progress.progress)\n : 0;\n\n if (logger) {\n logger.progress(\n ` Downloading ${progress.file}: ${pct}%`\n );\n } else {\n process.stdout.write(\n `\\r Downloading ${progress.file}: ${pct}% `\n );\n }\n } else if (progress.status === \"done\" && progress.file) {\n if (logger) {\n logger.clearProgress();\n logger.info(` Downloaded ${progress.file}`);\n } else if (hasDownloads) {\n process.stdout.write(\n `\\r Downloaded ${progress.file} \\n`\n );\n }\n }\n }\n : undefined,\n });\n\n // Only log completion if we actually downloaded something\n if (hasDownloads) {\n if (logger) {\n logger.clearProgress();\n logger.info(`Model ready: ${this.config.model}`);\n } else {\n console.log(` Model ready.\\n`);\n }\n }\n } catch (error) {\n this.pipeline = null;\n if (logger) {\n logger.clearProgress();\n }\n throw new Error(`Failed to load embedding model: ${error}`);\n } finally {\n this.isInitializing = false;\n this.initPromise = null;\n }\n })();\n\n return this.initPromise;\n }\n\n async getEmbedding(text: string): Promise<number[]> {\n await this.ensurePipeline();\n\n if (!this.pipeline) {\n throw new Error(\"Embedding pipeline not initialized\");\n }\n\n const output = await this.pipeline(text, {\n pooling: \"mean\",\n normalize: true,\n });\n\n return Array.from(output.data as Float32Array);\n }\n\n async getEmbeddings(texts: string[]): Promise<number[][]> {\n if (texts.length === 0) return [];\n\n await this.ensurePipeline();\n\n if (!this.pipeline) {\n throw new Error(\"Embedding pipeline not initialized\");\n }\n\n const results: number[][] = [];\n\n // Process in batches\n for (let i = 0; i < texts.length; i += BATCH_SIZE) {\n const batch = texts.slice(i, i + BATCH_SIZE);\n\n const outputs = await Promise.all(\n batch.map(async (text) => {\n const output = await this.pipeline!(text, {\n pooling: \"mean\",\n normalize: true,\n });\n return Array.from(output.data as Float32Array);\n })\n );\n\n results.push(...outputs);\n }\n\n return results;\n }\n\n getDimension(): number {\n return EMBEDDING_DIMENSIONS[this.config.model];\n }\n\n getModelName(): string {\n return this.config.model;\n }\n\n async dispose(): Promise<void> {\n this.pipeline = null;\n }\n}\n\n/**\n * Get the cache directory path\n */\nexport function getCacheDir(): string {\n return CACHE_DIR;\n}\n\n/**\n * Check if a model is already cached\n */\nexport async function isModelCached(\n model: EmbeddingModelName\n): Promise<boolean> {\n const modelId = EMBEDDING_MODELS[model];\n // transformers.js caches models in subdirectories matching the model ID\n // e.g., Xenova/all-MiniLM-L6-v2\n const modelPath = path.join(CACHE_DIR, modelId);\n\n try {\n const fs = await import(\"fs/promises\");\n // Check for the actual model file to ensure it's fully downloaded\n const onnxPath = path.join(modelPath, \"onnx\", \"model_quantized.onnx\");\n await fs.access(onnxPath);\n return true;\n } catch {\n return false;\n }\n}\n\n// ============================================================================\n// Global Embedding API (convenience functions)\n// ============================================================================\n\n/** Global provider instance for convenience functions */\nlet globalProvider: TransformersEmbeddingProvider | null = null;\nlet globalConfig: EmbeddingConfig = {\n model: \"bge-small-en-v1.5\",\n showProgress: false, // Silent by default for CLI usage\n logger: undefined,\n};\n\n/**\n * Configure the global embedding provider.\n */\nexport function configureEmbeddings(config: Partial<EmbeddingConfig>): void {\n const newConfig = { ...globalConfig, ...config };\n\n // If model or logger changed, reset provider to pick up new config\n if (\n newConfig.model !== globalConfig.model ||\n newConfig.logger !== globalConfig.logger\n ) {\n globalProvider = null;\n }\n\n globalConfig = newConfig as EmbeddingConfig;\n}\n\n/**\n * Get current embedding configuration.\n */\nexport function getEmbeddingConfig(): EmbeddingConfig {\n return { ...globalConfig };\n}\n\n/**\n * Ensure the global provider is initialized.\n */\nasync function ensureGlobalProvider(): Promise<TransformersEmbeddingProvider> {\n if (!globalProvider) {\n globalProvider = new TransformersEmbeddingProvider(globalConfig);\n await globalProvider.initialize();\n }\n return globalProvider;\n}\n\n/**\n * Get embedding for a single text using the global provider.\n */\nexport async function getEmbedding(text: string): Promise<number[]> {\n const provider = await ensureGlobalProvider();\n return provider.getEmbedding(text);\n}\n\n/**\n * Get embeddings for multiple texts using the global provider.\n */\nexport async function getEmbeddings(texts: string[]): Promise<number[][]> {\n const provider = await ensureGlobalProvider();\n return provider.getEmbeddings(texts);\n}\n",
6
6
  "/**\n * Embedding Infrastructure\n *\n * Provides embedding generation using Transformers.js.\n */\n\nexport {\n // Class-based API\n TransformersEmbeddingProvider,\n // Constants\n EMBEDDING_MODELS,\n EMBEDDING_DIMENSIONS,\n // Utilities\n getCacheDir,\n isModelCached,\n // Global API (convenience functions)\n configureEmbeddings,\n getEmbeddingConfig,\n getEmbedding,\n getEmbeddings,\n} from \"./transformersEmbedding\";\n",
7
- "/**\n * Logger Implementations\n *\n * Provides different logging strategies for various use cases:\n * - ConsoleLogger: Standard console output (default for SDK)\n * - InlineProgressLogger: Progress with inline replacement (for CLI)\n * - SilentLogger: No output (for quiet mode)\n */\n\nimport type { Logger } from \"../../domain/ports\";\n\n/**\n * Logger options\n */\nexport interface LoggerOptions {\n /** Show debug messages */\n verbose?: boolean;\n}\n\n/**\n * Standard console logger.\n * Logs messages normally without inline replacement.\n * Default for SDK usage.\n */\nexport class ConsoleLogger implements Logger {\n private verbose: boolean;\n\n constructor(options?: LoggerOptions) {\n this.verbose = options?.verbose ?? false;\n }\n\n info(message: string): void {\n console.log(message);\n }\n\n warn(message: string): void {\n console.warn(message);\n }\n\n error(message: string): void {\n console.error(message);\n }\n\n debug(message: string): void {\n if (this.verbose) {\n console.log(message);\n }\n }\n\n progress(message: string): void {\n // For SDK, just log the message normally\n console.log(message);\n }\n\n clearProgress(): void {\n // No-op for console logger\n }\n}\n\n/**\n * CLI logger with inline progress replacement.\n * Uses carriage return to overwrite progress lines in place.\n * Best for terminal environments with stdout/stderr.\n */\nexport class InlineProgressLogger implements Logger {\n private verbose: boolean;\n private lastProgressLength = 0;\n private hasProgress = false;\n\n constructor(options?: LoggerOptions) {\n this.verbose = options?.verbose ?? false;\n }\n\n info(message: string): void {\n this.clearProgress();\n console.log(message);\n }\n\n warn(message: string): void {\n this.clearProgress();\n console.warn(message);\n }\n\n error(message: string): void {\n this.clearProgress();\n console.error(message);\n }\n\n debug(message: string): void {\n if (this.verbose) {\n this.clearProgress();\n console.log(message);\n }\n }\n\n progress(message: string): void {\n // Use carriage return to go back to beginning of line\n process.stdout.write(`\\r${message}`);\n // Pad with spaces to clear any leftover characters from previous progress\n const padding = Math.max(0, this.lastProgressLength - message.length);\n if (padding > 0) {\n process.stdout.write(\" \".repeat(padding));\n }\n this.lastProgressLength = message.length;\n this.hasProgress = true;\n }\n\n clearProgress(): void {\n if (this.hasProgress && this.lastProgressLength > 0) {\n // Clear the line completely\n process.stdout.write(\"\\r\" + \" \".repeat(this.lastProgressLength) + \"\\r\");\n this.lastProgressLength = 0;\n this.hasProgress = false;\n }\n }\n}\n\n/**\n * Silent logger that produces no output.\n * Used for quiet mode or testing.\n */\nexport class SilentLogger implements Logger {\n info(): void {}\n warn(): void {}\n error(): void {}\n debug(): void {}\n progress(): void {}\n clearProgress(): void {}\n}\n\n/**\n * Create a standard console logger.\n * Default for SDK usage.\n */\nexport function createLogger(options?: LoggerOptions): Logger {\n return new ConsoleLogger(options);\n}\n\n/**\n * Create an inline progress logger for CLI usage.\n * Progress messages replace the current line.\n */\nexport function createInlineLogger(options?: LoggerOptions): Logger {\n return new InlineProgressLogger(options);\n}\n\n/**\n * Create a silent logger.\n * Produces no output.\n */\nexport function createSilentLogger(): Logger {\n return new SilentLogger();\n}\n\n",
7
+ "/**\n * Logger Implementations\n *\n * Provides different logging strategies for various use cases:\n * - ConsoleLogger: Standard console output (default for SDK)\n * - InlineProgressLogger: Progress with inline replacement (for CLI)\n * - SilentLogger: No output (for quiet mode)\n */\n\nimport type { Logger } from \"../../domain/ports\";\n\n/**\n * Logger options\n */\nexport interface LoggerOptions {\n /** Show debug messages */\n verbose?: boolean;\n}\n\n/**\n * Standard console logger.\n * Logs messages normally without inline replacement.\n * Default for SDK usage.\n */\nexport class ConsoleLogger implements Logger {\n private verbose: boolean;\n\n constructor(options?: LoggerOptions) {\n this.verbose = options?.verbose ?? false;\n }\n\n info(message: string): void {\n console.log(message);\n }\n\n warn(message: string): void {\n console.warn(message);\n }\n\n error(message: string): void {\n console.error(message);\n }\n\n debug(message: string): void {\n if (this.verbose) {\n console.log(message);\n }\n }\n\n progress(message: string): void {\n // For SDK, just log the message normally\n console.log(message);\n }\n\n clearProgress(): void {\n // No-op for console logger\n }\n}\n\n/**\n * CLI logger with inline progress replacement.\n * Uses carriage return to overwrite progress lines in place.\n * Best for terminal environments with stdout/stderr.\n */\nexport class InlineProgressLogger implements Logger {\n private verbose: boolean;\n private lastProgressLength = 0;\n private hasProgress = false;\n\n constructor(options?: LoggerOptions) {\n this.verbose = options?.verbose ?? false;\n }\n\n info(message: string): void {\n this.clearProgress();\n console.log(message);\n }\n\n warn(message: string): void {\n this.clearProgress();\n console.warn(message);\n }\n\n error(message: string): void {\n this.clearProgress();\n console.error(message);\n }\n\n debug(message: string): void {\n if (this.verbose) {\n this.clearProgress();\n console.log(message);\n }\n }\n\n progress(message: string): void {\n // Use carriage return to go back to beginning of line\n process.stdout.write(`\\r${message}`);\n // Pad with spaces to clear any leftover characters from previous progress\n const padding = Math.max(0, this.lastProgressLength - message.length);\n if (padding > 0) {\n process.stdout.write(\" \".repeat(padding));\n }\n this.lastProgressLength = message.length;\n this.hasProgress = true;\n }\n\n clearProgress(): void {\n if (this.hasProgress && this.lastProgressLength > 0) {\n // Clear the line completely\n process.stdout.write(\"\\r\" + \" \".repeat(this.lastProgressLength) + \"\\r\");\n this.lastProgressLength = 0;\n this.hasProgress = false;\n }\n }\n}\n\n/**\n * Silent logger that produces no output.\n * Used for quiet mode or testing.\n */\nexport class SilentLogger implements Logger {\n info(): void {}\n warn(): void {}\n error(): void {}\n debug(): void {}\n progress(): void {}\n clearProgress(): void {}\n}\n\n/**\n * Create a standard console logger.\n * Default for SDK usage.\n */\nexport function createLogger(options?: LoggerOptions): Logger {\n return new ConsoleLogger(options);\n}\n\n/**\n * Create an inline progress logger for CLI usage.\n * Progress messages replace the current line.\n */\nexport function createInlineLogger(options?: LoggerOptions): Logger {\n return new InlineProgressLogger(options);\n}\n\n/**\n * Create a silent logger.\n * Produces no output.\n */\nexport function createSilentLogger(): Logger {\n return new SilentLogger();\n}\n\n\n\n\n",
8
8
  "/**\n * SearchResult Entity\n *\n * Represents a single result from a search query.\n */\n\nimport type { Chunk } from \"./chunk\";\n\n/**\n * Contribution from the core index.\n */\nexport interface CoreContribution {\n /** Symbol name match score (0-1) */\n symbolMatch: number;\n /** BM25 keyword match score (0-1) */\n keywordMatch: number;\n}\n\n/**\n * Contribution from a language-specific index.\n */\nexport interface LanguageContribution {\n /** Semantic embedding similarity (0-1) */\n semanticMatch: number;\n /** BM25 keyword match score (0-1) */\n keywordMatch: number;\n}\n\n/**\n * Contribution from introspection boosting.\n */\nexport interface IntrospectionContribution {\n /** Boost from domain match */\n domainBoost: number;\n /** Boost from layer match */\n layerBoost: number;\n /** Boost from scope match */\n scopeBoost: number;\n /** Boost from path segment match */\n pathBoost: number;\n}\n\n/**\n * Tracks which indexes contributed to a search result's score.\n * Used for learning and tuning.\n */\nexport interface SearchContributions {\n /** Core index contribution */\n core?: CoreContribution;\n /** Language-specific index contribution (keyed by module ID) */\n language?: Record<string, LanguageContribution>;\n /** Introspection boost contribution */\n introspection?: IntrospectionContribution;\n}\n\n/**\n * A search result with relevance score and source information.\n */\nexport interface SearchResult {\n /** Path to the file containing the result */\n filepath: string;\n\n /** The matching chunk */\n chunk: Chunk;\n\n /** Final relevance score (0-1, higher is better) */\n score: number;\n\n /** ID of the module that produced this result */\n moduleId: string;\n\n /** Contribution tracking for learning */\n contributions?: SearchContributions;\n\n /** Additional context from the search (e.g., semantic vs keyword scores) */\n context?: Record<string, unknown>;\n}\n\n/**\n * Options for search operations.\n */\nexport interface SearchOptions {\n /** Maximum number of results to return (default: 10) */\n topK?: number;\n\n /** Minimum similarity score threshold 0-1 (default: 0.15) */\n minScore?: number;\n\n /** Filter to specific file patterns (e.g., ['*.ts', '*.tsx']) */\n filePatterns?: string[];\n\n /**\n * Filter results by path prefix or glob pattern.\n *\n * Supports two modes:\n * - Path prefix: 'src/auth' matches all files in src/auth/\n * - Glob pattern: '*.ts' matches all TypeScript files, '*.md' matches markdown\n *\n * Examples:\n * - ['src/auth'] - files in src/auth/\n * - ['*.ts'] - all TypeScript files\n * - ['*.md'] - all Markdown files\n * - ['src/**\\/*.test.ts'] - test files in src/\n */\n pathFilter?: string[];\n\n /**\n * Ensure the index is fresh before searching (default: true).\n *\n * When true, the search will automatically:\n * - Create the index if it doesn't exist\n * - Re-index any modified files\n * - Remove entries for deleted files\n *\n * Set to false if you've already ensured freshness or want explicit control.\n */\n ensureFresh?: boolean;\n}\n\n/**\n * Default search options.\n */\nexport const DEFAULT_SEARCH_OPTIONS: Required<SearchOptions> = {\n topK: 10,\n minScore: 0.15,\n filePatterns: [],\n pathFilter: [],\n ensureFresh: true,\n};\n",
9
9
  "/**\n * Config Entity\n *\n * Configuration for RAGgrep indexing and search operations.\n */\n\n/**\n * Configuration for a specific index module.\n */\nexport interface ModuleConfig {\n /** Unique module identifier */\n id: string;\n\n /** Whether the module is enabled */\n enabled: boolean;\n\n /** Module-specific options */\n options?: Record<string, unknown>;\n}\n\n/**\n * Main RAGgrep configuration.\n */\nexport interface Config {\n /** RAGgrep version */\n version: string;\n\n /** Directory name for index storage (default: '.raggrep') */\n indexDir: string;\n\n /** File extensions to index (e.g., ['.ts', '.tsx', '.js']) */\n extensions: string[];\n\n /** Paths to ignore during indexing */\n ignorePaths: string[];\n\n /** Enabled modules and their configurations */\n modules: ModuleConfig[];\n}\n\n/**\n * Default paths to ignore during indexing.\n */\nexport const DEFAULT_IGNORE_PATHS = [\n // Package managers & dependencies\n \"node_modules\",\n \".pnpm-store\",\n \".yarn\",\n \"vendor\",\n\n // Version control\n \".git\",\n\n // Build outputs\n \"dist\",\n \"build\",\n \"out\",\n \".output\",\n \"target\",\n\n // Framework-specific build outputs\n \".next\",\n \".nuxt\",\n \".svelte-kit\",\n \".vercel\",\n \".netlify\",\n\n // Caches\n \".cache\",\n \".turbo\",\n \".parcel-cache\",\n \".eslintcache\",\n\n // Test & coverage\n \"coverage\",\n \".nyc_output\",\n\n // Python\n \"__pycache__\",\n \".venv\",\n \"venv\",\n \".pytest_cache\",\n \"*.egg-info\",\n\n // IDE & editor\n \".idea\",\n\n // RAGgrep index\n \".raggrep\",\n];\n\n/**\n * Default file extensions to index.\n *\n * Note: Each module filters for its own supported extensions.\n * - language/typescript: .ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts\n * - data/json: .json\n * - docs/markdown: .md\n * - core: all remaining extensions\n */\nexport const DEFAULT_EXTENSIONS = [\n // TypeScript/JavaScript (language/typescript module)\n \".ts\",\n \".tsx\",\n \".js\",\n \".jsx\",\n \".mjs\",\n \".cjs\",\n \".mts\",\n \".cts\",\n // JSON (data/json module)\n \".json\",\n // Markdown (docs/markdown module)\n \".md\",\n // Other languages (core module)\n \".py\",\n \".go\",\n \".rs\",\n \".java\",\n // Config & data (core module)\n \".yaml\",\n \".yml\",\n \".toml\",\n // Database (core module)\n \".sql\",\n // Other documentation (core module)\n \".txt\",\n];\n\n/**\n * Create a default configuration.\n */\nexport function createDefaultConfig(): Config {\n return {\n version: \"0.1.0\",\n indexDir: \".raggrep\",\n extensions: DEFAULT_EXTENSIONS,\n ignorePaths: DEFAULT_IGNORE_PATHS,\n modules: [\n {\n id: \"core\",\n enabled: true,\n options: {},\n },\n {\n id: \"language/typescript\",\n enabled: true,\n options: {\n embeddingModel: \"all-MiniLM-L6-v2\",\n },\n },\n {\n id: \"data/json\",\n enabled: true,\n options: {\n embeddingModel: \"all-MiniLM-L6-v2\",\n },\n },\n {\n id: \"docs/markdown\",\n enabled: true,\n options: {\n embeddingModel: \"all-MiniLM-L6-v2\",\n },\n },\n ],\n };\n}\n",
10
10
  "/**\n * Lexicon Types\n *\n * Type definitions for Structured Semantic Expansion (SSE).\n * SSE improves search recall by expanding query terms with domain-specific synonyms.\n *\n * This is a pure domain entity with no external dependencies.\n */\n\n/**\n * Correlation grade for synonyms.\n * Determines how much weight a synonym contributes to scoring.\n *\n * - strong: Near-equivalent concepts (function ↔ method)\n * - moderate: Related but distinct (function ↔ handler)\n * - weak: Loosely associated (auth ↔ security)\n */\nexport type SynonymGrade = \"strong\" | \"moderate\" | \"weak\";\n\n/**\n * A single synonym with its correlation grade.\n */\nexport interface Synonym {\n /** The synonym term */\n term: string;\n\n /** Correlation strength with the parent term */\n grade: SynonymGrade;\n}\n\n/**\n * A synonym entry in the lexicon.\n */\nexport interface SynonymEntry {\n /** The canonical term */\n term: string;\n\n /** Synonyms with their correlation grades */\n synonyms: Synonym[];\n\n /** Optional context restriction (e.g., \"typescript\", \"database\") */\n context?: string;\n}\n\n/**\n * The lexicon containing all synonym mappings.\n */\nexport interface Lexicon {\n /** Version for compatibility checking */\n version: string;\n\n /** All synonym entries */\n entries: SynonymEntry[];\n\n /** Optional module-specific overrides */\n moduleOverrides?: Record<string, SynonymEntry[]>;\n}\n\n/**\n * An expanded term with weight information.\n */\nexport interface ExpandedTerm {\n /** The term (original or synonym) */\n term: string;\n\n /** Weight for scoring (1.0 for original, lower for synonyms) */\n weight: number;\n\n /** How this term was derived */\n source: \"original\" | \"strong\" | \"moderate\" | \"weak\";\n\n /** The original term this was expanded from (if synonym) */\n expandedFrom?: string;\n}\n\n/**\n * Result of expanding a query.\n */\nexport interface ExpandedQuery {\n /** Original query string */\n originalQuery: string;\n\n /** Original query terms (tokenized) */\n originalTerms: string[];\n\n /** All terms including expansions with weights */\n expandedTerms: ExpandedTerm[];\n\n /** Query string with expansions (for embedding) */\n expandedQueryString: string;\n\n /** Whether any expansion occurred */\n wasExpanded: boolean;\n}\n\n/**\n * Options for query expansion.\n */\nexport interface ExpansionOptions {\n /** Maximum expansion depth (passes). Default: 1 */\n maxDepth?: number;\n\n /** Include weak synonyms. Default: true */\n includeWeak?: boolean;\n\n /** Maximum total terms after expansion. Default: 20 */\n maxTerms?: number;\n\n /** Minimum term length to expand. Default: 2 */\n minTermLength?: number;\n\n /** Context filter (only use entries matching this context) */\n context?: string;\n}\n\n/**\n * Default expansion options.\n */\nexport const DEFAULT_EXPANSION_OPTIONS: Required<\n Omit<ExpansionOptions, \"context\">\n> = {\n maxDepth: 1,\n includeWeak: true,\n maxTerms: 20,\n minTermLength: 2,\n};\n\n/**\n * Weights applied to synonyms by grade.\n */\nexport const EXPANSION_WEIGHTS: Record<SynonymGrade, number> = {\n strong: 0.9,\n moderate: 0.6,\n weak: 0.3,\n};\n",
11
11
  "/**\n * Domain Entities\n *\n * Core business objects with no external dependencies.\n * These represent the fundamental concepts in the RAGgrep domain.\n */\n\n// Chunk - The fundamental unit of indexing\nexport type { Chunk, ChunkType } from \"./chunk\";\nexport { createChunkId } from \"./chunk\";\n\n// FileIndex - Tier 2 full index data\nexport type {\n FileIndex,\n FileManifestEntry,\n ModuleManifest,\n GlobalManifest,\n} from \"./fileIndex\";\n\n// FileSummary - Symbolic index (lightweight summaries)\nexport type {\n FileSummary,\n SymbolicIndexMeta,\n Tier1Manifest,\n} from \"./fileSummary\";\n\n// SearchResult - Query results\nexport type {\n SearchResult,\n SearchOptions,\n SearchContributions,\n CoreContribution,\n LanguageContribution,\n IntrospectionContribution,\n} from \"./searchResult\";\nexport { DEFAULT_SEARCH_OPTIONS } from \"./searchResult\";\n\n// Config - Application configuration\nexport type { Config, ModuleConfig } from \"./config\";\nexport {\n DEFAULT_IGNORE_PATHS,\n DEFAULT_EXTENSIONS,\n createDefaultConfig,\n} from \"./config\";\n\n// Introspection - File metadata for context-aware search\nexport type {\n FileIntrospection,\n ProjectStructure,\n Project,\n ProjectType,\n Scope,\n IntrospectionConfig,\n} from \"./introspection\";\n\n// Conventions - File pattern recognition\nexport type {\n FileConvention,\n ConventionCategory,\n FrameworkConventions,\n ConventionMatch,\n} from \"./conventions\";\n\n// Literal - Types for literal boosting\nexport type {\n LiteralType,\n LiteralMatchType,\n LiteralConfidence,\n LiteralDetectionMethod,\n ExtractedLiteral,\n DetectedLiteral,\n QueryLiteralParseResult,\n LiteralMatch,\n LiteralIndexEntry,\n LiteralIndexData,\n} from \"./literal\";\nexport { LITERAL_SCORING } from \"./literal\";\n\n// Lexicon - Types for structured semantic expansion\nexport type {\n SynonymGrade,\n Synonym,\n SynonymEntry,\n Lexicon,\n ExpandedTerm,\n ExpandedQuery,\n ExpansionOptions,\n} from \"./lexicon\";\nexport { DEFAULT_EXPANSION_OPTIONS, EXPANSION_WEIGHTS } from \"./lexicon\";\n",
12
12
  "/**\n * Configuration Loader\n *\n * Infrastructure adapter for loading and saving RAGgrep configuration.\n * Handles file I/O operations for configuration management.\n */\n\nimport * as path from \"path\";\nimport * as fs from \"fs/promises\";\nimport * as os from \"os\";\nimport * as crypto from \"crypto\";\nimport type { Config, ModuleConfig } from \"../../domain/entities\";\nimport { createDefaultConfig } from \"../../domain/entities\";\nimport type { EmbeddingConfig, EmbeddingModelName } from \"../../domain/ports\";\n\n// ============================================================================\n// Constants\n// ============================================================================\n\n/** Default configuration instance */\nexport const DEFAULT_CONFIG: Config = createDefaultConfig();\n\n/** Base directory for raggrep temp indexes */\nconst RAGGREP_TEMP_BASE = path.join(os.tmpdir(), \"raggrep-indexes\");\n\n/** Available embedding models (for validation) */\nexport const EMBEDDING_MODELS: Record<EmbeddingModelName, string> = {\n \"all-MiniLM-L6-v2\": \"Xenova/all-MiniLM-L6-v2\",\n \"all-MiniLM-L12-v2\": \"Xenova/all-MiniLM-L12-v2\",\n \"bge-small-en-v1.5\": \"Xenova/bge-small-en-v1.5\",\n \"paraphrase-MiniLM-L3-v2\": \"Xenova/paraphrase-MiniLM-L3-v2\",\n \"nomic-embed-text-v1.5\": \"nomic-ai/nomic-embed-text-v1.5\",\n};\n\n// ============================================================================\n// Path Utilities (pure functions)\n// ============================================================================\n\n/**\n * Generate a short hash of a string for use in directory names.\n * Uses first 12 characters of SHA256 hash.\n */\nfunction hashPath(inputPath: string): string {\n return crypto\n .createHash(\"sha256\")\n .update(inputPath)\n .digest(\"hex\")\n .slice(0, 12);\n}\n\n/**\n * Get the index storage directory path.\n *\n * Index data is stored in a system temp directory to avoid cluttering\n * the user's project with index files. The temp path is derived from\n * a hash of the project's absolute path to ensure uniqueness.\n *\n * Structure: {tmpdir}/raggrep-indexes/{hash}/\n *\n * @param rootDir - Absolute path to the project root\n * @returns Absolute path to the index storage directory\n */\nexport function getRaggrepDir(\n rootDir: string,\n _config: Config = DEFAULT_CONFIG\n): string {\n // Ensure we have an absolute path\n const absoluteRoot = path.resolve(rootDir);\n\n // Generate a unique hash for this project\n const projectHash = hashPath(absoluteRoot);\n\n // Return the temp directory path\n return path.join(RAGGREP_TEMP_BASE, projectHash);\n}\n\n/**\n * Get the index storage path and also return useful metadata.\n * Helpful for debugging and user feedback.\n */\nexport function getIndexLocation(rootDir: string): {\n indexDir: string;\n projectRoot: string;\n projectHash: string;\n} {\n const absoluteRoot = path.resolve(rootDir);\n const projectHash = hashPath(absoluteRoot);\n\n return {\n indexDir: path.join(RAGGREP_TEMP_BASE, projectHash),\n projectRoot: absoluteRoot,\n projectHash,\n };\n}\n\n/**\n * Get the index data directory for a specific module\n */\nexport function getModuleIndexPath(\n rootDir: string,\n moduleId: string,\n config: Config = DEFAULT_CONFIG\n): string {\n const indexDir = getRaggrepDir(rootDir, config);\n return path.join(indexDir, \"index\", moduleId);\n}\n\n/**\n * Get the manifest path for a specific module\n */\nexport function getModuleManifestPath(\n rootDir: string,\n moduleId: string,\n config: Config = DEFAULT_CONFIG\n): string {\n const indexDir = getRaggrepDir(rootDir, config);\n return path.join(indexDir, \"index\", moduleId, \"manifest.json\");\n}\n\n/**\n * Get the global manifest path\n */\nexport function getGlobalManifestPath(\n rootDir: string,\n config: Config = DEFAULT_CONFIG\n): string {\n const indexDir = getRaggrepDir(rootDir, config);\n return path.join(indexDir, \"manifest.json\");\n}\n\n/**\n * Get the config file path.\n * Note: Config is still stored in the temp index directory, not the project.\n */\nexport function getConfigPath(\n rootDir: string,\n config: Config = DEFAULT_CONFIG\n): string {\n const indexDir = getRaggrepDir(rootDir, config);\n return path.join(indexDir, \"config.json\");\n}\n\n// ============================================================================\n// Config I/O (infrastructure)\n// ============================================================================\n\n/**\n * Load config from file or return default\n */\nexport async function loadConfig(rootDir: string): Promise<Config> {\n const configPath = getConfigPath(rootDir, DEFAULT_CONFIG);\n\n try {\n const content = await fs.readFile(configPath, \"utf-8\");\n const savedConfig = JSON.parse(content) as Partial<Config>;\n return { ...DEFAULT_CONFIG, ...savedConfig };\n } catch {\n return DEFAULT_CONFIG;\n }\n}\n\n/**\n * Save config to file\n */\nexport async function saveConfig(\n rootDir: string,\n config: Config\n): Promise<void> {\n const configPath = getConfigPath(rootDir, config);\n await fs.mkdir(path.dirname(configPath), { recursive: true });\n await fs.writeFile(configPath, JSON.stringify(config, null, 2));\n}\n\n// ============================================================================\n// Config Utilities (pure functions)\n// ============================================================================\n\n/**\n * Get module config by ID\n */\nexport function getModuleConfig(\n config: Config,\n moduleId: string\n): ModuleConfig | undefined {\n return config.modules.find((m) => m.id === moduleId);\n}\n\n/**\n * Extract embedding config from module options\n */\nexport function getEmbeddingConfigFromModule(\n moduleConfig: ModuleConfig\n): EmbeddingConfig {\n const options = moduleConfig.options || {};\n const modelName = (options.embeddingModel as string) || \"bge-small-en-v1.5\";\n\n // Validate model name\n if (!(modelName in EMBEDDING_MODELS)) {\n console.warn(\n `Unknown embedding model: ${modelName}, falling back to bge-small-en-v1.5`\n );\n return { model: \"bge-small-en-v1.5\" };\n }\n\n return {\n model: modelName as EmbeddingModelName,\n // Default to NO progress logs unless explicitly enabled\n showProgress: options.showProgress === true,\n };\n}\n",
13
13
  "/**\n * Configuration Infrastructure\n *\n * Handles loading and saving RAGgrep configuration from the filesystem.\n */\n\nexport {\n // Constants\n DEFAULT_CONFIG,\n EMBEDDING_MODELS,\n // Path utilities\n getRaggrepDir,\n getIndexLocation,\n getModuleIndexPath,\n getModuleManifestPath,\n getGlobalManifestPath,\n getConfigPath,\n // I/O operations\n loadConfig,\n saveConfig,\n // Config utilities\n getModuleConfig,\n getEmbeddingConfigFromModule,\n} from \"./configLoader\";\n\n",
14
- "/**\n * BM25 (Best Matching 25) Implementation\n * \n * A ranking function for keyword-based search. This is a pure domain service\n * with no external dependencies - just algorithms operating on data.\n * \n * BM25 estimates relevance of documents to a search query using term frequency\n * and inverse document frequency with length normalization.\n */\n\n/**\n * BM25 parameters\n * - k1: Term frequency saturation (typical: 1.2-2.0)\n * - b: Length normalization (typical: 0.75)\n */\nconst BM25_K1 = 1.5;\nconst BM25_B = 0.75;\n\n/**\n * Tokenize text into normalized terms.\n * \n * @param text - Text to tokenize\n * @returns Array of lowercase tokens\n */\nexport function tokenize(text: string): string[] {\n return text\n .toLowerCase()\n .replace(/[^\\w\\s]/g, ' ')\n .split(/\\s+/)\n .filter(token => token.length > 1);\n}\n\n/**\n * Calculate term frequency (TF) for a term in a document.\n */\nfunction termFrequency(term: string, tokens: string[]): number {\n return tokens.filter(t => t === term).length;\n}\n\n/**\n * Document data for BM25 scoring.\n */\nexport interface BM25Document {\n id: string;\n content: string;\n /** Pre-computed tokens (optional, computed from content if not provided) */\n tokens?: string[];\n}\n\n/**\n * BM25 search result.\n */\nexport interface BM25Result {\n id: string;\n score: number;\n}\n\n/**\n * BM25 search index.\n * \n * This is a pure in-memory data structure with no I/O operations.\n * Build the index by adding documents, then search against it.\n */\nexport class BM25Index {\n private documents: Map<string, { content: string; tokens: string[] }> = new Map();\n private avgDocLength: number = 0;\n private documentFrequencies: Map<string, number> = new Map();\n private totalDocs: number = 0;\n\n /**\n * Add documents to the index.\n * \n * @param documents - Array of documents to index\n */\n addDocuments(documents: BM25Document[]): void {\n let totalLength = this.avgDocLength * this.totalDocs;\n\n for (const doc of documents) {\n const tokens = doc.tokens ?? tokenize(doc.content);\n this.documents.set(doc.id, { content: doc.content, tokens });\n totalLength += tokens.length;\n this.totalDocs++;\n\n // Update document frequencies\n const uniqueTerms = new Set(tokens);\n for (const term of uniqueTerms) {\n const count = this.documentFrequencies.get(term) || 0;\n this.documentFrequencies.set(term, count + 1);\n }\n }\n\n this.avgDocLength = this.totalDocs > 0 ? totalLength / this.totalDocs : 0;\n }\n\n /**\n * Calculate IDF (Inverse Document Frequency) for a term.\n */\n private idf(term: string): number {\n const docFreq = this.documentFrequencies.get(term) || 0;\n if (docFreq === 0) return 0;\n \n // Standard IDF formula with smoothing\n return Math.log(1 + (this.totalDocs - docFreq + 0.5) / (docFreq + 0.5));\n }\n\n /**\n * Calculate BM25 score for a document given query terms.\n */\n private score(tokens: string[], queryTerms: string[]): number {\n const docLength = tokens.length;\n let score = 0;\n\n for (const term of queryTerms) {\n const tf = termFrequency(term, tokens);\n if (tf === 0) continue;\n\n const idfScore = this.idf(term);\n \n // BM25 formula\n const numerator = tf * (BM25_K1 + 1);\n const denominator = tf + BM25_K1 * (1 - BM25_B + BM25_B * (docLength / this.avgDocLength));\n \n score += idfScore * (numerator / denominator);\n }\n\n return score;\n }\n\n /**\n * Search the index with a query.\n * \n * @param query - Search query\n * @param topK - Maximum number of results to return\n * @returns Sorted array of results (highest score first)\n */\n search(query: string, topK: number = 10): BM25Result[] {\n const queryTerms = tokenize(query);\n if (queryTerms.length === 0) return [];\n\n const results: BM25Result[] = [];\n\n for (const [id, { tokens }] of this.documents) {\n const score = this.score(tokens, queryTerms);\n if (score > 0) {\n results.push({ id, score });\n }\n }\n\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n\n /**\n * Get the number of indexed documents.\n */\n get size(): number {\n return this.totalDocs;\n }\n\n /**\n * Clear the index.\n */\n clear(): void {\n this.documents.clear();\n this.documentFrequencies.clear();\n this.avgDocLength = 0;\n this.totalDocs = 0;\n }\n\n /**\n * Add a single document by ID and pre-computed tokens.\n *\n * @param id - Document identifier\n * @param tokens - Pre-computed tokens\n */\n addDocument(id: string, tokens: string[]): void {\n this.addDocuments([{ id, content: \"\", tokens }]);\n }\n\n /**\n * Serialize the index to a JSON-compatible object.\n */\n serialize(): BM25SerializedData {\n const documents: Record<string, string[]> = {};\n for (const [id, { tokens }] of this.documents) {\n documents[id] = tokens;\n }\n\n return {\n documents,\n avgDocLength: this.avgDocLength,\n documentFrequencies: Object.fromEntries(this.documentFrequencies),\n totalDocs: this.totalDocs,\n };\n }\n\n /**\n * Deserialize a BM25 index from saved data.\n */\n static deserialize(data: BM25SerializedData): BM25Index {\n const index = new BM25Index();\n index.avgDocLength = data.avgDocLength;\n index.totalDocs = data.totalDocs;\n index.documentFrequencies = new Map(Object.entries(data.documentFrequencies));\n\n for (const [id, tokens] of Object.entries(data.documents)) {\n index.documents.set(id, { content: \"\", tokens });\n }\n\n return index;\n }\n}\n\n/**\n * Serialized BM25 index data.\n */\nexport interface BM25SerializedData {\n documents: Record<string, string[]>;\n avgDocLength: number;\n documentFrequencies: Record<string, number>;\n totalDocs: number;\n}\n\n/**\n * Normalize a raw score to 0-1 range using sigmoid function.\n * \n * @param score - Raw score\n * @param midpoint - Score at which output is 0.5\n * @returns Normalized score between 0 and 1\n */\nexport function normalizeScore(score: number, midpoint: number = 5): number {\n return 1 / (1 + Math.exp(-score / midpoint + 1));\n}\n\n",
14
+ "/**\n * BM25 (Best Matching 25) Implementation\n * \n * A ranking function for keyword-based search. This is a pure domain service\n * with no external dependencies - just algorithms operating on data.\n * \n * BM25 estimates relevance of documents to a search query using term frequency\n * and inverse document frequency with length normalization.\n */\n\n/**\n * BM25 parameters\n * - k1: Term frequency saturation (typical: 1.2-2.0)\n * - b: Length normalization (typical: 0.75)\n */\nconst BM25_K1 = 1.5;\nconst BM25_B = 0.75;\n\n/**\n * Tokenize text into normalized terms.\n * \n * @param text - Text to tokenize\n * @returns Array of lowercase tokens\n */\nexport function tokenize(text: string): string[] {\n return text\n .toLowerCase()\n .replace(/[^\\w\\s]/g, ' ')\n .split(/\\s+/)\n .filter(token => token.length > 1);\n}\n\n/**\n * Calculate term frequency (TF) for a term in a document.\n */\nfunction termFrequency(term: string, tokens: string[]): number {\n return tokens.filter(t => t === term).length;\n}\n\n/**\n * Document data for BM25 scoring.\n */\nexport interface BM25Document {\n id: string;\n content: string;\n /** Pre-computed tokens (optional, computed from content if not provided) */\n tokens?: string[];\n}\n\n/**\n * BM25 search result.\n */\nexport interface BM25Result {\n id: string;\n score: number;\n}\n\n/**\n * BM25 search index.\n * \n * This is a pure in-memory data structure with no I/O operations.\n * Build the index by adding documents, then search against it.\n */\nexport class BM25Index {\n private documents: Map<string, { content: string; tokens: string[] }> = new Map();\n private avgDocLength: number = 0;\n private documentFrequencies: Map<string, number> = new Map();\n private totalDocs: number = 0;\n\n /**\n * Add documents to the index.\n * \n * @param documents - Array of documents to index\n */\n addDocuments(documents: BM25Document[]): void {\n let totalLength = this.avgDocLength * this.totalDocs;\n\n for (const doc of documents) {\n const tokens = doc.tokens ?? tokenize(doc.content);\n this.documents.set(doc.id, { content: doc.content, tokens });\n totalLength += tokens.length;\n this.totalDocs++;\n\n // Update document frequencies\n const uniqueTerms = new Set(tokens);\n for (const term of uniqueTerms) {\n const count = this.documentFrequencies.get(term) || 0;\n this.documentFrequencies.set(term, count + 1);\n }\n }\n\n this.avgDocLength = this.totalDocs > 0 ? totalLength / this.totalDocs : 0;\n }\n\n /**\n * Calculate IDF (Inverse Document Frequency) for a term.\n */\n private idf(term: string): number {\n const docFreq = this.documentFrequencies.get(term) || 0;\n if (docFreq === 0) return 0;\n \n // Standard IDF formula with smoothing\n return Math.log(1 + (this.totalDocs - docFreq + 0.5) / (docFreq + 0.5));\n }\n\n /**\n * Calculate BM25 score for a document given query terms.\n */\n private score(tokens: string[], queryTerms: string[]): number {\n const docLength = tokens.length;\n let score = 0;\n\n for (const term of queryTerms) {\n const tf = termFrequency(term, tokens);\n if (tf === 0) continue;\n\n const idfScore = this.idf(term);\n \n // BM25 formula\n const numerator = tf * (BM25_K1 + 1);\n const denominator = tf + BM25_K1 * (1 - BM25_B + BM25_B * (docLength / this.avgDocLength));\n \n score += idfScore * (numerator / denominator);\n }\n\n return score;\n }\n\n /**\n * Search the index with a query.\n * \n * @param query - Search query\n * @param topK - Maximum number of results to return\n * @returns Sorted array of results (highest score first)\n */\n search(query: string, topK: number = 10): BM25Result[] {\n const queryTerms = tokenize(query);\n if (queryTerms.length === 0) return [];\n\n const results: BM25Result[] = [];\n\n for (const [id, { tokens }] of this.documents) {\n const score = this.score(tokens, queryTerms);\n if (score > 0) {\n results.push({ id, score });\n }\n }\n\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n\n /**\n * Get the number of indexed documents.\n */\n get size(): number {\n return this.totalDocs;\n }\n\n /**\n * Clear the index.\n */\n clear(): void {\n this.documents.clear();\n this.documentFrequencies.clear();\n this.avgDocLength = 0;\n this.totalDocs = 0;\n }\n\n /**\n * Add a single document by ID and pre-computed tokens.\n *\n * @param id - Document identifier\n * @param tokens - Pre-computed tokens\n */\n addDocument(id: string, tokens: string[]): void {\n this.addDocuments([{ id, content: \"\", tokens }]);\n }\n\n /**\n * Remove a document from the index.\n * Updates document frequencies and average document length.\n *\n * @param id - Document identifier to remove\n * @returns true if document was removed, false if not found\n */\n removeDocument(id: string): boolean {\n const doc = this.documents.get(id);\n if (!doc) return false;\n\n const tokens = doc.tokens;\n\n // Update document frequencies\n const uniqueTerms = new Set(tokens);\n for (const term of uniqueTerms) {\n const count = this.documentFrequencies.get(term) || 0;\n if (count <= 1) {\n this.documentFrequencies.delete(term);\n } else {\n this.documentFrequencies.set(term, count - 1);\n }\n }\n\n // Update average document length\n const totalLength = this.avgDocLength * this.totalDocs - tokens.length;\n this.totalDocs--;\n this.avgDocLength = this.totalDocs > 0 ? totalLength / this.totalDocs : 0;\n\n // Remove the document\n this.documents.delete(id);\n return true;\n }\n\n /**\n * Update a document in the index (remove + add).\n * More efficient than separate remove/add as it batches the operations.\n *\n * @param id - Document identifier\n * @param newTokens - New tokens for the document\n */\n updateDocument(id: string, newTokens: string[]): void {\n this.removeDocument(id);\n this.addDocument(id, newTokens);\n }\n\n /**\n * Check if a document exists in the index.\n *\n * @param id - Document identifier\n * @returns true if document exists\n */\n hasDocument(id: string): boolean {\n return this.documents.has(id);\n }\n\n /**\n * Serialize the index to a JSON-compatible object.\n */\n serialize(): BM25SerializedData {\n const documents: Record<string, string[]> = {};\n for (const [id, { tokens }] of this.documents) {\n documents[id] = tokens;\n }\n\n return {\n documents,\n avgDocLength: this.avgDocLength,\n documentFrequencies: Object.fromEntries(this.documentFrequencies),\n totalDocs: this.totalDocs,\n };\n }\n\n /**\n * Deserialize a BM25 index from saved data.\n */\n static deserialize(data: BM25SerializedData): BM25Index {\n const index = new BM25Index();\n index.avgDocLength = data.avgDocLength;\n index.totalDocs = data.totalDocs;\n index.documentFrequencies = new Map(Object.entries(data.documentFrequencies));\n\n for (const [id, tokens] of Object.entries(data.documents)) {\n index.documents.set(id, { content: \"\", tokens });\n }\n\n return index;\n }\n}\n\n/**\n * Serialized BM25 index data.\n */\nexport interface BM25SerializedData {\n documents: Record<string, string[]>;\n avgDocLength: number;\n documentFrequencies: Record<string, number>;\n totalDocs: number;\n}\n\n/**\n * Normalize a raw score to 0-1 range using sigmoid function.\n * \n * @param score - Raw score\n * @param midpoint - Score at which output is 0.5\n * @returns Normalized score between 0 and 1\n */\nexport function normalizeScore(score: number, midpoint: number = 5): number {\n return 1 / (1 + Math.exp(-score / midpoint + 1));\n}\n\n",
15
15
  "/**\n * Entry Point Conventions\n *\n * Patterns for recognizing module entry points and barrel files.\n */\n\nimport * as path from \"path\";\nimport type { FileConvention } from \"../../entities/conventions\";\n\n/**\n * Get the parent folder name from a filepath.\n */\nfunction getParentFolder(filepath: string): string {\n const dir = path.dirname(filepath);\n return path.basename(dir);\n}\n\n/**\n * Entry point conventions for JavaScript/TypeScript projects.\n */\nexport const entryPointConventions: FileConvention[] = [\n {\n id: \"index-file\",\n name: \"Index/Barrel File\",\n description:\n \"Module entry point that typically re-exports from other files\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return /^index\\.(ts|tsx|js|jsx|mjs|cjs)$/.test(filename);\n },\n keywords: [\"entry\", \"barrel\", \"exports\", \"module\"],\n // Add parent folder as a strong keyword since \"auth/index.ts\" should match \"auth\"\n dynamicKeywords: (filepath) => {\n const parent = getParentFolder(filepath);\n // Don't add generic folder names\n if ([\"src\", \"lib\", \"dist\", \"build\", \".\", \"\"].includes(parent)) {\n return [];\n }\n return [parent.toLowerCase()];\n },\n },\n\n {\n id: \"main-file\",\n name: \"Main Entry Point\",\n description: \"Application main entry point\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return /^main\\.(ts|tsx|js|jsx|mjs|cjs)$/.test(filename);\n },\n keywords: [\"entry\", \"main\", \"entrypoint\", \"bootstrap\", \"startup\"],\n },\n\n {\n id: \"app-component\",\n name: \"Root App Component\",\n description: \"Root application component (React, Vue, etc.)\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return /^App\\.(tsx|jsx|vue|svelte)$/.test(filename);\n },\n keywords: [\"root\", \"app\", \"application\", \"component\", \"main\"],\n },\n\n {\n id: \"deno-mod\",\n name: \"Deno Module Entry\",\n description: \"Deno module entry point\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"mod.ts\";\n },\n keywords: [\"entry\", \"module\", \"deno\", \"exports\"],\n dynamicKeywords: (filepath) => {\n const parent = getParentFolder(filepath);\n if ([\"src\", \"lib\", \".\", \"\"].includes(parent)) {\n return [];\n }\n return [parent.toLowerCase()];\n },\n },\n\n {\n id: \"python-init\",\n name: \"Python Package Init\",\n description: \"Python package initialization file\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"__init__.py\";\n },\n keywords: [\"entry\", \"package\", \"init\", \"python\", \"module\"],\n dynamicKeywords: (filepath) => {\n const parent = getParentFolder(filepath);\n if ([\"src\", \"lib\", \".\", \"\"].includes(parent)) {\n return [];\n }\n return [parent.toLowerCase()];\n },\n },\n\n {\n id: \"rust-lib\",\n name: \"Rust Library Entry\",\n description: \"Rust library crate entry point\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"lib.rs\" || filename === \"main.rs\";\n },\n keywords: [\"entry\", \"crate\", \"rust\", \"module\"],\n },\n\n // ============================================================================\n // Go Entry Points\n // ============================================================================\n {\n id: \"go-main\",\n name: \"Go Main Entry\",\n description: \"Go application main entry point\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"main.go\";\n },\n keywords: [\"entry\", \"main\", \"go\", \"golang\", \"entrypoint\"],\n dynamicKeywords: (filepath) => {\n const parent = getParentFolder(filepath);\n // cmd/myapp/main.go -> \"myapp\"\n if (parent && ![\"cmd\", \"src\", \".\", \"\"].includes(parent)) {\n return [parent.toLowerCase()];\n }\n return [];\n },\n },\n\n // ============================================================================\n // Python Entry Points\n // ============================================================================\n {\n id: \"python-main\",\n name: \"Python Main Module\",\n description: \"Python package main entry point\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"__main__.py\";\n },\n keywords: [\"entry\", \"main\", \"python\", \"entrypoint\", \"cli\"],\n dynamicKeywords: (filepath) => {\n const parent = getParentFolder(filepath);\n if ([\"src\", \"lib\", \".\", \"\"].includes(parent)) {\n return [];\n }\n return [parent.toLowerCase()];\n },\n },\n {\n id: \"python-app\",\n name: \"Python App Entry\",\n description: \"Common Python application entry points\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return (\n filename === \"app.py\" || filename === \"main.py\" || filename === \"run.py\"\n );\n },\n keywords: [\"entry\", \"main\", \"python\", \"app\", \"entrypoint\"],\n },\n {\n id: \"python-manage\",\n name: \"Django Manage\",\n description: \"Django management script\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"manage.py\";\n },\n keywords: [\"entry\", \"django\", \"python\", \"manage\", \"cli\", \"admin\"],\n },\n {\n id: \"python-wsgi\",\n name: \"Python WSGI Entry\",\n description: \"Python WSGI application entry point\",\n category: \"entry-point\",\n match: (filepath, filename) => {\n return filename === \"wsgi.py\" || filename === \"asgi.py\";\n },\n keywords: [\"entry\", \"wsgi\", \"asgi\", \"python\", \"server\", \"web\"],\n },\n];\n",
16
16
  "/**\n * Configuration File Conventions\n *\n * Patterns for recognizing common configuration files.\n */\n\nimport type { FileConvention } from \"../../entities/conventions\";\n\n/**\n * Configuration file conventions.\n */\nexport const configFileConventions: FileConvention[] = [\n // ============================================================================\n // Package Management\n // ============================================================================\n {\n id: \"package-json\",\n name: \"Package.json\",\n description: \"Node.js package manifest\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"package.json\",\n keywords: [\"package\", \"dependencies\", \"npm\", \"scripts\", \"manifest\", \"node\"],\n },\n {\n id: \"pnpm-workspace\",\n name: \"PNPM Workspace\",\n description: \"PNPM monorepo workspace configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"pnpm-workspace.yaml\" || filename === \"pnpm-workspace.yml\",\n keywords: [\"workspace\", \"monorepo\", \"pnpm\", \"packages\"],\n },\n {\n id: \"yarn-lock\",\n name: \"Yarn Lock\",\n description: \"Yarn dependency lock file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"yarn.lock\",\n keywords: [\"dependencies\", \"lock\", \"yarn\", \"versions\"],\n },\n {\n id: \"package-lock\",\n name: \"Package Lock\",\n description: \"NPM dependency lock file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"package-lock.json\",\n keywords: [\"dependencies\", \"lock\", \"npm\", \"versions\"],\n },\n {\n id: \"bun-lockb\",\n name: \"Bun Lock\",\n description: \"Bun dependency lock file\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"bun.lockb\" || filename === \"bun.lock\",\n keywords: [\"dependencies\", \"lock\", \"bun\", \"versions\"],\n },\n\n // ============================================================================\n // Go\n // ============================================================================\n {\n id: \"go-mod\",\n name: \"Go Module\",\n description: \"Go module definition file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"go.mod\",\n keywords: [\n \"go\",\n \"golang\",\n \"module\",\n \"dependencies\",\n \"package\",\n \"workspace\",\n ],\n },\n {\n id: \"go-sum\",\n name: \"Go Sum\",\n description: \"Go module checksum file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"go.sum\",\n keywords: [\"go\", \"golang\", \"dependencies\", \"checksum\", \"lock\", \"versions\"],\n },\n {\n id: \"go-work\",\n name: \"Go Workspace\",\n description: \"Go workspace configuration for multi-module development\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"go.work\" || filename === \"go.work.sum\",\n keywords: [\"go\", \"golang\", \"workspace\", \"monorepo\", \"modules\"],\n },\n {\n id: \"makefile\",\n name: \"Makefile\",\n description: \"Make build automation file\",\n category: \"build\",\n match: (filepath, filename) =>\n filename === \"Makefile\" ||\n filename === \"makefile\" ||\n filename === \"GNUmakefile\",\n keywords: [\"make\", \"build\", \"automation\", \"tasks\", \"compile\"],\n },\n\n // ============================================================================\n // Python\n // ============================================================================\n {\n id: \"requirements-txt\",\n name: \"Python Requirements\",\n description: \"Python pip requirements file\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"requirements.txt\" ||\n filename.startsWith(\"requirements-\") ||\n filename.startsWith(\"requirements_\"),\n keywords: [\"python\", \"pip\", \"dependencies\", \"packages\", \"requirements\"],\n },\n {\n id: \"pyproject-toml\",\n name: \"Python Project\",\n description: \"Python project configuration (PEP 518/621)\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"pyproject.toml\",\n keywords: [\n \"python\",\n \"project\",\n \"config\",\n \"poetry\",\n \"build\",\n \"dependencies\",\n \"package\",\n ],\n },\n {\n id: \"setup-py\",\n name: \"Python Setup\",\n description: \"Python package setup script\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"setup.py\",\n keywords: [\"python\", \"setup\", \"package\", \"install\", \"distribution\"],\n },\n {\n id: \"setup-cfg\",\n name: \"Python Setup Config\",\n description: \"Python setup configuration file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"setup.cfg\",\n keywords: [\"python\", \"setup\", \"config\", \"package\", \"metadata\"],\n },\n {\n id: \"pipfile\",\n name: \"Pipfile\",\n description: \"Pipenv dependency file\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"Pipfile\" || filename === \"Pipfile.lock\",\n keywords: [\"python\", \"pipenv\", \"dependencies\", \"packages\", \"virtualenv\"],\n },\n {\n id: \"poetry-lock\",\n name: \"Poetry Lock\",\n description: \"Poetry dependency lock file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"poetry.lock\",\n keywords: [\"python\", \"poetry\", \"dependencies\", \"lock\", \"versions\"],\n },\n {\n id: \"tox-ini\",\n name: \"Tox Config\",\n description: \"Tox testing automation configuration\",\n category: \"test\",\n match: (filepath, filename) => filename === \"tox.ini\",\n keywords: [\"python\", \"tox\", \"testing\", \"automation\", \"environments\"],\n },\n {\n id: \"pytest-ini\",\n name: \"Pytest Config\",\n description: \"Pytest configuration file\",\n category: \"test\",\n match: (filepath, filename) =>\n filename === \"pytest.ini\" || filename === \"conftest.py\",\n keywords: [\"python\", \"pytest\", \"testing\", \"test\", \"fixtures\"],\n },\n {\n id: \"mypy-ini\",\n name: \"Mypy Config\",\n description: \"Mypy type checker configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"mypy.ini\" || filename === \".mypy.ini\",\n keywords: [\"python\", \"mypy\", \"types\", \"type checking\", \"static analysis\"],\n },\n {\n id: \"flake8\",\n name: \"Flake8 Config\",\n description: \"Flake8 linter configuration\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \".flake8\",\n keywords: [\"python\", \"flake8\", \"linting\", \"lint\", \"style\"],\n },\n {\n id: \"pylintrc\",\n name: \"Pylint Config\",\n description: \"Pylint linter configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \".pylintrc\" ||\n filename === \"pylintrc\" ||\n filename === \"pylint.toml\",\n keywords: [\"python\", \"pylint\", \"linting\", \"lint\", \"code quality\"],\n },\n {\n id: \"ruff-toml\",\n name: \"Ruff Config\",\n description: \"Ruff linter/formatter configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"ruff.toml\" || filename === \".ruff.toml\",\n keywords: [\"python\", \"ruff\", \"linting\", \"formatting\", \"fast\"],\n },\n {\n id: \"black-toml\",\n name: \"Black Config\",\n description: \"Black formatter configuration\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \".black.toml\",\n keywords: [\"python\", \"black\", \"formatting\", \"format\", \"style\"],\n },\n\n // ============================================================================\n // TypeScript\n // ============================================================================\n {\n id: \"tsconfig\",\n name: \"TypeScript Config\",\n description: \"TypeScript compiler configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"tsconfig.json\" ||\n (filename.startsWith(\"tsconfig.\") && filename.endsWith(\".json\")),\n keywords: [\n \"typescript\",\n \"config\",\n \"compiler\",\n \"ts\",\n \"settings\",\n \"paths\",\n \"types\",\n ],\n },\n {\n id: \"jsconfig\",\n name: \"JavaScript Config\",\n description: \"JavaScript project configuration\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"jsconfig.json\",\n keywords: [\"javascript\", \"config\", \"compiler\", \"js\", \"settings\", \"paths\"],\n },\n\n // ============================================================================\n // Linting & Formatting\n // ============================================================================\n {\n id: \"eslint-config\",\n name: \"ESLint Config\",\n description: \"ESLint linting configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \".eslintrc\" ||\n filename === \".eslintrc.js\" ||\n filename === \".eslintrc.cjs\" ||\n filename === \".eslintrc.json\" ||\n filename === \".eslintrc.yml\" ||\n filename === \".eslintrc.yaml\" ||\n filename === \"eslint.config.js\" ||\n filename === \"eslint.config.mjs\" ||\n filename === \"eslint.config.cjs\",\n keywords: [\"eslint\", \"linting\", \"lint\", \"rules\", \"code quality\"],\n },\n {\n id: \"prettier-config\",\n name: \"Prettier Config\",\n description: \"Prettier code formatting configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \".prettierrc\" ||\n filename === \".prettierrc.js\" ||\n filename === \".prettierrc.cjs\" ||\n filename === \".prettierrc.json\" ||\n filename === \".prettierrc.yml\" ||\n filename === \".prettierrc.yaml\" ||\n filename === \"prettier.config.js\" ||\n filename === \"prettier.config.cjs\" ||\n filename === \"prettier.config.mjs\",\n keywords: [\"prettier\", \"formatting\", \"format\", \"code style\", \"style\"],\n },\n {\n id: \"biome-config\",\n name: \"Biome Config\",\n description: \"Biome linting and formatting configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"biome.json\" || filename === \"biome.jsonc\",\n keywords: [\"biome\", \"linting\", \"formatting\", \"lint\", \"format\"],\n },\n\n // ============================================================================\n // Build Tools\n // ============================================================================\n {\n id: \"vite-config\",\n name: \"Vite Config\",\n description: \"Vite build tool configuration\",\n category: \"build\",\n match: (filepath, filename) =>\n filename === \"vite.config.ts\" ||\n filename === \"vite.config.js\" ||\n filename === \"vite.config.mjs\",\n keywords: [\"vite\", \"bundler\", \"build\", \"dev server\", \"hmr\"],\n },\n {\n id: \"webpack-config\",\n name: \"Webpack Config\",\n description: \"Webpack bundler configuration\",\n category: \"build\",\n match: (filepath, filename) =>\n filename === \"webpack.config.js\" ||\n filename === \"webpack.config.ts\" ||\n (filename.startsWith(\"webpack.\") &&\n (filename.endsWith(\".js\") || filename.endsWith(\".ts\"))),\n keywords: [\"webpack\", \"bundler\", \"build\", \"loaders\", \"plugins\"],\n },\n {\n id: \"rollup-config\",\n name: \"Rollup Config\",\n description: \"Rollup bundler configuration\",\n category: \"build\",\n match: (filepath, filename) =>\n filename === \"rollup.config.js\" ||\n filename === \"rollup.config.ts\" ||\n filename === \"rollup.config.mjs\",\n keywords: [\"rollup\", \"bundler\", \"build\", \"esm\", \"bundle\"],\n },\n {\n id: \"esbuild-config\",\n name: \"esbuild Config\",\n description: \"esbuild bundler configuration\",\n category: \"build\",\n match: (filepath, filename) =>\n filename === \"esbuild.config.js\" ||\n filename === \"esbuild.config.ts\" ||\n filename === \"esbuild.config.mjs\",\n keywords: [\"esbuild\", \"bundler\", \"build\", \"fast\"],\n },\n\n // ============================================================================\n // Testing\n // ============================================================================\n {\n id: \"jest-config\",\n name: \"Jest Config\",\n description: \"Jest testing framework configuration\",\n category: \"test\",\n match: (filepath, filename) =>\n filename === \"jest.config.js\" ||\n filename === \"jest.config.ts\" ||\n filename === \"jest.config.mjs\" ||\n filename === \"jest.config.cjs\" ||\n filename === \"jest.config.json\",\n keywords: [\"jest\", \"testing\", \"test\", \"unit test\", \"config\"],\n },\n {\n id: \"vitest-config\",\n name: \"Vitest Config\",\n description: \"Vitest testing framework configuration\",\n category: \"test\",\n match: (filepath, filename) =>\n filename === \"vitest.config.ts\" ||\n filename === \"vitest.config.js\" ||\n filename === \"vitest.config.mts\",\n keywords: [\"vitest\", \"testing\", \"test\", \"unit test\", \"config\"],\n },\n {\n id: \"playwright-config\",\n name: \"Playwright Config\",\n description: \"Playwright E2E testing configuration\",\n category: \"test\",\n match: (filepath, filename) =>\n filename === \"playwright.config.ts\" ||\n filename === \"playwright.config.js\",\n keywords: [\"playwright\", \"testing\", \"e2e\", \"end-to-end\", \"browser test\"],\n },\n {\n id: \"cypress-config\",\n name: \"Cypress Config\",\n description: \"Cypress E2E testing configuration\",\n category: \"test\",\n match: (filepath, filename) =>\n filename === \"cypress.config.ts\" ||\n filename === \"cypress.config.js\" ||\n filename === \"cypress.json\",\n keywords: [\"cypress\", \"testing\", \"e2e\", \"end-to-end\", \"browser test\"],\n },\n\n // ============================================================================\n // Styling\n // ============================================================================\n {\n id: \"tailwind-config\",\n name: \"Tailwind Config\",\n description: \"Tailwind CSS configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"tailwind.config.js\" ||\n filename === \"tailwind.config.ts\" ||\n filename === \"tailwind.config.cjs\" ||\n filename === \"tailwind.config.mjs\",\n keywords: [\"tailwind\", \"css\", \"styling\", \"utility\", \"design\"],\n },\n {\n id: \"postcss-config\",\n name: \"PostCSS Config\",\n description: \"PostCSS configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"postcss.config.js\" ||\n filename === \"postcss.config.cjs\" ||\n filename === \"postcss.config.mjs\" ||\n filename === \".postcssrc\" ||\n filename === \".postcssrc.json\",\n keywords: [\"postcss\", \"css\", \"styling\", \"transforms\"],\n },\n\n // ============================================================================\n // Environment & Secrets\n // ============================================================================\n {\n id: \"env-file\",\n name: \"Environment File\",\n description: \"Environment variables file\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \".env\" ||\n filename === \".env.local\" ||\n filename === \".env.development\" ||\n filename === \".env.production\" ||\n filename === \".env.test\" ||\n filename.startsWith(\".env.\"),\n keywords: [\"environment\", \"env\", \"variables\", \"secrets\", \"config\"],\n },\n {\n id: \"env-example\",\n name: \"Environment Example\",\n description: \"Example environment variables file\",\n category: \"documentation\",\n match: (filepath, filename) =>\n filename === \".env.example\" ||\n filename === \".env.sample\" ||\n filename === \".env.template\",\n keywords: [\"environment\", \"env\", \"example\", \"template\", \"setup\"],\n },\n\n // ============================================================================\n // Deployment & CI/CD\n // ============================================================================\n {\n id: \"dockerfile\",\n name: \"Dockerfile\",\n description: \"Docker container image definition\",\n category: \"deployment\",\n match: (filepath, filename) =>\n filename === \"Dockerfile\" || filename.startsWith(\"Dockerfile.\"),\n keywords: [\"docker\", \"container\", \"image\", \"deployment\", \"build\"],\n },\n {\n id: \"docker-compose\",\n name: \"Docker Compose\",\n description: \"Docker Compose multi-container configuration\",\n category: \"deployment\",\n match: (filepath, filename) =>\n filename === \"docker-compose.yml\" ||\n filename === \"docker-compose.yaml\" ||\n filename === \"compose.yml\" ||\n filename === \"compose.yaml\" ||\n filename.startsWith(\"docker-compose.\"),\n keywords: [\"docker\", \"compose\", \"containers\", \"services\", \"deployment\"],\n },\n {\n id: \"github-actions\",\n name: \"GitHub Actions Workflow\",\n description: \"GitHub Actions CI/CD workflow\",\n category: \"deployment\",\n match: (filepath) =>\n filepath.includes(\".github/workflows/\") && filepath.endsWith(\".yml\"),\n keywords: [\"github\", \"actions\", \"ci\", \"cd\", \"workflow\", \"automation\"],\n },\n {\n id: \"vercel-config\",\n name: \"Vercel Config\",\n description: \"Vercel deployment configuration\",\n category: \"deployment\",\n match: (filepath, filename) => filename === \"vercel.json\",\n keywords: [\"vercel\", \"deployment\", \"hosting\", \"serverless\"],\n },\n {\n id: \"netlify-config\",\n name: \"Netlify Config\",\n description: \"Netlify deployment configuration\",\n category: \"deployment\",\n match: (filepath, filename) => filename === \"netlify.toml\",\n keywords: [\"netlify\", \"deployment\", \"hosting\", \"functions\"],\n },\n\n // ============================================================================\n // Git\n // ============================================================================\n {\n id: \"gitignore\",\n name: \"Git Ignore\",\n description: \"Git ignored files configuration\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \".gitignore\",\n keywords: [\"git\", \"ignore\", \"version control\", \"excluded\"],\n },\n {\n id: \"gitattributes\",\n name: \"Git Attributes\",\n description: \"Git file attributes configuration\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \".gitattributes\",\n keywords: [\"git\", \"attributes\", \"version control\", \"line endings\"],\n },\n\n // ============================================================================\n // Documentation\n // ============================================================================\n {\n id: \"readme\",\n name: \"README\",\n description: \"Project documentation\",\n category: \"documentation\",\n match: (filepath, filename) =>\n filename.toLowerCase() === \"readme.md\" ||\n filename.toLowerCase() === \"readme\",\n keywords: [\n \"readme\",\n \"documentation\",\n \"docs\",\n \"overview\",\n \"getting started\",\n ],\n },\n {\n id: \"changelog\",\n name: \"Changelog\",\n description: \"Project changelog\",\n category: \"documentation\",\n match: (filepath, filename) =>\n filename.toLowerCase() === \"changelog.md\" ||\n filename.toLowerCase() === \"changelog\",\n keywords: [\"changelog\", \"changes\", \"releases\", \"history\", \"versions\"],\n },\n {\n id: \"contributing\",\n name: \"Contributing Guide\",\n description: \"Contribution guidelines\",\n category: \"documentation\",\n match: (filepath, filename) =>\n filename.toLowerCase() === \"contributing.md\" ||\n filename.toLowerCase() === \"contributing\",\n keywords: [\"contributing\", \"contribution\", \"guidelines\", \"development\"],\n },\n {\n id: \"license\",\n name: \"License\",\n description: \"Project license\",\n category: \"documentation\",\n match: (filepath, filename) =>\n filename.toLowerCase() === \"license\" ||\n filename.toLowerCase() === \"license.md\" ||\n filename.toLowerCase() === \"license.txt\",\n keywords: [\"license\", \"legal\", \"copyright\", \"terms\"],\n },\n];\n",
17
17
  "/**\n * Next.js Framework Conventions\n *\n * Patterns for recognizing Next.js specific files and structures.\n */\n\nimport type {\n FileConvention,\n FrameworkConventions,\n} from \"../../../entities/conventions\";\n\nconst nextjsConventions: FileConvention[] = [\n // ============================================================================\n // Configuration\n // ============================================================================\n {\n id: \"next-config\",\n name: \"Next.js Config\",\n description: \"Next.js framework configuration\",\n category: \"configuration\",\n match: (filepath, filename) =>\n filename === \"next.config.js\" ||\n filename === \"next.config.mjs\" ||\n filename === \"next.config.ts\",\n keywords: [\"nextjs\", \"next\", \"config\", \"framework\", \"settings\"],\n },\n {\n id: \"next-env\",\n name: \"Next.js Environment Types\",\n description: \"Next.js TypeScript environment declarations\",\n category: \"types\",\n match: (filepath, filename) => filename === \"next-env.d.ts\",\n keywords: [\"nextjs\", \"types\", \"typescript\", \"declarations\"],\n },\n\n // ============================================================================\n // App Router (Next.js 13+)\n // ============================================================================\n {\n id: \"next-layout\",\n name: \"Next.js Layout\",\n description: \"Next.js layout component (App Router)\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"layout.tsx\" || filename === \"layout.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"layout\", \"wrapper\", \"template\", \"app router\"],\n dynamicKeywords: (filepath) => {\n // Extract route segment from path\n const match = filepath.match(/app\\/(.+?)\\/layout\\./);\n if (match) {\n const segments = match[1]\n .split(\"/\")\n .filter((s) => !s.startsWith(\"(\") && !s.startsWith(\"[\"));\n return segments.map((s) => s.toLowerCase());\n }\n if (filepath === \"app/layout.tsx\" || filepath === \"app/layout.js\") {\n return [\"root\", \"main\"];\n }\n return [];\n },\n },\n {\n id: \"next-page\",\n name: \"Next.js Page\",\n description: \"Next.js page component (App Router)\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"page.tsx\" || filename === \"page.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"page\", \"route\", \"view\", \"app router\"],\n dynamicKeywords: (filepath) => {\n // Extract route from path\n const match = filepath.match(/app\\/(.+?)\\/page\\./);\n if (match) {\n const segments = match[1]\n .split(\"/\")\n .filter((s) => !s.startsWith(\"(\"))\n .map((s) => s.replace(/^\\[(.+?)\\]$/, \"$1\")); // [id] -> id\n return segments.map((s) => s.toLowerCase());\n }\n if (filepath === \"app/page.tsx\" || filepath === \"app/page.js\") {\n return [\"home\", \"index\", \"root\"];\n }\n return [];\n },\n },\n {\n id: \"next-loading\",\n name: \"Next.js Loading\",\n description: \"Next.js loading UI component\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"loading.tsx\" || filename === \"loading.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"loading\", \"suspense\", \"skeleton\", \"spinner\"],\n },\n {\n id: \"next-error\",\n name: \"Next.js Error\",\n description: \"Next.js error boundary component\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"error.tsx\" || filename === \"error.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"error\", \"boundary\", \"fallback\", \"catch\"],\n },\n {\n id: \"next-not-found\",\n name: \"Next.js Not Found\",\n description: \"Next.js 404 page component\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"not-found.tsx\" || filename === \"not-found.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"404\", \"not found\", \"missing\", \"error\"],\n },\n {\n id: \"next-template\",\n name: \"Next.js Template\",\n description: \"Next.js template component\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"template.tsx\" || filename === \"template.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"template\", \"wrapper\", \"app router\"],\n },\n\n // ============================================================================\n // API Routes (App Router)\n // ============================================================================\n {\n id: \"next-route-handler\",\n name: \"Next.js Route Handler\",\n description: \"Next.js API route handler (App Router)\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"route.ts\" || filename === \"route.js\") &&\n (filepath.includes(\"/app/\") || filepath.startsWith(\"app/\")),\n keywords: [\"nextjs\", \"api\", \"route\", \"handler\", \"endpoint\", \"rest\"],\n dynamicKeywords: (filepath) => {\n // Extract API path\n const match = filepath.match(/app\\/api\\/(.+?)\\/route\\./);\n if (match) {\n const segments = match[1]\n .split(\"/\")\n .filter((s) => !s.startsWith(\"(\"))\n .map((s) => s.replace(/^\\[(.+?)\\]$/, \"$1\"));\n return [\"api\", ...segments.map((s) => s.toLowerCase())];\n }\n return [\"api\"];\n },\n },\n\n // ============================================================================\n // Middleware & Special Files\n // ============================================================================\n {\n id: \"next-middleware\",\n name: \"Next.js Middleware\",\n description: \"Next.js edge middleware\",\n category: \"framework\",\n match: (filepath, filename) =>\n filename === \"middleware.ts\" || filename === \"middleware.js\",\n keywords: [\"nextjs\", \"middleware\", \"edge\", \"request\", \"interceptor\"],\n },\n {\n id: \"next-global-error\",\n name: \"Next.js Global Error\",\n description: \"Next.js global error handler\",\n category: \"framework\",\n match: (filepath, filename) =>\n filename === \"global-error.tsx\" || filename === \"global-error.js\",\n keywords: [\"nextjs\", \"error\", \"global\", \"boundary\", \"catch\"],\n },\n\n // ============================================================================\n // Pages Router (Legacy)\n // ============================================================================\n {\n id: \"next-pages-api\",\n name: \"Next.js API Route (Pages)\",\n description: \"Next.js API route (Pages Router)\",\n category: \"framework\",\n match: (filepath) =>\n filepath.includes(\"/pages/api/\") || filepath.startsWith(\"pages/api/\"),\n keywords: [\"nextjs\", \"api\", \"route\", \"handler\", \"endpoint\", \"pages router\"],\n dynamicKeywords: (filepath) => {\n const match = filepath.match(/pages\\/api\\/(.+?)\\.(ts|js)/);\n if (match) {\n const segments = match[1]\n .split(\"/\")\n .map((s) => s.replace(/^\\[(.+?)\\]$/, \"$1\"));\n return [\"api\", ...segments.map((s) => s.toLowerCase())];\n }\n return [\"api\"];\n },\n },\n {\n id: \"next-pages-document\",\n name: \"Next.js Document\",\n description: \"Next.js custom document (Pages Router)\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"_document.tsx\" || filename === \"_document.js\") &&\n (filepath.includes(\"/pages/\") || filepath.startsWith(\"pages/\")),\n keywords: [\"nextjs\", \"document\", \"html\", \"head\", \"body\", \"pages router\"],\n },\n {\n id: \"next-pages-app\",\n name: \"Next.js App (Pages)\",\n description: \"Next.js custom app (Pages Router)\",\n category: \"framework\",\n match: (filepath, filename) =>\n (filename === \"_app.tsx\" || filename === \"_app.js\") &&\n (filepath.includes(\"/pages/\") || filepath.startsWith(\"pages/\")),\n keywords: [\"nextjs\", \"app\", \"wrapper\", \"provider\", \"pages router\"],\n },\n];\n\n/**\n * Next.js framework conventions provider.\n */\nexport const nextjsFramework: FrameworkConventions = {\n id: \"nextjs\",\n name: \"Next.js\",\n detect: (filepath) => {\n // Detect if this is likely a Next.js project\n return (\n filepath === \"next.config.js\" ||\n filepath === \"next.config.mjs\" ||\n filepath === \"next.config.ts\" ||\n filepath.includes(\"/app/page.\") ||\n filepath.includes(\"/pages/_app.\")\n );\n },\n conventions: nextjsConventions,\n};\n",
18
18
  "/**\n * Convex Framework Conventions\n *\n * Patterns for recognizing Convex backend files and structures.\n * Convex is a backend platform with real-time sync.\n */\n\nimport type {\n FileConvention,\n FrameworkConventions,\n} from \"../../../entities/conventions\";\n\nconst convexConventions: FileConvention[] = [\n // ============================================================================\n // Configuration\n // ============================================================================\n {\n id: \"convex-config\",\n name: \"Convex Config\",\n description: \"Convex project configuration\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"convex.json\",\n keywords: [\"convex\", \"config\", \"backend\", \"settings\"],\n },\n\n // ============================================================================\n // Schema\n // ============================================================================\n {\n id: \"convex-schema\",\n name: \"Convex Schema\",\n description: \"Convex database schema definition\",\n category: \"framework\",\n match: (filepath, filename) =>\n filename === \"schema.ts\" &&\n (filepath.includes(\"/convex/\") || filepath.startsWith(\"convex/\")),\n keywords: [\"convex\", \"schema\", \"database\", \"tables\", \"types\", \"model\"],\n },\n\n // ============================================================================\n // Functions\n // ============================================================================\n {\n id: \"convex-function\",\n name: \"Convex Function File\",\n description: \"Convex backend function file\",\n category: \"framework\",\n match: (filepath, filename, extension) =>\n (extension === \".ts\" || extension === \".js\") &&\n (filepath.includes(\"/convex/\") || filepath.startsWith(\"convex/\")) &&\n !filepath.includes(\"/_generated/\") &&\n filename !== \"schema.ts\" &&\n !filename.startsWith(\"_\"),\n keywords: [\"convex\", \"function\", \"backend\", \"query\", \"mutation\", \"action\"],\n dynamicKeywords: (filepath) => {\n // Extract function file name as keyword\n const match = filepath.match(/convex\\/(.+?)\\.(ts|js)/);\n if (match) {\n const name = match[1].replace(/\\//g, \" \").split(\" \").pop() || \"\";\n if (name && ![\"schema\", \"http\", \"crons\"].includes(name)) {\n return [name.toLowerCase()];\n }\n }\n return [];\n },\n },\n\n // ============================================================================\n // HTTP Routes\n // ============================================================================\n {\n id: \"convex-http\",\n name: \"Convex HTTP Routes\",\n description: \"Convex HTTP endpoint definitions\",\n category: \"framework\",\n match: (filepath, filename) =>\n filename === \"http.ts\" &&\n (filepath.includes(\"/convex/\") || filepath.startsWith(\"convex/\")),\n keywords: [\"convex\", \"http\", \"routes\", \"api\", \"endpoints\", \"rest\"],\n },\n\n // ============================================================================\n // Cron Jobs\n // ============================================================================\n {\n id: \"convex-crons\",\n name: \"Convex Cron Jobs\",\n description: \"Convex scheduled function definitions\",\n category: \"framework\",\n match: (filepath, filename) =>\n filename === \"crons.ts\" &&\n (filepath.includes(\"/convex/\") || filepath.startsWith(\"convex/\")),\n keywords: [\n \"convex\",\n \"crons\",\n \"scheduled\",\n \"jobs\",\n \"background\",\n \"recurring\",\n ],\n },\n\n // ============================================================================\n // Generated Files\n // ============================================================================\n {\n id: \"convex-generated\",\n name: \"Convex Generated\",\n description: \"Convex auto-generated files\",\n category: \"framework\",\n match: (filepath) =>\n filepath.includes(\"/convex/_generated/\") ||\n filepath.startsWith(\"convex/_generated/\"),\n keywords: [\"convex\", \"generated\", \"types\", \"api\"],\n },\n\n // ============================================================================\n // Auth\n // ============================================================================\n {\n id: \"convex-auth\",\n name: \"Convex Auth\",\n description: \"Convex authentication configuration\",\n category: \"framework\",\n match: (filepath, filename) =>\n filename === \"auth.ts\" &&\n (filepath.includes(\"/convex/\") || filepath.startsWith(\"convex/\")),\n keywords: [\"convex\", \"auth\", \"authentication\", \"login\", \"users\"],\n },\n {\n id: \"convex-auth-config\",\n name: \"Convex Auth Config\",\n description: \"Convex auth configuration file\",\n category: \"configuration\",\n match: (filepath, filename) => filename === \"auth.config.ts\",\n keywords: [\"convex\", \"auth\", \"config\", \"providers\", \"oauth\"],\n },\n];\n\n/**\n * Convex framework conventions provider.\n */\nexport const convexFramework: FrameworkConventions = {\n id: \"convex\",\n name: \"Convex\",\n detect: (filepath) => {\n // Detect if this is likely a Convex project\n return (\n filepath === \"convex.json\" ||\n filepath.startsWith(\"convex/\") ||\n filepath.includes(\"/convex/\")\n );\n },\n conventions: convexConventions,\n};\n",
19
19
  "/**\n * Framework Conventions Registry\n *\n * Central registry for framework-specific conventions.\n * Add new frameworks here to extend convention support.\n */\n\nimport type { FrameworkConventions } from \"../../../entities/conventions\";\nimport { nextjsFramework } from \"./nextjs\";\nimport { convexFramework } from \"./convex\";\n\n/**\n * All registered framework convention providers.\n * Add new frameworks to this array.\n */\nexport const frameworkProviders: FrameworkConventions[] = [\n nextjsFramework,\n convexFramework,\n];\n\n/**\n * Get all framework conventions.\n */\nexport function getAllFrameworkConventions() {\n return frameworkProviders.flatMap((f) => f.conventions);\n}\n\n/**\n * Get frameworks by ID.\n */\nexport function getFramework(id: string): FrameworkConventions | undefined {\n return frameworkProviders.find((f) => f.id === id);\n}\n\n// Re-export individual frameworks\nexport { nextjsFramework } from \"./nextjs\";\nexport { convexFramework } from \"./convex\";\n",
20
- "/**\n * File Conventions Service\n *\n * Pure functions for matching files against conventions and extracting keywords.\n * No I/O operations - all functions operate on file paths.\n *\n * Categories:\n * - Entry Points: index.ts, main.ts, App.tsx, etc.\n * - Configuration: tsconfig.json, .prettierrc, package.json, etc.\n * - Frameworks: Next.js, Convex, and other framework-specific patterns\n * - Type Definitions: *.d.ts, *.types.ts\n *\n * Extensibility:\n * - Add new conventions to entryPoints.ts or configFiles.ts\n * - Add new frameworks in the frameworks/ directory\n */\n\nimport * as path from \"path\";\nimport type {\n FileConvention,\n ConventionMatch,\n} from \"../../entities/conventions\";\nimport { entryPointConventions } from \"./entryPoints\";\nimport { configFileConventions } from \"./configFiles\";\nimport { getAllFrameworkConventions } from \"./frameworks\";\n\n// Re-export types from entities\nexport type {\n FileConvention,\n ConventionCategory,\n ConventionMatch,\n FrameworkConventions,\n} from \"../../entities/conventions\";\n\n/**\n * Type definition file conventions (built-in).\n */\nconst typeDefinitionConventions: FileConvention[] = [\n {\n id: \"dts-file\",\n name: \"TypeScript Declaration\",\n description: \"TypeScript type declaration file\",\n category: \"types\",\n match: (filepath, filename) => filename.endsWith(\".d.ts\"),\n keywords: [\"types\", \"declarations\", \"typescript\", \"definitions\"],\n },\n {\n id: \"types-file\",\n name: \"Types File\",\n description: \"TypeScript types file\",\n category: \"types\",\n match: (filepath, filename) =>\n filename.endsWith(\".types.ts\") || filename === \"types.ts\",\n keywords: [\"types\", \"definitions\", \"typescript\", \"interfaces\"],\n dynamicKeywords: (filepath) => {\n const match = filepath.match(/([^/]+)\\.types\\.ts$/);\n if (match) return [match[1].toLowerCase()];\n return [];\n },\n },\n {\n id: \"types-folder\",\n name: \"Types Folder File\",\n description: \"File in a types folder\",\n category: \"types\",\n match: (filepath) =>\n filepath.includes(\"/types/\") || filepath.startsWith(\"types/\"),\n keywords: [\"types\", \"definitions\"],\n },\n];\n\n/**\n * Test file conventions (built-in).\n */\nconst testFileConventions: FileConvention[] = [\n {\n id: \"test-file\",\n name: \"Test File\",\n description: \"Unit/integration test file\",\n category: \"test\",\n match: (filepath, filename) =>\n filename.includes(\".test.\") ||\n filename.includes(\".spec.\") ||\n filename.includes(\"_test.\"),\n keywords: [\"test\", \"spec\", \"unit test\"],\n dynamicKeywords: (filepath) => {\n const match = filepath.match(/([^/]+)\\.(test|spec)\\./);\n if (match) return [match[1].toLowerCase()];\n return [];\n },\n },\n {\n id: \"test-folder\",\n name: \"Test Folder File\",\n description: \"File in a test folder\",\n category: \"test\",\n match: (filepath) =>\n filepath.includes(\"/__tests__/\") ||\n filepath.includes(\"/test/\") ||\n filepath.includes(\"/tests/\") ||\n filepath.startsWith(\"__tests__/\") ||\n filepath.startsWith(\"test/\") ||\n filepath.startsWith(\"tests/\"),\n keywords: [\"test\", \"testing\"],\n },\n];\n\n/**\n * Get all conventions including built-in ones.\n */\nexport function getConventions(): FileConvention[] {\n return [\n ...entryPointConventions,\n ...configFileConventions,\n ...getAllFrameworkConventions(),\n ...typeDefinitionConventions,\n ...testFileConventions,\n ];\n}\n\n/**\n * Match a filepath against all conventions and return keywords.\n *\n * @param filepath - The file path (relative to project root)\n * @returns Array of keywords from all matching conventions\n */\nexport function getConventionKeywords(filepath: string): string[] {\n const conventions = getConventions();\n const filename = path.basename(filepath);\n const extension = path.extname(filepath);\n const keywords = new Set<string>();\n\n for (const convention of conventions) {\n try {\n if (convention.match(filepath, filename, extension)) {\n // Add static keywords\n for (const keyword of convention.keywords) {\n keywords.add(keyword.toLowerCase());\n }\n\n // Add dynamic keywords\n if (convention.dynamicKeywords) {\n const dynamicKws = convention.dynamicKeywords(filepath);\n for (const kw of dynamicKws) {\n if (kw && kw.length > 1) {\n keywords.add(kw.toLowerCase());\n }\n }\n }\n }\n } catch {\n // Skip conventions that throw errors\n }\n }\n\n return Array.from(keywords);\n}\n\n/**\n * Match a filepath against all conventions and return detailed matches.\n *\n * @param filepath - The file path (relative to project root)\n * @returns Array of convention matches with details\n */\nexport function matchConventions(filepath: string): ConventionMatch[] {\n const conventions = getConventions();\n const filename = path.basename(filepath);\n const extension = path.extname(filepath);\n const matches: ConventionMatch[] = [];\n\n for (const convention of conventions) {\n try {\n if (convention.match(filepath, filename, extension)) {\n const keywords = [...convention.keywords];\n\n if (convention.dynamicKeywords) {\n const dynamicKws = convention.dynamicKeywords(filepath);\n keywords.push(...dynamicKws.filter((k) => k && k.length > 1));\n }\n\n matches.push({\n convention,\n keywords: keywords.map((k) => k.toLowerCase()),\n });\n }\n } catch {\n // Skip conventions that throw errors\n }\n }\n\n return matches;\n}\n\n// Re-export convention collections for extension\nexport { entryPointConventions } from \"./entryPoints\";\nexport { configFileConventions } from \"./configFiles\";\nexport { frameworkProviders, getAllFrameworkConventions } from \"./frameworks\";\n\n\n\n\n",
21
- "/**\n * Introspection Service\n *\n * Pure functions for extracting file metadata from paths and content.\n * No I/O operations - all functions operate on provided data.\n */\n\nimport * as path from \"path\";\nimport type {\n FileIntrospection,\n Project,\n ProjectStructure,\n Scope,\n ProjectType,\n} from \"../entities/introspection\";\nimport { getConventionKeywords } from \"./conventions\";\n\n// ============================================================================\n// Constants\n// ============================================================================\n\n/**\n * Layer detection patterns.\n */\nconst LAYER_PATTERNS: Record<string, string[]> = {\n controller: [\"controller\", \"api\", \"routes\", \"route\", \"handler\"],\n service: [\"service\", \"logic\", \"usecase\", \"usecases\", \"handler\"],\n repository: [\"repository\", \"repo\", \"dao\", \"store\", \"persistence\"],\n model: [\n \"model\",\n \"models\",\n \"entity\",\n \"entities\",\n \"schema\",\n \"schemas\",\n \"types\",\n \"type\",\n ],\n util: [\"util\", \"utils\", \"helper\", \"helpers\", \"common\", \"lib\"],\n config: [\"config\", \"configuration\", \"settings\"],\n middleware: [\"middleware\", \"middlewares\"],\n domain: [\"domain\"],\n infrastructure: [\"infrastructure\", \"infra\"],\n application: [\"application\", \"app\"],\n presentation: [\n \"presentation\",\n \"ui\",\n \"views\",\n \"view\",\n \"component\",\n \"components\",\n ],\n test: [\"test\", \"tests\", \"spec\", \"specs\", \"__tests__\", \"e2e\"],\n};\n\n/**\n * Domain detection patterns (feature areas).\n */\nconst DOMAIN_PATTERNS = [\n \"auth\",\n \"authentication\",\n \"user\",\n \"users\",\n \"account\",\n \"accounts\",\n \"profile\",\n \"profiles\",\n \"product\",\n \"products\",\n \"item\",\n \"items\",\n \"catalog\",\n \"order\",\n \"orders\",\n \"cart\",\n \"checkout\",\n \"payment\",\n \"payments\",\n \"billing\",\n \"subscription\",\n \"subscriptions\",\n \"notification\",\n \"notifications\",\n \"email\",\n \"sms\",\n \"report\",\n \"reports\",\n \"analytics\",\n \"metrics\",\n \"dashboard\",\n \"admin\",\n \"settings\",\n \"search\",\n \"chat\",\n \"message\",\n \"messages\",\n \"feed\",\n \"post\",\n \"posts\",\n \"comment\",\n \"comments\",\n \"media\",\n \"upload\",\n \"file\",\n \"files\",\n \"storage\",\n \"cache\",\n \"session\",\n \"log\",\n \"logs\",\n \"audit\",\n];\n\n/**\n * Framework detection from imports.\n */\nconst FRAMEWORK_INDICATORS: Record<string, string[]> = {\n nextjs: [\"next\", \"next/\"],\n express: [\"express\"],\n fastify: [\"fastify\"],\n react: [\"react\"],\n vue: [\"vue\"],\n angular: [\"@angular/\"],\n nestjs: [\"@nestjs/\"],\n koa: [\"koa\"],\n};\n\n/**\n * Language detection from file extension.\n */\nconst EXTENSION_TO_LANGUAGE: Record<string, string> = {\n \".ts\": \"typescript\",\n \".tsx\": \"typescript\",\n \".js\": \"javascript\",\n \".jsx\": \"javascript\",\n \".mjs\": \"javascript\",\n \".cjs\": \"javascript\",\n \".py\": \"python\",\n \".go\": \"go\",\n \".rs\": \"rust\",\n \".java\": \"java\",\n \".kt\": \"kotlin\",\n \".swift\": \"swift\",\n \".rb\": \"ruby\",\n \".php\": \"php\",\n \".cs\": \"csharp\",\n \".cpp\": \"cpp\",\n \".c\": \"c\",\n \".h\": \"c\",\n \".hpp\": \"cpp\",\n \".md\": \"markdown\",\n \".json\": \"json\",\n \".yaml\": \"yaml\",\n \".yml\": \"yaml\",\n \".txt\": \"text\",\n};\n\n/**\n * Keywords for detecting scope from project name or path.\n */\nconst SCOPE_KEYWORDS: Record<Scope, string[]> = {\n frontend: [\n \"web\",\n \"webapp\",\n \"frontend\",\n \"client\",\n \"ui\",\n \"app\",\n \"mobile\",\n \"react\",\n \"vue\",\n \"angular\",\n \"next\",\n \"nuxt\",\n ],\n backend: [\n \"api\",\n \"server\",\n \"backend\",\n \"service\",\n \"worker\",\n \"lambda\",\n \"functions\",\n ],\n shared: [\"shared\", \"common\", \"utils\", \"lib\", \"core\", \"types\", \"models\"],\n tooling: [\"scripts\", \"tools\", \"cli\", \"devtools\", \"build\", \"config\", \"infra\"],\n unknown: [],\n};\n\n/**\n * Patterns for detecting project directories.\n */\nconst PROJECT_PATTERNS: Array<{\n pattern: RegExp;\n type: ProjectType;\n defaultScope: Scope;\n}> = [\n { pattern: /^apps\\/([^/]+)/, type: \"app\", defaultScope: \"unknown\" },\n { pattern: /^packages\\/([^/]+)/, type: \"library\", defaultScope: \"shared\" },\n { pattern: /^libs\\/([^/]+)/, type: \"library\", defaultScope: \"shared\" },\n { pattern: /^services\\/([^/]+)/, type: \"service\", defaultScope: \"backend\" },\n { pattern: /^scripts\\/([^/]+)/, type: \"script\", defaultScope: \"tooling\" },\n { pattern: /^tools\\/([^/]+)/, type: \"script\", defaultScope: \"tooling\" },\n];\n\n// ============================================================================\n// Public Functions\n// ============================================================================\n\n/**\n * Extract introspection metadata for a file.\n *\n * @param filepath - Relative file path\n * @param structure - Project structure (from detectProjectStructure)\n * @param fileContent - Optional file content for framework detection\n */\nexport function introspectFile(\n filepath: string,\n structure: ProjectStructure,\n fileContent?: string\n): FileIntrospection {\n const normalizedPath = filepath.replace(/\\\\/g, \"/\");\n const segments = normalizedPath.split(\"/\").filter((s) => s.length > 0);\n const filename = segments[segments.length - 1] || \"\";\n const ext = path.extname(filename);\n\n const project = findProjectForFile(normalizedPath, structure);\n const language = EXTENSION_TO_LANGUAGE[ext] || \"unknown\";\n const layer = detectLayer(segments, filename);\n const domain = detectDomain(segments);\n const scope = detectScope(segments, project, layer);\n const framework = fileContent ? detectFramework(fileContent) : undefined;\n\n return {\n filepath: normalizedPath,\n project,\n scope,\n layer,\n domain,\n language,\n framework,\n depth: segments.length - 1,\n pathSegments: segments.slice(0, -1),\n };\n}\n\n/**\n * Extract keywords from introspection for search boosting.\n */\nexport function introspectionToKeywords(intro: FileIntrospection): string[] {\n const keywords: string[] = [];\n\n // Add filename keywords (without extension)\n const filename = path.basename(intro.filepath);\n const filenameWithoutExt = filename.replace(/\\.[^.]+$/, \"\");\n const filenameParts = filenameWithoutExt\n .split(/[-_.]/)\n .flatMap((part) => part.split(/(?=[A-Z])/))\n .map((part) => part.toLowerCase())\n .filter((part) => part.length > 1);\n keywords.push(...filenameParts);\n keywords.push(filenameWithoutExt.toLowerCase());\n\n // Add project name keywords\n if (intro.project.name && intro.project.name !== \"root\") {\n keywords.push(intro.project.name.toLowerCase());\n }\n\n // Add scope, layer, domain, language, framework\n if (intro.scope !== \"unknown\") keywords.push(intro.scope);\n if (intro.layer) keywords.push(intro.layer);\n if (intro.domain) keywords.push(intro.domain);\n if (intro.language !== \"unknown\") keywords.push(intro.language);\n if (intro.framework) keywords.push(intro.framework);\n\n // Add path segments (filtered)\n const skipSegments = new Set([\"src\", \"lib\", \"index\"]);\n for (const segment of intro.pathSegments) {\n if (!skipSegments.has(segment.toLowerCase()) && segment.length > 2) {\n keywords.push(segment.toLowerCase());\n }\n }\n\n // Add convention-based keywords\n const conventionKeywords = getConventionKeywords(intro.filepath);\n keywords.push(...conventionKeywords);\n\n return [...new Set(keywords)];\n}\n\n/**\n * Detect scope from project name.\n */\nexport function detectScopeFromName(name: string): Scope {\n const nameLower = name.toLowerCase();\n\n for (const [scope, keywords] of Object.entries(SCOPE_KEYWORDS)) {\n if (scope === \"unknown\") continue;\n for (const keyword of keywords) {\n if (nameLower.includes(keyword)) {\n return scope as Scope;\n }\n }\n }\n\n return \"unknown\";\n}\n\n/**\n * Find which project a file belongs to.\n */\nexport function findProjectForFile(\n filepath: string,\n structure: ProjectStructure\n): Project {\n const normalizedPath = filepath.replace(/\\\\/g, \"/\");\n const matches: Project[] = [];\n\n // Check against detected projects\n for (const project of structure.projects) {\n if (\n normalizedPath === project.root ||\n normalizedPath.startsWith(project.root + \"/\")\n ) {\n matches.push(project);\n }\n }\n\n // Return the most specific match (longest root path)\n if (matches.length > 0) {\n return matches.reduce((best, current) =>\n current.root.length > best.root.length ? current : best\n );\n }\n\n // Fallback: pattern matching\n for (const { pattern, type } of PROJECT_PATTERNS) {\n const match = normalizedPath.match(pattern);\n if (match) {\n return { name: match[1], root: match[0], type };\n }\n }\n\n // Default: root project\n return { name: \"root\", root: \"\", type: structure.rootType ?? \"unknown\" };\n}\n\n/**\n * Calculate search boost based on introspection and query.\n */\nexport function calculateIntrospectionBoost(\n intro: FileIntrospection,\n query: string\n): number {\n let boost = 1.0;\n const queryTerms = query.toLowerCase().split(/\\s+/);\n\n // Domain match: +10%\n if (\n intro.domain &&\n queryTerms.some(\n (t) => intro.domain!.includes(t) || t.includes(intro.domain!)\n )\n ) {\n boost *= 1.1;\n }\n\n // Layer match: +5%\n if (\n intro.layer &&\n queryTerms.some((t) => intro.layer!.includes(t) || t.includes(intro.layer!))\n ) {\n boost *= 1.05;\n }\n\n // Scope match for backend queries: +5%\n const backendTerms = [\"api\", \"server\", \"backend\", \"endpoint\", \"route\"];\n if (\n queryTerms.some((t) => backendTerms.includes(t)) &&\n intro.scope === \"backend\"\n ) {\n boost *= 1.05;\n }\n\n // Scope match for frontend queries: +5%\n const frontendTerms = [\n \"ui\",\n \"component\",\n \"page\",\n \"view\",\n \"frontend\",\n \"client\",\n ];\n if (\n queryTerms.some((t) => frontendTerms.includes(t)) &&\n intro.scope === \"frontend\"\n ) {\n boost *= 1.05;\n }\n\n // Path segment match: +3% per match\n for (const segment of intro.pathSegments) {\n if (queryTerms.some((t) => segment.toLowerCase().includes(t))) {\n boost *= 1.03;\n }\n }\n\n // Project name match: +5%\n if (\n intro.project.name !== \"root\" &&\n queryTerms.some((t) => intro.project.name.toLowerCase().includes(t))\n ) {\n boost *= 1.05;\n }\n\n return boost;\n}\n\n// ============================================================================\n// Internal Helper Functions\n// ============================================================================\n\nfunction detectLayer(segments: string[], filename: string): string | undefined {\n const filenameLower = filename.toLowerCase();\n for (const [layer, patterns] of Object.entries(LAYER_PATTERNS)) {\n for (const pattern of patterns) {\n if (filenameLower.includes(pattern)) return layer;\n }\n }\n\n for (let i = segments.length - 2; i >= 0; i--) {\n const segment = segments[i].toLowerCase();\n for (const [layer, patterns] of Object.entries(LAYER_PATTERNS)) {\n if (patterns.includes(segment)) return layer;\n }\n }\n\n return undefined;\n}\n\nfunction detectDomain(segments: string[]): string | undefined {\n const skipSegments = new Set([\n \"src\",\n \"lib\",\n \"app\",\n \"apps\",\n \"packages\",\n \"services\",\n \"modules\",\n \"features\",\n ...Object.values(LAYER_PATTERNS).flat(),\n ]);\n\n for (const segment of segments) {\n const segmentLower = segment.toLowerCase();\n if (skipSegments.has(segmentLower)) continue;\n\n if (DOMAIN_PATTERNS.includes(segmentLower)) return segmentLower;\n\n for (const domain of DOMAIN_PATTERNS) {\n if (segmentLower.startsWith(domain) || segmentLower.endsWith(domain)) {\n return domain;\n }\n }\n }\n\n return undefined;\n}\n\nfunction detectScope(\n segments: string[],\n project: Project,\n layer?: string\n): Scope {\n const projectScope = detectScopeFromName(project.name);\n if (projectScope !== \"unknown\") return projectScope;\n\n if (layer) {\n switch (layer) {\n case \"controller\":\n case \"repository\":\n case \"middleware\":\n return \"backend\";\n case \"presentation\":\n return \"frontend\";\n case \"util\":\n case \"model\":\n return \"shared\";\n case \"test\":\n return \"tooling\";\n }\n }\n\n for (const segment of segments) {\n const segmentLower = segment.toLowerCase();\n if ([\"server\", \"api\", \"backend\"].includes(segmentLower)) return \"backend\";\n if ([\"client\", \"web\", \"frontend\", \"ui\"].includes(segmentLower))\n return \"frontend\";\n if ([\"shared\", \"common\", \"lib\", \"libs\"].includes(segmentLower))\n return \"shared\";\n }\n\n return \"unknown\";\n}\n\nfunction detectFramework(content: string): string | undefined {\n for (const [framework, indicators] of Object.entries(FRAMEWORK_INDICATORS)) {\n for (const indicator of indicators) {\n if (\n content.includes(`from '${indicator}`) ||\n content.includes(`from \"${indicator}`) ||\n content.includes(`require('${indicator}`) ||\n content.includes(`require(\"${indicator}`)\n ) {\n return framework;\n }\n }\n }\n return undefined;\n}\n\n\n\n\n",
20
+ "/**\n * File Conventions Service\n *\n * Pure functions for matching files against conventions and extracting keywords.\n * No I/O operations - all functions operate on file paths.\n *\n * Categories:\n * - Entry Points: index.ts, main.ts, App.tsx, etc.\n * - Configuration: tsconfig.json, .prettierrc, package.json, etc.\n * - Frameworks: Next.js, Convex, and other framework-specific patterns\n * - Type Definitions: *.d.ts, *.types.ts\n *\n * Extensibility:\n * - Add new conventions to entryPoints.ts or configFiles.ts\n * - Add new frameworks in the frameworks/ directory\n */\n\nimport * as path from \"path\";\nimport type {\n FileConvention,\n ConventionMatch,\n} from \"../../entities/conventions\";\nimport { entryPointConventions } from \"./entryPoints\";\nimport { configFileConventions } from \"./configFiles\";\nimport { getAllFrameworkConventions } from \"./frameworks\";\n\n// Re-export types from entities\nexport type {\n FileConvention,\n ConventionCategory,\n ConventionMatch,\n FrameworkConventions,\n} from \"../../entities/conventions\";\n\n/**\n * Type definition file conventions (built-in).\n */\nconst typeDefinitionConventions: FileConvention[] = [\n {\n id: \"dts-file\",\n name: \"TypeScript Declaration\",\n description: \"TypeScript type declaration file\",\n category: \"types\",\n match: (filepath, filename) => filename.endsWith(\".d.ts\"),\n keywords: [\"types\", \"declarations\", \"typescript\", \"definitions\"],\n },\n {\n id: \"types-file\",\n name: \"Types File\",\n description: \"TypeScript types file\",\n category: \"types\",\n match: (filepath, filename) =>\n filename.endsWith(\".types.ts\") || filename === \"types.ts\",\n keywords: [\"types\", \"definitions\", \"typescript\", \"interfaces\"],\n dynamicKeywords: (filepath) => {\n const match = filepath.match(/([^/]+)\\.types\\.ts$/);\n if (match) return [match[1].toLowerCase()];\n return [];\n },\n },\n {\n id: \"types-folder\",\n name: \"Types Folder File\",\n description: \"File in a types folder\",\n category: \"types\",\n match: (filepath) =>\n filepath.includes(\"/types/\") || filepath.startsWith(\"types/\"),\n keywords: [\"types\", \"definitions\"],\n },\n];\n\n/**\n * Test file conventions (built-in).\n */\nconst testFileConventions: FileConvention[] = [\n {\n id: \"test-file\",\n name: \"Test File\",\n description: \"Unit/integration test file\",\n category: \"test\",\n match: (filepath, filename) =>\n filename.includes(\".test.\") ||\n filename.includes(\".spec.\") ||\n filename.includes(\"_test.\"),\n keywords: [\"test\", \"spec\", \"unit test\"],\n dynamicKeywords: (filepath) => {\n const match = filepath.match(/([^/]+)\\.(test|spec)\\./);\n if (match) return [match[1].toLowerCase()];\n return [];\n },\n },\n {\n id: \"test-folder\",\n name: \"Test Folder File\",\n description: \"File in a test folder\",\n category: \"test\",\n match: (filepath) =>\n filepath.includes(\"/__tests__/\") ||\n filepath.includes(\"/test/\") ||\n filepath.includes(\"/tests/\") ||\n filepath.startsWith(\"__tests__/\") ||\n filepath.startsWith(\"test/\") ||\n filepath.startsWith(\"tests/\"),\n keywords: [\"test\", \"testing\"],\n },\n];\n\n/**\n * Get all conventions including built-in ones.\n */\nexport function getConventions(): FileConvention[] {\n return [\n ...entryPointConventions,\n ...configFileConventions,\n ...getAllFrameworkConventions(),\n ...typeDefinitionConventions,\n ...testFileConventions,\n ];\n}\n\n/**\n * Match a filepath against all conventions and return keywords.\n *\n * @param filepath - The file path (relative to project root)\n * @returns Array of keywords from all matching conventions\n */\nexport function getConventionKeywords(filepath: string): string[] {\n const conventions = getConventions();\n const filename = path.basename(filepath);\n const extension = path.extname(filepath);\n const keywords = new Set<string>();\n\n for (const convention of conventions) {\n try {\n if (convention.match(filepath, filename, extension)) {\n // Add static keywords\n for (const keyword of convention.keywords) {\n keywords.add(keyword.toLowerCase());\n }\n\n // Add dynamic keywords\n if (convention.dynamicKeywords) {\n const dynamicKws = convention.dynamicKeywords(filepath);\n for (const kw of dynamicKws) {\n if (kw && kw.length > 1) {\n keywords.add(kw.toLowerCase());\n }\n }\n }\n }\n } catch {\n // Skip conventions that throw errors\n }\n }\n\n return Array.from(keywords);\n}\n\n/**\n * Match a filepath against all conventions and return detailed matches.\n *\n * @param filepath - The file path (relative to project root)\n * @returns Array of convention matches with details\n */\nexport function matchConventions(filepath: string): ConventionMatch[] {\n const conventions = getConventions();\n const filename = path.basename(filepath);\n const extension = path.extname(filepath);\n const matches: ConventionMatch[] = [];\n\n for (const convention of conventions) {\n try {\n if (convention.match(filepath, filename, extension)) {\n const keywords = [...convention.keywords];\n\n if (convention.dynamicKeywords) {\n const dynamicKws = convention.dynamicKeywords(filepath);\n keywords.push(...dynamicKws.filter((k) => k && k.length > 1));\n }\n\n matches.push({\n convention,\n keywords: keywords.map((k) => k.toLowerCase()),\n });\n }\n } catch {\n // Skip conventions that throw errors\n }\n }\n\n return matches;\n}\n\n// Re-export convention collections for extension\nexport { entryPointConventions } from \"./entryPoints\";\nexport { configFileConventions } from \"./configFiles\";\nexport { frameworkProviders, getAllFrameworkConventions } from \"./frameworks\";\n\n\n\n\n\n\n\n",
21
+ "/**\n * Introspection Service\n *\n * Pure functions for extracting file metadata from paths and content.\n * No I/O operations - all functions operate on provided data.\n */\n\nimport * as path from \"path\";\nimport type {\n FileIntrospection,\n Project,\n ProjectStructure,\n Scope,\n ProjectType,\n} from \"../entities/introspection\";\nimport { getConventionKeywords } from \"./conventions\";\n\n// ============================================================================\n// Constants\n// ============================================================================\n\n/**\n * Layer detection patterns.\n */\nconst LAYER_PATTERNS: Record<string, string[]> = {\n controller: [\"controller\", \"api\", \"routes\", \"route\", \"handler\"],\n service: [\"service\", \"logic\", \"usecase\", \"usecases\", \"handler\"],\n repository: [\"repository\", \"repo\", \"dao\", \"store\", \"persistence\"],\n model: [\n \"model\",\n \"models\",\n \"entity\",\n \"entities\",\n \"schema\",\n \"schemas\",\n \"types\",\n \"type\",\n ],\n util: [\"util\", \"utils\", \"helper\", \"helpers\", \"common\", \"lib\"],\n config: [\"config\", \"configuration\", \"settings\"],\n middleware: [\"middleware\", \"middlewares\"],\n domain: [\"domain\"],\n infrastructure: [\"infrastructure\", \"infra\"],\n application: [\"application\", \"app\"],\n presentation: [\n \"presentation\",\n \"ui\",\n \"views\",\n \"view\",\n \"component\",\n \"components\",\n ],\n test: [\"test\", \"tests\", \"spec\", \"specs\", \"__tests__\", \"e2e\"],\n};\n\n/**\n * Domain detection patterns (feature areas).\n */\nconst DOMAIN_PATTERNS = [\n \"auth\",\n \"authentication\",\n \"user\",\n \"users\",\n \"account\",\n \"accounts\",\n \"profile\",\n \"profiles\",\n \"product\",\n \"products\",\n \"item\",\n \"items\",\n \"catalog\",\n \"order\",\n \"orders\",\n \"cart\",\n \"checkout\",\n \"payment\",\n \"payments\",\n \"billing\",\n \"subscription\",\n \"subscriptions\",\n \"notification\",\n \"notifications\",\n \"email\",\n \"sms\",\n \"report\",\n \"reports\",\n \"analytics\",\n \"metrics\",\n \"dashboard\",\n \"admin\",\n \"settings\",\n \"search\",\n \"chat\",\n \"message\",\n \"messages\",\n \"feed\",\n \"post\",\n \"posts\",\n \"comment\",\n \"comments\",\n \"media\",\n \"upload\",\n \"file\",\n \"files\",\n \"storage\",\n \"cache\",\n \"session\",\n \"log\",\n \"logs\",\n \"audit\",\n];\n\n/**\n * Framework detection from imports.\n */\nconst FRAMEWORK_INDICATORS: Record<string, string[]> = {\n nextjs: [\"next\", \"next/\"],\n express: [\"express\"],\n fastify: [\"fastify\"],\n react: [\"react\"],\n vue: [\"vue\"],\n angular: [\"@angular/\"],\n nestjs: [\"@nestjs/\"],\n koa: [\"koa\"],\n};\n\n/**\n * Language detection from file extension.\n */\nconst EXTENSION_TO_LANGUAGE: Record<string, string> = {\n \".ts\": \"typescript\",\n \".tsx\": \"typescript\",\n \".js\": \"javascript\",\n \".jsx\": \"javascript\",\n \".mjs\": \"javascript\",\n \".cjs\": \"javascript\",\n \".py\": \"python\",\n \".go\": \"go\",\n \".rs\": \"rust\",\n \".java\": \"java\",\n \".kt\": \"kotlin\",\n \".swift\": \"swift\",\n \".rb\": \"ruby\",\n \".php\": \"php\",\n \".cs\": \"csharp\",\n \".cpp\": \"cpp\",\n \".c\": \"c\",\n \".h\": \"c\",\n \".hpp\": \"cpp\",\n \".md\": \"markdown\",\n \".json\": \"json\",\n \".yaml\": \"yaml\",\n \".yml\": \"yaml\",\n \".txt\": \"text\",\n};\n\n/**\n * Keywords for detecting scope from project name or path.\n */\nconst SCOPE_KEYWORDS: Record<Scope, string[]> = {\n frontend: [\n \"web\",\n \"webapp\",\n \"frontend\",\n \"client\",\n \"ui\",\n \"app\",\n \"mobile\",\n \"react\",\n \"vue\",\n \"angular\",\n \"next\",\n \"nuxt\",\n ],\n backend: [\n \"api\",\n \"server\",\n \"backend\",\n \"service\",\n \"worker\",\n \"lambda\",\n \"functions\",\n ],\n shared: [\"shared\", \"common\", \"utils\", \"lib\", \"core\", \"types\", \"models\"],\n tooling: [\"scripts\", \"tools\", \"cli\", \"devtools\", \"build\", \"config\", \"infra\"],\n unknown: [],\n};\n\n/**\n * Patterns for detecting project directories.\n */\nconst PROJECT_PATTERNS: Array<{\n pattern: RegExp;\n type: ProjectType;\n defaultScope: Scope;\n}> = [\n { pattern: /^apps\\/([^/]+)/, type: \"app\", defaultScope: \"unknown\" },\n { pattern: /^packages\\/([^/]+)/, type: \"library\", defaultScope: \"shared\" },\n { pattern: /^libs\\/([^/]+)/, type: \"library\", defaultScope: \"shared\" },\n { pattern: /^services\\/([^/]+)/, type: \"service\", defaultScope: \"backend\" },\n { pattern: /^scripts\\/([^/]+)/, type: \"script\", defaultScope: \"tooling\" },\n { pattern: /^tools\\/([^/]+)/, type: \"script\", defaultScope: \"tooling\" },\n];\n\n// ============================================================================\n// Public Functions\n// ============================================================================\n\n/**\n * Extract introspection metadata for a file.\n *\n * @param filepath - Relative file path\n * @param structure - Project structure (from detectProjectStructure)\n * @param fileContent - Optional file content for framework detection\n */\nexport function introspectFile(\n filepath: string,\n structure: ProjectStructure,\n fileContent?: string\n): FileIntrospection {\n const normalizedPath = filepath.replace(/\\\\/g, \"/\");\n const segments = normalizedPath.split(\"/\").filter((s) => s.length > 0);\n const filename = segments[segments.length - 1] || \"\";\n const ext = path.extname(filename);\n\n const project = findProjectForFile(normalizedPath, structure);\n const language = EXTENSION_TO_LANGUAGE[ext] || \"unknown\";\n const layer = detectLayer(segments, filename);\n const domain = detectDomain(segments);\n const scope = detectScope(segments, project, layer);\n const framework = fileContent ? detectFramework(fileContent) : undefined;\n\n return {\n filepath: normalizedPath,\n project,\n scope,\n layer,\n domain,\n language,\n framework,\n depth: segments.length - 1,\n pathSegments: segments.slice(0, -1),\n };\n}\n\n/**\n * Extract keywords from introspection for search boosting.\n */\nexport function introspectionToKeywords(intro: FileIntrospection): string[] {\n const keywords: string[] = [];\n\n // Add filename keywords (without extension)\n const filename = path.basename(intro.filepath);\n const filenameWithoutExt = filename.replace(/\\.[^.]+$/, \"\");\n const filenameParts = filenameWithoutExt\n .split(/[-_.]/)\n .flatMap((part) => part.split(/(?=[A-Z])/))\n .map((part) => part.toLowerCase())\n .filter((part) => part.length > 1);\n keywords.push(...filenameParts);\n keywords.push(filenameWithoutExt.toLowerCase());\n\n // Add project name keywords\n if (intro.project.name && intro.project.name !== \"root\") {\n keywords.push(intro.project.name.toLowerCase());\n }\n\n // Add scope, layer, domain, language, framework\n if (intro.scope !== \"unknown\") keywords.push(intro.scope);\n if (intro.layer) keywords.push(intro.layer);\n if (intro.domain) keywords.push(intro.domain);\n if (intro.language !== \"unknown\") keywords.push(intro.language);\n if (intro.framework) keywords.push(intro.framework);\n\n // Add path segments (filtered)\n const skipSegments = new Set([\"src\", \"lib\", \"index\"]);\n for (const segment of intro.pathSegments) {\n if (!skipSegments.has(segment.toLowerCase()) && segment.length > 2) {\n keywords.push(segment.toLowerCase());\n }\n }\n\n // Add convention-based keywords\n const conventionKeywords = getConventionKeywords(intro.filepath);\n keywords.push(...conventionKeywords);\n\n return [...new Set(keywords)];\n}\n\n/**\n * Detect scope from project name.\n */\nexport function detectScopeFromName(name: string): Scope {\n const nameLower = name.toLowerCase();\n\n for (const [scope, keywords] of Object.entries(SCOPE_KEYWORDS)) {\n if (scope === \"unknown\") continue;\n for (const keyword of keywords) {\n if (nameLower.includes(keyword)) {\n return scope as Scope;\n }\n }\n }\n\n return \"unknown\";\n}\n\n/**\n * Find which project a file belongs to.\n */\nexport function findProjectForFile(\n filepath: string,\n structure: ProjectStructure\n): Project {\n const normalizedPath = filepath.replace(/\\\\/g, \"/\");\n const matches: Project[] = [];\n\n // Check against detected projects\n for (const project of structure.projects) {\n if (\n normalizedPath === project.root ||\n normalizedPath.startsWith(project.root + \"/\")\n ) {\n matches.push(project);\n }\n }\n\n // Return the most specific match (longest root path)\n if (matches.length > 0) {\n return matches.reduce((best, current) =>\n current.root.length > best.root.length ? current : best\n );\n }\n\n // Fallback: pattern matching\n for (const { pattern, type } of PROJECT_PATTERNS) {\n const match = normalizedPath.match(pattern);\n if (match) {\n return { name: match[1], root: match[0], type };\n }\n }\n\n // Default: root project\n return { name: \"root\", root: \"\", type: structure.rootType ?? \"unknown\" };\n}\n\n/**\n * Calculate search boost based on introspection and query.\n */\nexport function calculateIntrospectionBoost(\n intro: FileIntrospection,\n query: string\n): number {\n let boost = 1.0;\n const queryTerms = query.toLowerCase().split(/\\s+/);\n\n // Domain match: +10%\n if (\n intro.domain &&\n queryTerms.some(\n (t) => intro.domain!.includes(t) || t.includes(intro.domain!)\n )\n ) {\n boost *= 1.1;\n }\n\n // Layer match: +5%\n if (\n intro.layer &&\n queryTerms.some((t) => intro.layer!.includes(t) || t.includes(intro.layer!))\n ) {\n boost *= 1.05;\n }\n\n // Scope match for backend queries: +5%\n const backendTerms = [\"api\", \"server\", \"backend\", \"endpoint\", \"route\"];\n if (\n queryTerms.some((t) => backendTerms.includes(t)) &&\n intro.scope === \"backend\"\n ) {\n boost *= 1.05;\n }\n\n // Scope match for frontend queries: +5%\n const frontendTerms = [\n \"ui\",\n \"component\",\n \"page\",\n \"view\",\n \"frontend\",\n \"client\",\n ];\n if (\n queryTerms.some((t) => frontendTerms.includes(t)) &&\n intro.scope === \"frontend\"\n ) {\n boost *= 1.05;\n }\n\n // Path segment match: +3% per match\n for (const segment of intro.pathSegments) {\n if (queryTerms.some((t) => segment.toLowerCase().includes(t))) {\n boost *= 1.03;\n }\n }\n\n // Project name match: +5%\n if (\n intro.project.name !== \"root\" &&\n queryTerms.some((t) => intro.project.name.toLowerCase().includes(t))\n ) {\n boost *= 1.05;\n }\n\n return boost;\n}\n\n// ============================================================================\n// Internal Helper Functions\n// ============================================================================\n\nfunction detectLayer(segments: string[], filename: string): string | undefined {\n const filenameLower = filename.toLowerCase();\n for (const [layer, patterns] of Object.entries(LAYER_PATTERNS)) {\n for (const pattern of patterns) {\n if (filenameLower.includes(pattern)) return layer;\n }\n }\n\n for (let i = segments.length - 2; i >= 0; i--) {\n const segment = segments[i].toLowerCase();\n for (const [layer, patterns] of Object.entries(LAYER_PATTERNS)) {\n if (patterns.includes(segment)) return layer;\n }\n }\n\n return undefined;\n}\n\nfunction detectDomain(segments: string[]): string | undefined {\n const skipSegments = new Set([\n \"src\",\n \"lib\",\n \"app\",\n \"apps\",\n \"packages\",\n \"services\",\n \"modules\",\n \"features\",\n ...Object.values(LAYER_PATTERNS).flat(),\n ]);\n\n for (const segment of segments) {\n const segmentLower = segment.toLowerCase();\n if (skipSegments.has(segmentLower)) continue;\n\n if (DOMAIN_PATTERNS.includes(segmentLower)) return segmentLower;\n\n for (const domain of DOMAIN_PATTERNS) {\n if (segmentLower.startsWith(domain) || segmentLower.endsWith(domain)) {\n return domain;\n }\n }\n }\n\n return undefined;\n}\n\nfunction detectScope(\n segments: string[],\n project: Project,\n layer?: string\n): Scope {\n const projectScope = detectScopeFromName(project.name);\n if (projectScope !== \"unknown\") return projectScope;\n\n if (layer) {\n switch (layer) {\n case \"controller\":\n case \"repository\":\n case \"middleware\":\n return \"backend\";\n case \"presentation\":\n return \"frontend\";\n case \"util\":\n case \"model\":\n return \"shared\";\n case \"test\":\n return \"tooling\";\n }\n }\n\n for (const segment of segments) {\n const segmentLower = segment.toLowerCase();\n if ([\"server\", \"api\", \"backend\"].includes(segmentLower)) return \"backend\";\n if ([\"client\", \"web\", \"frontend\", \"ui\"].includes(segmentLower))\n return \"frontend\";\n if ([\"shared\", \"common\", \"lib\", \"libs\"].includes(segmentLower))\n return \"shared\";\n }\n\n return \"unknown\";\n}\n\nfunction detectFramework(content: string): string | undefined {\n for (const [framework, indicators] of Object.entries(FRAMEWORK_INDICATORS)) {\n for (const indicator of indicators) {\n if (\n content.includes(`from '${indicator}`) ||\n content.includes(`from \"${indicator}`) ||\n content.includes(`require('${indicator}`) ||\n content.includes(`require(\"${indicator}`)\n ) {\n return framework;\n }\n }\n }\n return undefined;\n}\n\n\n\n\n\n\n\n",
22
22
  "/**\n * Regex-based Symbol Extraction\n *\n * Extracts symbols from code using regular expressions.\n * Language-agnostic but optimized for common patterns.\n */\n\nexport type SymbolType =\n | \"function\"\n | \"class\"\n | \"variable\"\n | \"interface\"\n | \"type\"\n | \"enum\"\n | \"method\"\n | \"other\";\n\nexport interface ExtractedSymbol {\n name: string;\n type: SymbolType;\n line: number;\n isExported: boolean;\n}\n\n/**\n * Patterns for extracting symbols from code.\n * Order matters - more specific patterns should come first.\n */\nconst SYMBOL_PATTERNS: Array<{\n type: SymbolType;\n pattern: RegExp;\n exported: boolean;\n}> = [\n // Exported function declarations\n {\n type: \"function\",\n pattern: /^export\\s+(?:async\\s+)?function\\s+(\\w+)/gm,\n exported: true,\n },\n // Exported arrow functions\n {\n type: \"function\",\n pattern: /^export\\s+(?:const|let)\\s+(\\w+)\\s*=\\s*(?:async\\s*)?\\(/gm,\n exported: true,\n },\n // Exported classes\n {\n type: \"class\",\n pattern: /^export\\s+(?:abstract\\s+)?class\\s+(\\w+)/gm,\n exported: true,\n },\n // Exported interfaces (TypeScript)\n {\n type: \"interface\",\n pattern: /^export\\s+interface\\s+(\\w+)/gm,\n exported: true,\n },\n // Exported types (TypeScript)\n {\n type: \"type\",\n pattern: /^export\\s+type\\s+(\\w+)/gm,\n exported: true,\n },\n // Exported enums\n {\n type: \"enum\",\n pattern: /^export\\s+(?:const\\s+)?enum\\s+(\\w+)/gm,\n exported: true,\n },\n // Exported variables\n {\n type: \"variable\",\n pattern: /^export\\s+(?:const|let|var)\\s+(\\w+)\\s*(?::|=)/gm,\n exported: true,\n },\n // Default exports\n {\n type: \"function\",\n pattern: /^export\\s+default\\s+(?:async\\s+)?function\\s+(\\w+)/gm,\n exported: true,\n },\n {\n type: \"class\",\n pattern: /^export\\s+default\\s+class\\s+(\\w+)/gm,\n exported: true,\n },\n\n // Non-exported declarations\n {\n type: \"function\",\n pattern: /^(?:async\\s+)?function\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"function\",\n pattern: /^(?:const|let)\\s+(\\w+)\\s*=\\s*(?:async\\s*)?\\(/gm,\n exported: false,\n },\n {\n type: \"class\",\n pattern: /^(?:abstract\\s+)?class\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"interface\",\n pattern: /^interface\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"type\",\n pattern: /^type\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"enum\",\n pattern: /^(?:const\\s+)?enum\\s+(\\w+)/gm,\n exported: false,\n },\n\n // Python patterns\n {\n type: \"function\",\n pattern: /^def\\s+(\\w+)\\s*\\(/gm,\n exported: false,\n },\n {\n type: \"class\",\n pattern: /^class\\s+(\\w+)(?:\\s*\\(|:)/gm,\n exported: false,\n },\n\n // Go patterns\n {\n type: \"function\",\n pattern: /^func\\s+(?:\\([^)]+\\)\\s+)?(\\w+)\\s*\\(/gm,\n exported: false,\n },\n {\n type: \"type\",\n pattern: /^type\\s+(\\w+)\\s+(?:struct|interface)/gm,\n exported: false,\n },\n\n // Rust patterns\n {\n type: \"function\",\n pattern: /^(?:pub\\s+)?(?:async\\s+)?fn\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"type\",\n pattern: /^(?:pub\\s+)?struct\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"enum\",\n pattern: /^(?:pub\\s+)?enum\\s+(\\w+)/gm,\n exported: false,\n },\n {\n type: \"interface\",\n pattern: /^(?:pub\\s+)?trait\\s+(\\w+)/gm,\n exported: false,\n },\n];\n\n/**\n * Extract symbols from code content using regex patterns.\n *\n * @param content - The source code content\n * @returns Array of extracted symbols with their locations\n */\nexport function extractSymbols(content: string): ExtractedSymbol[] {\n const symbols: ExtractedSymbol[] = [];\n const seenSymbols = new Set<string>(); // Track seen symbols to avoid duplicates\n\n // Split content into lines for line number calculation\n const lines = content.split(\"\\n\");\n\n for (const { type, pattern, exported } of SYMBOL_PATTERNS) {\n // Reset regex state\n pattern.lastIndex = 0;\n\n let match: RegExpExecArray | null;\n while ((match = pattern.exec(content)) !== null) {\n const name = match[1];\n const symbolKey = `${name}:${type}`;\n\n // Skip if we've already seen this symbol (from a more specific pattern)\n if (seenSymbols.has(symbolKey)) continue;\n seenSymbols.add(symbolKey);\n\n // Calculate line number\n const beforeMatch = content.substring(0, match.index);\n const line = beforeMatch.split(\"\\n\").length;\n\n symbols.push({\n name,\n type,\n line,\n isExported: exported,\n });\n }\n }\n\n // Sort by line number\n return symbols.sort((a, b) => a.line - b.line);\n}\n\n/**\n * Extract symbol names as keywords for BM25 indexing.\n *\n * @param symbols - Array of extracted symbols\n * @returns Array of unique symbol names\n */\nexport function symbolsToKeywords(symbols: ExtractedSymbol[]): string[] {\n const keywords = new Set<string>();\n\n for (const symbol of symbols) {\n // Add the full name\n keywords.add(symbol.name.toLowerCase());\n\n // Split camelCase/PascalCase into parts\n const parts = symbol.name\n .replace(/([a-z])([A-Z])/g, \"$1 $2\")\n .replace(/([A-Z]+)([A-Z][a-z])/g, \"$1 $2\")\n .toLowerCase()\n .split(/\\s+/);\n\n for (const part of parts) {\n if (part.length > 2) {\n keywords.add(part);\n }\n }\n }\n\n return Array.from(keywords);\n}\n\n",
23
23
  "/**\n * Core Index Module\n *\n * Language-agnostic text search using:\n * - Regex-based symbol extraction\n * - BM25 keyword matching\n * - Line-based chunking\n *\n * Index location: .raggrep/index/core/\n *\n * This module provides fast, deterministic search without embeddings.\n * It complements language-specific modules by catching symbol matches.\n */\n\nimport * as path from \"path\";\nimport * as fs from \"fs/promises\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n} from \"../../types\";\nimport type {\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n ChunkType,\n} from \"../../domain/entities\";\nimport {\n BM25Index,\n tokenize,\n normalizeScore,\n} from \"../../domain/services/bm25\";\nimport { getRaggrepDir } from \"../../infrastructure/config\";\nimport { introspectionToKeywords } from \"../../domain/services/introspection\";\nimport {\n extractSymbols,\n symbolsToKeywords,\n type ExtractedSymbol,\n} from \"./symbols\";\n\n/** Default minimum score for core search results */\nconst DEFAULT_MIN_SCORE = 0.1;\n\n/** Default number of results */\nconst DEFAULT_TOP_K = 20;\n\n/** Lines per chunk for basic chunking */\nconst LINES_PER_CHUNK = 50;\n\n/** Overlap between chunks */\nconst CHUNK_OVERLAP = 10;\n\n/**\n * Core module-specific data stored with file index\n */\nexport interface CoreModuleData {\n /** Extracted symbols */\n symbols: ExtractedSymbol[];\n /** BM25 tokens for this file */\n tokens: string[];\n [key: string]: unknown;\n}\n\n/**\n * Stored symbol index for fast lookup\n */\ninterface SymbolIndexEntry {\n filepath: string;\n symbols: ExtractedSymbol[];\n tokens: string[];\n}\n\nexport class CoreModule implements IndexModule {\n readonly id = \"core\";\n readonly name = \"Core Search\";\n readonly description = \"Language-agnostic text search with symbol extraction\";\n readonly version = \"1.0.0\";\n\n /**\n * Core module accepts all files (it's the fallback).\n */\n supportsFile(_filepath: string): boolean {\n return true;\n }\n\n private symbolIndex: Map<string, SymbolIndexEntry> = new Map();\n private bm25Index: BM25Index | null = null;\n private rootDir: string = \"\";\n\n async initialize(_config: ModuleConfig): Promise<void> {\n // Core module needs no initialization\n }\n\n /**\n * Index a single file.\n */\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n this.rootDir = ctx.rootDir;\n\n // Extract symbols using regex\n const symbols = extractSymbols(content);\n const symbolKeywords = symbolsToKeywords(symbols);\n\n // Tokenize content for BM25\n const contentTokens = tokenize(content);\n\n // Get introspection keywords (includes filename, path segments, etc.)\n const intro = ctx.getIntrospection?.(filepath);\n const introKeywords = intro ? introspectionToKeywords(intro) : [];\n\n const allTokens = [\n ...new Set([...contentTokens, ...symbolKeywords, ...introKeywords]),\n ];\n\n // Create line-based chunks\n const chunks = this.createChunks(filepath, content, symbols);\n\n // Get file stats\n const stats = await ctx.getFileStats(filepath);\n\n // Store in memory for finalize\n this.symbolIndex.set(filepath, {\n filepath,\n symbols,\n tokens: allTokens,\n });\n\n // Build module data\n const moduleData: CoreModuleData = {\n symbols,\n tokens: allTokens,\n };\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n };\n }\n\n /**\n * Create line-based chunks from content.\n */\n private createChunks(\n filepath: string,\n content: string,\n symbols: ExtractedSymbol[]\n ): Chunk[] {\n const lines = content.split(\"\\n\");\n const chunks: Chunk[] = [];\n\n // Create overlapping chunks\n for (\n let start = 0;\n start < lines.length;\n start += LINES_PER_CHUNK - CHUNK_OVERLAP\n ) {\n const end = Math.min(start + LINES_PER_CHUNK, lines.length);\n const chunkLines = lines.slice(start, end);\n const chunkContent = chunkLines.join(\"\\n\");\n\n // Find symbols in this chunk\n const chunkSymbols = symbols.filter(\n (s) => s.line >= start + 1 && s.line <= end\n );\n\n // Determine chunk type based on symbols\n let chunkType: ChunkType = \"block\";\n let chunkName: string | undefined;\n let isExported = false;\n\n if (chunkSymbols.length > 0) {\n const primarySymbol = chunkSymbols[0];\n chunkType = this.symbolTypeToChunkType(primarySymbol.type);\n chunkName = primarySymbol.name;\n isExported = primarySymbol.isExported;\n }\n\n const chunkId = `${filepath}:${start + 1}-${end}`;\n\n chunks.push({\n id: chunkId,\n content: chunkContent,\n startLine: start + 1,\n endLine: end,\n type: chunkType,\n name: chunkName,\n isExported,\n });\n\n // Stop if we've reached the end\n if (end >= lines.length) break;\n }\n\n return chunks;\n }\n\n /**\n * Convert symbol type to chunk type.\n */\n private symbolTypeToChunkType(symbolType: string): ChunkType {\n switch (symbolType) {\n case \"function\":\n case \"method\":\n return \"function\";\n case \"class\":\n return \"class\";\n case \"interface\":\n return \"interface\";\n case \"type\":\n return \"type\";\n case \"enum\":\n return \"enum\";\n case \"variable\":\n return \"variable\";\n default:\n return \"block\";\n }\n }\n\n /**\n * Finalize indexing - build BM25 index and save symbol index.\n */\n async finalize(ctx: IndexContext): Promise<void> {\n const config = ctx.config;\n const coreDir = path.join(\n getRaggrepDir(ctx.rootDir, config),\n \"index\",\n \"core\"\n );\n\n // Ensure directory exists\n await fs.mkdir(coreDir, { recursive: true });\n\n // Build BM25 index from all tokens\n this.bm25Index = new BM25Index();\n for (const [filepath, entry] of this.symbolIndex) {\n this.bm25Index.addDocument(filepath, entry.tokens);\n }\n\n // Save symbol index\n const symbolIndexData = {\n version: this.version,\n lastUpdated: new Date().toISOString(),\n files: Object.fromEntries(this.symbolIndex),\n bm25Data: this.bm25Index.serialize(),\n };\n\n await fs.writeFile(\n path.join(coreDir, \"symbols.json\"),\n JSON.stringify(symbolIndexData, null, 2)\n );\n }\n\n /**\n * Search the index.\n */\n async search(\n query: string,\n ctx: SearchContext,\n options?: SearchOptions\n ): Promise<SearchResult[]> {\n const config = ctx.config;\n const topK = options?.topK ?? DEFAULT_TOP_K;\n const minScore = options?.minScore ?? DEFAULT_MIN_SCORE;\n\n // Load symbol index if not in memory\n if (this.symbolIndex.size === 0) {\n await this.loadSymbolIndex(ctx.rootDir, config);\n }\n\n if (!this.bm25Index || this.symbolIndex.size === 0) {\n return [];\n }\n\n // Tokenize query\n const queryTokens = tokenize(query);\n\n // Get BM25 scores\n const bm25Results = this.bm25Index.search(query, topK * 2);\n const bm25Scores = new Map(bm25Results.map((r) => [r.id, r.score]));\n\n // Check for symbol name matches (exact or partial)\n const symbolMatches = this.findSymbolMatches(queryTokens);\n\n // Combine results\n const results: SearchResult[] = [];\n\n for (const filepath of this.symbolIndex.keys()) {\n const entry = this.symbolIndex.get(filepath)!;\n const bm25Score = bm25Scores.get(filepath) ?? 0;\n const symbolScore = symbolMatches.get(filepath) ?? 0;\n\n // Skip if no match\n if (bm25Score === 0 && symbolScore === 0) continue;\n\n // Combined score: symbol matches are highly weighted\n const combinedScore = 0.6 * normalizeScore(bm25Score) + 0.4 * symbolScore;\n\n if (combinedScore >= minScore) {\n // Load file index to get chunks\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n // Find best matching chunk\n const bestChunk = this.findBestChunk(\n fileIndex.chunks,\n queryTokens,\n entry.symbols\n );\n\n results.push({\n filepath,\n chunk: bestChunk,\n score: combinedScore,\n moduleId: this.id,\n context: {\n bm25Score: normalizeScore(bm25Score),\n symbolScore,\n },\n });\n }\n }\n\n // Sort by score and limit\n return results.sort((a, b) => b.score - a.score).slice(0, topK);\n }\n\n /**\n * Find symbol name matches for query tokens.\n */\n private findSymbolMatches(queryTokens: string[]): Map<string, number> {\n const matches = new Map<string, number>();\n\n for (const [filepath, entry] of this.symbolIndex) {\n let matchScore = 0;\n\n for (const symbol of entry.symbols) {\n const symbolName = symbol.name.toLowerCase();\n const symbolParts = symbolsToKeywords([symbol]);\n\n for (const token of queryTokens) {\n // Exact match on symbol name\n if (symbolName === token) {\n matchScore += symbol.isExported ? 1.0 : 0.8;\n }\n // Partial match on symbol name\n else if (symbolName.includes(token) || token.includes(symbolName)) {\n matchScore += symbol.isExported ? 0.5 : 0.4;\n }\n // Match on symbol parts (camelCase split)\n else if (symbolParts.some((p) => p === token)) {\n matchScore += symbol.isExported ? 0.3 : 0.2;\n }\n }\n }\n\n if (matchScore > 0) {\n // Normalize by number of query tokens\n matches.set(filepath, Math.min(1, matchScore / queryTokens.length));\n }\n }\n\n return matches;\n }\n\n /**\n * Find the best matching chunk based on query tokens.\n */\n private findBestChunk(\n chunks: Chunk[],\n queryTokens: string[],\n symbols: ExtractedSymbol[]\n ): Chunk {\n let bestChunk = chunks[0];\n let bestScore = 0;\n\n for (const chunk of chunks) {\n let score = 0;\n const chunkContent = chunk.content.toLowerCase();\n\n // Score based on query token presence\n for (const token of queryTokens) {\n if (chunkContent.includes(token)) {\n score += 1;\n }\n }\n\n // Bonus for named chunks matching query\n if (chunk.name) {\n const nameLower = chunk.name.toLowerCase();\n for (const token of queryTokens) {\n if (nameLower.includes(token)) {\n score += 2;\n }\n }\n }\n\n // Bonus for exported symbols\n if (chunk.isExported) {\n score += 0.5;\n }\n\n if (score > bestScore) {\n bestScore = score;\n bestChunk = chunk;\n }\n }\n\n return bestChunk;\n }\n\n /**\n * Load the symbol index from disk.\n */\n private async loadSymbolIndex(rootDir: string, config: any): Promise<void> {\n const coreDir = path.join(getRaggrepDir(rootDir, config), \"index\", \"core\");\n const symbolsPath = path.join(coreDir, \"symbols.json\");\n\n try {\n const content = await fs.readFile(symbolsPath, \"utf-8\");\n const data = JSON.parse(content);\n\n // Restore symbol index\n this.symbolIndex = new Map(Object.entries(data.files));\n\n // Restore BM25 index\n if (data.bm25Data) {\n this.bm25Index = BM25Index.deserialize(data.bm25Data);\n }\n } catch (error) {\n // Index doesn't exist yet\n this.symbolIndex = new Map();\n this.bm25Index = null;\n }\n }\n\n async dispose(): Promise<void> {\n this.symbolIndex.clear();\n this.bm25Index = null;\n }\n}\n",
24
24
  "/**\n * Keyword Extraction Service\n * \n * Pure domain service for extracting keywords from code.\n * No external dependencies - operates only on string data.\n */\n\n/**\n * Common programming keywords to exclude from keyword extraction.\n * These appear in almost every code file and don't add search value.\n */\nexport const COMMON_KEYWORDS = new Set([\n // JavaScript/TypeScript\n 'const', 'let', 'var', 'function', 'class', 'interface', 'type', 'enum',\n 'export', 'import', 'from', 'return', 'async', 'await', 'new', 'this',\n 'true', 'false', 'null', 'undefined', 'if', 'else', 'for', 'while',\n 'switch', 'case', 'break', 'continue', 'try', 'catch', 'finally',\n 'throw', 'typeof', 'instanceof', 'void', 'delete', 'in', 'of',\n 'string', 'number', 'boolean', 'any', 'unknown', 'never', 'object',\n 'public', 'private', 'protected', 'static', 'readonly', 'abstract',\n 'implements', 'extends', 'super', 'get', 'set', 'constructor',\n // Common words\n 'the', 'and', 'for', 'not', 'with', 'are', 'was', 'has', 'have',\n]);\n\n/**\n * Common architectural layer patterns in file names/paths.\n * Used to detect the layer a file belongs to.\n */\nexport const LAYER_PATTERNS: Record<string, string[]> = {\n 'controller': ['controller', 'controllers', 'handler', 'handlers', 'route', 'routes', 'api'],\n 'service': ['service', 'services', 'usecase', 'usecases', 'application'],\n 'repository': ['repository', 'repositories', 'repo', 'repos', 'dao', 'store', 'storage'],\n 'model': ['model', 'models', 'entity', 'entities', 'schema', 'schemas'],\n 'util': ['util', 'utils', 'utility', 'utilities', 'helper', 'helpers', 'common', 'shared'],\n 'config': ['config', 'configs', 'configuration', 'settings'],\n 'middleware': ['middleware', 'middlewares', 'interceptor', 'interceptors'],\n 'domain': ['domain', 'core', 'business'],\n 'infrastructure': ['infrastructure', 'infra', 'external', 'adapters'],\n 'presentation': ['presentation', 'view', 'views', 'component', 'components', 'ui'],\n 'test': ['test', 'tests', 'spec', 'specs', '__tests__', '__test__'],\n};\n\n/**\n * Extract keywords from code content and optional name.\n * \n * @param content - Code content to extract keywords from\n * @param name - Optional name (function name, class name, etc.)\n * @param maxKeywords - Maximum keywords to return (default: 50)\n * @returns Array of unique lowercase keywords\n */\nexport function extractKeywords(\n content: string, \n name?: string,\n maxKeywords: number = 50\n): string[] {\n const keywords = new Set<string>();\n \n // Add the name if present\n if (name) {\n keywords.add(name.toLowerCase());\n \n // Also add camelCase parts (e.g., \"getUserById\" → [\"get\", \"user\", \"by\", \"id\"])\n const parts = name.split(/(?=[A-Z])/).map(p => p.toLowerCase());\n parts.forEach(p => p.length > 2 && keywords.add(p));\n }\n \n // Extract identifiers from content\n const identifierRegex = /\\b([a-zA-Z_][a-zA-Z0-9_]{2,})\\b/g;\n let match;\n \n while ((match = identifierRegex.exec(content)) !== null) {\n const word = match[1].toLowerCase();\n \n // Skip common keywords and very short words\n if (!COMMON_KEYWORDS.has(word) && word.length > 2) {\n keywords.add(word);\n }\n }\n \n return Array.from(keywords).slice(0, maxKeywords);\n}\n\n/**\n * Split a string by camelCase, PascalCase, snake_case, and kebab-case.\n */\nfunction splitIdentifier(str: string): string[] {\n return str\n // Split camelCase and PascalCase\n .replace(/([a-z])([A-Z])/g, '$1 $2')\n // Split snake_case and kebab-case\n .replace(/[_-]/g, ' ')\n .split(/\\s+/)\n .map(s => s.toLowerCase())\n .filter(s => s.length > 1);\n}\n\n/**\n * Extract keywords from a file path.\n * \n * Enhanced extraction that:\n * - Splits camelCase/PascalCase filenames\n * - Extracts directory segments\n * - Recognizes common patterns (Service, Controller, etc.)\n * \n * @param filepath - File path to extract keywords from\n * @returns Array of keywords from path segments\n */\nexport function extractPathKeywords(filepath: string): string[] {\n const keywords = new Set<string>();\n \n // Split path into segments (excluding extension)\n const pathWithoutExt = filepath.replace(/\\.[^.]+$/, '');\n const segments = pathWithoutExt.split(/[/\\\\]/);\n \n for (const segment of segments) {\n if (segment.length < 2) continue;\n \n // Add the full segment\n const lower = segment.toLowerCase();\n if (!COMMON_KEYWORDS.has(lower) && lower.length > 2) {\n keywords.add(lower);\n }\n \n // Split camelCase/PascalCase/snake_case and add parts\n const parts = splitIdentifier(segment);\n for (const part of parts) {\n if (!COMMON_KEYWORDS.has(part) && part.length > 2) {\n keywords.add(part);\n }\n }\n }\n \n return Array.from(keywords);\n}\n\n/**\n * Path context information extracted from a file path.\n */\nexport interface PathContext {\n /** Directory segments (excluding filename) */\n segments: string[];\n /** Detected architectural layer (service, controller, repository, etc.) */\n layer?: string;\n /** Detected feature domain (auth, users, payments, etc.) */\n domain?: string;\n /** Path depth (number of directory levels) */\n depth: number;\n /** Keywords extracted from the path */\n keywords: string[];\n}\n\n/**\n * Parse a file path and extract structural context.\n * \n * This helps with:\n * - Boosting files in related directories\n * - Understanding architectural layer\n * - Grouping by feature domain\n * \n * @param filepath - File path to parse\n * @returns Parsed path context\n */\nexport function parsePathContext(filepath: string): PathContext {\n const pathWithoutExt = filepath.replace(/\\.[^.]+$/, '');\n const allSegments = pathWithoutExt.split(/[/\\\\]/);\n const filename = allSegments[allSegments.length - 1];\n const dirSegments = allSegments.slice(0, -1);\n \n // Extract keywords from all segments\n const keywords = extractPathKeywords(filepath);\n \n // Detect layer from filename and path\n let layer: string | undefined;\n const allLower = [...dirSegments, filename].map(s => s.toLowerCase()).join(' ');\n const filenameLower = filename.toLowerCase();\n \n for (const [layerName, patterns] of Object.entries(LAYER_PATTERNS)) {\n for (const pattern of patterns) {\n // Check filename first (higher priority)\n if (filenameLower.includes(pattern)) {\n layer = layerName;\n break;\n }\n // Check path segments\n if (dirSegments.some(s => s.toLowerCase() === pattern)) {\n layer = layerName;\n break;\n }\n }\n if (layer) break;\n }\n \n // Detect domain from non-layer directory names\n // e.g., src/services/auth/authService.ts → domain = \"auth\"\n // Traverse from innermost to outermost to find the most specific domain\n let domain: string | undefined;\n const layerPatternSet = new Set(Object.values(LAYER_PATTERNS).flat());\n \n // Create a reversed copy to traverse from innermost to outermost\n const reversedSegments = [...dirSegments].reverse();\n for (const segment of reversedSegments) {\n const lower = segment.toLowerCase();\n // Skip common non-domain directories\n if (['src', 'lib', 'app', 'packages', 'modules'].includes(lower)) continue;\n // Skip layer directories\n if (layerPatternSet.has(lower)) continue;\n // This is likely the domain\n if (lower.length > 2) {\n domain = lower;\n break;\n }\n }\n \n return {\n segments: dirSegments,\n layer,\n domain,\n depth: dirSegments.length,\n keywords,\n };\n}\n\n/**\n * Generate a path context string for embedding.\n * This is prepended to content to give the embedding model path awareness.\n * \n * @param pathContext - Parsed path context\n * @returns A string representation of the path context\n */\nexport function formatPathContextForEmbedding(pathContext: PathContext): string {\n const parts: string[] = [];\n \n if (pathContext.domain) {\n parts.push(pathContext.domain);\n }\n \n if (pathContext.layer) {\n parts.push(pathContext.layer);\n }\n \n // Add significant path segments (limit to avoid noise)\n const significantSegments = pathContext.segments\n .slice(-3) // Last 3 directories\n .filter(s => s.length > 2 && !['src', 'lib', 'app'].includes(s.toLowerCase()));\n \n if (significantSegments.length > 0) {\n parts.push(...significantSegments.map(s => s.toLowerCase()));\n }\n \n if (parts.length === 0) return '';\n \n // Deduplicate\n const unique = [...new Set(parts)];\n return `[${unique.join(' ')}]`;\n}\n\n",
25
25
  "/**\n * Similarity Service\n *\n * Pure mathematical functions for computing vector similarity.\n * No external dependencies.\n */\n\n/**\n * Calculate cosine similarity between two vectors.\n *\n * @param a - First vector\n * @param b - Second vector\n * @returns Similarity score between -1 and 1 (1 = identical, 0 = orthogonal, -1 = opposite)\n * @throws Error if vectors have different lengths\n */\nexport function cosineSimilarity(a: number[], b: number[]): number {\n if (a.length !== b.length) {\n throw new Error(`Vector length mismatch: ${a.length} vs ${b.length}`);\n }\n\n let dotProduct = 0;\n let normA = 0;\n let normB = 0;\n\n for (let i = 0; i < a.length; i++) {\n dotProduct += a[i] * b[i];\n normA += a[i] * a[i];\n normB += b[i] * b[i];\n }\n\n const magnitude = Math.sqrt(normA) * Math.sqrt(normB);\n\n if (magnitude === 0) return 0;\n\n return dotProduct / magnitude;\n}\n\n/**\n * Calculate Euclidean distance between two vectors.\n *\n * @param a - First vector\n * @param b - Second vector\n * @returns Distance (0 = identical, larger = more different)\n */\nexport function euclideanDistance(a: number[], b: number[]): number {\n if (a.length !== b.length) {\n throw new Error(`Vector length mismatch: ${a.length} vs ${b.length}`);\n }\n\n let sum = 0;\n for (let i = 0; i < a.length; i++) {\n const diff = a[i] - b[i];\n sum += diff * diff;\n }\n\n return Math.sqrt(sum);\n}\n\n",
26
- "/**\n * Query Intent Detection Service\n *\n * Detects whether a search query is looking for implementation code\n * or documentation, and calculates appropriate boosts.\n */\n\nimport * as path from \"path\";\n\n// ============================================================================\n// Constants\n// ============================================================================\n\n/** Implementation-related query terms that boost source code files */\nexport const IMPLEMENTATION_TERMS = [\n \"function\",\n \"method\",\n \"class\",\n \"interface\",\n \"implement\",\n \"implementation\",\n \"endpoint\",\n \"route\",\n \"handler\",\n \"controller\",\n \"module\",\n \"code\",\n];\n\n/** Documentation-related query terms that boost documentation files */\nexport const DOCUMENTATION_TERMS = [\n \"documentation\",\n \"docs\",\n \"guide\",\n \"tutorial\",\n \"readme\",\n \"how\",\n \"what\",\n \"why\",\n \"explain\",\n \"overview\",\n \"getting\",\n \"started\",\n \"requirements\",\n \"setup\",\n \"install\",\n \"configure\",\n \"configuration\",\n];\n\n/** Source code file extensions */\nexport const SOURCE_CODE_EXTENSIONS = [\n \".ts\",\n \".tsx\",\n \".js\",\n \".jsx\",\n \".mjs\",\n \".cjs\",\n \".py\",\n \".go\",\n \".rs\",\n \".java\",\n];\n\n/** Documentation file extensions */\nexport const DOC_EXTENSIONS = [\".md\", \".txt\", \".rst\"];\n\n/** Data/config file extensions */\nexport const DATA_EXTENSIONS = [\".json\", \".yaml\", \".yml\", \".toml\"];\n\n// ============================================================================\n// Query Intent Detection\n// ============================================================================\n\n/** Query intent types */\nexport type QueryIntent = \"implementation\" | \"documentation\" | \"neutral\";\n\n/**\n * Detect query intent based on terms.\n * Returns: 'implementation' | 'documentation' | 'neutral'\n *\n * @param queryTerms - Array of query terms (lowercase)\n * @returns The detected intent\n */\nexport function detectQueryIntent(queryTerms: string[]): QueryIntent {\n const hasImplementationTerm = queryTerms.some((term) =>\n IMPLEMENTATION_TERMS.includes(term)\n );\n const hasDocumentationTerm = queryTerms.some((term) =>\n DOCUMENTATION_TERMS.includes(term)\n );\n\n // Documentation terms take precedence if both are present\n // (e.g., \"api documentation\" should favor docs)\n if (hasDocumentationTerm) {\n return \"documentation\";\n }\n\n if (hasImplementationTerm) {\n return \"implementation\";\n }\n\n return \"neutral\";\n}\n\n/**\n * Extract query terms from a search query.\n *\n * @param query - The search query string\n * @returns Array of lowercase terms (length > 2)\n */\nexport function extractQueryTerms(query: string): string[] {\n return query\n .toLowerCase()\n .split(/\\s+/)\n .filter((t) => t.length > 2);\n}\n\n// ============================================================================\n// File Type Boosts\n// ============================================================================\n\n/**\n * Determine if a file is a source code file based on extension.\n */\nexport function isSourceCodeFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return SOURCE_CODE_EXTENSIONS.includes(ext);\n}\n\n/**\n * Determine if a file is a documentation file based on extension.\n */\nexport function isDocFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return DOC_EXTENSIONS.includes(ext);\n}\n\n/**\n * Determine if a file is a data/config file based on extension.\n */\nexport function isDataFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return DATA_EXTENSIONS.includes(ext);\n}\n\n/**\n * Calculate boost based on file type and query context.\n * Bidirectional: boosts code for implementation queries, docs for documentation queries.\n * Only applies when query intent is clear.\n *\n * @param filepath - The file path\n * @param queryTerms - Array of query terms (lowercase)\n * @returns Boost value (0 to ~0.1)\n */\nexport function calculateFileTypeBoost(\n filepath: string,\n queryTerms: string[]\n): number {\n const isSourceCode = isSourceCodeFile(filepath);\n const isDoc = isDocFile(filepath);\n\n const intent = detectQueryIntent(queryTerms);\n\n // For implementation-focused queries, boost source code\n if (intent === \"implementation\") {\n if (isSourceCode) {\n return 0.06; // Moderate boost for source code\n }\n // No penalty for docs - they might still be relevant\n return 0;\n }\n\n // For documentation-focused queries, boost documentation files\n if (intent === \"documentation\") {\n if (isDoc) {\n return 0.08; // Boost documentation files\n }\n // No penalty for code - they might still be relevant\n return 0;\n }\n\n // Neutral queries: no boost either way\n return 0;\n}\n\n",
27
- "/**\n * Text Chunking Service\n *\n * Provides generic text chunking strategies for indexing.\n * These are language-agnostic and work with any text content.\n */\n\nimport type { ChunkType } from \"../entities\";\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * Represents a chunk of text with location information.\n */\nexport interface TextChunk {\n /** The text content */\n content: string;\n /** 1-based start line number */\n startLine: number;\n /** 1-based end line number */\n endLine: number;\n /** The type of chunk */\n type: ChunkType;\n /** Optional name for the chunk */\n name?: string;\n}\n\n/**\n * Options for line-based chunking.\n */\nexport interface ChunkingOptions {\n /** Lines per chunk (default: 30) */\n chunkSize?: number;\n /** Overlap between chunks (default: 5) */\n overlap?: number;\n /** Minimum lines to create multiple chunks (default: chunkSize) */\n minLinesForMultipleChunks?: number;\n}\n\n// ============================================================================\n// Default Configuration\n// ============================================================================\n\n/** Default lines per chunk */\nexport const DEFAULT_CHUNK_SIZE = 30;\n\n/** Default overlap between chunks */\nexport const DEFAULT_OVERLAP = 5;\n\n// ============================================================================\n// Chunking Functions\n// ============================================================================\n\n/**\n * Split text into overlapping chunks based on line boundaries.\n *\n * This is a generic chunking strategy that works with any text content.\n * It creates overlapping chunks to ensure context is preserved across\n * chunk boundaries.\n *\n * @param content - The text content to chunk\n * @param options - Chunking options\n * @returns Array of text chunks\n */\nexport function createLineBasedChunks(\n content: string,\n options: ChunkingOptions = {}\n): TextChunk[] {\n const {\n chunkSize = DEFAULT_CHUNK_SIZE,\n overlap = DEFAULT_OVERLAP,\n minLinesForMultipleChunks = chunkSize,\n } = options;\n\n const lines = content.split(\"\\n\");\n const chunks: TextChunk[] = [];\n\n // If file is small, treat as single chunk\n if (lines.length <= minLinesForMultipleChunks) {\n return [\n {\n content: content,\n startLine: 1,\n endLine: lines.length,\n type: \"file\",\n },\n ];\n }\n\n // Split into overlapping chunks\n for (let i = 0; i < lines.length; i += chunkSize - overlap) {\n const endIdx = Math.min(i + chunkSize, lines.length);\n chunks.push({\n content: lines.slice(i, endIdx).join(\"\\n\"),\n startLine: i + 1,\n endLine: endIdx,\n type: \"block\",\n });\n\n if (endIdx >= lines.length) break;\n }\n\n return chunks;\n}\n\n/**\n * Create a single chunk from entire content.\n * Useful for small files or when chunking isn't needed.\n *\n * @param content - The text content\n * @returns A single file chunk\n */\nexport function createSingleChunk(content: string): TextChunk {\n const lines = content.split(\"\\n\");\n return {\n content,\n startLine: 1,\n endLine: lines.length,\n type: \"file\",\n };\n}\n\n/**\n * Generate a unique chunk ID from filepath and line numbers.\n *\n * @param filepath - The source file path\n * @param startLine - Start line number\n * @param endLine - End line number\n * @returns Unique chunk identifier\n */\nexport function generateChunkId(\n filepath: string,\n startLine: number,\n endLine: number\n): string {\n const safePath = filepath.replace(/[/\\\\]/g, \"-\").replace(/\\./g, \"_\");\n return `${safePath}-${startLine}-${endLine}`;\n}\n\n",
26
+ "/**\n * Query Intent Detection Service\n *\n * Detects whether a search query is looking for implementation code\n * or documentation, and calculates appropriate boosts.\n */\n\nimport * as path from \"path\";\n\n// ============================================================================\n// Constants\n// ============================================================================\n\n/** Implementation-related query terms that boost source code files */\nexport const IMPLEMENTATION_TERMS = [\n \"function\",\n \"method\",\n \"class\",\n \"interface\",\n \"implement\",\n \"implementation\",\n \"endpoint\",\n \"route\",\n \"handler\",\n \"controller\",\n \"module\",\n \"code\",\n];\n\n/** Documentation-related query terms that boost documentation files */\nexport const DOCUMENTATION_TERMS = [\n \"documentation\",\n \"docs\",\n \"guide\",\n \"tutorial\",\n \"readme\",\n \"how\",\n \"what\",\n \"why\",\n \"explain\",\n \"overview\",\n \"getting\",\n \"started\",\n \"requirements\",\n \"setup\",\n \"install\",\n \"configure\",\n \"configuration\",\n];\n\n/** Source code file extensions */\nexport const SOURCE_CODE_EXTENSIONS = [\n \".ts\",\n \".tsx\",\n \".js\",\n \".jsx\",\n \".mjs\",\n \".cjs\",\n \".py\",\n \".go\",\n \".rs\",\n \".java\",\n];\n\n/** Documentation file extensions */\nexport const DOC_EXTENSIONS = [\".md\", \".txt\", \".rst\"];\n\n/** Data/config file extensions */\nexport const DATA_EXTENSIONS = [\".json\", \".yaml\", \".yml\", \".toml\"];\n\n// ============================================================================\n// Query Intent Detection\n// ============================================================================\n\n/** Query intent types */\nexport type QueryIntent = \"implementation\" | \"documentation\" | \"neutral\";\n\n/**\n * Detect query intent based on terms.\n * Returns: 'implementation' | 'documentation' | 'neutral'\n *\n * @param queryTerms - Array of query terms (lowercase)\n * @returns The detected intent\n */\nexport function detectQueryIntent(queryTerms: string[]): QueryIntent {\n const hasImplementationTerm = queryTerms.some((term) =>\n IMPLEMENTATION_TERMS.includes(term)\n );\n const hasDocumentationTerm = queryTerms.some((term) =>\n DOCUMENTATION_TERMS.includes(term)\n );\n\n // Documentation terms take precedence if both are present\n // (e.g., \"api documentation\" should favor docs)\n if (hasDocumentationTerm) {\n return \"documentation\";\n }\n\n if (hasImplementationTerm) {\n return \"implementation\";\n }\n\n return \"neutral\";\n}\n\n/**\n * Extract query terms from a search query.\n *\n * @param query - The search query string\n * @returns Array of lowercase terms (length > 2)\n */\nexport function extractQueryTerms(query: string): string[] {\n return query\n .toLowerCase()\n .split(/\\s+/)\n .filter((t) => t.length > 2);\n}\n\n// ============================================================================\n// File Type Boosts\n// ============================================================================\n\n/**\n * Determine if a file is a source code file based on extension.\n */\nexport function isSourceCodeFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return SOURCE_CODE_EXTENSIONS.includes(ext);\n}\n\n/**\n * Determine if a file is a documentation file based on extension.\n */\nexport function isDocFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return DOC_EXTENSIONS.includes(ext);\n}\n\n/**\n * Determine if a file is a data/config file based on extension.\n */\nexport function isDataFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return DATA_EXTENSIONS.includes(ext);\n}\n\n/**\n * Calculate boost based on file type and query context.\n * Bidirectional: boosts code for implementation queries, docs for documentation queries.\n * Only applies when query intent is clear.\n *\n * @param filepath - The file path\n * @param queryTerms - Array of query terms (lowercase)\n * @returns Boost value (0 to ~0.1)\n */\nexport function calculateFileTypeBoost(\n filepath: string,\n queryTerms: string[]\n): number {\n const isSourceCode = isSourceCodeFile(filepath);\n const isDoc = isDocFile(filepath);\n\n const intent = detectQueryIntent(queryTerms);\n\n // For implementation-focused queries, boost source code\n if (intent === \"implementation\") {\n if (isSourceCode) {\n return 0.06; // Moderate boost for source code\n }\n // No penalty for docs - they might still be relevant\n return 0;\n }\n\n // For documentation-focused queries, boost documentation files\n if (intent === \"documentation\") {\n if (isDoc) {\n return 0.08; // Boost documentation files\n }\n // No penalty for code - they might still be relevant\n return 0;\n }\n\n // Neutral queries: no boost either way\n return 0;\n}\n\n\n\n\n",
27
+ "/**\n * Text Chunking Service\n *\n * Provides generic text chunking strategies for indexing.\n * These are language-agnostic and work with any text content.\n */\n\nimport type { ChunkType } from \"../entities\";\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * Represents a chunk of text with location information.\n */\nexport interface TextChunk {\n /** The text content */\n content: string;\n /** 1-based start line number */\n startLine: number;\n /** 1-based end line number */\n endLine: number;\n /** The type of chunk */\n type: ChunkType;\n /** Optional name for the chunk */\n name?: string;\n}\n\n/**\n * Options for line-based chunking.\n */\nexport interface ChunkingOptions {\n /** Lines per chunk (default: 30) */\n chunkSize?: number;\n /** Overlap between chunks (default: 5) */\n overlap?: number;\n /** Minimum lines to create multiple chunks (default: chunkSize) */\n minLinesForMultipleChunks?: number;\n}\n\n// ============================================================================\n// Default Configuration\n// ============================================================================\n\n/** Default lines per chunk */\nexport const DEFAULT_CHUNK_SIZE = 30;\n\n/** Default overlap between chunks */\nexport const DEFAULT_OVERLAP = 5;\n\n// ============================================================================\n// Chunking Functions\n// ============================================================================\n\n/**\n * Split text into overlapping chunks based on line boundaries.\n *\n * This is a generic chunking strategy that works with any text content.\n * It creates overlapping chunks to ensure context is preserved across\n * chunk boundaries.\n *\n * @param content - The text content to chunk\n * @param options - Chunking options\n * @returns Array of text chunks\n */\nexport function createLineBasedChunks(\n content: string,\n options: ChunkingOptions = {}\n): TextChunk[] {\n const {\n chunkSize = DEFAULT_CHUNK_SIZE,\n overlap = DEFAULT_OVERLAP,\n minLinesForMultipleChunks = chunkSize,\n } = options;\n\n const lines = content.split(\"\\n\");\n const chunks: TextChunk[] = [];\n\n // If file is small, treat as single chunk\n if (lines.length <= minLinesForMultipleChunks) {\n return [\n {\n content: content,\n startLine: 1,\n endLine: lines.length,\n type: \"file\",\n },\n ];\n }\n\n // Split into overlapping chunks\n for (let i = 0; i < lines.length; i += chunkSize - overlap) {\n const endIdx = Math.min(i + chunkSize, lines.length);\n chunks.push({\n content: lines.slice(i, endIdx).join(\"\\n\"),\n startLine: i + 1,\n endLine: endIdx,\n type: \"block\",\n });\n\n if (endIdx >= lines.length) break;\n }\n\n return chunks;\n}\n\n/**\n * Create a single chunk from entire content.\n * Useful for small files or when chunking isn't needed.\n *\n * @param content - The text content\n * @returns A single file chunk\n */\nexport function createSingleChunk(content: string): TextChunk {\n const lines = content.split(\"\\n\");\n return {\n content,\n startLine: 1,\n endLine: lines.length,\n type: \"file\",\n };\n}\n\n/**\n * Generate a unique chunk ID from filepath and line numbers.\n *\n * @param filepath - The source file path\n * @param startLine - Start line number\n * @param endLine - End line number\n * @returns Unique chunk identifier\n */\nexport function generateChunkId(\n filepath: string,\n startLine: number,\n endLine: number\n): string {\n const safePath = filepath.replace(/[/\\\\]/g, \"-\").replace(/\\./g, \"_\");\n return `${safePath}-${startLine}-${endLine}`;\n}\n\n\n\n\n",
28
28
  "/**\n * Query Literal Parser\n *\n * Parses search queries to extract literals for exact-match boosting.\n * Supports explicit detection (backticks, quotes) and implicit detection (casing patterns).\n *\n * This is a pure domain service with no external dependencies.\n */\n\nimport type {\n DetectedLiteral,\n QueryLiteralParseResult,\n LiteralType,\n LiteralConfidence,\n LiteralDetectionMethod,\n} from \"../entities/literal\";\n\n/**\n * Pattern definitions for implicit literal detection.\n */\ninterface ImplicitPattern {\n /** Regex pattern to match */\n pattern: RegExp;\n /** Confidence level for matches */\n confidence: LiteralConfidence;\n /** Inferred type for matches */\n inferredType: LiteralType;\n /** Minimum length for valid match */\n minLength?: number;\n}\n\n/**\n * Implicit detection patterns ordered by specificity.\n *\n * PascalCase: AuthService, UserRepository (2+ capital transitions)\n * camelCase: getUserById, handleLogin (lowercase start, then capital)\n * SCREAMING_SNAKE: MAX_RETRIES, API_KEY (all caps with underscores)\n * snake_case: user_auth, get_user (lowercase with underscores)\n * kebab-case: auth-service, user-auth (lowercase with hyphens)\n */\nconst IMPLICIT_PATTERNS: ImplicitPattern[] = [\n // PascalCase: Must have at least one capital after the first letter\n // e.g., AuthService, UserRepository, MyClass\n {\n pattern: /\\b([A-Z][a-z]+(?:[A-Z][a-z0-9]*)+)\\b/g,\n confidence: \"medium\",\n inferredType: \"className\",\n minLength: 3,\n },\n // camelCase: Starts lowercase, has at least one capital\n // e.g., getUserById, handleLogin, myFunction\n {\n pattern: /\\b([a-z][a-z0-9]*(?:[A-Z][a-zA-Z0-9]*)+)\\b/g,\n confidence: \"medium\",\n inferredType: \"functionName\",\n minLength: 3,\n },\n // SCREAMING_SNAKE_CASE: All caps with underscores\n // e.g., MAX_RETRIES, API_KEY, DEFAULT_TIMEOUT\n {\n pattern: /\\b([A-Z][A-Z0-9]*(?:_[A-Z0-9]+)+)\\b/g,\n confidence: \"medium\",\n inferredType: \"variableName\",\n minLength: 3,\n },\n // snake_case: All lowercase with underscores\n // e.g., user_auth, get_user_by_id\n {\n pattern: /\\b([a-z][a-z0-9]*(?:_[a-z0-9]+)+)\\b/g,\n confidence: \"low\",\n inferredType: \"identifier\",\n minLength: 3,\n },\n // kebab-case: All lowercase with hyphens\n // e.g., auth-service, user-auth-middleware\n // Exclude patterns that look like URLs or file paths\n {\n pattern: /(?<![/:.])\\b([a-z][a-z0-9]*(?:-[a-z0-9]+)+)\\b(?![/:])/g,\n confidence: \"low\",\n inferredType: \"packageName\",\n minLength: 3,\n },\n];\n\n/**\n * Parse a search query to extract literals.\n *\n * Detects:\n * - Explicit literals: `backticks` or \"quotes\"\n * - Implicit literals: PascalCase, camelCase, SCREAMING_SNAKE, snake_case, kebab-case\n *\n * @param query - The search query to parse\n * @returns Detected literals and remaining query for semantic search\n */\nexport function parseQueryLiterals(query: string): QueryLiteralParseResult {\n if (!query || query.trim() === \"\") {\n return { literals: [], remainingQuery: \"\" };\n }\n\n const literals: DetectedLiteral[] = [];\n let remainingQuery = query;\n\n // Track positions that have been matched to avoid duplicates\n const matchedPositions = new Set<string>();\n\n // 1. Extract explicit backtick literals\n const backtickResult = extractExplicitLiterals(\n remainingQuery,\n /`([^`]+)`/g,\n \"explicit-backtick\",\n matchedPositions\n );\n literals.push(...backtickResult.literals);\n remainingQuery = backtickResult.remainingQuery;\n\n // 2. Extract explicit quoted literals\n const quoteResult = extractExplicitLiterals(\n remainingQuery,\n /\"([^\"]+)\"/g,\n \"explicit-quote\",\n matchedPositions\n );\n literals.push(...quoteResult.literals);\n remainingQuery = quoteResult.remainingQuery;\n\n // 3. Extract implicit literals from the ORIGINAL query\n // (we keep implicit literals in remainingQuery for semantic search)\n const implicitLiterals = extractImplicitLiterals(query, matchedPositions);\n literals.push(...implicitLiterals);\n\n return {\n literals,\n remainingQuery: remainingQuery.trim(),\n };\n}\n\n/**\n * Extract explicit literals (backticks or quotes) from query.\n */\nfunction extractExplicitLiterals(\n query: string,\n pattern: RegExp,\n method: LiteralDetectionMethod,\n matchedPositions: Set<string>\n): { literals: DetectedLiteral[]; remainingQuery: string } {\n const literals: DetectedLiteral[] = [];\n let remainingQuery = query;\n\n // Reset regex state\n pattern.lastIndex = 0;\n\n let match: RegExpExecArray | null;\n const replacements: Array<{ start: number; end: number; text: string }> = [];\n\n while ((match = pattern.exec(query)) !== null) {\n const value = match[1];\n const rawValue = match[0];\n\n // Skip empty matches\n if (!value || value.trim() === \"\") {\n continue;\n }\n\n // Track this position to avoid implicit detection of same term\n const posKey = `${match.index}:${match.index + rawValue.length}`;\n matchedPositions.add(posKey);\n\n // Also track the value itself to help avoid duplicates\n matchedPositions.add(`value:${value.toLowerCase()}`);\n\n literals.push({\n value,\n rawValue,\n confidence: \"high\",\n detectionMethod: method,\n // Don't infer type for explicit - user knows what they want\n inferredType: inferTypeFromValue(value),\n });\n\n replacements.push({\n start: match.index,\n end: match.index + rawValue.length,\n text: \"\",\n });\n }\n\n // Apply replacements in reverse order to maintain positions\n replacements\n .sort((a, b) => b.start - a.start)\n .forEach((r) => {\n remainingQuery =\n remainingQuery.slice(0, r.start) + r.text + remainingQuery.slice(r.end);\n });\n\n return { literals, remainingQuery };\n}\n\n/**\n * Extract implicit literals based on casing patterns.\n */\nfunction extractImplicitLiterals(\n query: string,\n matchedPositions: Set<string>\n): DetectedLiteral[] {\n const literals: DetectedLiteral[] = [];\n const seenValues = new Set<string>();\n\n for (const patternDef of IMPLICIT_PATTERNS) {\n // Reset regex state\n patternDef.pattern.lastIndex = 0;\n\n let match: RegExpExecArray | null;\n while ((match = patternDef.pattern.exec(query)) !== null) {\n const value = match[1];\n\n // Skip if too short\n if (patternDef.minLength && value.length < patternDef.minLength) {\n continue;\n }\n\n // Skip if this position was already matched by explicit pattern\n const posKey = `${match.index}:${match.index + value.length}`;\n if (matchedPositions.has(posKey)) {\n continue;\n }\n\n // Skip if value was already matched explicitly\n if (matchedPositions.has(`value:${value.toLowerCase()}`)) {\n continue;\n }\n\n // Skip if we've already seen this value (from another pattern)\n const lowerValue = value.toLowerCase();\n if (seenValues.has(lowerValue)) {\n continue;\n }\n seenValues.add(lowerValue);\n\n // Skip common false positives\n if (isCommonWord(value)) {\n continue;\n }\n\n literals.push({\n value,\n rawValue: value,\n confidence: patternDef.confidence,\n detectionMethod: \"implicit-casing\",\n inferredType: patternDef.inferredType,\n });\n }\n }\n\n return literals;\n}\n\n/**\n * Infer type from value pattern (for explicit literals).\n */\nfunction inferTypeFromValue(value: string): LiteralType | undefined {\n // Check each pattern\n if (/^[A-Z][a-z]+(?:[A-Z][a-z0-9]*)+$/.test(value)) {\n return \"className\";\n }\n if (/^[a-z][a-z0-9]*(?:[A-Z][a-zA-Z0-9]*)+$/.test(value)) {\n return \"functionName\";\n }\n if (/^[A-Z][A-Z0-9]*(?:_[A-Z0-9]+)+$/.test(value)) {\n return \"variableName\";\n }\n if (/^[a-z][a-z0-9]*(?:_[a-z0-9]+)+$/.test(value)) {\n return \"identifier\";\n }\n if (/^[a-z][a-z0-9]*(?:-[a-z0-9]+)+$/.test(value)) {\n return \"packageName\";\n }\n // Can't infer type\n return undefined;\n}\n\n/**\n * Check if a word is a common English word that shouldn't be detected as a literal.\n *\n * This helps avoid false positives for words like \"Find\", \"The\", etc.\n * that might be capitalized at the start of a sentence.\n */\nfunction isCommonWord(word: string): boolean {\n const commonWords = new Set([\n // Common sentence starters\n \"find\",\n \"the\",\n \"a\",\n \"an\",\n \"is\",\n \"are\",\n \"was\",\n \"were\",\n \"what\",\n \"where\",\n \"when\",\n \"how\",\n \"why\",\n \"which\",\n \"who\",\n \"this\",\n \"that\",\n \"these\",\n \"those\",\n \"and\",\n \"or\",\n \"but\",\n \"for\",\n \"with\",\n \"from\",\n \"to\",\n \"in\",\n \"on\",\n \"at\",\n \"by\",\n \"of\",\n \"all\",\n \"any\",\n \"some\",\n // Common programming terms that shouldn't be literals alone\n \"get\",\n \"set\",\n \"new\",\n \"class\",\n \"function\",\n \"const\",\n \"let\",\n \"var\",\n \"type\",\n \"interface\",\n \"import\",\n \"export\",\n \"default\",\n \"return\",\n \"async\",\n \"await\",\n \"null\",\n \"undefined\",\n \"true\",\n \"false\",\n ]);\n\n return commonWords.has(word.toLowerCase());\n}\n",
29
29
  "/**\n * Literal Extractor\n *\n * Extracts literals from code chunks for indexing.\n * For TypeScript/JavaScript, uses the chunk name from AST parsing.\n *\n * This is a pure domain service with no external dependencies.\n */\n\nimport type { Chunk } from \"../entities/chunk\";\nimport type { ExtractedLiteral, LiteralType } from \"../entities/literal\";\n\n/**\n * Map from ChunkType to LiteralType for named chunks.\n */\nconst CHUNK_TYPE_TO_LITERAL_TYPE: Record<string, LiteralType> = {\n class: \"className\",\n function: \"functionName\",\n interface: \"interfaceName\",\n type: \"typeName\",\n enum: \"enumName\",\n variable: \"variableName\",\n};\n\n/**\n * Extract literals from a code chunk.\n *\n * For TypeScript/JavaScript chunks, this extracts the chunk's name\n * as a \"definition\" literal. The name comes from proper AST parsing,\n * so it's accurate and reliable.\n *\n * @param chunk - The code chunk to extract literals from\n * @returns Array of extracted literals (typically just the definition)\n */\nexport function extractLiterals(chunk: Chunk): ExtractedLiteral[] {\n const literals: ExtractedLiteral[] = [];\n\n // Extract the chunk's own name as a definition\n // This name comes from TypeScript AST parsing, so it's accurate\n if (chunk.name) {\n const literalType = CHUNK_TYPE_TO_LITERAL_TYPE[chunk.type] || \"identifier\";\n\n literals.push({\n value: chunk.name,\n type: literalType,\n matchType: \"definition\",\n });\n }\n\n return literals;\n}\n\n/**\n * Extract literals from a code chunk with additional reference extraction.\n *\n * This version also extracts references from the chunk content using\n * pattern matching. Use this for modules that want deeper literal indexing.\n *\n * @param chunk - The code chunk to extract literals from\n * @param options - Extraction options\n * @returns Array of extracted literals\n */\nexport function extractLiteralsWithReferences(\n chunk: Chunk,\n options: { includeImports?: boolean; includeTypeRefs?: boolean } = {}\n): ExtractedLiteral[] {\n const literals: ExtractedLiteral[] = [];\n const seenValues = new Set<string>();\n\n // 1. Extract the chunk's own name as a definition\n if (chunk.name) {\n const literalType = CHUNK_TYPE_TO_LITERAL_TYPE[chunk.type] || \"identifier\";\n\n literals.push({\n value: chunk.name,\n type: literalType,\n matchType: \"definition\",\n });\n seenValues.add(chunk.name.toLowerCase());\n }\n\n // 2. Optionally extract imports\n if (options.includeImports) {\n const imports = extractImportLiterals(chunk.content);\n for (const lit of imports) {\n if (!seenValues.has(lit.value.toLowerCase())) {\n literals.push(lit);\n seenValues.add(lit.value.toLowerCase());\n }\n }\n }\n\n // 3. Optionally extract type references\n if (options.includeTypeRefs) {\n const refs = extractTypeReferences(chunk.content, chunk.name);\n for (const lit of refs) {\n if (!seenValues.has(lit.value.toLowerCase())) {\n literals.push(lit);\n seenValues.add(lit.value.toLowerCase());\n }\n }\n }\n\n return literals;\n}\n\n/**\n * Extract literals from import statements.\n * Only extracts PascalCase identifiers (likely classes/types).\n */\nfunction extractImportLiterals(content: string): ExtractedLiteral[] {\n const literals: ExtractedLiteral[] = [];\n const seen = new Set<string>();\n\n // Named imports: import { Foo, Bar as Baz } from 'module'\n const namedImportPattern = /import\\s*\\{([^}]+)\\}\\s*from/g;\n let match: RegExpExecArray | null;\n\n while ((match = namedImportPattern.exec(content)) !== null) {\n const importList = match[1];\n const identifiers = importList.split(\",\").map((s) => s.trim());\n\n for (const id of identifiers) {\n const parts = id.split(/\\s+as\\s+/);\n const name = parts[0].trim();\n\n // Only extract PascalCase identifiers\n if (/^[A-Z][a-zA-Z0-9]*$/.test(name) && !seen.has(name.toLowerCase())) {\n seen.add(name.toLowerCase());\n literals.push({\n value: name,\n type: \"className\",\n matchType: \"import\",\n });\n }\n }\n }\n\n // Default imports: import Foo from 'module'\n const defaultImportPattern = /import\\s+([A-Z][a-zA-Z0-9]*)\\s+from/g;\n while ((match = defaultImportPattern.exec(content)) !== null) {\n if (!seen.has(match[1].toLowerCase())) {\n seen.add(match[1].toLowerCase());\n literals.push({\n value: match[1],\n type: \"className\",\n matchType: \"import\",\n });\n }\n }\n\n return literals;\n}\n\n/**\n * Extract type reference literals (extends, implements).\n */\nfunction extractTypeReferences(\n content: string,\n chunkName?: string\n): ExtractedLiteral[] {\n const literals: ExtractedLiteral[] = [];\n const seen = new Set<string>();\n\n if (chunkName) {\n seen.add(chunkName.toLowerCase());\n }\n\n // Match: extends Foo, implements Bar\n const extendsPattern = /(?:extends|implements)\\s+([A-Z][a-zA-Z0-9]*)/g;\n let match: RegExpExecArray | null;\n\n while ((match = extendsPattern.exec(content)) !== null) {\n const value = match[1];\n if (!seen.has(value.toLowerCase()) && !isBuiltInType(value)) {\n seen.add(value.toLowerCase());\n literals.push({\n value,\n type: \"className\",\n matchType: \"reference\",\n });\n }\n }\n\n return literals;\n}\n\n/**\n * Check if a type name is a built-in TypeScript type.\n */\nfunction isBuiltInType(name: string): boolean {\n const builtIns = new Set([\n \"String\",\n \"Number\",\n \"Boolean\",\n \"Object\",\n \"Array\",\n \"Function\",\n \"Symbol\",\n \"BigInt\",\n \"Promise\",\n \"Map\",\n \"Set\",\n \"WeakMap\",\n \"WeakSet\",\n \"Date\",\n \"RegExp\",\n \"Error\",\n \"Partial\",\n \"Required\",\n \"Readonly\",\n \"Record\",\n \"Pick\",\n \"Omit\",\n \"Exclude\",\n \"Extract\",\n \"NonNullable\",\n \"ReturnType\",\n \"InstanceType\",\n \"Parameters\",\n \"ConstructorParameters\",\n \"Awaited\",\n ]);\n return builtIns.has(name);\n}\n",
30
30
  "/**\n * Literal Scorer\n *\n * Calculates multiplicative score boosts for literal matches.\n * Implements the three-source merge strategy for literal boosting.\n *\n * This is a pure domain service with no external dependencies.\n */\n\nimport type {\n LiteralMatch,\n LiteralMatchType,\n LiteralConfidence,\n LITERAL_SCORING,\n} from \"../entities/literal\";\n\n/**\n * Scoring constants for literal boosting.\n */\nexport const LITERAL_SCORING_CONSTANTS = {\n /** Base score for chunks found only via literal index */\n BASE_SCORE: 0.5,\n\n /** Multipliers by match type and confidence */\n MULTIPLIERS: {\n definition: { high: 2.5, medium: 2.0, low: 1.5 },\n reference: { high: 2.0, medium: 1.5, low: 1.3 },\n import: { high: 1.5, medium: 1.3, low: 1.1 },\n } as Record<LiteralMatchType, Record<LiteralConfidence, number>>,\n};\n\n/**\n * Calculate the literal multiplier for a given match type and confidence.\n *\n * @param matchType - How the chunk relates to the literal (definition/reference/import)\n * @param confidence - Detection confidence of the query literal\n * @returns Multiplier to apply to the base score\n */\nexport function calculateLiteralMultiplier(\n matchType: LiteralMatchType,\n confidence: LiteralConfidence\n): number {\n return LITERAL_SCORING_CONSTANTS.MULTIPLIERS[matchType][confidence];\n}\n\n/**\n * Calculate the maximum multiplier for a set of literal matches.\n *\n * When a chunk has multiple literal matches, use the highest multiplier.\n *\n * @param matches - Array of literal matches for a chunk\n * @returns The maximum multiplier, or 1.0 if no matches\n */\nexport function calculateMaxMultiplier(matches: LiteralMatch[]): number {\n if (!matches || matches.length === 0) {\n return 1.0;\n }\n\n return Math.max(\n ...matches.map((m) =>\n calculateLiteralMultiplier(\n m.indexedLiteral.matchType,\n m.queryLiteral.confidence\n )\n )\n );\n}\n\n/**\n * Score contribution from literal matches.\n * Used for debugging and explainability.\n */\nexport interface LiteralScoreContribution {\n /** The multiplier applied */\n multiplier: number;\n\n /** Whether this is a literal-only match (not found by semantic/BM25) */\n literalOnly: boolean;\n\n /** Match type of the best match */\n bestMatchType?: LiteralMatchType;\n\n /** Confidence of the best match */\n bestConfidence?: LiteralConfidence;\n\n /** Number of literal matches */\n matchCount: number;\n}\n\n/**\n * Calculate the literal score contribution for a chunk.\n *\n * @param matches - Literal matches for the chunk (may be empty)\n * @param hasSemanticOrBm25 - Whether the chunk was found by semantic or BM25 search\n * @returns Score contribution details\n */\nexport function calculateLiteralContribution(\n matches: LiteralMatch[],\n hasSemanticOrBm25: boolean\n): LiteralScoreContribution {\n if (!matches || matches.length === 0) {\n return {\n multiplier: 1.0,\n literalOnly: false,\n matchCount: 0,\n };\n }\n\n // Find the best match (highest multiplier)\n let bestMatch: LiteralMatch | null = null;\n let bestMultiplier = 0;\n\n for (const match of matches) {\n const mult = calculateLiteralMultiplier(\n match.indexedLiteral.matchType,\n match.queryLiteral.confidence\n );\n if (mult > bestMultiplier) {\n bestMultiplier = mult;\n bestMatch = match;\n }\n }\n\n return {\n multiplier: bestMultiplier,\n literalOnly: !hasSemanticOrBm25,\n bestMatchType: bestMatch?.indexedLiteral.matchType,\n bestConfidence: bestMatch?.queryLiteral.confidence,\n matchCount: matches.length,\n };\n}\n\n/**\n * Apply literal boosting to a base score.\n *\n * Scoring rules:\n * - If chunk has both semantic/BM25 and literal match: multiply base by multiplier\n * - If chunk has only literal match: use BASE_SCORE\n * - If chunk has no literal match: use base score as-is\n *\n * @param baseScore - Score from semantic/BM25 search (0 if not found)\n * @param matches - Literal matches for the chunk\n * @param hasSemanticOrBm25 - Whether the chunk was found by semantic or BM25\n * @returns Final score after literal boosting\n */\nexport function applyLiteralBoost(\n baseScore: number,\n matches: LiteralMatch[],\n hasSemanticOrBm25: boolean\n): number {\n // No literal matches - return base score\n if (!matches || matches.length === 0) {\n return baseScore;\n }\n\n const multiplier = calculateMaxMultiplier(matches);\n\n // Literal match but no semantic/BM25 - use base score\n if (!hasSemanticOrBm25) {\n return LITERAL_SCORING_CONSTANTS.BASE_SCORE * multiplier;\n }\n\n // Has both - multiply the base score\n return baseScore * multiplier;\n}\n\n/**\n * Merge results from three search sources with literal boosting.\n *\n * @param semanticBm25Results - Results from semantic and BM25 search\n * @param literalMatches - Map from chunk ID to literal matches\n * @returns Results with literal boosting applied\n */\nexport interface MergeInput {\n /** Chunk ID */\n chunkId: string;\n /** Score from semantic/BM25 search */\n baseScore: number;\n}\n\nexport interface MergeOutput extends MergeInput {\n /** Final score after literal boosting */\n finalScore: number;\n /** Literal contribution details */\n literalContribution: LiteralScoreContribution;\n}\n\nexport function mergeWithLiteralBoost(\n semanticBm25Results: MergeInput[],\n literalMatchMap: Map<string, LiteralMatch[]>\n): MergeOutput[] {\n const results: MergeOutput[] = [];\n const processedChunks = new Set<string>();\n\n // Process results that have semantic/BM25 scores\n for (const result of semanticBm25Results) {\n const matches = literalMatchMap.get(result.chunkId) || [];\n const contribution = calculateLiteralContribution(matches, true);\n const finalScore = applyLiteralBoost(result.baseScore, matches, true);\n\n results.push({\n ...result,\n finalScore,\n literalContribution: contribution,\n });\n processedChunks.add(result.chunkId);\n }\n\n // Add literal-only results (not found by semantic/BM25)\n for (const [chunkId, matches] of literalMatchMap) {\n if (processedChunks.has(chunkId)) {\n continue;\n }\n\n const contribution = calculateLiteralContribution(matches, false);\n const finalScore = applyLiteralBoost(0, matches, false);\n\n results.push({\n chunkId,\n baseScore: 0,\n finalScore,\n literalContribution: contribution,\n });\n }\n\n return results;\n}\n",
@@ -33,18 +33,18 @@
33
33
  "/**\n * Domain Services\n *\n * Pure algorithms and business logic with no external dependencies.\n * These services operate only on domain entities and primitive data.\n */\n\n// BM25 keyword search\nexport {\n BM25Index,\n tokenize,\n normalizeScore,\n type BM25Document,\n type BM25Result,\n type BM25SerializedData,\n} from \"./bm25\";\n\n// Keyword extraction\nexport {\n extractKeywords,\n extractPathKeywords,\n parsePathContext,\n formatPathContextForEmbedding,\n COMMON_KEYWORDS,\n type PathContext,\n} from \"./keywords\";\n\n// Vector similarity\nexport { cosineSimilarity, euclideanDistance } from \"./similarity\";\n\n// Query intent detection\nexport {\n detectQueryIntent,\n extractQueryTerms,\n calculateFileTypeBoost,\n isSourceCodeFile,\n isDocFile,\n isDataFile,\n IMPLEMENTATION_TERMS,\n DOCUMENTATION_TERMS,\n SOURCE_CODE_EXTENSIONS,\n DOC_EXTENSIONS,\n DATA_EXTENSIONS,\n type QueryIntent,\n} from \"./queryIntent\";\n\n// Text chunking\nexport {\n createLineBasedChunks,\n createSingleChunk,\n generateChunkId,\n DEFAULT_CHUNK_SIZE,\n DEFAULT_OVERLAP,\n type TextChunk,\n type ChunkingOptions,\n} from \"./chunking\";\n\n// Literal boosting - Query parsing\nexport { parseQueryLiterals } from \"./queryLiteralParser\";\n\n// Literal boosting - Code extraction\nexport {\n extractLiterals,\n extractLiteralsWithReferences,\n} from \"./literalExtractor\";\n\n// Literal boosting - Scoring\nexport {\n calculateLiteralMultiplier,\n calculateMaxMultiplier,\n calculateLiteralContribution,\n applyLiteralBoost,\n mergeWithLiteralBoost,\n LITERAL_SCORING_CONSTANTS,\n type LiteralScoreContribution,\n type MergeInput,\n type MergeOutput,\n} from \"./literalScorer\";\n\n// Structured Semantic Expansion - Query expansion with synonyms\nexport {\n getSynonyms,\n expandQuery,\n DEFAULT_LEXICON,\n EXPANSION_WEIGHTS,\n DEFAULT_EXPANSION_OPTIONS,\n} from \"./lexicon\";\n\n// JSON path extraction for literal indexing\nexport { extractJsonPaths, extractJsonKeywords } from \"./jsonPathExtractor\";\n",
34
34
  "/**\n * TypeScript/JavaScript Code Parser\n *\n * Uses the TypeScript Compiler API for accurate AST-based parsing.\n * Extracts semantic chunks: functions, classes, interfaces, types, enums.\n *\n * This parser is specifically for TypeScript/JavaScript files.\n * For other file types, use the generic chunking in domain/services/chunking.\n */\n\nimport * as ts from \"typescript\";\nimport type { ChunkType } from \"../../../domain/entities\";\n\n/**\n * Represents a parsed chunk of code with location information\n */\nexport interface ParsedChunk {\n /** The source code content */\n content: string;\n /** 1-based start line number */\n startLine: number;\n /** 1-based end line number */\n endLine: number;\n /** The type of code construct */\n type: ChunkType;\n /** Name of the construct (function name, class name, etc.) */\n name?: string;\n /** Whether this is exported */\n isExported?: boolean;\n /** JSDoc comment if present */\n jsDoc?: string;\n}\n\n/**\n * Parse TypeScript/JavaScript code into semantic chunks.\n *\n * Uses the TypeScript Compiler API for accurate AST-based parsing.\n * Returns chunks for functions, classes, interfaces, types, enums, and exported variables.\n *\n * @param content - The source code content\n * @param filepath - The file path (used for JSX detection)\n * @returns Array of parsed chunks\n */\nexport function parseTypeScriptCode(\n content: string,\n filepath: string\n): ParsedChunk[] {\n return parseTypeScript(content, filepath);\n}\n\n/**\n * Parse TypeScript/JavaScript code using the TypeScript Compiler API\n * @param content - The source code content\n * @param filepath - The file path\n * @returns Array of parsed chunks\n */\nfunction parseTypeScript(content: string, filepath: string): ParsedChunk[] {\n const chunks: ParsedChunk[] = [];\n const lines = content.split(\"\\n\");\n\n // Create a source file from the content\n const sourceFile = ts.createSourceFile(\n filepath,\n content,\n ts.ScriptTarget.Latest,\n true, // setParentNodes\n filepath.endsWith(\".tsx\") || filepath.endsWith(\".jsx\")\n ? ts.ScriptKind.TSX\n : ts.ScriptKind.TS\n );\n\n /**\n * Get line numbers for a node (1-based)\n */\n function getLineNumbers(node: ts.Node): {\n startLine: number;\n endLine: number;\n } {\n const start = sourceFile.getLineAndCharacterOfPosition(node.getStart());\n const end = sourceFile.getLineAndCharacterOfPosition(node.getEnd());\n return {\n startLine: start.line + 1,\n endLine: end.line + 1,\n };\n }\n\n /**\n * Get the source text for a node\n */\n function getNodeText(node: ts.Node): string {\n return node.getText(sourceFile);\n }\n\n /**\n * Check if a node has export modifier\n */\n function isExported(node: ts.Node): boolean {\n if (!ts.canHaveModifiers(node)) return false;\n const modifiers = ts.getModifiers(node);\n return (\n modifiers?.some((m) => m.kind === ts.SyntaxKind.ExportKeyword) ?? false\n );\n }\n\n /**\n * Get JSDoc comment for a node\n */\n function getJSDoc(node: ts.Node): string | undefined {\n const jsDocNodes = ts.getJSDocCommentsAndTags(node);\n if (jsDocNodes.length === 0) return undefined;\n\n return jsDocNodes.map((doc) => doc.getText(sourceFile)).join(\"\\n\");\n }\n\n /**\n * Get function name from various function declarations\n */\n function getFunctionName(node: ts.Node): string | undefined {\n if (ts.isFunctionDeclaration(node) && node.name) {\n return node.name.text;\n }\n if (ts.isMethodDeclaration(node) && ts.isIdentifier(node.name)) {\n return node.name.text;\n }\n if (ts.isVariableDeclaration(node) && ts.isIdentifier(node.name)) {\n return node.name.text;\n }\n return undefined;\n }\n\n /**\n * Visit nodes recursively to extract chunks\n */\n function visit(node: ts.Node): void {\n const { startLine, endLine } = getLineNumbers(node);\n\n // Function declarations (including async)\n if (ts.isFunctionDeclaration(node) && node.name) {\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"function\",\n name: node.name.text,\n isExported: isExported(node),\n jsDoc: getJSDoc(node),\n });\n return; // Don't recurse into function body\n }\n\n // Arrow functions and function expressions assigned to variables\n if (ts.isVariableStatement(node)) {\n for (const decl of node.declarationList.declarations) {\n if (\n decl.initializer &&\n (ts.isArrowFunction(decl.initializer) ||\n ts.isFunctionExpression(decl.initializer))\n ) {\n const name = ts.isIdentifier(decl.name) ? decl.name.text : undefined;\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"function\",\n name,\n isExported: isExported(node),\n jsDoc: getJSDoc(node),\n });\n return;\n }\n }\n }\n\n // Class declarations\n if (ts.isClassDeclaration(node) && node.name) {\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"class\",\n name: node.name.text,\n isExported: isExported(node),\n jsDoc: getJSDoc(node),\n });\n return; // Don't recurse into class body (it's included in the chunk)\n }\n\n // Interface declarations\n if (ts.isInterfaceDeclaration(node)) {\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"interface\",\n name: node.name.text,\n isExported: isExported(node),\n jsDoc: getJSDoc(node),\n });\n return;\n }\n\n // Type alias declarations\n if (ts.isTypeAliasDeclaration(node)) {\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"type\",\n name: node.name.text,\n isExported: isExported(node),\n jsDoc: getJSDoc(node),\n });\n return;\n }\n\n // Enum declarations\n if (ts.isEnumDeclaration(node)) {\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"enum\",\n name: node.name.text,\n isExported: isExported(node),\n jsDoc: getJSDoc(node),\n });\n return;\n }\n\n // Exported variable declarations (constants)\n if (ts.isVariableStatement(node) && isExported(node)) {\n for (const decl of node.declarationList.declarations) {\n // Skip if it's a function (already handled above)\n if (\n decl.initializer &&\n (ts.isArrowFunction(decl.initializer) ||\n ts.isFunctionExpression(decl.initializer))\n ) {\n continue;\n }\n const name = ts.isIdentifier(decl.name) ? decl.name.text : undefined;\n chunks.push({\n content: getNodeText(node),\n startLine,\n endLine,\n type: \"variable\",\n name,\n isExported: true,\n jsDoc: getJSDoc(node),\n });\n }\n return;\n }\n\n // Recurse into children\n ts.forEachChild(node, visit);\n }\n\n // Start visiting from the root\n ts.forEachChild(sourceFile, visit);\n\n // If no semantic chunks found, create a single file chunk\n // (This can happen for files with only top-level statements or imports)\n if (chunks.length === 0) {\n const lines = content.split(\"\\n\");\n return [\n {\n content,\n startLine: 1,\n endLine: lines.length,\n type: \"file\",\n },\n ];\n }\n\n return chunks;\n}\n\n/**\n * Generate a unique chunk ID from filepath and line numbers\n * @param filepath - The source file path\n * @param startLine - Start line number\n * @param endLine - End line number\n * @returns Unique chunk identifier\n */\nexport function generateChunkId(\n filepath: string,\n startLine: number,\n endLine: number\n): string {\n const safePath = filepath.replace(/[/\\\\]/g, \"-\").replace(/\\./g, \"_\");\n return `${safePath}-${startLine}-${endLine}`;\n}\n",
35
35
  "/**\n * File-based Index Storage Adapter\n * \n * Implements the IndexStorage port using the filesystem.\n * Index data is stored as JSON files in the .raggrep directory.\n */\n\nimport type { IndexStorage } from '../../domain/ports';\nimport type { FileSystem } from '../../domain/ports';\nimport type { \n Config, \n FileIndex, \n ModuleManifest, \n GlobalManifest,\n FileSummary,\n SymbolicIndexMeta,\n Tier1Manifest \n} from '../../domain/entities';\nimport { createDefaultConfig } from '../../domain/entities';\n\n/**\n * Filesystem-based index storage.\n * \n * Structure:\n * .raggrep/\n * ├── config.json\n * ├── manifest.json (global)\n * └── index/\n * └── <moduleId>/\n * ├── manifest.json (module)\n * ├── symbolic/\n * │ ├── _meta.json (BM25 statistics)\n * │ └── <filepath>.json (per-file summaries)\n * └── <filepath>.json (file indexes with embeddings)\n */\nexport class FileIndexStorage implements IndexStorage {\n private fs: FileSystem;\n private rootDir: string;\n private indexDir: string;\n\n constructor(fs: FileSystem, rootDir: string, indexDir: string = '.raggrep') {\n this.fs = fs;\n this.rootDir = fs.resolve(rootDir);\n this.indexDir = indexDir;\n }\n\n // ============================================================================\n // Path Helpers\n // ============================================================================\n\n private getIndexPath(): string {\n return this.fs.join(this.rootDir, this.indexDir);\n }\n\n private getConfigPath(): string {\n return this.fs.join(this.getIndexPath(), 'config.json');\n }\n\n private getGlobalManifestPath(): string {\n return this.fs.join(this.getIndexPath(), 'manifest.json');\n }\n\n private getModuleIndexPath(moduleId: string): string {\n return this.fs.join(this.getIndexPath(), 'index', moduleId);\n }\n\n private getModuleManifestPath(moduleId: string): string {\n return this.fs.join(this.getModuleIndexPath(moduleId), 'manifest.json');\n }\n\n // Symbolic index paths\n private getSymbolicPath(moduleId: string): string {\n return this.fs.join(this.getModuleIndexPath(moduleId), 'symbolic');\n }\n\n private getSymbolicMetaPath(moduleId: string): string {\n return this.fs.join(this.getSymbolicPath(moduleId), '_meta.json');\n }\n\n private getSymbolicFilePath(moduleId: string, filepath: string): string {\n const jsonPath = filepath.replace(/\\.[^.]+$/, '.json');\n return this.fs.join(this.getSymbolicPath(moduleId), jsonPath);\n }\n\n // File index paths (embeddings)\n private getFileIndexPath(moduleId: string, filepath: string): string {\n const jsonPath = filepath.replace(/\\.[^.]+$/, '.json');\n return this.fs.join(this.getModuleIndexPath(moduleId), jsonPath);\n }\n\n /** @deprecated Use getSymbolicMetaPath instead */\n private getTier1Path(moduleId: string): string {\n return this.fs.join(this.getModuleIndexPath(moduleId), 'tier1.json');\n }\n\n // ============================================================================\n // Configuration\n // ============================================================================\n\n async loadConfig(): Promise<Config> {\n try {\n const content = await this.fs.readFile(this.getConfigPath());\n const savedConfig = JSON.parse(content) as Partial<Config>;\n return { ...createDefaultConfig(), ...savedConfig };\n } catch {\n return createDefaultConfig();\n }\n }\n\n async saveConfig(config: Config): Promise<void> {\n await this.fs.writeFile(this.getConfigPath(), JSON.stringify(config, null, 2));\n }\n\n // ============================================================================\n // Global Manifest\n // ============================================================================\n\n async loadGlobalManifest(): Promise<GlobalManifest | null> {\n try {\n const content = await this.fs.readFile(this.getGlobalManifestPath());\n return JSON.parse(content);\n } catch {\n return null;\n }\n }\n\n async saveGlobalManifest(manifest: GlobalManifest): Promise<void> {\n await this.fs.writeFile(this.getGlobalManifestPath(), JSON.stringify(manifest, null, 2));\n }\n\n // ============================================================================\n // Module Manifest\n // ============================================================================\n\n async loadModuleManifest(moduleId: string): Promise<ModuleManifest | null> {\n try {\n const content = await this.fs.readFile(this.getModuleManifestPath(moduleId));\n return JSON.parse(content);\n } catch {\n return null;\n }\n }\n\n async saveModuleManifest(moduleId: string, manifest: ModuleManifest): Promise<void> {\n await this.fs.writeFile(this.getModuleManifestPath(moduleId), JSON.stringify(manifest, null, 2));\n }\n\n // ============================================================================\n // Symbolic Index (lightweight file summaries for keyword search)\n // ============================================================================\n\n async loadSymbolicMeta(moduleId: string): Promise<SymbolicIndexMeta | null> {\n try {\n const content = await this.fs.readFile(this.getSymbolicMetaPath(moduleId));\n return JSON.parse(content);\n } catch {\n return null;\n }\n }\n\n async saveSymbolicMeta(moduleId: string, meta: SymbolicIndexMeta): Promise<void> {\n await this.fs.writeFile(this.getSymbolicMetaPath(moduleId), JSON.stringify(meta, null, 2));\n }\n\n async loadFileSummary(moduleId: string, filepath: string): Promise<FileSummary | null> {\n try {\n const content = await this.fs.readFile(this.getSymbolicFilePath(moduleId, filepath));\n return JSON.parse(content);\n } catch {\n return null;\n }\n }\n\n async saveFileSummary(moduleId: string, filepath: string, summary: FileSummary): Promise<void> {\n await this.fs.writeFile(this.getSymbolicFilePath(moduleId, filepath), JSON.stringify(summary, null, 2));\n }\n\n async deleteFileSummary(moduleId: string, filepath: string): Promise<void> {\n try {\n await this.fs.deleteFile(this.getSymbolicFilePath(moduleId, filepath));\n } catch {\n // Ignore if file doesn't exist\n }\n }\n\n /**\n * List all file summaries by reading the module manifest.\n * Returns filepaths relative to the project root.\n */\n async listFileSummaries(moduleId: string): Promise<string[]> {\n const manifest = await this.loadModuleManifest(moduleId);\n if (!manifest) {\n return [];\n }\n return Object.keys(manifest.files);\n }\n\n // ============================================================================\n // Tier 1 Index (deprecated - use Symbolic Index instead)\n // ============================================================================\n\n /** @deprecated Use loadSymbolicMeta and loadFileSummary instead */\n async loadTier1Index(moduleId: string): Promise<Tier1Manifest | null> {\n try {\n const content = await this.fs.readFile(this.getTier1Path(moduleId));\n return JSON.parse(content);\n } catch {\n return null;\n }\n }\n\n /** @deprecated Use saveSymbolicMeta and saveFileSummary instead */\n async saveTier1Index(moduleId: string, manifest: Tier1Manifest): Promise<void> {\n await this.fs.writeFile(this.getTier1Path(moduleId), JSON.stringify(manifest, null, 2));\n }\n\n // ============================================================================\n // File Indexes (full index with embeddings)\n // ============================================================================\n\n async loadFileIndex(moduleId: string, filepath: string): Promise<FileIndex | null> {\n try {\n const content = await this.fs.readFile(this.getFileIndexPath(moduleId, filepath));\n return JSON.parse(content);\n } catch {\n return null;\n }\n }\n\n async saveFileIndex(moduleId: string, filepath: string, index: FileIndex): Promise<void> {\n await this.fs.writeFile(this.getFileIndexPath(moduleId, filepath), JSON.stringify(index, null, 2));\n }\n\n async deleteFileIndex(moduleId: string, filepath: string): Promise<void> {\n await this.fs.deleteFile(this.getFileIndexPath(moduleId, filepath));\n }\n\n async listIndexedFiles(moduleId: string): Promise<string[]> {\n const manifest = await this.loadModuleManifest(moduleId);\n if (!manifest) {\n return [];\n }\n return Object.keys(manifest.files);\n }\n\n // ============================================================================\n // Utilities\n // ============================================================================\n\n async indexExists(): Promise<boolean> {\n return this.fs.exists(this.getIndexPath());\n }\n\n async deleteIndex(): Promise<void> {\n // Note: This is a simplified implementation\n // A full implementation would recursively delete the directory\n const indexPath = this.getIndexPath();\n if (await this.fs.exists(indexPath)) {\n // For safety, we don't implement recursive delete here\n throw new Error('deleteIndex not fully implemented - please delete .raggrep manually');\n }\n }\n\n getRootDir(): string {\n return this.rootDir;\n }\n}\n\n",
36
- "/**\n * Symbolic Index Storage\n *\n * Manages the keyword-based index for fast file filtering.\n * Handles file I/O for persisting index data.\n *\n * Structure:\n * .raggrep/index/<module>/symbolic/\n * ├── _meta.json (BM25 statistics)\n * └── <filepath>.json (per-file summaries)\n */\n\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport { BM25Index } from \"../../domain/services/bm25\";\nimport { extractPathKeywords } from \"../../domain/services/keywords\";\nimport type { FileSummary, SymbolicIndexMeta } from \"../../domain/entities\";\n\n/**\n * Symbolic Index Manager\n *\n * Manages the keyword-based index for fast file filtering.\n */\nexport class SymbolicIndex {\n private meta: SymbolicIndexMeta | null = null;\n private fileSummaries: Map<string, FileSummary> = new Map();\n private bm25Index: BM25Index | null = null;\n private symbolicPath: string;\n private moduleId: string;\n\n constructor(indexDir: string, moduleId: string) {\n this.symbolicPath = path.join(indexDir, \"index\", moduleId, \"symbolic\");\n this.moduleId = moduleId;\n }\n\n /**\n * Initialize or load the symbolic index\n */\n async initialize(): Promise<void> {\n try {\n await this.load();\n } catch {\n // Create empty metadata\n this.meta = {\n version: \"1.0.0\",\n lastUpdated: new Date().toISOString(),\n moduleId: this.moduleId,\n fileCount: 0,\n bm25Data: {\n avgDocLength: 0,\n documentFrequencies: {},\n totalDocs: 0,\n },\n };\n this.bm25Index = new BM25Index();\n }\n }\n\n /**\n * Add or update a file summary\n */\n addFile(summary: FileSummary): void {\n this.fileSummaries.set(summary.filepath, summary);\n }\n\n /**\n * Remove a file from the index\n */\n removeFile(filepath: string): boolean {\n return this.fileSummaries.delete(filepath);\n }\n\n /**\n * Build BM25 index from file summaries\n */\n buildBM25Index(): void {\n this.bm25Index = new BM25Index();\n\n // Add each file's keywords as a document\n for (const [filepath, summary] of this.fileSummaries) {\n const content = [\n ...summary.keywords,\n ...summary.exports,\n ...extractPathKeywords(filepath),\n ].join(\" \");\n\n this.bm25Index.addDocuments([{ id: filepath, content }]);\n }\n\n // Update metadata\n if (this.meta) {\n this.meta.fileCount = this.fileSummaries.size;\n this.meta.bm25Data.totalDocs = this.fileSummaries.size;\n }\n }\n\n /**\n * Find candidate files using BM25 keyword search\n */\n findCandidates(query: string, maxCandidates: number = 20): string[] {\n if (!this.bm25Index) {\n return Array.from(this.fileSummaries.keys());\n }\n\n const results = this.bm25Index.search(query, maxCandidates);\n return results.map((r) => r.id);\n }\n\n /**\n * Get all file paths in the index\n */\n getAllFiles(): string[] {\n return Array.from(this.fileSummaries.keys());\n }\n\n /**\n * Get summary for a specific file\n */\n getFileSummary(filepath: string): FileSummary | undefined {\n return this.fileSummaries.get(filepath);\n }\n\n /**\n * Save the index to disk (per-file structure)\n */\n async save(): Promise<void> {\n if (!this.meta) throw new Error(\"Index not initialized\");\n\n // Update metadata\n this.meta.lastUpdated = new Date().toISOString();\n this.meta.fileCount = this.fileSummaries.size;\n\n // Ensure symbolic directory exists\n await fs.mkdir(this.symbolicPath, { recursive: true });\n\n // Save metadata\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n await fs.writeFile(metaPath, JSON.stringify(this.meta, null, 2));\n\n // Save each file summary\n for (const [filepath, summary] of this.fileSummaries) {\n const summaryPath = this.getFileSummaryPath(filepath);\n await fs.mkdir(path.dirname(summaryPath), { recursive: true });\n await fs.writeFile(summaryPath, JSON.stringify(summary, null, 2));\n }\n }\n\n /**\n * Load the index from disk\n */\n async load(): Promise<void> {\n // Load metadata\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n const metaContent = await fs.readFile(metaPath, \"utf-8\");\n this.meta = JSON.parse(metaContent);\n\n // Load all file summaries by walking the symbolic directory\n this.fileSummaries.clear();\n await this.loadFileSummariesRecursive(this.symbolicPath);\n\n // Rebuild BM25 index\n this.buildBM25Index();\n }\n\n /**\n * Recursively load file summaries from the symbolic directory\n */\n private async loadFileSummariesRecursive(dir: string): Promise<void> {\n try {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n\n if (entry.isDirectory()) {\n await this.loadFileSummariesRecursive(fullPath);\n } else if (entry.name.endsWith(\".json\") && entry.name !== \"_meta.json\") {\n try {\n const content = await fs.readFile(fullPath, \"utf-8\");\n const summary = JSON.parse(content) as FileSummary;\n if (summary.filepath) {\n this.fileSummaries.set(summary.filepath, summary);\n }\n } catch {\n // Skip invalid files\n }\n }\n }\n } catch {\n // Directory doesn't exist yet\n }\n }\n\n /**\n * Get the path for a file summary\n */\n private getFileSummaryPath(filepath: string): string {\n const jsonPath = filepath.replace(/\\.[^.]+$/, \".json\");\n return path.join(this.symbolicPath, jsonPath);\n }\n\n /**\n * Delete a file summary from disk\n */\n async deleteFileSummary(filepath: string): Promise<void> {\n try {\n await fs.unlink(this.getFileSummaryPath(filepath));\n } catch {\n // Ignore if file doesn't exist\n }\n this.fileSummaries.delete(filepath);\n }\n\n /**\n * Check if the index exists on disk\n */\n async exists(): Promise<boolean> {\n try {\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n await fs.access(metaPath);\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Get the number of indexed files\n */\n get size(): number {\n return this.fileSummaries.size;\n }\n\n /**\n * Clear the index\n */\n clear(): void {\n this.fileSummaries.clear();\n if (this.meta) {\n this.meta.fileCount = 0;\n this.meta.bm25Data = {\n avgDocLength: 0,\n documentFrequencies: {},\n totalDocs: 0,\n };\n }\n this.bm25Index = new BM25Index();\n }\n}\n\n/**\n * Get the symbolic index path for a module\n */\nexport function getSymbolicPath(\n rootDir: string,\n moduleId: string,\n indexDir: string = \".raggrep\"\n): string {\n return path.join(rootDir, indexDir, \"index\", moduleId, \"symbolic\");\n}\n\n",
36
+ "/**\n * Symbolic Index Storage\n *\n * Manages the keyword-based index for fast file filtering.\n * Handles file I/O for persisting index data.\n *\n * Structure:\n * .raggrep/index/<module>/symbolic/\n * ├── _meta.json (BM25 statistics + serialized BM25 data)\n * └── <filepath>.json (per-file summaries)\n */\n\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport { BM25Index, tokenize } from \"../../domain/services/bm25\";\nimport { extractPathKeywords } from \"../../domain/services/keywords\";\nimport type { FileSummary, SymbolicIndexMeta } from \"../../domain/entities\";\n\n/**\n * Extended metadata that includes serialized BM25 index\n */\ninterface SymbolicIndexMetaWithBM25 extends SymbolicIndexMeta {\n /** Serialized BM25 index data for fast loading */\n bm25Serialized?: {\n documents: Record<string, string[]>;\n avgDocLength: number;\n documentFrequencies: Record<string, number>;\n totalDocs: number;\n };\n}\n\n/**\n * Symbolic Index Manager\n *\n * Manages the keyword-based index for fast file filtering.\n * Supports incremental updates to avoid full rebuilds.\n */\nexport class SymbolicIndex {\n private meta: SymbolicIndexMetaWithBM25 | null = null;\n private fileSummaries: Map<string, FileSummary> = new Map();\n private bm25Index: BM25Index | null = null;\n private symbolicPath: string;\n private moduleId: string;\n\n constructor(indexDir: string, moduleId: string) {\n this.symbolicPath = path.join(indexDir, \"index\", moduleId, \"symbolic\");\n this.moduleId = moduleId;\n }\n\n /**\n * Initialize or load the symbolic index\n */\n async initialize(): Promise<void> {\n try {\n await this.load();\n } catch {\n // Create empty metadata\n this.meta = {\n version: \"1.0.0\",\n lastUpdated: new Date().toISOString(),\n moduleId: this.moduleId,\n fileCount: 0,\n bm25Data: {\n avgDocLength: 0,\n documentFrequencies: {},\n totalDocs: 0,\n },\n };\n this.bm25Index = new BM25Index();\n }\n }\n\n /**\n * Add or update a file summary (for batch operations, use with buildBM25Index)\n */\n addFile(summary: FileSummary): void {\n this.fileSummaries.set(summary.filepath, summary);\n }\n\n /**\n * Add or update a file summary with incremental BM25 update.\n * Use this for incremental indexing instead of addFile + buildBM25Index.\n */\n addFileIncremental(summary: FileSummary): void {\n const filepath = summary.filepath;\n const oldSummary = this.fileSummaries.get(filepath);\n\n // Update the summary\n this.fileSummaries.set(filepath, summary);\n\n // Update BM25 incrementally\n if (this.bm25Index) {\n // If file existed before, remove its old BM25 entry\n if (oldSummary) {\n this.bm25Index.removeDocument(filepath);\n }\n\n // Add the new entry\n const tokens = this.getTokensForSummary(filepath, summary);\n this.bm25Index.addDocument(filepath, tokens);\n }\n }\n\n /**\n * Remove a file from the index (for batch operations)\n */\n removeFile(filepath: string): boolean {\n return this.fileSummaries.delete(filepath);\n }\n\n /**\n * Remove a file from the index with incremental BM25 update.\n * Use this for incremental indexing.\n */\n removeFileIncremental(filepath: string): boolean {\n const existed = this.fileSummaries.delete(filepath);\n\n // Update BM25 incrementally\n if (existed && this.bm25Index) {\n this.bm25Index.removeDocument(filepath);\n }\n\n return existed;\n }\n\n /**\n * Get tokens for a file summary (for BM25 indexing)\n */\n private getTokensForSummary(filepath: string, summary: FileSummary): string[] {\n const content = [\n ...summary.keywords,\n ...summary.exports,\n ...extractPathKeywords(filepath),\n ].join(\" \");\n return tokenize(content);\n }\n\n /**\n * Build BM25 index from file summaries (full rebuild)\n */\n buildBM25Index(): void {\n this.bm25Index = new BM25Index();\n\n // Add each file's keywords as a document\n for (const [filepath, summary] of this.fileSummaries) {\n const tokens = this.getTokensForSummary(filepath, summary);\n this.bm25Index.addDocument(filepath, tokens);\n }\n\n // Update metadata\n if (this.meta) {\n this.meta.fileCount = this.fileSummaries.size;\n this.meta.bm25Data.totalDocs = this.fileSummaries.size;\n }\n }\n\n /**\n * Find candidate files using BM25 keyword search\n */\n findCandidates(query: string, maxCandidates: number = 20): string[] {\n if (!this.bm25Index) {\n return Array.from(this.fileSummaries.keys());\n }\n\n const results = this.bm25Index.search(query, maxCandidates);\n return results.map((r) => r.id);\n }\n\n /**\n * Get all file paths in the index\n */\n getAllFiles(): string[] {\n return Array.from(this.fileSummaries.keys());\n }\n\n /**\n * Get summary for a specific file\n */\n getFileSummary(filepath: string): FileSummary | undefined {\n return this.fileSummaries.get(filepath);\n }\n\n /**\n * Save the index to disk (per-file structure with BM25 serialization)\n */\n async save(): Promise<void> {\n if (!this.meta) throw new Error(\"Index not initialized\");\n\n // Update metadata\n this.meta.lastUpdated = new Date().toISOString();\n this.meta.fileCount = this.fileSummaries.size;\n\n // Serialize BM25 index for fast loading\n if (this.bm25Index) {\n this.meta.bm25Serialized = this.bm25Index.serialize();\n }\n\n // Ensure symbolic directory exists\n await fs.mkdir(this.symbolicPath, { recursive: true });\n\n // Save metadata (includes serialized BM25)\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n await fs.writeFile(metaPath, JSON.stringify(this.meta, null, 2));\n\n // Save each file summary\n for (const [filepath, summary] of this.fileSummaries) {\n const summaryPath = this.getFileSummaryPath(filepath);\n await fs.mkdir(path.dirname(summaryPath), { recursive: true });\n await fs.writeFile(summaryPath, JSON.stringify(summary, null, 2));\n }\n }\n\n /**\n * Save only the updated file summaries (for incremental saves)\n * @param filepaths - List of filepaths that were updated\n */\n async saveIncremental(filepaths: string[]): Promise<void> {\n if (!this.meta) throw new Error(\"Index not initialized\");\n\n // Update metadata\n this.meta.lastUpdated = new Date().toISOString();\n this.meta.fileCount = this.fileSummaries.size;\n\n // Serialize BM25 index\n if (this.bm25Index) {\n this.meta.bm25Serialized = this.bm25Index.serialize();\n }\n\n // Ensure symbolic directory exists\n await fs.mkdir(this.symbolicPath, { recursive: true });\n\n // Save metadata (includes serialized BM25)\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n await fs.writeFile(metaPath, JSON.stringify(this.meta, null, 2));\n\n // Save only the updated file summaries\n for (const filepath of filepaths) {\n const summary = this.fileSummaries.get(filepath);\n if (summary) {\n const summaryPath = this.getFileSummaryPath(filepath);\n await fs.mkdir(path.dirname(summaryPath), { recursive: true });\n await fs.writeFile(summaryPath, JSON.stringify(summary, null, 2));\n }\n }\n }\n\n /**\n * Load the index from disk\n */\n async load(): Promise<void> {\n // Load metadata\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n const metaContent = await fs.readFile(metaPath, \"utf-8\");\n this.meta = JSON.parse(metaContent);\n\n // Load all file summaries by walking the symbolic directory\n this.fileSummaries.clear();\n await this.loadFileSummariesRecursive(this.symbolicPath);\n\n // Try to load BM25 from serialized data (fast path)\n if (this.meta?.bm25Serialized) {\n this.bm25Index = BM25Index.deserialize(this.meta.bm25Serialized);\n } else {\n // Fall back to rebuilding if no serialized data\n this.buildBM25Index();\n }\n }\n\n /**\n * Recursively load file summaries from the symbolic directory\n */\n private async loadFileSummariesRecursive(dir: string): Promise<void> {\n try {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n\n if (entry.isDirectory()) {\n await this.loadFileSummariesRecursive(fullPath);\n } else if (entry.name.endsWith(\".json\") && entry.name !== \"_meta.json\") {\n try {\n const content = await fs.readFile(fullPath, \"utf-8\");\n const summary = JSON.parse(content) as FileSummary;\n if (summary.filepath) {\n this.fileSummaries.set(summary.filepath, summary);\n }\n } catch {\n // Skip invalid files\n }\n }\n }\n } catch {\n // Directory doesn't exist yet\n }\n }\n\n /**\n * Get the path for a file summary\n */\n private getFileSummaryPath(filepath: string): string {\n const jsonPath = filepath.replace(/\\.[^.]+$/, \".json\");\n return path.join(this.symbolicPath, jsonPath);\n }\n\n /**\n * Delete a file summary from disk\n */\n async deleteFileSummary(filepath: string): Promise<void> {\n try {\n await fs.unlink(this.getFileSummaryPath(filepath));\n } catch {\n // Ignore if file doesn't exist\n }\n this.fileSummaries.delete(filepath);\n }\n\n /**\n * Check if the index exists on disk\n */\n async exists(): Promise<boolean> {\n try {\n const metaPath = path.join(this.symbolicPath, \"_meta.json\");\n await fs.access(metaPath);\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Get the number of indexed files\n */\n get size(): number {\n return this.fileSummaries.size;\n }\n\n /**\n * Clear the index\n */\n clear(): void {\n this.fileSummaries.clear();\n if (this.meta) {\n this.meta.fileCount = 0;\n this.meta.bm25Data = {\n avgDocLength: 0,\n documentFrequencies: {},\n totalDocs: 0,\n };\n }\n this.bm25Index = new BM25Index();\n }\n}\n\n/**\n * Get the symbolic index path for a module\n */\nexport function getSymbolicPath(\n rootDir: string,\n moduleId: string,\n indexDir: string = \".raggrep\"\n): string {\n return path.join(rootDir, indexDir, \"index\", moduleId, \"symbolic\");\n}\n\n",
37
37
  "/**\n * Literal Index Storage\n *\n * Manages the literal index for exact-match boosting.\n * Handles file I/O for persisting literal data.\n *\n * Structure:\n * .raggrep/index/<module>/literals/\n * └── _index.json (literal → chunk mappings)\n */\n\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport type {\n ExtractedLiteral,\n DetectedLiteral,\n LiteralMatch,\n LiteralIndexData,\n LiteralIndexEntry,\n LiteralType,\n LiteralMatchType,\n} from \"../../domain/entities/literal\";\n\n/**\n * Literal Index Manager\n *\n * Manages the literal index for exact-match boosting.\n * Provides O(1) lookup for literal matches.\n */\nexport class LiteralIndex {\n private indexPath: string;\n private moduleId: string;\n\n /**\n * In-memory index: lowercase literal value → entries\n */\n private entries: Map<string, LiteralIndexEntry[]> = new Map();\n\n /**\n * Schema version for compatibility checking.\n */\n private static readonly VERSION = \"1.0.0\";\n\n constructor(indexDir: string, moduleId: string) {\n this.indexPath = path.join(indexDir, \"index\", moduleId, \"literals\");\n this.moduleId = moduleId;\n }\n\n /**\n * Initialize the literal index.\n * Attempts to load from disk, creates empty index if not found.\n */\n async initialize(): Promise<void> {\n try {\n await this.load();\n } catch {\n // Create empty index\n this.entries = new Map();\n }\n }\n\n /**\n * Add literals from a chunk to the index.\n *\n * @param chunkId - Unique identifier for the chunk\n * @param filepath - Path to the file containing the chunk\n * @param literals - Extracted literals from the chunk\n */\n addLiterals(\n chunkId: string,\n filepath: string,\n literals: ExtractedLiteral[]\n ): void {\n for (const literal of literals) {\n const key = literal.value.toLowerCase();\n const existingEntries = this.entries.get(key) || [];\n\n // Check if this chunk already has an entry for this literal\n const existingIndex = existingEntries.findIndex(\n (e) => e.chunkId === chunkId\n );\n\n const newEntry: LiteralIndexEntry = {\n chunkId,\n filepath,\n originalCasing: literal.value,\n type: literal.type,\n matchType: literal.matchType,\n };\n\n if (existingIndex >= 0) {\n // Update existing entry (prefer definition over reference)\n const existing = existingEntries[existingIndex];\n if (shouldReplaceMatchType(existing.matchType, literal.matchType)) {\n existingEntries[existingIndex] = newEntry;\n }\n } else {\n existingEntries.push(newEntry);\n }\n\n this.entries.set(key, existingEntries);\n }\n }\n\n /**\n * Remove all literals for a chunk.\n *\n * @param chunkId - Chunk ID to remove\n */\n removeChunk(chunkId: string): void {\n for (const [key, entries] of this.entries) {\n const filtered = entries.filter((e) => e.chunkId !== chunkId);\n if (filtered.length === 0) {\n this.entries.delete(key);\n } else if (filtered.length !== entries.length) {\n this.entries.set(key, filtered);\n }\n }\n }\n\n /**\n * Remove all literals for a file.\n * Used when a file is re-indexed or deleted.\n *\n * @param filepath - Filepath to remove all literals for\n * @returns Number of literals removed\n */\n removeFile(filepath: string): number {\n let removed = 0;\n for (const [key, entries] of this.entries) {\n const filtered = entries.filter((e) => e.filepath !== filepath);\n const removedCount = entries.length - filtered.length;\n if (removedCount > 0) {\n removed += removedCount;\n if (filtered.length === 0) {\n this.entries.delete(key);\n } else {\n this.entries.set(key, filtered);\n }\n }\n }\n return removed;\n }\n\n /**\n * Find matches for query literals.\n *\n * @param queryLiterals - Literals detected in the query\n * @returns Array of matches with chunk IDs and filepaths\n */\n findMatches(queryLiterals: DetectedLiteral[]): LiteralMatch[] {\n const matches: LiteralMatch[] = [];\n\n for (const queryLiteral of queryLiterals) {\n const key = queryLiteral.value.toLowerCase();\n const entries = this.entries.get(key);\n\n if (!entries) {\n continue;\n }\n\n for (const entry of entries) {\n const exactMatch = entry.originalCasing === queryLiteral.value;\n\n matches.push({\n queryLiteral,\n indexedLiteral: {\n value: entry.originalCasing,\n type: entry.type,\n matchType: entry.matchType,\n },\n chunkId: entry.chunkId,\n filepath: entry.filepath,\n exactMatch,\n });\n }\n }\n\n return matches;\n }\n\n /**\n * Get all chunk IDs that contain a specific literal.\n *\n * @param literal - The literal value to search for\n * @returns Array of chunk IDs\n */\n getChunksForLiteral(literal: string): string[] {\n const key = literal.toLowerCase();\n const entries = this.entries.get(key);\n return entries ? entries.map((e) => e.chunkId) : [];\n }\n\n /**\n * Save the index to disk.\n */\n async save(): Promise<void> {\n // Ensure directory exists\n await fs.mkdir(this.indexPath, { recursive: true });\n\n // Convert Map to serializable format\n const data: LiteralIndexData = {\n version: LiteralIndex.VERSION,\n entries: Object.fromEntries(this.entries),\n };\n\n const indexFile = path.join(this.indexPath, \"_index.json\");\n await fs.writeFile(indexFile, JSON.stringify(data, null, 2));\n }\n\n /**\n * Load the index from disk.\n */\n async load(): Promise<void> {\n const indexFile = path.join(this.indexPath, \"_index.json\");\n const content = await fs.readFile(indexFile, \"utf-8\");\n const data: LiteralIndexData = JSON.parse(content);\n\n // Version check\n if (data.version !== LiteralIndex.VERSION) {\n console.warn(\n `Literal index version mismatch: expected ${LiteralIndex.VERSION}, got ${data.version}`\n );\n }\n\n // Convert back to Map\n this.entries = new Map(Object.entries(data.entries));\n }\n\n /**\n * Check if the index exists on disk.\n */\n async exists(): Promise<boolean> {\n try {\n const indexFile = path.join(this.indexPath, \"_index.json\");\n await fs.access(indexFile);\n return true;\n } catch {\n return false;\n }\n }\n\n /**\n * Clear the index.\n */\n clear(): void {\n this.entries.clear();\n }\n\n /**\n * Get the number of unique literals in the index.\n */\n get size(): number {\n return this.entries.size;\n }\n\n /**\n * Get the total number of literal-to-chunk mappings.\n */\n get totalMappings(): number {\n let count = 0;\n for (const entries of this.entries.values()) {\n count += entries.length;\n }\n return count;\n }\n\n /**\n * Get all unique literals in the index.\n */\n getAllLiterals(): string[] {\n return Array.from(this.entries.keys());\n }\n\n /**\n * Build a map from chunk ID to literal matches for a set of query literals.\n * Convenience method for search integration.\n *\n * @param queryLiterals - Literals detected in the query\n * @returns Map from chunk ID to array of matches\n */\n buildMatchMap(queryLiterals: DetectedLiteral[]): Map<string, LiteralMatch[]> {\n const matches = this.findMatches(queryLiterals);\n const matchMap = new Map<string, LiteralMatch[]>();\n\n for (const match of matches) {\n const existing = matchMap.get(match.chunkId) || [];\n existing.push(match);\n matchMap.set(match.chunkId, existing);\n }\n\n return matchMap;\n }\n}\n\n/**\n * Determine if we should replace an existing match type with a new one.\n * Priority: definition > reference > import\n */\nfunction shouldReplaceMatchType(\n existing: LiteralMatchType,\n incoming: LiteralMatchType\n): boolean {\n const priority: Record<LiteralMatchType, number> = {\n definition: 3,\n reference: 2,\n import: 1,\n };\n return priority[incoming] > priority[existing];\n}\n\n/**\n * Get the literal index path for a module.\n */\nexport function getLiteralIndexPath(\n rootDir: string,\n moduleId: string,\n indexDir: string = \".raggrep\"\n): string {\n return path.join(rootDir, indexDir, \"index\", moduleId, \"literals\");\n}\n",
38
38
  "/**\n * Storage Infrastructure\n *\n * Handles persistence of index data to the filesystem.\n */\n\nexport { FileIndexStorage } from \"./fileIndexStorage\";\nexport { SymbolicIndex, getSymbolicPath } from \"./symbolicIndex\";\nexport { LiteralIndex, getLiteralIndexPath } from \"./literalIndex\";\n",
39
- "/**\n * TypeScript/JavaScript Language Index Module\n *\n * Provides TypeScript/JavaScript-aware code search using:\n * - AST parsing via TypeScript Compiler API\n * - Local text embeddings for semantic similarity\n * - BM25 keyword matching for fast filtering\n *\n * Supported file types: .ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts\n *\n * Index location: .raggrep/index/language/typescript/\n */\n\nimport * as path from \"path\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n ChunkType,\n} from \"../../../types\";\nimport {\n getEmbeddings,\n getEmbedding,\n configureEmbeddings,\n getEmbeddingConfig,\n} from \"../../../infrastructure/embeddings\";\nimport {\n cosineSimilarity,\n BM25Index,\n normalizeScore,\n extractKeywords,\n parsePathContext,\n formatPathContextForEmbedding,\n calculateFileTypeBoost,\n extractQueryTerms,\n // Literal boosting\n parseQueryLiterals,\n extractLiterals,\n calculateLiteralContribution,\n applyLiteralBoost,\n LITERAL_SCORING_CONSTANTS,\n // Structured Semantic Expansion\n expandQuery,\n} from \"../../../domain/services\";\nimport {\n getEmbeddingConfigFromModule,\n getRaggrepDir,\n} from \"../../../infrastructure/config\";\nimport { parseTypeScriptCode, generateChunkId } from \"./parseCode\";\nimport { SymbolicIndex, LiteralIndex } from \"../../../infrastructure/storage\";\nimport type { EmbeddingConfig, Logger } from \"../../../domain/ports\";\nimport type {\n FileSummary,\n ExtractedLiteral,\n LiteralMatch,\n} from \"../../../domain/entities\";\n\n/** Default minimum similarity score for search results */\nexport const DEFAULT_MIN_SCORE = 0.15;\n\n/** Default number of results to return */\nexport const DEFAULT_TOP_K = 10;\n\n/** Weight for semantic similarity in hybrid scoring (0-1) */\nconst SEMANTIC_WEIGHT = 0.7;\n\n/** Weight for BM25 keyword matching in hybrid scoring (0-1) */\nconst BM25_WEIGHT = 0.3;\n\n/** File extensions supported by this module */\nexport const TYPESCRIPT_EXTENSIONS = [\n \".ts\",\n \".tsx\",\n \".js\",\n \".jsx\",\n \".mjs\",\n \".cjs\",\n \".mts\",\n \".cts\",\n];\n\n/**\n * Check if a file is supported by this module.\n */\nexport function isTypeScriptFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return TYPESCRIPT_EXTENSIONS.includes(ext);\n}\n\n// Re-export for module interface\nexport const supportsFile = isTypeScriptFile;\n\n/**\n * Calculate boost based on chunk type.\n * Function/class/interface chunks rank higher than generic blocks.\n */\nfunction calculateChunkTypeBoost(chunk: Chunk): number {\n switch (chunk.type) {\n case \"function\":\n return 0.05;\n case \"class\":\n case \"interface\":\n return 0.04;\n case \"type\":\n case \"enum\":\n return 0.03;\n case \"variable\":\n return 0.02;\n case \"file\":\n case \"block\":\n default:\n return 0;\n }\n}\n\n/**\n * Calculate boost for exported symbols.\n * Public APIs are more likely to be what users are searching for.\n */\nfunction calculateExportBoost(chunk: Chunk): number {\n return chunk.isExported ? 0.03 : 0;\n}\n\n/**\n * Module-specific data stored alongside file index\n */\nexport interface SemanticModuleData {\n embeddings: number[][];\n /** Store the model used for these embeddings for compatibility checking */\n embeddingModel: string;\n [key: string]: unknown; // Index signature for compatibility with Record<string, unknown>\n}\n\nexport class TypeScriptModule implements IndexModule {\n readonly id = \"language/typescript\";\n readonly name = \"TypeScript Search\";\n readonly description =\n \"TypeScript-aware code search with AST parsing and semantic embeddings\";\n readonly version = \"1.0.0\";\n\n supportsFile(filepath: string): boolean {\n return isTypeScriptFile(filepath);\n }\n\n private embeddingConfig: EmbeddingConfig | null = null;\n private symbolicIndex: SymbolicIndex | null = null;\n private literalIndex: LiteralIndex | null = null;\n private pendingSummaries: Map<string, FileSummary> = new Map();\n /** Map from chunkId → { filepath, literals } for building literal index */\n private pendingLiterals: Map<\n string,\n { filepath: string; literals: ExtractedLiteral[] }\n > = new Map();\n private rootDir: string = \"\";\n private logger: Logger | undefined = undefined;\n\n async initialize(config: ModuleConfig): Promise<void> {\n // Extract embedding config from module options\n this.embeddingConfig = getEmbeddingConfigFromModule(config);\n\n // Extract logger from module options (passed from indexer)\n this.logger = config.options?.logger as Logger | undefined;\n\n // Add logger to embedding config\n if (this.logger) {\n this.embeddingConfig = {\n ...this.embeddingConfig,\n logger: this.logger,\n };\n }\n\n // Configure the embedding provider\n configureEmbeddings(this.embeddingConfig);\n\n // Clear pending data for fresh indexing\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n // Only process TypeScript/JavaScript files\n if (!isTypeScriptFile(filepath)) {\n return null;\n }\n\n // Store rootDir for finalize\n this.rootDir = ctx.rootDir;\n\n // Parse code into chunks using TypeScript AST\n const parsedChunks = parseTypeScriptCode(content, filepath);\n\n if (parsedChunks.length === 0) {\n return null;\n }\n\n // Parse path context for structural awareness\n const pathContext = parsePathContext(filepath);\n const pathPrefix = formatPathContextForEmbedding(pathContext);\n\n // Generate embeddings for all chunks with path context\n // Prepending path context helps the embedding model understand file structure\n const chunkContents = parsedChunks.map((c) => {\n // For named chunks, include the name for better embedding\n const namePrefix = c.name ? `${c.name}: ` : \"\";\n return `${pathPrefix} ${namePrefix}${c.content}`;\n });\n const embeddings = await getEmbeddings(chunkContents);\n\n // Create chunks with all metadata\n const chunks: Chunk[] = parsedChunks.map((pc) => ({\n id: generateChunkId(filepath, pc.startLine, pc.endLine),\n content: pc.content,\n startLine: pc.startLine,\n endLine: pc.endLine,\n type: pc.type,\n name: pc.name,\n isExported: pc.isExported,\n jsDoc: pc.jsDoc,\n }));\n\n // Extract references (imports)\n const references = this.extractReferences(content, filepath);\n\n const stats = await ctx.getFileStats(filepath);\n const currentConfig = getEmbeddingConfig();\n\n const moduleData: SemanticModuleData = {\n embeddings,\n embeddingModel: currentConfig.model,\n };\n\n // Build Tier 1 summary for this file\n const chunkTypes = [\n ...new Set(parsedChunks.map((pc) => pc.type)),\n ] as ChunkType[];\n const exports = parsedChunks\n .filter((pc) => pc.isExported && pc.name)\n .map((pc) => pc.name!);\n\n // Extract keywords from all chunks + path keywords\n const allKeywords = new Set<string>();\n for (const pc of parsedChunks) {\n const keywords = extractKeywords(pc.content, pc.name);\n keywords.forEach((k) => allKeywords.add(k));\n }\n // Add path keywords\n pathContext.keywords.forEach((k) => allKeywords.add(k));\n\n const fileSummary: FileSummary = {\n filepath,\n chunkCount: chunks.length,\n chunkTypes,\n keywords: Array.from(allKeywords),\n exports,\n lastModified: stats.lastModified,\n // Include parsed path context for search boosting\n pathContext: {\n segments: pathContext.segments,\n layer: pathContext.layer,\n domain: pathContext.domain,\n depth: pathContext.depth,\n },\n };\n\n // Store summary for finalize\n this.pendingSummaries.set(filepath, fileSummary);\n\n // Extract literals from each chunk for literal boosting\n for (const chunk of chunks) {\n const literals = extractLiterals(chunk);\n if (literals.length > 0) {\n const existing = this.pendingLiterals.get(chunk.id);\n if (existing) {\n existing.literals.push(...literals);\n } else {\n this.pendingLiterals.set(chunk.id, { filepath, literals });\n }\n }\n }\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n references,\n };\n }\n\n /**\n * Finalize indexing by building and saving the symbolic and literal indexes\n */\n async finalize(ctx: IndexContext): Promise<void> {\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Initialize symbolic index\n this.symbolicIndex = new SymbolicIndex(indexDir, this.id);\n await this.symbolicIndex.initialize();\n\n // Add all pending summaries\n for (const [filepath, summary] of this.pendingSummaries) {\n this.symbolicIndex.addFile(summary);\n }\n\n // Build BM25 index from summaries\n this.symbolicIndex.buildBM25Index();\n\n // Save to disk (creates symbolic/ folder with per-file summaries)\n await this.symbolicIndex.save();\n\n // Initialize and build literal index\n this.literalIndex = new LiteralIndex(indexDir, this.id);\n await this.literalIndex.initialize();\n\n // Get all filepaths that were indexed in this run\n // (both from summaries for any indexed files and from literals for chunks with names)\n const indexedFilepaths = new Set<string>();\n for (const filepath of this.pendingSummaries.keys()) {\n indexedFilepaths.add(filepath);\n }\n for (const { filepath } of this.pendingLiterals.values()) {\n indexedFilepaths.add(filepath);\n }\n\n // Remove old literals for all files that were re-indexed\n // This ensures stale literals (from renamed/deleted functions) are removed\n for (const filepath of indexedFilepaths) {\n this.literalIndex.removeFile(filepath);\n }\n\n // Add all pending literals (fresh data from this indexing run)\n for (const [chunkId, { filepath, literals }] of this.pendingLiterals) {\n this.literalIndex.addLiterals(chunkId, filepath, literals);\n }\n\n // Save literal index to disk\n await this.literalIndex.save();\n\n // Clear pending data\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n /**\n * Search the semantic index for chunks matching the query.\n *\n * Uses a three-source approach:\n * 1. Semantic search with embeddings\n * 2. BM25 keyword search\n * 3. Literal index for exact-match boosting\n *\n * @param query - Natural language search query\n * @param ctx - Search context with index access\n * @param options - Search options (topK, minScore, filePatterns)\n * @returns Array of search results sorted by relevance\n */\n async search(\n query: string,\n ctx: SearchContext,\n options: SearchOptions = {}\n ): Promise<SearchResult[]> {\n const {\n topK = DEFAULT_TOP_K,\n minScore = DEFAULT_MIN_SCORE,\n filePatterns,\n } = options;\n\n // Parse query for literals (explicit backticks/quotes and implicit casing)\n const { literals: queryLiterals, remainingQuery } =\n parseQueryLiterals(query);\n\n // Load symbolic index for BM25 scoring (not filtering)\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n const symbolicIndex = new SymbolicIndex(indexDir, this.id);\n\n // Load literal index for exact-match boosting\n const literalIndex = new LiteralIndex(indexDir, this.id);\n let literalMatchMap = new Map<string, LiteralMatch[]>();\n\n try {\n await literalIndex.initialize();\n literalMatchMap = literalIndex.buildMatchMap(queryLiterals);\n } catch {\n // Literal index doesn't exist yet, continue without it\n }\n\n // Get ALL indexed files - semantic search needs to check all embeddings\n // BM25 contributes to the hybrid score but doesn't filter candidates\n let allFiles: string[];\n\n try {\n await symbolicIndex.initialize();\n allFiles = symbolicIndex.getAllFiles();\n } catch {\n // Symbolic index doesn't exist, fall back to loading all files\n allFiles = await ctx.listIndexedFiles();\n }\n\n // Apply file pattern filter if specified\n let filesToSearch = allFiles;\n if (filePatterns && filePatterns.length > 0) {\n filesToSearch = allFiles.filter((filepath) => {\n return filePatterns.some((pattern) => {\n if (pattern.startsWith(\"*.\")) {\n const ext = pattern.slice(1);\n return filepath.endsWith(ext);\n }\n return filepath.includes(pattern);\n });\n });\n }\n\n // Get query embedding for semantic search\n // Use remaining query (without explicit literals) for semantic search\n const semanticQuery = remainingQuery.trim() || query; // Fall back to full query if empty\n\n // Apply Structured Semantic Expansion to broaden search recall\n // This adds domain-specific synonyms (function → method, auth → authentication, etc.)\n // Use conservative settings: no weak synonyms, limited max terms\n const expandedQuery = expandQuery(semanticQuery, undefined, {\n maxDepth: 1,\n includeWeak: false, // Only strong and moderate synonyms\n maxTerms: 10, // Conservative limit to avoid diluting specificity\n });\n\n // Use expanded query for embedding to improve semantic recall\n const queryEmbedding = await getEmbedding(\n expandedQuery.expandedQueryString\n );\n\n // Load all indexed files and compute scores\n // BM25 is used for keyword scoring, not filtering\n const bm25Index = new BM25Index();\n const allChunksData: Array<{\n filepath: string;\n chunk: Chunk;\n embedding: number[];\n }> = [];\n\n for (const filepath of filesToSearch) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const moduleData = fileIndex.moduleData as unknown as SemanticModuleData;\n if (!moduleData?.embeddings) continue;\n\n for (let i = 0; i < fileIndex.chunks.length; i++) {\n const chunk = fileIndex.chunks[i];\n const embedding = moduleData.embeddings[i];\n\n if (!embedding) continue;\n\n allChunksData.push({\n filepath: fileIndex.filepath,\n chunk,\n embedding,\n });\n\n // Add to BM25 index for chunk-level keyword matching\n bm25Index.addDocuments([{ id: chunk.id, content: chunk.content }]);\n }\n }\n\n // Perform BM25 search at chunk level (use full query for BM25)\n const bm25Results = bm25Index.search(query, topK * 3);\n const bm25Scores = new Map<string, number>();\n\n for (const result of bm25Results) {\n bm25Scores.set(result.id, normalizeScore(result.score, 3));\n }\n\n // Extract query terms for path matching and intent detection\n const queryTerms = extractQueryTerms(query);\n\n // Build path boost map from file summaries\n const pathBoosts = new Map<string, number>();\n for (const filepath of filesToSearch) {\n const summary = symbolicIndex.getFileSummary(filepath);\n if (summary?.pathContext) {\n let boost = 0;\n const pathCtx = summary.pathContext;\n\n // Check if query terms match domain\n if (\n pathCtx.domain &&\n queryTerms.some(\n (t) => pathCtx.domain!.includes(t) || t.includes(pathCtx.domain!)\n )\n ) {\n boost += 0.1;\n }\n\n // Check if query terms match layer\n if (\n pathCtx.layer &&\n queryTerms.some(\n (t) => pathCtx.layer!.includes(t) || t.includes(pathCtx.layer!)\n )\n ) {\n boost += 0.05;\n }\n\n // Check if query terms match path segments\n const segmentMatch = pathCtx.segments.some((seg) =>\n queryTerms.some(\n (t) =>\n seg.toLowerCase().includes(t) || t.includes(seg.toLowerCase())\n )\n );\n if (segmentMatch) {\n boost += 0.05;\n }\n\n pathBoosts.set(filepath, boost);\n }\n }\n\n // Calculate hybrid scores for all chunks\n const results: SearchResult[] = [];\n const processedChunkIds = new Set<string>();\n\n for (const { filepath, chunk, embedding } of allChunksData) {\n const semanticScore = cosineSimilarity(queryEmbedding, embedding);\n const bm25Score = bm25Scores.get(chunk.id) || 0;\n const pathBoost = pathBoosts.get(filepath) || 0;\n\n // Additional boosts for ranking improvement\n const fileTypeBoost = calculateFileTypeBoost(filepath, queryTerms);\n const chunkTypeBoost = calculateChunkTypeBoost(chunk);\n const exportBoost = calculateExportBoost(chunk);\n const additiveBoost =\n pathBoost + fileTypeBoost + chunkTypeBoost + exportBoost;\n\n // Base hybrid score: weighted combination of semantic and BM25\n const baseScore =\n SEMANTIC_WEIGHT * semanticScore + BM25_WEIGHT * bm25Score;\n\n // Apply literal boosting (multiplicative)\n const literalMatches = literalMatchMap.get(chunk.id) || [];\n const literalContribution = calculateLiteralContribution(\n literalMatches,\n true // hasSemanticOrBm25\n );\n const boostedScore = applyLiteralBoost(baseScore, literalMatches, true);\n\n // Final score = boosted base score + additive boosts\n const finalScore = boostedScore + additiveBoost;\n\n processedChunkIds.add(chunk.id);\n\n if (\n finalScore >= minScore ||\n bm25Score > 0.3 ||\n literalMatches.length > 0\n ) {\n results.push({\n filepath,\n chunk,\n score: finalScore,\n moduleId: this.id,\n context: {\n semanticScore,\n bm25Score,\n pathBoost,\n fileTypeBoost,\n chunkTypeBoost,\n exportBoost,\n // Literal boosting context\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n // Semantic expansion context\n synonymsUsed: expandedQuery.wasExpanded\n ? expandedQuery.expandedTerms\n .filter((t) => t.source !== \"original\")\n .map((t) => t.term)\n : undefined,\n },\n });\n }\n }\n\n // Add literal-only results (chunks found by literal index but not loaded above)\n // This ensures exact matches always surface even if they weren't in the search scope\n const literalOnlyFiles = new Map<string, LiteralMatch[]>();\n\n // Group unprocessed literal matches by filepath\n for (const [chunkId, matches] of literalMatchMap) {\n if (processedChunkIds.has(chunkId)) {\n continue;\n }\n\n // Get filepath from the first match (all matches for same chunkId have same filepath)\n const filepath = matches[0]?.filepath;\n if (!filepath) continue;\n\n const existing = literalOnlyFiles.get(filepath) || [];\n existing.push(...matches);\n literalOnlyFiles.set(filepath, existing);\n }\n\n // Load and score literal-only chunks\n for (const [filepath, matches] of literalOnlyFiles) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const moduleData = fileIndex.moduleData as unknown as SemanticModuleData;\n\n // Group matches by chunkId for this file\n const chunkMatches = new Map<string, LiteralMatch[]>();\n for (const match of matches) {\n const existing = chunkMatches.get(match.chunkId) || [];\n existing.push(match);\n chunkMatches.set(match.chunkId, existing);\n }\n\n // Find and score each matched chunk\n for (const [chunkId, chunkLiteralMatches] of chunkMatches) {\n if (processedChunkIds.has(chunkId)) continue;\n\n const chunkIndex = fileIndex.chunks.findIndex((c) => c.id === chunkId);\n if (chunkIndex === -1) continue;\n\n const chunk = fileIndex.chunks[chunkIndex];\n const embedding = moduleData?.embeddings?.[chunkIndex];\n\n // Calculate semantic score if embedding available\n let semanticScore = 0;\n if (embedding) {\n semanticScore = cosineSimilarity(queryEmbedding, embedding);\n }\n\n // BM25 score (chunk wasn't in our search, so typically 0)\n const bm25Score = bm25Scores.get(chunkId) || 0;\n\n // Additional boosts\n const pathBoost = pathBoosts.get(filepath) || 0;\n const fileTypeBoost = calculateFileTypeBoost(filepath, queryTerms);\n const chunkTypeBoost = calculateChunkTypeBoost(chunk);\n const exportBoost = calculateExportBoost(chunk);\n const additiveBoost =\n pathBoost + fileTypeBoost + chunkTypeBoost + exportBoost;\n\n // For literal-only results, use literal scoring\n const literalContribution = calculateLiteralContribution(\n chunkLiteralMatches,\n false // hasSemanticOrBm25 = false (literal-only)\n );\n\n // Use LITERAL_SCORING_CONSTANTS.BASE_SCORE as base for literal-only\n const baseScore =\n semanticScore > 0\n ? SEMANTIC_WEIGHT * semanticScore + BM25_WEIGHT * bm25Score\n : LITERAL_SCORING_CONSTANTS.BASE_SCORE;\n\n const boostedScore = applyLiteralBoost(\n baseScore,\n chunkLiteralMatches,\n semanticScore > 0\n );\n const finalScore = boostedScore + additiveBoost;\n\n processedChunkIds.add(chunkId);\n\n results.push({\n filepath,\n chunk,\n score: finalScore,\n moduleId: this.id,\n context: {\n semanticScore,\n bm25Score,\n pathBoost,\n fileTypeBoost,\n chunkTypeBoost,\n exportBoost,\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n literalOnly: true, // Mark as literal-only result\n },\n });\n }\n }\n\n // Sort by score descending and take top K\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n\n private extractReferences(content: string, filepath: string): string[] {\n const references: string[] = [];\n\n // Extract import statements\n const importRegex = /import\\s+.*?\\s+from\\s+['\"]([^'\"]+)['\"]/g;\n const requireRegex = /require\\s*\\(\\s*['\"]([^'\"]+)['\"]\\s*\\)/g;\n\n let match;\n while ((match = importRegex.exec(content)) !== null) {\n const importPath = match[1];\n if (importPath.startsWith(\".\")) {\n const dir = path.dirname(filepath);\n const resolved = path.normalize(path.join(dir, importPath));\n references.push(resolved);\n }\n }\n\n while ((match = requireRegex.exec(content)) !== null) {\n const importPath = match[1];\n if (importPath.startsWith(\".\")) {\n const dir = path.dirname(filepath);\n const resolved = path.normalize(path.join(dir, importPath));\n references.push(resolved);\n }\n }\n\n return references;\n }\n}\n",
40
- "/**\n * JSON Data Index Module\n *\n * Provides JSON file search using:\n * - Literal indexing of dot-notation key paths (e.g., \"package.dependencies.react\")\n * - BM25 keyword matching for fuzzy search\n *\n * Note: This module uses literal-only indexing (no embeddings) for fast indexing.\n * JSON keys are indexed as dot-notation paths prefixed with the filename.\n *\n * Supported file types: .json\n *\n * Index location: .raggrep/index/data/json/\n */\n\nimport * as path from \"path\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n} from \"../../../types\";\nimport {\n BM25Index,\n normalizeScore,\n generateChunkId,\n // Literal boosting\n parseQueryLiterals,\n calculateLiteralContribution,\n applyLiteralBoost,\n LITERAL_SCORING_CONSTANTS,\n // JSON path extraction\n extractJsonPaths,\n extractJsonKeywords,\n} from \"../../../domain/services\";\nimport { getRaggrepDir } from \"../../../infrastructure/config\";\nimport { SymbolicIndex, LiteralIndex } from \"../../../infrastructure/storage\";\nimport type { Logger } from \"../../../domain/ports\";\nimport type {\n FileSummary,\n ExtractedLiteral,\n LiteralMatch,\n} from \"../../../domain/entities\";\n\n/** Default minimum similarity score for search results */\nexport const DEFAULT_MIN_SCORE = 0.1;\n\n/** Default number of results to return */\nexport const DEFAULT_TOP_K = 10;\n\n/** Weight for BM25 keyword matching in scoring */\nconst BM25_WEIGHT = 0.4;\n\n/** Weight for literal matching in scoring */\nconst LITERAL_WEIGHT = 0.6;\n\n/** File extensions supported by this module */\nexport const JSON_EXTENSIONS = [\".json\"];\n\n/**\n * Check if a file is supported by this module.\n */\nexport function isJsonFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return JSON_EXTENSIONS.includes(ext);\n}\n\n// Re-export for module interface\nexport const supportsFile = isJsonFile;\n\n/**\n * Module-specific data stored alongside file index\n */\nexport interface JsonModuleData {\n /** Dot-notation paths extracted from the JSON file */\n jsonPaths: string[];\n [key: string]: unknown;\n}\n\nexport class JsonModule implements IndexModule {\n readonly id = \"data/json\";\n readonly name = \"JSON Search\";\n readonly description =\n \"JSON file search with literal-based key path indexing\";\n readonly version = \"2.0.0\"; // Bumped for literal-only mode\n\n supportsFile(filepath: string): boolean {\n return isJsonFile(filepath);\n }\n\n private symbolicIndex: SymbolicIndex | null = null;\n private literalIndex: LiteralIndex | null = null;\n private pendingSummaries: Map<string, FileSummary> = new Map();\n /** Map from chunkId → { filepath, literals } for building literal index */\n private pendingLiterals: Map<\n string,\n { filepath: string; literals: ExtractedLiteral[] }\n > = new Map();\n private rootDir: string = \"\";\n private logger: Logger | undefined = undefined;\n\n async initialize(config: ModuleConfig): Promise<void> {\n this.logger = config.options?.logger as Logger | undefined;\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n // Only process JSON files\n if (!isJsonFile(filepath)) {\n return null;\n }\n\n this.rootDir = ctx.rootDir;\n\n // Parse JSON content\n let parsed: unknown;\n try {\n parsed = JSON.parse(content);\n } catch {\n // Invalid JSON, skip indexing\n return null;\n }\n\n // Get filename without extension for path prefix\n const fileBasename = path.basename(filepath, path.extname(filepath));\n\n // Extract dot-notation paths as literals\n const jsonPathLiterals = extractJsonPaths(parsed, fileBasename);\n\n // Count lines for chunk metadata\n const lines = content.split(\"\\n\");\n const lineCount = lines.length;\n\n // Create single chunk for the entire file\n const chunkId = generateChunkId(filepath, 1, lineCount);\n const chunks: Chunk[] = [\n {\n id: chunkId,\n content: content,\n startLine: 1,\n endLine: lineCount,\n type: \"file\",\n },\n ];\n\n // Store literals for finalize\n if (jsonPathLiterals.length > 0) {\n this.pendingLiterals.set(chunkId, {\n filepath,\n literals: jsonPathLiterals,\n });\n }\n\n const stats = await ctx.getFileStats(filepath);\n\n // Module data without embeddings\n const moduleData: JsonModuleData = {\n jsonPaths: jsonPathLiterals.map((l) => l.value),\n };\n\n // Build file summary with keywords for BM25\n const keywords = extractJsonKeywords(parsed);\n\n const fileSummary: FileSummary = {\n filepath,\n chunkCount: 1,\n chunkTypes: [\"file\"],\n keywords,\n exports: [], // JSON files don't have exports\n lastModified: stats.lastModified,\n };\n\n this.pendingSummaries.set(filepath, fileSummary);\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n };\n }\n\n /**\n * Finalize indexing by building and saving the symbolic and literal indexes\n */\n async finalize(ctx: IndexContext): Promise<void> {\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Initialize symbolic index\n this.symbolicIndex = new SymbolicIndex(indexDir, this.id);\n await this.symbolicIndex.initialize();\n\n // Add all pending summaries\n for (const [filepath, summary] of this.pendingSummaries) {\n this.symbolicIndex.addFile(summary);\n }\n\n // Build BM25 index from summaries\n this.symbolicIndex.buildBM25Index();\n\n // Save to disk\n await this.symbolicIndex.save();\n\n // Initialize and build literal index\n this.literalIndex = new LiteralIndex(indexDir, this.id);\n await this.literalIndex.initialize();\n\n // Get all filepaths that were indexed in this run\n const indexedFilepaths = new Set<string>();\n for (const filepath of this.pendingSummaries.keys()) {\n indexedFilepaths.add(filepath);\n }\n for (const { filepath } of this.pendingLiterals.values()) {\n indexedFilepaths.add(filepath);\n }\n\n // Remove old literals for all files that were re-indexed\n for (const filepath of indexedFilepaths) {\n this.literalIndex.removeFile(filepath);\n }\n\n // Add all pending literals\n for (const [chunkId, { filepath, literals }] of this.pendingLiterals) {\n this.literalIndex.addLiterals(chunkId, filepath, literals);\n }\n\n // Save literal index to disk\n await this.literalIndex.save();\n\n // Clear pending data\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n /**\n * Search the JSON index for files matching the query.\n *\n * Uses a two-source approach:\n * 1. Literal index for exact path matches (e.g., `package.dependencies.react`)\n * 2. BM25 keyword search for fuzzy matching\n *\n * @param query - Search query (supports backticks for exact literal matching)\n * @param ctx - Search context with index access\n * @param options - Search options (topK, minScore, filePatterns)\n * @returns Array of search results sorted by relevance\n */\n async search(\n query: string,\n ctx: SearchContext,\n options: SearchOptions = {}\n ): Promise<SearchResult[]> {\n const {\n topK = DEFAULT_TOP_K,\n minScore = DEFAULT_MIN_SCORE,\n filePatterns,\n } = options;\n\n // Parse query for literals (explicit backticks/quotes and implicit patterns)\n const { literals: queryLiterals, remainingQuery } =\n parseQueryLiterals(query);\n\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Load symbolic index for BM25 and file listing\n const symbolicIndex = new SymbolicIndex(indexDir, this.id);\n\n // Load literal index for exact-match boosting\n const literalIndex = new LiteralIndex(indexDir, this.id);\n let literalMatchMap = new Map<string, LiteralMatch[]>();\n\n try {\n await literalIndex.initialize();\n literalMatchMap = literalIndex.buildMatchMap(queryLiterals);\n } catch {\n // Literal index doesn't exist yet, continue without it\n }\n\n // Get all indexed JSON files\n let allFiles: string[];\n try {\n await symbolicIndex.initialize();\n allFiles = symbolicIndex.getAllFiles();\n } catch {\n allFiles = await ctx.listIndexedFiles();\n }\n\n // Filter to JSON files only\n let filesToSearch = allFiles.filter((f) => isJsonFile(f));\n\n // Apply file pattern filter if specified\n if (filePatterns && filePatterns.length > 0) {\n filesToSearch = filesToSearch.filter((filepath) => {\n return filePatterns.some((pattern) => {\n if (pattern.startsWith(\"*.\")) {\n const ext = pattern.slice(1);\n return filepath.endsWith(ext);\n }\n return filepath.includes(pattern);\n });\n });\n }\n\n // Build BM25 index from all chunks\n const bm25Index = new BM25Index();\n const allChunksData: Array<{\n filepath: string;\n chunk: Chunk;\n }> = [];\n\n for (const filepath of filesToSearch) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n for (const chunk of fileIndex.chunks) {\n allChunksData.push({\n filepath: fileIndex.filepath,\n chunk,\n });\n\n // Add to BM25 index\n bm25Index.addDocuments([{ id: chunk.id, content: chunk.content }]);\n }\n }\n\n // Perform BM25 search\n const bm25Results = bm25Index.search(query, topK * 3);\n const bm25Scores = new Map<string, number>();\n\n for (const result of bm25Results) {\n bm25Scores.set(result.id, normalizeScore(result.score, 3));\n }\n\n // Calculate scores for all chunks\n const results: SearchResult[] = [];\n const processedChunkIds = new Set<string>();\n\n for (const { filepath, chunk } of allChunksData) {\n const bm25Score = bm25Scores.get(chunk.id) || 0;\n\n // Get literal matches for this chunk\n const literalMatches = literalMatchMap.get(chunk.id) || [];\n const literalContribution = calculateLiteralContribution(\n literalMatches,\n bm25Score > 0 // hasSemanticOrBm25\n );\n\n // Base score from BM25\n const baseScore = BM25_WEIGHT * bm25Score;\n\n // Apply literal boosting\n const boostedScore = applyLiteralBoost(\n baseScore,\n literalMatches,\n bm25Score > 0\n );\n\n // Add literal contribution if no BM25 score\n const literalBase =\n literalMatches.length > 0 && bm25Score === 0\n ? LITERAL_SCORING_CONSTANTS.BASE_SCORE * LITERAL_WEIGHT\n : 0;\n\n const finalScore = boostedScore + literalBase;\n\n processedChunkIds.add(chunk.id);\n\n // Include if score meets threshold or has literal matches\n if (finalScore >= minScore || literalMatches.length > 0) {\n results.push({\n filepath,\n chunk,\n score: finalScore,\n moduleId: this.id,\n context: {\n bm25Score,\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n },\n });\n }\n }\n\n // Add literal-only results (chunks found by literal index but not loaded)\n for (const [chunkId, matches] of literalMatchMap) {\n if (processedChunkIds.has(chunkId)) {\n continue;\n }\n\n const filepath = matches[0]?.filepath;\n if (!filepath) continue;\n\n // Load the file index\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const chunk = fileIndex.chunks.find((c) => c.id === chunkId);\n if (!chunk) continue;\n\n const literalContribution = calculateLiteralContribution(matches, false);\n\n const score =\n LITERAL_SCORING_CONSTANTS.BASE_SCORE * literalContribution.multiplier;\n\n processedChunkIds.add(chunkId);\n\n results.push({\n filepath,\n chunk,\n score,\n moduleId: this.id,\n context: {\n bm25Score: 0,\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n literalOnly: true,\n },\n });\n }\n\n // Sort by score descending and take top K\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n}\n",
41
- "/**\n * Markdown Documentation Index Module\n *\n * Provides Markdown file search using:\n * - Heading-based section parsing\n * - Local text embeddings for semantic similarity\n * - Structure-aware chunking\n *\n * Supported file types: .md\n *\n * Index location: .raggrep/index/docs/markdown/\n */\n\nimport * as path from \"path\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n} from \"../../../types\";\nimport {\n getEmbeddings,\n getEmbedding,\n configureEmbeddings,\n getEmbeddingConfig,\n} from \"../../../infrastructure/embeddings\";\nimport {\n cosineSimilarity,\n BM25Index,\n normalizeScore,\n extractQueryTerms,\n generateChunkId,\n} from \"../../../domain/services\";\nimport {\n getEmbeddingConfigFromModule,\n getRaggrepDir,\n} from \"../../../infrastructure/config\";\nimport { SymbolicIndex } from \"../../../infrastructure/storage\";\nimport type { EmbeddingConfig, Logger } from \"../../../domain/ports\";\nimport type { FileSummary, ChunkType } from \"../../../domain/entities\";\n\n/** Default minimum similarity score for search results */\nexport const DEFAULT_MIN_SCORE = 0.15;\n\n/** Default number of results to return */\nexport const DEFAULT_TOP_K = 10;\n\n/** Weight for semantic similarity in hybrid scoring (0-1) */\nconst SEMANTIC_WEIGHT = 0.7;\n\n/** Weight for BM25 keyword matching in hybrid scoring (0-1) */\nconst BM25_WEIGHT = 0.3;\n\n/** File extensions supported by this module */\nexport const MARKDOWN_EXTENSIONS = [\".md\", \".txt\"];\n\n/**\n * Check if a file is supported by this module.\n */\nexport function isMarkdownFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return MARKDOWN_EXTENSIONS.includes(ext);\n}\n\n// Re-export for module interface\nexport const supportsFile = isMarkdownFile;\n\n/**\n * Represents a parsed section from a Markdown document.\n */\ninterface MarkdownSection {\n /** The heading text (without #) */\n heading: string;\n /** The heading level (1-6) */\n level: number;\n /** The content under this heading */\n content: string;\n /** 1-based start line number */\n startLine: number;\n /** 1-based end line number */\n endLine: number;\n}\n\n/**\n * Parse Markdown content into sections based on headings.\n */\nfunction parseMarkdownSections(content: string): MarkdownSection[] {\n const lines = content.split(\"\\n\");\n const sections: MarkdownSection[] = [];\n\n let currentSection: MarkdownSection | null = null;\n let currentContent: string[] = [];\n let startLine = 1;\n\n for (let i = 0; i < lines.length; i++) {\n const line = lines[i];\n const headingMatch = line.match(/^(#{1,6})\\s+(.+)$/);\n\n if (headingMatch) {\n // Save previous section\n if (currentSection) {\n currentSection.content = currentContent.join(\"\\n\").trim();\n currentSection.endLine = i; // Previous line\n if (currentSection.content || currentSection.heading) {\n sections.push(currentSection);\n }\n } else if (currentContent.length > 0) {\n // Content before first heading\n sections.push({\n heading: \"\",\n level: 0,\n content: currentContent.join(\"\\n\").trim(),\n startLine: 1,\n endLine: i,\n });\n }\n\n // Start new section\n currentSection = {\n heading: headingMatch[2],\n level: headingMatch[1].length,\n content: \"\",\n startLine: i + 1,\n endLine: lines.length,\n };\n currentContent = [];\n } else {\n currentContent.push(line);\n }\n }\n\n // Save final section\n if (currentSection) {\n currentSection.content = currentContent.join(\"\\n\").trim();\n currentSection.endLine = lines.length;\n if (currentSection.content || currentSection.heading) {\n sections.push(currentSection);\n }\n } else if (currentContent.length > 0) {\n // No headings at all\n sections.push({\n heading: \"\",\n level: 0,\n content: currentContent.join(\"\\n\").trim(),\n startLine: 1,\n endLine: lines.length,\n });\n }\n\n return sections;\n}\n\n/**\n * Extract keywords from Markdown content.\n */\nfunction extractMarkdownKeywords(content: string): string[] {\n const keywords: string[] = [];\n\n // Extract headings\n const headingMatches = content.matchAll(/^#{1,6}\\s+(.+)$/gm);\n for (const match of headingMatches) {\n const heading = match[1].toLowerCase();\n const words = heading.split(/\\s+/).filter((w) => w.length > 2);\n keywords.push(...words);\n }\n\n // Extract bold/emphasized text\n const emphasisMatches = content.matchAll(/\\*\\*(.+?)\\*\\*|\\*(.+?)\\*/g);\n for (const match of emphasisMatches) {\n const text = (match[1] || match[2] || \"\").toLowerCase();\n const words = text.split(/\\s+/).filter((w) => w.length > 2);\n keywords.push(...words);\n }\n\n // Extract code blocks (inline)\n const codeMatches = content.matchAll(/`([^`]+)`/g);\n for (const match of codeMatches) {\n const code = match[1].toLowerCase();\n if (code.length > 2 && code.length < 50) {\n keywords.push(code);\n }\n }\n\n // Extract links\n const linkMatches = content.matchAll(/\\[([^\\]]+)\\]/g);\n for (const match of linkMatches) {\n const text = match[1].toLowerCase();\n const words = text.split(/\\s+/).filter((w) => w.length > 2);\n keywords.push(...words);\n }\n\n return [...new Set(keywords)];\n}\n\n/**\n * Module-specific data stored alongside file index\n */\nexport interface MarkdownModuleData {\n embeddings: number[][];\n embeddingModel: string;\n headings: string[];\n [key: string]: unknown;\n}\n\nexport class MarkdownModule implements IndexModule {\n readonly id = \"docs/markdown\";\n readonly name = \"Markdown Search\";\n readonly description =\n \"Markdown documentation search with section-aware indexing\";\n readonly version = \"1.0.0\";\n\n supportsFile(filepath: string): boolean {\n return isMarkdownFile(filepath);\n }\n\n private embeddingConfig: EmbeddingConfig | null = null;\n private symbolicIndex: SymbolicIndex | null = null;\n private pendingSummaries: Map<string, FileSummary> = new Map();\n private rootDir: string = \"\";\n private logger: Logger | undefined = undefined;\n\n async initialize(config: ModuleConfig): Promise<void> {\n this.embeddingConfig = getEmbeddingConfigFromModule(config);\n this.logger = config.options?.logger as Logger | undefined;\n\n if (this.logger) {\n this.embeddingConfig = {\n ...this.embeddingConfig,\n logger: this.logger,\n };\n }\n\n configureEmbeddings(this.embeddingConfig);\n this.pendingSummaries.clear();\n }\n\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n // Only process Markdown files\n if (!isMarkdownFile(filepath)) {\n return null;\n }\n\n this.rootDir = ctx.rootDir;\n\n // Parse Markdown into sections\n const sections = parseMarkdownSections(content);\n\n if (sections.length === 0) {\n return null;\n }\n\n // Generate embeddings for sections\n const chunkContents = sections.map((s) => {\n const filename = path.basename(filepath);\n const headingContext = s.heading ? `${s.heading}: ` : \"\";\n return `${filename} ${headingContext}${s.content}`;\n });\n const embeddings = await getEmbeddings(chunkContents);\n\n // Create chunks from sections\n const chunks: Chunk[] = sections.map((section, i) => ({\n id: generateChunkId(filepath, section.startLine, section.endLine),\n content: section.heading\n ? `## ${section.heading}\\n\\n${section.content}`\n : section.content,\n startLine: section.startLine,\n endLine: section.endLine,\n type: \"block\" as ChunkType,\n name: section.heading || undefined,\n }));\n\n // Extract headings for metadata\n const headings = sections.filter((s) => s.heading).map((s) => s.heading);\n\n const stats = await ctx.getFileStats(filepath);\n const currentConfig = getEmbeddingConfig();\n\n const moduleData: MarkdownModuleData = {\n embeddings,\n embeddingModel: currentConfig.model,\n headings,\n };\n\n // Build file summary\n const keywords = extractMarkdownKeywords(content);\n\n const fileSummary: FileSummary = {\n filepath,\n chunkCount: chunks.length,\n chunkTypes: [\"block\"],\n keywords,\n exports: headings, // Use headings as \"exports\" for searchability\n lastModified: stats.lastModified,\n };\n\n this.pendingSummaries.set(filepath, fileSummary);\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n };\n }\n\n async finalize(ctx: IndexContext): Promise<void> {\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n this.symbolicIndex = new SymbolicIndex(indexDir, this.id);\n await this.symbolicIndex.initialize();\n\n for (const [filepath, summary] of this.pendingSummaries) {\n this.symbolicIndex.addFile(summary);\n }\n\n this.symbolicIndex.buildBM25Index();\n await this.symbolicIndex.save();\n this.pendingSummaries.clear();\n }\n\n async search(\n query: string,\n ctx: SearchContext,\n options: SearchOptions = {}\n ): Promise<SearchResult[]> {\n const {\n topK = DEFAULT_TOP_K,\n minScore = DEFAULT_MIN_SCORE,\n filePatterns,\n } = options;\n\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n const symbolicIndex = new SymbolicIndex(indexDir, this.id);\n\n let allFiles: string[];\n\n try {\n await symbolicIndex.initialize();\n allFiles = symbolicIndex.getAllFiles();\n } catch {\n allFiles = await ctx.listIndexedFiles();\n }\n\n // Filter to Markdown files only\n let filesToSearch = allFiles.filter((f) => isMarkdownFile(f));\n\n if (filePatterns && filePatterns.length > 0) {\n filesToSearch = filesToSearch.filter((filepath) => {\n return filePatterns.some((pattern) => {\n if (pattern.startsWith(\"*.\")) {\n const ext = pattern.slice(1);\n return filepath.endsWith(ext);\n }\n return filepath.includes(pattern);\n });\n });\n }\n\n const queryEmbedding = await getEmbedding(query);\n const bm25Index = new BM25Index();\n const allChunksData: Array<{\n filepath: string;\n chunk: Chunk;\n embedding: number[];\n }> = [];\n\n for (const filepath of filesToSearch) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const moduleData = fileIndex.moduleData as unknown as MarkdownModuleData;\n if (!moduleData?.embeddings) continue;\n\n for (let i = 0; i < fileIndex.chunks.length; i++) {\n const chunk = fileIndex.chunks[i];\n const embedding = moduleData.embeddings[i];\n\n if (!embedding) continue;\n\n allChunksData.push({\n filepath: fileIndex.filepath,\n chunk,\n embedding,\n });\n\n bm25Index.addDocuments([{ id: chunk.id, content: chunk.content }]);\n }\n }\n\n const bm25Results = bm25Index.search(query, topK * 3);\n const bm25Scores = new Map<string, number>();\n\n for (const result of bm25Results) {\n bm25Scores.set(result.id, normalizeScore(result.score, 3));\n }\n\n const queryTerms = extractQueryTerms(query);\n const results: SearchResult[] = [];\n\n for (const { filepath, chunk, embedding } of allChunksData) {\n const semanticScore = cosineSimilarity(queryEmbedding, embedding);\n const bm25Score = bm25Scores.get(chunk.id) || 0;\n\n // Documentation files get a small boost for documentation-intent queries\n let docBoost = 0;\n if (\n queryTerms.some((t) =>\n [\n \"docs\",\n \"documentation\",\n \"readme\",\n \"guide\",\n \"how\",\n \"what\",\n \"explain\",\n ].includes(t)\n )\n ) {\n docBoost = 0.05;\n }\n\n const hybridScore =\n SEMANTIC_WEIGHT * semanticScore + BM25_WEIGHT * bm25Score + docBoost;\n\n if (hybridScore >= minScore || bm25Score > 0.3) {\n results.push({\n filepath,\n chunk,\n score: hybridScore,\n moduleId: this.id,\n context: {\n semanticScore,\n bm25Score,\n docBoost,\n },\n });\n }\n }\n\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n}\n\n",
39
+ "/**\n * TypeScript/JavaScript Language Index Module\n *\n * Provides TypeScript/JavaScript-aware code search using:\n * - AST parsing via TypeScript Compiler API\n * - Local text embeddings for semantic similarity\n * - BM25 keyword matching for fast filtering\n *\n * Supported file types: .ts, .tsx, .js, .jsx, .mjs, .cjs, .mts, .cts\n *\n * Index location: .raggrep/index/language/typescript/\n */\n\nimport * as path from \"path\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n ChunkType,\n} from \"../../../types\";\nimport {\n getEmbeddings,\n getEmbedding,\n configureEmbeddings,\n getEmbeddingConfig,\n} from \"../../../infrastructure/embeddings\";\nimport {\n cosineSimilarity,\n BM25Index,\n normalizeScore,\n extractKeywords,\n parsePathContext,\n formatPathContextForEmbedding,\n calculateFileTypeBoost,\n extractQueryTerms,\n // Literal boosting\n parseQueryLiterals,\n extractLiterals,\n calculateLiteralContribution,\n applyLiteralBoost,\n LITERAL_SCORING_CONSTANTS,\n // Structured Semantic Expansion\n expandQuery,\n} from \"../../../domain/services\";\nimport {\n getEmbeddingConfigFromModule,\n getRaggrepDir,\n} from \"../../../infrastructure/config\";\nimport { parseTypeScriptCode, generateChunkId } from \"./parseCode\";\nimport { SymbolicIndex, LiteralIndex } from \"../../../infrastructure/storage\";\nimport type { EmbeddingConfig, Logger } from \"../../../domain/ports\";\nimport type {\n FileSummary,\n ExtractedLiteral,\n LiteralMatch,\n} from \"../../../domain/entities\";\n\n/** Default minimum similarity score for search results */\nexport const DEFAULT_MIN_SCORE = 0.15;\n\n/** Default number of results to return */\nexport const DEFAULT_TOP_K = 10;\n\n/** Weight for semantic similarity in hybrid scoring (0-1) */\nconst SEMANTIC_WEIGHT = 0.7;\n\n/** Weight for BM25 keyword matching in hybrid scoring (0-1) */\nconst BM25_WEIGHT = 0.3;\n\n/** File extensions supported by this module */\nexport const TYPESCRIPT_EXTENSIONS = [\n \".ts\",\n \".tsx\",\n \".js\",\n \".jsx\",\n \".mjs\",\n \".cjs\",\n \".mts\",\n \".cts\",\n];\n\n/**\n * Check if a file is supported by this module.\n */\nexport function isTypeScriptFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return TYPESCRIPT_EXTENSIONS.includes(ext);\n}\n\n// Re-export for module interface\nexport const supportsFile = isTypeScriptFile;\n\n/**\n * Calculate boost based on chunk type.\n * Function/class/interface chunks rank higher than generic blocks.\n */\nfunction calculateChunkTypeBoost(chunk: Chunk): number {\n switch (chunk.type) {\n case \"function\":\n return 0.05;\n case \"class\":\n case \"interface\":\n return 0.04;\n case \"type\":\n case \"enum\":\n return 0.03;\n case \"variable\":\n return 0.02;\n case \"file\":\n case \"block\":\n default:\n return 0;\n }\n}\n\n/**\n * Calculate boost for exported symbols.\n * Public APIs are more likely to be what users are searching for.\n */\nfunction calculateExportBoost(chunk: Chunk): number {\n return chunk.isExported ? 0.03 : 0;\n}\n\n/**\n * Module-specific data stored alongside file index\n */\nexport interface SemanticModuleData {\n embeddings: number[][];\n /** Store the model used for these embeddings for compatibility checking */\n embeddingModel: string;\n [key: string]: unknown; // Index signature for compatibility with Record<string, unknown>\n}\n\nexport class TypeScriptModule implements IndexModule {\n readonly id = \"language/typescript\";\n readonly name = \"TypeScript Search\";\n readonly description =\n \"TypeScript-aware code search with AST parsing and semantic embeddings\";\n readonly version = \"1.0.0\";\n\n supportsFile(filepath: string): boolean {\n return isTypeScriptFile(filepath);\n }\n\n private embeddingConfig: EmbeddingConfig | null = null;\n private symbolicIndex: SymbolicIndex | null = null;\n private literalIndex: LiteralIndex | null = null;\n private pendingSummaries: Map<string, FileSummary> = new Map();\n /** Map from chunkId → { filepath, literals } for building literal index */\n private pendingLiterals: Map<\n string,\n { filepath: string; literals: ExtractedLiteral[] }\n > = new Map();\n private rootDir: string = \"\";\n private logger: Logger | undefined = undefined;\n\n async initialize(config: ModuleConfig): Promise<void> {\n // Extract embedding config from module options\n this.embeddingConfig = getEmbeddingConfigFromModule(config);\n\n // Extract logger from module options (passed from indexer)\n this.logger = config.options?.logger as Logger | undefined;\n\n // Add logger to embedding config\n if (this.logger) {\n this.embeddingConfig = {\n ...this.embeddingConfig,\n logger: this.logger,\n };\n }\n\n // Configure the embedding provider\n configureEmbeddings(this.embeddingConfig);\n\n // Clear pending data for fresh indexing\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n // Only process TypeScript/JavaScript files\n if (!isTypeScriptFile(filepath)) {\n return null;\n }\n\n // Store rootDir for finalize\n this.rootDir = ctx.rootDir;\n\n // Parse code into chunks using TypeScript AST\n const parsedChunks = parseTypeScriptCode(content, filepath);\n\n if (parsedChunks.length === 0) {\n return null;\n }\n\n // Parse path context for structural awareness\n const pathContext = parsePathContext(filepath);\n const pathPrefix = formatPathContextForEmbedding(pathContext);\n\n // Generate embeddings for all chunks with path context\n // Prepending path context helps the embedding model understand file structure\n const chunkContents = parsedChunks.map((c) => {\n // For named chunks, include the name for better embedding\n const namePrefix = c.name ? `${c.name}: ` : \"\";\n return `${pathPrefix} ${namePrefix}${c.content}`;\n });\n const embeddings = await getEmbeddings(chunkContents);\n\n // Create chunks with all metadata\n const chunks: Chunk[] = parsedChunks.map((pc) => ({\n id: generateChunkId(filepath, pc.startLine, pc.endLine),\n content: pc.content,\n startLine: pc.startLine,\n endLine: pc.endLine,\n type: pc.type,\n name: pc.name,\n isExported: pc.isExported,\n jsDoc: pc.jsDoc,\n }));\n\n // Extract references (imports)\n const references = this.extractReferences(content, filepath);\n\n const stats = await ctx.getFileStats(filepath);\n const currentConfig = getEmbeddingConfig();\n\n const moduleData: SemanticModuleData = {\n embeddings,\n embeddingModel: currentConfig.model,\n };\n\n // Build Tier 1 summary for this file\n const chunkTypes = [\n ...new Set(parsedChunks.map((pc) => pc.type)),\n ] as ChunkType[];\n const exports = parsedChunks\n .filter((pc) => pc.isExported && pc.name)\n .map((pc) => pc.name!);\n\n // Extract keywords from all chunks + path keywords\n const allKeywords = new Set<string>();\n for (const pc of parsedChunks) {\n const keywords = extractKeywords(pc.content, pc.name);\n keywords.forEach((k) => allKeywords.add(k));\n }\n // Add path keywords\n pathContext.keywords.forEach((k) => allKeywords.add(k));\n\n const fileSummary: FileSummary = {\n filepath,\n chunkCount: chunks.length,\n chunkTypes,\n keywords: Array.from(allKeywords),\n exports,\n lastModified: stats.lastModified,\n // Include parsed path context for search boosting\n pathContext: {\n segments: pathContext.segments,\n layer: pathContext.layer,\n domain: pathContext.domain,\n depth: pathContext.depth,\n },\n };\n\n // Store summary for finalize\n this.pendingSummaries.set(filepath, fileSummary);\n\n // Extract literals from each chunk for literal boosting\n for (const chunk of chunks) {\n const literals = extractLiterals(chunk);\n if (literals.length > 0) {\n const existing = this.pendingLiterals.get(chunk.id);\n if (existing) {\n existing.literals.push(...literals);\n } else {\n this.pendingLiterals.set(chunk.id, { filepath, literals });\n }\n }\n }\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n references,\n };\n }\n\n /**\n * Finalize indexing by building and saving the symbolic and literal indexes.\n * Uses incremental updates when possible to avoid full rebuilds.\n */\n async finalize(ctx: IndexContext): Promise<void> {\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Initialize symbolic index (loads existing data including BM25)\n this.symbolicIndex = new SymbolicIndex(indexDir, this.id);\n await this.symbolicIndex.initialize();\n\n // Track which files were updated for incremental save\n const updatedFilepaths: string[] = [];\n\n // Add all pending summaries incrementally (updates BM25 as we go)\n for (const [filepath, summary] of this.pendingSummaries) {\n this.symbolicIndex.addFileIncremental(summary);\n updatedFilepaths.push(filepath);\n }\n\n // Save to disk (only saves updated files + serialized BM25)\n if (updatedFilepaths.length > 0) {\n await this.symbolicIndex.saveIncremental(updatedFilepaths);\n }\n\n // Initialize and build literal index\n this.literalIndex = new LiteralIndex(indexDir, this.id);\n await this.literalIndex.initialize();\n\n // Get all filepaths that were indexed in this run\n // (both from summaries for any indexed files and from literals for chunks with names)\n const indexedFilepaths = new Set<string>();\n for (const filepath of this.pendingSummaries.keys()) {\n indexedFilepaths.add(filepath);\n }\n for (const { filepath } of this.pendingLiterals.values()) {\n indexedFilepaths.add(filepath);\n }\n\n // Remove old literals for all files that were re-indexed\n // This ensures stale literals (from renamed/deleted functions) are removed\n for (const filepath of indexedFilepaths) {\n this.literalIndex.removeFile(filepath);\n }\n\n // Add all pending literals (fresh data from this indexing run)\n for (const [chunkId, { filepath, literals }] of this.pendingLiterals) {\n this.literalIndex.addLiterals(chunkId, filepath, literals);\n }\n\n // Save literal index to disk\n await this.literalIndex.save();\n\n // Clear pending data\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n /**\n * Search the semantic index for chunks matching the query.\n *\n * Uses a three-source approach:\n * 1. Semantic search with embeddings\n * 2. BM25 keyword search\n * 3. Literal index for exact-match boosting\n *\n * @param query - Natural language search query\n * @param ctx - Search context with index access\n * @param options - Search options (topK, minScore, filePatterns)\n * @returns Array of search results sorted by relevance\n */\n async search(\n query: string,\n ctx: SearchContext,\n options: SearchOptions = {}\n ): Promise<SearchResult[]> {\n const {\n topK = DEFAULT_TOP_K,\n minScore = DEFAULT_MIN_SCORE,\n filePatterns,\n } = options;\n\n // Parse query for literals (explicit backticks/quotes and implicit casing)\n const { literals: queryLiterals, remainingQuery } =\n parseQueryLiterals(query);\n\n // Load symbolic index for BM25 scoring (not filtering)\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n const symbolicIndex = new SymbolicIndex(indexDir, this.id);\n\n // Load literal index for exact-match boosting\n const literalIndex = new LiteralIndex(indexDir, this.id);\n let literalMatchMap = new Map<string, LiteralMatch[]>();\n\n try {\n await literalIndex.initialize();\n literalMatchMap = literalIndex.buildMatchMap(queryLiterals);\n } catch {\n // Literal index doesn't exist yet, continue without it\n }\n\n // Get ALL indexed files - semantic search needs to check all embeddings\n // BM25 contributes to the hybrid score but doesn't filter candidates\n let allFiles: string[];\n\n try {\n await symbolicIndex.initialize();\n allFiles = symbolicIndex.getAllFiles();\n } catch {\n // Symbolic index doesn't exist, fall back to loading all files\n allFiles = await ctx.listIndexedFiles();\n }\n\n // Apply file pattern filter if specified\n let filesToSearch = allFiles;\n if (filePatterns && filePatterns.length > 0) {\n filesToSearch = allFiles.filter((filepath) => {\n return filePatterns.some((pattern) => {\n if (pattern.startsWith(\"*.\")) {\n const ext = pattern.slice(1);\n return filepath.endsWith(ext);\n }\n return filepath.includes(pattern);\n });\n });\n }\n\n // Get query embedding for semantic search\n // Use remaining query (without explicit literals) for semantic search\n const semanticQuery = remainingQuery.trim() || query; // Fall back to full query if empty\n\n // Apply Structured Semantic Expansion to broaden search recall\n // This adds domain-specific synonyms (function → method, auth → authentication, etc.)\n // Use conservative settings: no weak synonyms, limited max terms\n const expandedQuery = expandQuery(semanticQuery, undefined, {\n maxDepth: 1,\n includeWeak: false, // Only strong and moderate synonyms\n maxTerms: 10, // Conservative limit to avoid diluting specificity\n });\n\n // Use expanded query for embedding to improve semantic recall\n const queryEmbedding = await getEmbedding(\n expandedQuery.expandedQueryString\n );\n\n // Load all indexed files and compute scores\n // BM25 is used for keyword scoring, not filtering\n const bm25Index = new BM25Index();\n const allChunksData: Array<{\n filepath: string;\n chunk: Chunk;\n embedding: number[];\n }> = [];\n\n for (const filepath of filesToSearch) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const moduleData = fileIndex.moduleData as unknown as SemanticModuleData;\n if (!moduleData?.embeddings) continue;\n\n for (let i = 0; i < fileIndex.chunks.length; i++) {\n const chunk = fileIndex.chunks[i];\n const embedding = moduleData.embeddings[i];\n\n if (!embedding) continue;\n\n allChunksData.push({\n filepath: fileIndex.filepath,\n chunk,\n embedding,\n });\n\n // Add to BM25 index for chunk-level keyword matching\n bm25Index.addDocuments([{ id: chunk.id, content: chunk.content }]);\n }\n }\n\n // Perform BM25 search at chunk level (use full query for BM25)\n const bm25Results = bm25Index.search(query, topK * 3);\n const bm25Scores = new Map<string, number>();\n\n for (const result of bm25Results) {\n bm25Scores.set(result.id, normalizeScore(result.score, 3));\n }\n\n // Extract query terms for path matching and intent detection\n const queryTerms = extractQueryTerms(query);\n\n // Build path boost map from file summaries\n const pathBoosts = new Map<string, number>();\n for (const filepath of filesToSearch) {\n const summary = symbolicIndex.getFileSummary(filepath);\n if (summary?.pathContext) {\n let boost = 0;\n const pathCtx = summary.pathContext;\n\n // Check if query terms match domain\n if (\n pathCtx.domain &&\n queryTerms.some(\n (t) => pathCtx.domain!.includes(t) || t.includes(pathCtx.domain!)\n )\n ) {\n boost += 0.1;\n }\n\n // Check if query terms match layer\n if (\n pathCtx.layer &&\n queryTerms.some(\n (t) => pathCtx.layer!.includes(t) || t.includes(pathCtx.layer!)\n )\n ) {\n boost += 0.05;\n }\n\n // Check if query terms match path segments\n const segmentMatch = pathCtx.segments.some((seg) =>\n queryTerms.some(\n (t) =>\n seg.toLowerCase().includes(t) || t.includes(seg.toLowerCase())\n )\n );\n if (segmentMatch) {\n boost += 0.05;\n }\n\n pathBoosts.set(filepath, boost);\n }\n }\n\n // Calculate hybrid scores for all chunks\n const results: SearchResult[] = [];\n const processedChunkIds = new Set<string>();\n\n for (const { filepath, chunk, embedding } of allChunksData) {\n const semanticScore = cosineSimilarity(queryEmbedding, embedding);\n const bm25Score = bm25Scores.get(chunk.id) || 0;\n const pathBoost = pathBoosts.get(filepath) || 0;\n\n // Additional boosts for ranking improvement\n const fileTypeBoost = calculateFileTypeBoost(filepath, queryTerms);\n const chunkTypeBoost = calculateChunkTypeBoost(chunk);\n const exportBoost = calculateExportBoost(chunk);\n const additiveBoost =\n pathBoost + fileTypeBoost + chunkTypeBoost + exportBoost;\n\n // Base hybrid score: weighted combination of semantic and BM25\n const baseScore =\n SEMANTIC_WEIGHT * semanticScore + BM25_WEIGHT * bm25Score;\n\n // Apply literal boosting (multiplicative)\n const literalMatches = literalMatchMap.get(chunk.id) || [];\n const literalContribution = calculateLiteralContribution(\n literalMatches,\n true // hasSemanticOrBm25\n );\n const boostedScore = applyLiteralBoost(baseScore, literalMatches, true);\n\n // Final score = boosted base score + additive boosts\n const finalScore = boostedScore + additiveBoost;\n\n processedChunkIds.add(chunk.id);\n\n if (\n finalScore >= minScore ||\n bm25Score > 0.3 ||\n literalMatches.length > 0\n ) {\n results.push({\n filepath,\n chunk,\n score: finalScore,\n moduleId: this.id,\n context: {\n semanticScore,\n bm25Score,\n pathBoost,\n fileTypeBoost,\n chunkTypeBoost,\n exportBoost,\n // Literal boosting context\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n // Semantic expansion context\n synonymsUsed: expandedQuery.wasExpanded\n ? expandedQuery.expandedTerms\n .filter((t) => t.source !== \"original\")\n .map((t) => t.term)\n : undefined,\n },\n });\n }\n }\n\n // Add literal-only results (chunks found by literal index but not loaded above)\n // This ensures exact matches always surface even if they weren't in the search scope\n const literalOnlyFiles = new Map<string, LiteralMatch[]>();\n\n // Group unprocessed literal matches by filepath\n for (const [chunkId, matches] of literalMatchMap) {\n if (processedChunkIds.has(chunkId)) {\n continue;\n }\n\n // Get filepath from the first match (all matches for same chunkId have same filepath)\n const filepath = matches[0]?.filepath;\n if (!filepath) continue;\n\n const existing = literalOnlyFiles.get(filepath) || [];\n existing.push(...matches);\n literalOnlyFiles.set(filepath, existing);\n }\n\n // Load and score literal-only chunks\n for (const [filepath, matches] of literalOnlyFiles) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const moduleData = fileIndex.moduleData as unknown as SemanticModuleData;\n\n // Group matches by chunkId for this file\n const chunkMatches = new Map<string, LiteralMatch[]>();\n for (const match of matches) {\n const existing = chunkMatches.get(match.chunkId) || [];\n existing.push(match);\n chunkMatches.set(match.chunkId, existing);\n }\n\n // Find and score each matched chunk\n for (const [chunkId, chunkLiteralMatches] of chunkMatches) {\n if (processedChunkIds.has(chunkId)) continue;\n\n const chunkIndex = fileIndex.chunks.findIndex((c) => c.id === chunkId);\n if (chunkIndex === -1) continue;\n\n const chunk = fileIndex.chunks[chunkIndex];\n const embedding = moduleData?.embeddings?.[chunkIndex];\n\n // Calculate semantic score if embedding available\n let semanticScore = 0;\n if (embedding) {\n semanticScore = cosineSimilarity(queryEmbedding, embedding);\n }\n\n // BM25 score (chunk wasn't in our search, so typically 0)\n const bm25Score = bm25Scores.get(chunkId) || 0;\n\n // Additional boosts\n const pathBoost = pathBoosts.get(filepath) || 0;\n const fileTypeBoost = calculateFileTypeBoost(filepath, queryTerms);\n const chunkTypeBoost = calculateChunkTypeBoost(chunk);\n const exportBoost = calculateExportBoost(chunk);\n const additiveBoost =\n pathBoost + fileTypeBoost + chunkTypeBoost + exportBoost;\n\n // For literal-only results, use literal scoring\n const literalContribution = calculateLiteralContribution(\n chunkLiteralMatches,\n false // hasSemanticOrBm25 = false (literal-only)\n );\n\n // Use LITERAL_SCORING_CONSTANTS.BASE_SCORE as base for literal-only\n const baseScore =\n semanticScore > 0\n ? SEMANTIC_WEIGHT * semanticScore + BM25_WEIGHT * bm25Score\n : LITERAL_SCORING_CONSTANTS.BASE_SCORE;\n\n const boostedScore = applyLiteralBoost(\n baseScore,\n chunkLiteralMatches,\n semanticScore > 0\n );\n const finalScore = boostedScore + additiveBoost;\n\n processedChunkIds.add(chunkId);\n\n results.push({\n filepath,\n chunk,\n score: finalScore,\n moduleId: this.id,\n context: {\n semanticScore,\n bm25Score,\n pathBoost,\n fileTypeBoost,\n chunkTypeBoost,\n exportBoost,\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n literalOnly: true, // Mark as literal-only result\n },\n });\n }\n }\n\n // Sort by score descending and take top K\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n\n private extractReferences(content: string, filepath: string): string[] {\n const references: string[] = [];\n\n // Extract import statements\n const importRegex = /import\\s+.*?\\s+from\\s+['\"]([^'\"]+)['\"]/g;\n const requireRegex = /require\\s*\\(\\s*['\"]([^'\"]+)['\"]\\s*\\)/g;\n\n let match;\n while ((match = importRegex.exec(content)) !== null) {\n const importPath = match[1];\n if (importPath.startsWith(\".\")) {\n const dir = path.dirname(filepath);\n const resolved = path.normalize(path.join(dir, importPath));\n references.push(resolved);\n }\n }\n\n while ((match = requireRegex.exec(content)) !== null) {\n const importPath = match[1];\n if (importPath.startsWith(\".\")) {\n const dir = path.dirname(filepath);\n const resolved = path.normalize(path.join(dir, importPath));\n references.push(resolved);\n }\n }\n\n return references;\n }\n}\n",
40
+ "/**\n * JSON Data Index Module\n *\n * Provides JSON file search using:\n * - Literal indexing of dot-notation key paths (e.g., \"package.dependencies.react\")\n * - BM25 keyword matching for fuzzy search\n *\n * Note: This module uses literal-only indexing (no embeddings) for fast indexing.\n * JSON keys are indexed as dot-notation paths prefixed with the filename.\n *\n * Supported file types: .json\n *\n * Index location: .raggrep/index/data/json/\n */\n\nimport * as path from \"path\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n} from \"../../../types\";\nimport {\n BM25Index,\n normalizeScore,\n generateChunkId,\n // Literal boosting\n parseQueryLiterals,\n calculateLiteralContribution,\n applyLiteralBoost,\n LITERAL_SCORING_CONSTANTS,\n // JSON path extraction\n extractJsonPaths,\n extractJsonKeywords,\n} from \"../../../domain/services\";\nimport { getRaggrepDir } from \"../../../infrastructure/config\";\nimport { SymbolicIndex, LiteralIndex } from \"../../../infrastructure/storage\";\nimport type { Logger } from \"../../../domain/ports\";\nimport type {\n FileSummary,\n ExtractedLiteral,\n LiteralMatch,\n} from \"../../../domain/entities\";\n\n/** Default minimum similarity score for search results */\nexport const DEFAULT_MIN_SCORE = 0.1;\n\n/** Default number of results to return */\nexport const DEFAULT_TOP_K = 10;\n\n/** Weight for BM25 keyword matching in scoring */\nconst BM25_WEIGHT = 0.4;\n\n/** Weight for literal matching in scoring */\nconst LITERAL_WEIGHT = 0.6;\n\n/** File extensions supported by this module */\nexport const JSON_EXTENSIONS = [\".json\"];\n\n/**\n * Check if a file is supported by this module.\n */\nexport function isJsonFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return JSON_EXTENSIONS.includes(ext);\n}\n\n// Re-export for module interface\nexport const supportsFile = isJsonFile;\n\n/**\n * Module-specific data stored alongside file index\n */\nexport interface JsonModuleData {\n /** Dot-notation paths extracted from the JSON file */\n jsonPaths: string[];\n [key: string]: unknown;\n}\n\nexport class JsonModule implements IndexModule {\n readonly id = \"data/json\";\n readonly name = \"JSON Search\";\n readonly description =\n \"JSON file search with literal-based key path indexing\";\n readonly version = \"2.0.0\"; // Bumped for literal-only mode\n\n supportsFile(filepath: string): boolean {\n return isJsonFile(filepath);\n }\n\n private symbolicIndex: SymbolicIndex | null = null;\n private literalIndex: LiteralIndex | null = null;\n private pendingSummaries: Map<string, FileSummary> = new Map();\n /** Map from chunkId → { filepath, literals } for building literal index */\n private pendingLiterals: Map<\n string,\n { filepath: string; literals: ExtractedLiteral[] }\n > = new Map();\n private rootDir: string = \"\";\n private logger: Logger | undefined = undefined;\n\n async initialize(config: ModuleConfig): Promise<void> {\n this.logger = config.options?.logger as Logger | undefined;\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n // Only process JSON files\n if (!isJsonFile(filepath)) {\n return null;\n }\n\n this.rootDir = ctx.rootDir;\n\n // Parse JSON content\n let parsed: unknown;\n try {\n parsed = JSON.parse(content);\n } catch {\n // Invalid JSON, skip indexing\n return null;\n }\n\n // Get filename without extension for path prefix\n const fileBasename = path.basename(filepath, path.extname(filepath));\n\n // Extract dot-notation paths as literals\n const jsonPathLiterals = extractJsonPaths(parsed, fileBasename);\n\n // Count lines for chunk metadata\n const lines = content.split(\"\\n\");\n const lineCount = lines.length;\n\n // Create single chunk for the entire file\n const chunkId = generateChunkId(filepath, 1, lineCount);\n const chunks: Chunk[] = [\n {\n id: chunkId,\n content: content,\n startLine: 1,\n endLine: lineCount,\n type: \"file\",\n },\n ];\n\n // Store literals for finalize\n if (jsonPathLiterals.length > 0) {\n this.pendingLiterals.set(chunkId, {\n filepath,\n literals: jsonPathLiterals,\n });\n }\n\n const stats = await ctx.getFileStats(filepath);\n\n // Module data without embeddings\n const moduleData: JsonModuleData = {\n jsonPaths: jsonPathLiterals.map((l) => l.value),\n };\n\n // Build file summary with keywords for BM25\n const keywords = extractJsonKeywords(parsed);\n\n const fileSummary: FileSummary = {\n filepath,\n chunkCount: 1,\n chunkTypes: [\"file\"],\n keywords,\n exports: [], // JSON files don't have exports\n lastModified: stats.lastModified,\n };\n\n this.pendingSummaries.set(filepath, fileSummary);\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n };\n }\n\n /**\n * Finalize indexing by building and saving the symbolic and literal indexes.\n * Uses incremental updates when possible to avoid full rebuilds.\n */\n async finalize(ctx: IndexContext): Promise<void> {\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Initialize symbolic index (loads existing data including BM25)\n this.symbolicIndex = new SymbolicIndex(indexDir, this.id);\n await this.symbolicIndex.initialize();\n\n // Track which files were updated for incremental save\n const updatedFilepaths: string[] = [];\n\n // Add all pending summaries incrementally (updates BM25 as we go)\n for (const [filepath, summary] of this.pendingSummaries) {\n this.symbolicIndex.addFileIncremental(summary);\n updatedFilepaths.push(filepath);\n }\n\n // Save to disk (only saves updated files + serialized BM25)\n if (updatedFilepaths.length > 0) {\n await this.symbolicIndex.saveIncremental(updatedFilepaths);\n }\n\n // Initialize and build literal index\n this.literalIndex = new LiteralIndex(indexDir, this.id);\n await this.literalIndex.initialize();\n\n // Get all filepaths that were indexed in this run\n const indexedFilepaths = new Set<string>();\n for (const filepath of this.pendingSummaries.keys()) {\n indexedFilepaths.add(filepath);\n }\n for (const { filepath } of this.pendingLiterals.values()) {\n indexedFilepaths.add(filepath);\n }\n\n // Remove old literals for all files that were re-indexed\n for (const filepath of indexedFilepaths) {\n this.literalIndex.removeFile(filepath);\n }\n\n // Add all pending literals\n for (const [chunkId, { filepath, literals }] of this.pendingLiterals) {\n this.literalIndex.addLiterals(chunkId, filepath, literals);\n }\n\n // Save literal index to disk\n await this.literalIndex.save();\n\n // Clear pending data\n this.pendingSummaries.clear();\n this.pendingLiterals.clear();\n }\n\n /**\n * Search the JSON index for files matching the query.\n *\n * Uses a two-source approach:\n * 1. Literal index for exact path matches (e.g., `package.dependencies.react`)\n * 2. BM25 keyword search for fuzzy matching\n *\n * @param query - Search query (supports backticks for exact literal matching)\n * @param ctx - Search context with index access\n * @param options - Search options (topK, minScore, filePatterns)\n * @returns Array of search results sorted by relevance\n */\n async search(\n query: string,\n ctx: SearchContext,\n options: SearchOptions = {}\n ): Promise<SearchResult[]> {\n const {\n topK = DEFAULT_TOP_K,\n minScore = DEFAULT_MIN_SCORE,\n filePatterns,\n } = options;\n\n // Parse query for literals (explicit backticks/quotes and implicit patterns)\n const { literals: queryLiterals, remainingQuery } =\n parseQueryLiterals(query);\n\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Load symbolic index for BM25 and file listing\n const symbolicIndex = new SymbolicIndex(indexDir, this.id);\n\n // Load literal index for exact-match boosting\n const literalIndex = new LiteralIndex(indexDir, this.id);\n let literalMatchMap = new Map<string, LiteralMatch[]>();\n\n try {\n await literalIndex.initialize();\n literalMatchMap = literalIndex.buildMatchMap(queryLiterals);\n } catch {\n // Literal index doesn't exist yet, continue without it\n }\n\n // Get all indexed JSON files\n let allFiles: string[];\n try {\n await symbolicIndex.initialize();\n allFiles = symbolicIndex.getAllFiles();\n } catch {\n allFiles = await ctx.listIndexedFiles();\n }\n\n // Filter to JSON files only\n let filesToSearch = allFiles.filter((f) => isJsonFile(f));\n\n // Apply file pattern filter if specified\n if (filePatterns && filePatterns.length > 0) {\n filesToSearch = filesToSearch.filter((filepath) => {\n return filePatterns.some((pattern) => {\n if (pattern.startsWith(\"*.\")) {\n const ext = pattern.slice(1);\n return filepath.endsWith(ext);\n }\n return filepath.includes(pattern);\n });\n });\n }\n\n // Build BM25 index from all chunks\n const bm25Index = new BM25Index();\n const allChunksData: Array<{\n filepath: string;\n chunk: Chunk;\n }> = [];\n\n for (const filepath of filesToSearch) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n for (const chunk of fileIndex.chunks) {\n allChunksData.push({\n filepath: fileIndex.filepath,\n chunk,\n });\n\n // Add to BM25 index\n bm25Index.addDocuments([{ id: chunk.id, content: chunk.content }]);\n }\n }\n\n // Perform BM25 search\n const bm25Results = bm25Index.search(query, topK * 3);\n const bm25Scores = new Map<string, number>();\n\n for (const result of bm25Results) {\n bm25Scores.set(result.id, normalizeScore(result.score, 3));\n }\n\n // Calculate scores for all chunks\n const results: SearchResult[] = [];\n const processedChunkIds = new Set<string>();\n\n for (const { filepath, chunk } of allChunksData) {\n const bm25Score = bm25Scores.get(chunk.id) || 0;\n\n // Get literal matches for this chunk\n const literalMatches = literalMatchMap.get(chunk.id) || [];\n const literalContribution = calculateLiteralContribution(\n literalMatches,\n bm25Score > 0 // hasSemanticOrBm25\n );\n\n // Base score from BM25\n const baseScore = BM25_WEIGHT * bm25Score;\n\n // Apply literal boosting\n const boostedScore = applyLiteralBoost(\n baseScore,\n literalMatches,\n bm25Score > 0\n );\n\n // Add literal contribution if no BM25 score\n const literalBase =\n literalMatches.length > 0 && bm25Score === 0\n ? LITERAL_SCORING_CONSTANTS.BASE_SCORE * LITERAL_WEIGHT\n : 0;\n\n const finalScore = boostedScore + literalBase;\n\n processedChunkIds.add(chunk.id);\n\n // Include if score meets threshold or has literal matches\n if (finalScore >= minScore || literalMatches.length > 0) {\n results.push({\n filepath,\n chunk,\n score: finalScore,\n moduleId: this.id,\n context: {\n bm25Score,\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n },\n });\n }\n }\n\n // Add literal-only results (chunks found by literal index but not loaded)\n for (const [chunkId, matches] of literalMatchMap) {\n if (processedChunkIds.has(chunkId)) {\n continue;\n }\n\n const filepath = matches[0]?.filepath;\n if (!filepath) continue;\n\n // Load the file index\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const chunk = fileIndex.chunks.find((c) => c.id === chunkId);\n if (!chunk) continue;\n\n const literalContribution = calculateLiteralContribution(matches, false);\n\n const score =\n LITERAL_SCORING_CONSTANTS.BASE_SCORE * literalContribution.multiplier;\n\n processedChunkIds.add(chunkId);\n\n results.push({\n filepath,\n chunk,\n score,\n moduleId: this.id,\n context: {\n bm25Score: 0,\n literalMultiplier: literalContribution.multiplier,\n literalMatchType: literalContribution.bestMatchType,\n literalConfidence: literalContribution.bestConfidence,\n literalMatchCount: literalContribution.matchCount,\n literalOnly: true,\n },\n });\n }\n\n // Sort by score descending and take top K\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n}\n",
41
+ "/**\n * Markdown Documentation Index Module\n *\n * Provides Markdown file search using:\n * - Heading-based section parsing\n * - Local text embeddings for semantic similarity\n * - Structure-aware chunking\n *\n * Supported file types: .md\n *\n * Index location: .raggrep/index/docs/markdown/\n */\n\nimport * as path from \"path\";\nimport {\n IndexModule,\n IndexContext,\n SearchContext,\n SearchOptions,\n FileIndex,\n SearchResult,\n Chunk,\n ModuleConfig,\n} from \"../../../types\";\nimport {\n getEmbeddings,\n getEmbedding,\n configureEmbeddings,\n getEmbeddingConfig,\n} from \"../../../infrastructure/embeddings\";\nimport {\n cosineSimilarity,\n BM25Index,\n normalizeScore,\n extractQueryTerms,\n generateChunkId,\n} from \"../../../domain/services\";\nimport {\n getEmbeddingConfigFromModule,\n getRaggrepDir,\n} from \"../../../infrastructure/config\";\nimport { SymbolicIndex } from \"../../../infrastructure/storage\";\nimport type { EmbeddingConfig, Logger } from \"../../../domain/ports\";\nimport type { FileSummary, ChunkType } from \"../../../domain/entities\";\n\n/** Default minimum similarity score for search results */\nexport const DEFAULT_MIN_SCORE = 0.15;\n\n/** Default number of results to return */\nexport const DEFAULT_TOP_K = 10;\n\n/** Weight for semantic similarity in hybrid scoring (0-1) */\nconst SEMANTIC_WEIGHT = 0.7;\n\n/** Weight for BM25 keyword matching in hybrid scoring (0-1) */\nconst BM25_WEIGHT = 0.3;\n\n/** File extensions supported by this module */\nexport const MARKDOWN_EXTENSIONS = [\".md\", \".txt\"];\n\n/**\n * Check if a file is supported by this module.\n */\nexport function isMarkdownFile(filepath: string): boolean {\n const ext = path.extname(filepath).toLowerCase();\n return MARKDOWN_EXTENSIONS.includes(ext);\n}\n\n// Re-export for module interface\nexport const supportsFile = isMarkdownFile;\n\n/**\n * Represents a parsed section from a Markdown document.\n */\ninterface MarkdownSection {\n /** The heading text (without #) */\n heading: string;\n /** The heading level (1-6) */\n level: number;\n /** The content under this heading */\n content: string;\n /** 1-based start line number */\n startLine: number;\n /** 1-based end line number */\n endLine: number;\n}\n\n/**\n * Parse Markdown content into sections based on headings.\n */\nfunction parseMarkdownSections(content: string): MarkdownSection[] {\n const lines = content.split(\"\\n\");\n const sections: MarkdownSection[] = [];\n\n let currentSection: MarkdownSection | null = null;\n let currentContent: string[] = [];\n let startLine = 1;\n\n for (let i = 0; i < lines.length; i++) {\n const line = lines[i];\n const headingMatch = line.match(/^(#{1,6})\\s+(.+)$/);\n\n if (headingMatch) {\n // Save previous section\n if (currentSection) {\n currentSection.content = currentContent.join(\"\\n\").trim();\n currentSection.endLine = i; // Previous line\n if (currentSection.content || currentSection.heading) {\n sections.push(currentSection);\n }\n } else if (currentContent.length > 0) {\n // Content before first heading\n sections.push({\n heading: \"\",\n level: 0,\n content: currentContent.join(\"\\n\").trim(),\n startLine: 1,\n endLine: i,\n });\n }\n\n // Start new section\n currentSection = {\n heading: headingMatch[2],\n level: headingMatch[1].length,\n content: \"\",\n startLine: i + 1,\n endLine: lines.length,\n };\n currentContent = [];\n } else {\n currentContent.push(line);\n }\n }\n\n // Save final section\n if (currentSection) {\n currentSection.content = currentContent.join(\"\\n\").trim();\n currentSection.endLine = lines.length;\n if (currentSection.content || currentSection.heading) {\n sections.push(currentSection);\n }\n } else if (currentContent.length > 0) {\n // No headings at all\n sections.push({\n heading: \"\",\n level: 0,\n content: currentContent.join(\"\\n\").trim(),\n startLine: 1,\n endLine: lines.length,\n });\n }\n\n return sections;\n}\n\n/**\n * Extract keywords from Markdown content.\n */\nfunction extractMarkdownKeywords(content: string): string[] {\n const keywords: string[] = [];\n\n // Extract headings\n const headingMatches = content.matchAll(/^#{1,6}\\s+(.+)$/gm);\n for (const match of headingMatches) {\n const heading = match[1].toLowerCase();\n const words = heading.split(/\\s+/).filter((w) => w.length > 2);\n keywords.push(...words);\n }\n\n // Extract bold/emphasized text\n const emphasisMatches = content.matchAll(/\\*\\*(.+?)\\*\\*|\\*(.+?)\\*/g);\n for (const match of emphasisMatches) {\n const text = (match[1] || match[2] || \"\").toLowerCase();\n const words = text.split(/\\s+/).filter((w) => w.length > 2);\n keywords.push(...words);\n }\n\n // Extract code blocks (inline)\n const codeMatches = content.matchAll(/`([^`]+)`/g);\n for (const match of codeMatches) {\n const code = match[1].toLowerCase();\n if (code.length > 2 && code.length < 50) {\n keywords.push(code);\n }\n }\n\n // Extract links\n const linkMatches = content.matchAll(/\\[([^\\]]+)\\]/g);\n for (const match of linkMatches) {\n const text = match[1].toLowerCase();\n const words = text.split(/\\s+/).filter((w) => w.length > 2);\n keywords.push(...words);\n }\n\n return [...new Set(keywords)];\n}\n\n/**\n * Module-specific data stored alongside file index\n */\nexport interface MarkdownModuleData {\n embeddings: number[][];\n embeddingModel: string;\n headings: string[];\n [key: string]: unknown;\n}\n\nexport class MarkdownModule implements IndexModule {\n readonly id = \"docs/markdown\";\n readonly name = \"Markdown Search\";\n readonly description =\n \"Markdown documentation search with section-aware indexing\";\n readonly version = \"1.0.0\";\n\n supportsFile(filepath: string): boolean {\n return isMarkdownFile(filepath);\n }\n\n private embeddingConfig: EmbeddingConfig | null = null;\n private symbolicIndex: SymbolicIndex | null = null;\n private pendingSummaries: Map<string, FileSummary> = new Map();\n private rootDir: string = \"\";\n private logger: Logger | undefined = undefined;\n\n async initialize(config: ModuleConfig): Promise<void> {\n this.embeddingConfig = getEmbeddingConfigFromModule(config);\n this.logger = config.options?.logger as Logger | undefined;\n\n if (this.logger) {\n this.embeddingConfig = {\n ...this.embeddingConfig,\n logger: this.logger,\n };\n }\n\n configureEmbeddings(this.embeddingConfig);\n this.pendingSummaries.clear();\n }\n\n async indexFile(\n filepath: string,\n content: string,\n ctx: IndexContext\n ): Promise<FileIndex | null> {\n // Only process Markdown files\n if (!isMarkdownFile(filepath)) {\n return null;\n }\n\n this.rootDir = ctx.rootDir;\n\n // Parse Markdown into sections\n const sections = parseMarkdownSections(content);\n\n if (sections.length === 0) {\n return null;\n }\n\n // Generate embeddings for sections\n const chunkContents = sections.map((s) => {\n const filename = path.basename(filepath);\n const headingContext = s.heading ? `${s.heading}: ` : \"\";\n return `${filename} ${headingContext}${s.content}`;\n });\n const embeddings = await getEmbeddings(chunkContents);\n\n // Create chunks from sections\n const chunks: Chunk[] = sections.map((section, i) => ({\n id: generateChunkId(filepath, section.startLine, section.endLine),\n content: section.heading\n ? `## ${section.heading}\\n\\n${section.content}`\n : section.content,\n startLine: section.startLine,\n endLine: section.endLine,\n type: \"block\" as ChunkType,\n name: section.heading || undefined,\n }));\n\n // Extract headings for metadata\n const headings = sections.filter((s) => s.heading).map((s) => s.heading);\n\n const stats = await ctx.getFileStats(filepath);\n const currentConfig = getEmbeddingConfig();\n\n const moduleData: MarkdownModuleData = {\n embeddings,\n embeddingModel: currentConfig.model,\n headings,\n };\n\n // Build file summary\n const keywords = extractMarkdownKeywords(content);\n\n const fileSummary: FileSummary = {\n filepath,\n chunkCount: chunks.length,\n chunkTypes: [\"block\"],\n keywords,\n exports: headings, // Use headings as \"exports\" for searchability\n lastModified: stats.lastModified,\n };\n\n this.pendingSummaries.set(filepath, fileSummary);\n\n return {\n filepath,\n lastModified: stats.lastModified,\n chunks,\n moduleData,\n };\n }\n\n async finalize(ctx: IndexContext): Promise<void> {\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n\n // Initialize symbolic index (loads existing data including BM25)\n this.symbolicIndex = new SymbolicIndex(indexDir, this.id);\n await this.symbolicIndex.initialize();\n\n // Track which files were updated for incremental save\n const updatedFilepaths: string[] = [];\n\n // Add all pending summaries incrementally (updates BM25 as we go)\n for (const [filepath, summary] of this.pendingSummaries) {\n this.symbolicIndex.addFileIncremental(summary);\n updatedFilepaths.push(filepath);\n }\n\n // Save to disk (only saves updated files + serialized BM25)\n if (updatedFilepaths.length > 0) {\n await this.symbolicIndex.saveIncremental(updatedFilepaths);\n }\n\n this.pendingSummaries.clear();\n }\n\n async search(\n query: string,\n ctx: SearchContext,\n options: SearchOptions = {}\n ): Promise<SearchResult[]> {\n const {\n topK = DEFAULT_TOP_K,\n minScore = DEFAULT_MIN_SCORE,\n filePatterns,\n } = options;\n\n const indexDir = getRaggrepDir(ctx.rootDir, ctx.config);\n const symbolicIndex = new SymbolicIndex(indexDir, this.id);\n\n let allFiles: string[];\n\n try {\n await symbolicIndex.initialize();\n allFiles = symbolicIndex.getAllFiles();\n } catch {\n allFiles = await ctx.listIndexedFiles();\n }\n\n // Filter to Markdown files only\n let filesToSearch = allFiles.filter((f) => isMarkdownFile(f));\n\n if (filePatterns && filePatterns.length > 0) {\n filesToSearch = filesToSearch.filter((filepath) => {\n return filePatterns.some((pattern) => {\n if (pattern.startsWith(\"*.\")) {\n const ext = pattern.slice(1);\n return filepath.endsWith(ext);\n }\n return filepath.includes(pattern);\n });\n });\n }\n\n const queryEmbedding = await getEmbedding(query);\n const bm25Index = new BM25Index();\n const allChunksData: Array<{\n filepath: string;\n chunk: Chunk;\n embedding: number[];\n }> = [];\n\n for (const filepath of filesToSearch) {\n const fileIndex = await ctx.loadFileIndex(filepath);\n if (!fileIndex) continue;\n\n const moduleData = fileIndex.moduleData as unknown as MarkdownModuleData;\n if (!moduleData?.embeddings) continue;\n\n for (let i = 0; i < fileIndex.chunks.length; i++) {\n const chunk = fileIndex.chunks[i];\n const embedding = moduleData.embeddings[i];\n\n if (!embedding) continue;\n\n allChunksData.push({\n filepath: fileIndex.filepath,\n chunk,\n embedding,\n });\n\n bm25Index.addDocuments([{ id: chunk.id, content: chunk.content }]);\n }\n }\n\n const bm25Results = bm25Index.search(query, topK * 3);\n const bm25Scores = new Map<string, number>();\n\n for (const result of bm25Results) {\n bm25Scores.set(result.id, normalizeScore(result.score, 3));\n }\n\n const queryTerms = extractQueryTerms(query);\n const results: SearchResult[] = [];\n\n for (const { filepath, chunk, embedding } of allChunksData) {\n const semanticScore = cosineSimilarity(queryEmbedding, embedding);\n const bm25Score = bm25Scores.get(chunk.id) || 0;\n\n // Documentation files get a small boost for documentation-intent queries\n let docBoost = 0;\n if (\n queryTerms.some((t) =>\n [\n \"docs\",\n \"documentation\",\n \"readme\",\n \"guide\",\n \"how\",\n \"what\",\n \"explain\",\n ].includes(t)\n )\n ) {\n docBoost = 0.05;\n }\n\n const hybridScore =\n SEMANTIC_WEIGHT * semanticScore + BM25_WEIGHT * bm25Score + docBoost;\n\n if (hybridScore >= minScore || bm25Score > 0.3) {\n results.push({\n filepath,\n chunk,\n score: hybridScore,\n moduleId: this.id,\n context: {\n semanticScore,\n bm25Score,\n docBoost,\n },\n });\n }\n }\n\n results.sort((a, b) => b.score - a.score);\n return results.slice(0, topK);\n }\n}\n\n\n\n\n",
42
42
  "// Module registry - manages available index modules\nimport { IndexModule, ModuleRegistry, Config } from \"../types\";\n\nclass ModuleRegistryImpl implements ModuleRegistry {\n private modules = new Map<string, IndexModule>();\n\n register(module: IndexModule): void {\n // Idempotent registration: avoid noisy logs when called multiple times\n if (!this.modules.has(module.id)) {\n this.modules.set(module.id, module);\n }\n }\n\n get(id: string): IndexModule | undefined {\n return this.modules.get(id);\n }\n\n list(): IndexModule[] {\n return Array.from(this.modules.values());\n }\n\n getEnabled(config: Config): IndexModule[] {\n const enabledIds = new Set(\n config.modules.filter((m) => m.enabled).map((m) => m.id)\n );\n\n return this.list().filter((m) => enabledIds.has(m.id));\n }\n}\n\n// Global singleton registry\nexport const registry: ModuleRegistry = new ModuleRegistryImpl();\n\n// Auto-register built-in modules\nexport async function registerBuiltInModules(): Promise<void> {\n // Dynamic import to avoid circular dependencies\n const { CoreModule } = await import(\"./core\");\n const { TypeScriptModule } = await import(\"./language/typescript\");\n const { JsonModule } = await import(\"./data/json\");\n const { MarkdownModule } = await import(\"./docs/markdown\");\n\n // Register core module first (fast, language-agnostic)\n registry.register(new CoreModule());\n\n // Register language-specific modules\n registry.register(new TypeScriptModule());\n\n // Register data format modules\n registry.register(new JsonModule());\n\n // Register documentation modules\n registry.register(new MarkdownModule());\n}\n",
43
- "/**\n * Project Structure Detection\n *\n * Auto-detects monorepo structure and project types from:\n * - Folder layout (apps/, packages/, etc.)\n * - package.json files (for TypeScript/JavaScript projects)\n *\n * This module performs file I/O to scan the filesystem.\n */\n\nimport * as path from \"path\";\nimport * as fs from \"fs/promises\";\nimport type {\n Project,\n ProjectType,\n ProjectStructure,\n} from \"../../domain/entities/introspection\";\n\n/** Maximum depth to scan for package.json files */\nconst MAX_SCAN_DEPTH = 4;\n\n/** Directories to skip when scanning for package.json */\nconst SKIP_DIRS = new Set([\n \"node_modules\",\n \".git\",\n \"dist\",\n \"build\",\n \".next\",\n \".nuxt\",\n \"coverage\",\n \".raggrep\",\n]);\n\n/**\n * Parsed information from a package.json file.\n */\ninterface PackageJsonInfo {\n name: string;\n relativePath: string;\n type: ProjectType;\n hasWorkspaces: boolean;\n}\n\n/**\n * Scan for package.json files and extract project info.\n */\nasync function scanForPackageJsons(\n rootDir: string,\n currentDir: string = \"\",\n depth: number = 0\n): Promise<PackageJsonInfo[]> {\n if (depth > MAX_SCAN_DEPTH) return [];\n\n const results: PackageJsonInfo[] = [];\n const fullDir = currentDir ? path.join(rootDir, currentDir) : rootDir;\n\n try {\n const entries = await fs.readdir(fullDir, { withFileTypes: true });\n\n // Check for package.json in current directory\n const hasPackageJson = entries.some(\n (e) => e.isFile() && e.name === \"package.json\"\n );\n\n if (hasPackageJson && currentDir) {\n const info = await parsePackageJson(rootDir, currentDir);\n if (info) results.push(info);\n }\n\n // Recursively scan subdirectories\n for (const entry of entries) {\n if (!entry.isDirectory()) continue;\n if (SKIP_DIRS.has(entry.name)) continue;\n\n const subPath = currentDir ? `${currentDir}/${entry.name}` : entry.name;\n const subResults = await scanForPackageJsons(rootDir, subPath, depth + 1);\n results.push(...subResults);\n }\n } catch {\n // Directory not readable\n }\n\n return results;\n}\n\n/**\n * Parse a package.json file and extract project metadata.\n */\nasync function parsePackageJson(\n rootDir: string,\n relativePath: string\n): Promise<PackageJsonInfo | null> {\n try {\n const packageJsonPath = path.join(rootDir, relativePath, \"package.json\");\n const content = await fs.readFile(packageJsonPath, \"utf-8\");\n const pkg = JSON.parse(content);\n\n const name = pkg.name || path.basename(relativePath);\n const deps = { ...pkg.dependencies, ...pkg.devDependencies };\n let type: ProjectType = \"unknown\";\n\n if (deps[\"next\"] || deps[\"react\"] || deps[\"vue\"] || deps[\"svelte\"]) {\n type = \"app\";\n } else if (\n deps[\"express\"] ||\n deps[\"fastify\"] ||\n deps[\"koa\"] ||\n deps[\"hono\"]\n ) {\n type = \"service\";\n } else if (pkg.main || pkg.exports) {\n type = \"library\";\n }\n\n const hasWorkspaces = Boolean(pkg.workspaces);\n return { name, relativePath, type, hasWorkspaces };\n } catch {\n return null;\n }\n}\n\n/**\n * Get project type from pattern directory name.\n */\nfunction getProjectType(patternDir: string): ProjectType {\n switch (patternDir) {\n case \"apps\":\n return \"app\";\n case \"packages\":\n case \"libs\":\n return \"library\";\n case \"services\":\n return \"service\";\n case \"scripts\":\n case \"tools\":\n return \"script\";\n default:\n return \"unknown\";\n }\n}\n\n/**\n * Detect project structure in a workspace.\n *\n * Uses two strategies:\n * 1. Folder pattern detection (apps/, packages/, etc.)\n * 2. package.json scanning for more accurate project boundaries\n */\nexport async function detectProjectStructure(\n rootDir: string\n): Promise<ProjectStructure> {\n const projectMap = new Map<string, Project>();\n let isMonorepo = false;\n\n try {\n const entries = await fs.readdir(rootDir, { withFileTypes: true });\n const dirNames = entries.filter((e) => e.isDirectory()).map((e) => e.name);\n\n // Strategy 1: Check for standard monorepo patterns\n const monorepoPatterns = [\"apps\", \"packages\", \"libs\", \"services\"];\n const hasMonorepoStructure = monorepoPatterns.some((p) =>\n dirNames.includes(p)\n );\n\n if (hasMonorepoStructure) {\n isMonorepo = true;\n\n for (const pattern of monorepoPatterns) {\n if (!dirNames.includes(pattern)) continue;\n\n const patternDir = path.join(rootDir, pattern);\n try {\n const subDirs = await fs.readdir(patternDir, { withFileTypes: true });\n\n for (const subDir of subDirs) {\n if (!subDir.isDirectory()) continue;\n\n const projectRoot = `${pattern}/${subDir.name}`;\n const type = getProjectType(pattern);\n\n projectMap.set(projectRoot, {\n name: subDir.name,\n root: projectRoot,\n type,\n });\n }\n } catch {\n // Directory doesn't exist or not readable\n }\n }\n }\n\n // Strategy 2: Scan for package.json files\n const packageJsons = await scanForPackageJsons(rootDir);\n\n for (const pkg of packageJsons) {\n if (pkg.hasWorkspaces) isMonorepo = true;\n if (packageJsons.length > 1) isMonorepo = true;\n\n projectMap.set(pkg.relativePath, {\n name: pkg.name,\n root: pkg.relativePath,\n type: pkg.type,\n });\n }\n\n // Check root package.json\n let rootType: ProjectType = \"unknown\";\n try {\n const rootPkgPath = path.join(rootDir, \"package.json\");\n const rootPkg = JSON.parse(await fs.readFile(rootPkgPath, \"utf-8\"));\n\n if (rootPkg.workspaces) isMonorepo = true;\n\n const deps = { ...rootPkg.dependencies, ...rootPkg.devDependencies };\n if (deps[\"next\"] || deps[\"react\"] || deps[\"vue\"]) {\n rootType = \"app\";\n } else if (deps[\"express\"] || deps[\"fastify\"] || deps[\"koa\"]) {\n rootType = \"service\";\n }\n } catch {\n // No package.json\n }\n\n const projects = Array.from(projectMap.values()).sort(\n (a, b) => a.root.length - b.root.length\n );\n\n return {\n projects,\n isMonorepo,\n rootType: isMonorepo ? undefined : rootType,\n };\n } catch {\n return {\n projects: [],\n isMonorepo: false,\n rootType: \"unknown\",\n };\n }\n}\n\n\n\n\n",
43
+ "/**\n * Project Structure Detection\n *\n * Auto-detects monorepo structure and project types from:\n * - Folder layout (apps/, packages/, etc.)\n * - package.json files (for TypeScript/JavaScript projects)\n *\n * This module performs file I/O to scan the filesystem.\n */\n\nimport * as path from \"path\";\nimport * as fs from \"fs/promises\";\nimport type {\n Project,\n ProjectType,\n ProjectStructure,\n} from \"../../domain/entities/introspection\";\n\n/** Maximum depth to scan for package.json files */\nconst MAX_SCAN_DEPTH = 4;\n\n/** Directories to skip when scanning for package.json */\nconst SKIP_DIRS = new Set([\n \"node_modules\",\n \".git\",\n \"dist\",\n \"build\",\n \".next\",\n \".nuxt\",\n \"coverage\",\n \".raggrep\",\n]);\n\n/**\n * Parsed information from a package.json file.\n */\ninterface PackageJsonInfo {\n name: string;\n relativePath: string;\n type: ProjectType;\n hasWorkspaces: boolean;\n}\n\n/**\n * Scan for package.json files and extract project info.\n */\nasync function scanForPackageJsons(\n rootDir: string,\n currentDir: string = \"\",\n depth: number = 0\n): Promise<PackageJsonInfo[]> {\n if (depth > MAX_SCAN_DEPTH) return [];\n\n const results: PackageJsonInfo[] = [];\n const fullDir = currentDir ? path.join(rootDir, currentDir) : rootDir;\n\n try {\n const entries = await fs.readdir(fullDir, { withFileTypes: true });\n\n // Check for package.json in current directory\n const hasPackageJson = entries.some(\n (e) => e.isFile() && e.name === \"package.json\"\n );\n\n if (hasPackageJson && currentDir) {\n const info = await parsePackageJson(rootDir, currentDir);\n if (info) results.push(info);\n }\n\n // Recursively scan subdirectories\n for (const entry of entries) {\n if (!entry.isDirectory()) continue;\n if (SKIP_DIRS.has(entry.name)) continue;\n\n const subPath = currentDir ? `${currentDir}/${entry.name}` : entry.name;\n const subResults = await scanForPackageJsons(rootDir, subPath, depth + 1);\n results.push(...subResults);\n }\n } catch {\n // Directory not readable\n }\n\n return results;\n}\n\n/**\n * Parse a package.json file and extract project metadata.\n */\nasync function parsePackageJson(\n rootDir: string,\n relativePath: string\n): Promise<PackageJsonInfo | null> {\n try {\n const packageJsonPath = path.join(rootDir, relativePath, \"package.json\");\n const content = await fs.readFile(packageJsonPath, \"utf-8\");\n const pkg = JSON.parse(content);\n\n const name = pkg.name || path.basename(relativePath);\n const deps = { ...pkg.dependencies, ...pkg.devDependencies };\n let type: ProjectType = \"unknown\";\n\n if (deps[\"next\"] || deps[\"react\"] || deps[\"vue\"] || deps[\"svelte\"]) {\n type = \"app\";\n } else if (\n deps[\"express\"] ||\n deps[\"fastify\"] ||\n deps[\"koa\"] ||\n deps[\"hono\"]\n ) {\n type = \"service\";\n } else if (pkg.main || pkg.exports) {\n type = \"library\";\n }\n\n const hasWorkspaces = Boolean(pkg.workspaces);\n return { name, relativePath, type, hasWorkspaces };\n } catch {\n return null;\n }\n}\n\n/**\n * Get project type from pattern directory name.\n */\nfunction getProjectType(patternDir: string): ProjectType {\n switch (patternDir) {\n case \"apps\":\n return \"app\";\n case \"packages\":\n case \"libs\":\n return \"library\";\n case \"services\":\n return \"service\";\n case \"scripts\":\n case \"tools\":\n return \"script\";\n default:\n return \"unknown\";\n }\n}\n\n/**\n * Detect project structure in a workspace.\n *\n * Uses two strategies:\n * 1. Folder pattern detection (apps/, packages/, etc.)\n * 2. package.json scanning for more accurate project boundaries\n */\nexport async function detectProjectStructure(\n rootDir: string\n): Promise<ProjectStructure> {\n const projectMap = new Map<string, Project>();\n let isMonorepo = false;\n\n try {\n const entries = await fs.readdir(rootDir, { withFileTypes: true });\n const dirNames = entries.filter((e) => e.isDirectory()).map((e) => e.name);\n\n // Strategy 1: Check for standard monorepo patterns\n const monorepoPatterns = [\"apps\", \"packages\", \"libs\", \"services\"];\n const hasMonorepoStructure = monorepoPatterns.some((p) =>\n dirNames.includes(p)\n );\n\n if (hasMonorepoStructure) {\n isMonorepo = true;\n\n for (const pattern of monorepoPatterns) {\n if (!dirNames.includes(pattern)) continue;\n\n const patternDir = path.join(rootDir, pattern);\n try {\n const subDirs = await fs.readdir(patternDir, { withFileTypes: true });\n\n for (const subDir of subDirs) {\n if (!subDir.isDirectory()) continue;\n\n const projectRoot = `${pattern}/${subDir.name}`;\n const type = getProjectType(pattern);\n\n projectMap.set(projectRoot, {\n name: subDir.name,\n root: projectRoot,\n type,\n });\n }\n } catch {\n // Directory doesn't exist or not readable\n }\n }\n }\n\n // Strategy 2: Scan for package.json files\n const packageJsons = await scanForPackageJsons(rootDir);\n\n for (const pkg of packageJsons) {\n if (pkg.hasWorkspaces) isMonorepo = true;\n if (packageJsons.length > 1) isMonorepo = true;\n\n projectMap.set(pkg.relativePath, {\n name: pkg.name,\n root: pkg.relativePath,\n type: pkg.type,\n });\n }\n\n // Check root package.json\n let rootType: ProjectType = \"unknown\";\n try {\n const rootPkgPath = path.join(rootDir, \"package.json\");\n const rootPkg = JSON.parse(await fs.readFile(rootPkgPath, \"utf-8\"));\n\n if (rootPkg.workspaces) isMonorepo = true;\n\n const deps = { ...rootPkg.dependencies, ...rootPkg.devDependencies };\n if (deps[\"next\"] || deps[\"react\"] || deps[\"vue\"]) {\n rootType = \"app\";\n } else if (deps[\"express\"] || deps[\"fastify\"] || deps[\"koa\"]) {\n rootType = \"service\";\n }\n } catch {\n // No package.json\n }\n\n const projects = Array.from(projectMap.values()).sort(\n (a, b) => a.root.length - b.root.length\n );\n\n return {\n projects,\n isMonorepo,\n rootType: isMonorepo ? undefined : rootType,\n };\n } catch {\n return {\n projects: [],\n isMonorepo: false,\n rootType: \"unknown\",\n };\n }\n}\n\n\n\n\n\n\n\n",
44
44
  "/**\n * Introspection Index Storage\n *\n * Manages file metadata for context-aware search boosting.\n * Handles saving and loading introspection data to/from disk.\n */\n\nimport * as path from \"path\";\nimport * as fs from \"fs/promises\";\nimport type {\n FileIntrospection,\n ProjectStructure,\n IntrospectionConfig,\n Scope,\n Config,\n} from \"../../domain/entities\";\nimport { detectProjectStructure } from \"./projectDetector\";\nimport { introspectFile } from \"../../domain/services/introspection\";\nimport { getRaggrepDir } from \"../config\";\n\n/**\n * Introspection index for a workspace.\n */\nexport class IntrospectionIndex {\n private rootDir: string;\n private structure: ProjectStructure | null = null;\n private files: Map<string, FileIntrospection> = new Map();\n private config: IntrospectionConfig = {};\n\n constructor(rootDir: string) {\n this.rootDir = rootDir;\n }\n\n /**\n * Initialize by detecting project structure.\n */\n async initialize(): Promise<void> {\n this.structure = await detectProjectStructure(this.rootDir);\n\n // Try to load config overrides\n try {\n const configPath = path.join(this.rootDir, \".raggrep\", \"config.json\");\n const configContent = await fs.readFile(configPath, \"utf-8\");\n const config = JSON.parse(configContent);\n this.config = config.introspection || {};\n } catch {\n // No config or introspection section\n }\n }\n\n /**\n * Get project structure.\n */\n getStructure(): ProjectStructure | null {\n return this.structure;\n }\n\n /**\n * Introspect a file and add to index.\n */\n addFile(filepath: string, content?: string): FileIntrospection {\n if (!this.structure) {\n throw new Error(\"IntrospectionIndex not initialized\");\n }\n\n const intro = introspectFile(filepath, this.structure, content);\n\n // Apply config overrides\n this.applyOverrides(intro);\n\n this.files.set(filepath, intro);\n return intro;\n }\n\n /**\n * Get introspection for a file.\n */\n getFile(filepath: string): FileIntrospection | undefined {\n return this.files.get(filepath);\n }\n\n /**\n * Get all introspected files.\n */\n getAllFiles(): FileIntrospection[] {\n return Array.from(this.files.values());\n }\n\n /**\n * Apply config overrides to introspection.\n */\n private applyOverrides(intro: FileIntrospection): void {\n if (!this.config.projects) return;\n\n for (const [projectPath, overrides] of Object.entries(\n this.config.projects\n )) {\n if (\n intro.filepath.startsWith(projectPath + \"/\") ||\n intro.project.root === projectPath\n ) {\n if (overrides.scope) {\n intro.scope = overrides.scope as Scope;\n }\n if (overrides.framework) {\n intro.framework = overrides.framework;\n }\n break;\n }\n }\n }\n\n /**\n * Save introspection index to disk.\n */\n async save(config: Config): Promise<void> {\n const introDir = path.join(\n getRaggrepDir(this.rootDir, config),\n \"introspection\"\n );\n await fs.mkdir(introDir, { recursive: true });\n\n // Save project structure\n const projectPath = path.join(introDir, \"_project.json\");\n await fs.writeFile(\n projectPath,\n JSON.stringify(\n {\n version: \"1.0.0\",\n lastUpdated: new Date().toISOString(),\n structure: this.structure,\n },\n null,\n 2\n )\n );\n\n // Save file introspections in directory structure\n for (const [filepath, intro] of this.files) {\n const introFilePath = path.join(\n introDir,\n \"files\",\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n await fs.mkdir(path.dirname(introFilePath), { recursive: true });\n await fs.writeFile(introFilePath, JSON.stringify(intro, null, 2));\n }\n }\n\n /**\n * Load introspection index from disk.\n */\n async load(config: Config): Promise<void> {\n const introDir = path.join(\n getRaggrepDir(this.rootDir, config),\n \"introspection\"\n );\n\n try {\n // Load project structure\n const projectPath = path.join(introDir, \"_project.json\");\n const projectContent = await fs.readFile(projectPath, \"utf-8\");\n const projectData = JSON.parse(projectContent);\n this.structure = projectData.structure;\n\n // Load file introspections\n await this.loadFilesRecursive(path.join(introDir, \"files\"), \"\");\n } catch {\n // No introspection index yet\n this.structure = null;\n this.files.clear();\n }\n }\n\n /**\n * Recursively load file introspections.\n */\n private async loadFilesRecursive(\n basePath: string,\n prefix: string\n ): Promise<void> {\n try {\n const entries = await fs.readdir(basePath, { withFileTypes: true });\n\n for (const entry of entries) {\n const entryPath = path.join(basePath, entry.name);\n const relativePath = prefix ? `${prefix}/${entry.name}` : entry.name;\n\n if (entry.isDirectory()) {\n await this.loadFilesRecursive(entryPath, relativePath);\n } else if (entry.name.endsWith(\".json\")) {\n const content = await fs.readFile(entryPath, \"utf-8\");\n const intro: FileIntrospection = JSON.parse(content);\n this.files.set(intro.filepath, intro);\n }\n }\n } catch {\n // Directory doesn't exist\n }\n }\n\n /**\n * Clear the index.\n */\n clear(): void {\n this.files.clear();\n this.structure = null;\n }\n}\n",
45
- "/**\n * Introspection Infrastructure\n *\n * File I/O operations for introspection:\n * - Project structure detection (filesystem scanning)\n * - Introspection index storage (save/load)\n */\n\nexport { IntrospectionIndex } from \"./IntrospectionIndex\";\nexport { detectProjectStructure } from \"./projectDetector\";\n\n\n\n\n",
45
+ "/**\n * Introspection Infrastructure\n *\n * File I/O operations for introspection:\n * - Project structure detection (filesystem scanning)\n * - Introspection index storage (save/load)\n */\n\nexport { IntrospectionIndex } from \"./IntrospectionIndex\";\nexport { detectProjectStructure } from \"./projectDetector\";\n\n\n\n\n\n\n\n",
46
46
  "/**\n * File watcher for incremental indexing\n * \n * Best practices implemented:\n * - Debouncing: Batches rapid file changes (e.g., IDE saves, git operations)\n * - Queuing: Prevents concurrent index operations\n * - Efficient filtering: Only watches relevant file types\n * - Graceful shutdown: Proper cleanup on SIGINT/SIGTERM\n * - Error recovery: Continues watching after index errors\n */\n\nimport { watch, type FSWatcher } from 'chokidar';\nimport * as path from 'path';\nimport { loadConfig, getIndexLocation } from '../../infrastructure/config';\nimport type { Config } from '../../domain/entities';\nimport { indexDirectory, cleanupIndex, type IndexOptions, type IndexResult } from './index';\n\n/** Default debounce delay in milliseconds */\nconst DEFAULT_DEBOUNCE_MS = 300;\n\n/** Maximum files to batch before forcing an index */\nconst MAX_BATCH_SIZE = 100;\n\nexport interface WatchOptions extends IndexOptions {\n /** Debounce delay in milliseconds (default: 300) */\n debounceMs?: number;\n /** Callback when indexing starts */\n onIndexStart?: (files: string[]) => void;\n /** Callback when indexing completes */\n onIndexComplete?: (results: IndexResult[]) => void;\n /** Callback when a file change is detected */\n onFileChange?: (event: 'add' | 'change' | 'unlink', filepath: string) => void;\n /** Callback for errors */\n onError?: (error: Error) => void;\n}\n\nexport interface FileWatcher {\n /** Stop watching and clean up */\n stop: () => Promise<void>;\n /** Whether the watcher is currently running */\n isRunning: () => boolean;\n}\n\n/**\n * Start watching a directory for file changes and index incrementally\n */\nexport async function watchDirectory(\n rootDir: string,\n options: WatchOptions = {}\n): Promise<FileWatcher> {\n const {\n debounceMs = DEFAULT_DEBOUNCE_MS,\n verbose = false,\n model,\n onIndexStart,\n onIndexComplete,\n onFileChange,\n onError,\n } = options;\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n \n // Load config\n const config = await loadConfig(rootDir);\n \n // Get index location (now in temp directory, so no need to ignore in project)\n const indexLocation = getIndexLocation(rootDir);\n \n // Create a set of valid extensions for fast lookup\n const validExtensions = new Set(config.extensions);\n \n // Build ignore patterns - watch directory, filter by extension\n const ignorePatterns = [\n ...config.ignorePaths.map(p => `**/${p}/**`),\n '**/node_modules/**',\n '**/.git/**',\n ];\n \n /**\n * Check if a file should be watched based on its extension\n */\n function shouldWatchFile(filepath: string): boolean {\n const ext = path.extname(filepath);\n return validExtensions.has(ext);\n }\n\n // State management\n let isRunning = true;\n let isIndexing = false;\n let pendingChanges = new Map<string, 'add' | 'change' | 'unlink'>();\n let debounceTimer: ReturnType<typeof setTimeout> | null = null;\n let watcher: FSWatcher | null = null;\n\n /**\n * Process pending file changes\n */\n async function processPendingChanges(): Promise<void> {\n if (!isRunning || isIndexing || pendingChanges.size === 0) {\n return;\n }\n\n isIndexing = true;\n const changes = new Map(pendingChanges);\n pendingChanges.clear();\n\n try {\n // Separate additions/changes from deletions\n const filesToIndex: string[] = [];\n const filesToDelete: string[] = [];\n\n for (const [filepath, event] of changes) {\n if (event === 'unlink') {\n filesToDelete.push(filepath);\n } else {\n filesToIndex.push(filepath);\n }\n }\n\n // Handle deletions via cleanup\n if (filesToDelete.length > 0) {\n if (verbose) {\n console.log(`\\n[Watch] Cleaning up ${filesToDelete.length} deleted file(s)...`);\n }\n await cleanupIndex(rootDir, { verbose: false });\n }\n\n // Handle additions/changes via incremental index\n if (filesToIndex.length > 0) {\n if (onIndexStart) {\n onIndexStart(filesToIndex);\n }\n\n if (verbose) {\n console.log(`\\n[Watch] Indexing ${filesToIndex.length} changed file(s)...`);\n }\n\n const results = await indexDirectory(rootDir, {\n model,\n verbose: false, // Keep output clean in watch mode\n });\n\n if (onIndexComplete) {\n onIndexComplete(results);\n }\n\n // Print summary\n for (const result of results) {\n if (result.indexed > 0 || result.errors > 0) {\n console.log(`[Watch] ${result.moduleId}: ${result.indexed} indexed, ${result.errors} errors`);\n }\n }\n }\n } catch (error) {\n const err = error instanceof Error ? error : new Error(String(error));\n console.error('[Watch] Error during indexing:', err.message);\n if (onError) {\n onError(err);\n }\n } finally {\n isIndexing = false;\n\n // Process any changes that came in while we were indexing\n if (pendingChanges.size > 0) {\n scheduleProcessing();\n }\n }\n }\n\n /**\n * Schedule processing of pending changes (with debounce)\n */\n function scheduleProcessing(): void {\n if (debounceTimer) {\n clearTimeout(debounceTimer);\n }\n\n // Force processing if batch is too large\n if (pendingChanges.size >= MAX_BATCH_SIZE) {\n processPendingChanges();\n return;\n }\n\n debounceTimer = setTimeout(() => {\n debounceTimer = null;\n processPendingChanges();\n }, debounceMs);\n }\n\n /**\n * Handle a file event\n */\n function handleFileEvent(event: 'add' | 'change' | 'unlink', filepath: string): void {\n if (!isRunning) return;\n\n // Convert to relative path\n const relativePath = path.relative(rootDir, filepath);\n\n // Skip if file doesn't have a valid extension\n // For unlink events, we still need to check the extension to only clean up indexed files\n if (!shouldWatchFile(filepath)) {\n return;\n }\n\n // Skip if it's in an ignored directory (extra safety check)\n for (const ignorePath of config.ignorePaths) {\n if (relativePath.startsWith(ignorePath) || relativePath.includes(`/${ignorePath}/`)) {\n return;\n }\n }\n\n if (onFileChange) {\n onFileChange(event, relativePath);\n }\n\n if (verbose) {\n const symbol = event === 'add' ? '+' : event === 'unlink' ? '-' : '~';\n console.log(`[Watch] ${symbol} ${relativePath}`);\n }\n\n // Update pending changes (later events override earlier ones for same file)\n pendingChanges.set(relativePath, event);\n scheduleProcessing();\n }\n\n // Create the watcher - watch the directory itself (not glob patterns)\n // This ensures new files in new directories are detected\n watcher = watch(rootDir, {\n ignored: ignorePatterns,\n persistent: true,\n ignoreInitial: true, // Don't trigger events for existing files\n awaitWriteFinish: {\n stabilityThreshold: 100, // Wait for file to be stable\n pollInterval: 50,\n },\n // Performance optimizations\n usePolling: false, // Use native fs events when possible\n atomic: true, // Handle atomic writes (common in editors)\n // Watch directories for new file detection\n depth: 99, // Watch deeply nested directories\n });\n\n // Set up event handlers\n // When watching a directory directly, chokidar gives us absolute paths\n watcher.on('add', (filepath) => handleFileEvent('add', filepath));\n watcher.on('change', (filepath) => handleFileEvent('change', filepath));\n watcher.on('unlink', (filepath) => handleFileEvent('unlink', filepath));\n\n watcher.on('error', (error: unknown) => {\n const err = error instanceof Error ? error : new Error(String(error));\n console.error('[Watch] Watcher error:', err);\n if (onError) {\n onError(err);\n }\n });\n\n // Wait for watcher to be ready\n await new Promise<void>((resolve) => {\n watcher!.on('ready', () => {\n resolve();\n });\n });\n\n // Return control interface\n return {\n stop: async () => {\n isRunning = false;\n \n if (debounceTimer) {\n clearTimeout(debounceTimer);\n debounceTimer = null;\n }\n \n if (watcher) {\n await watcher.close();\n watcher = null;\n }\n },\n isRunning: () => isRunning,\n };\n}\n\n",
47
- "// Main indexer - coordinates modules for indexing files\nimport { glob } from \"glob\";\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport * as os from \"os\";\nimport {\n Config,\n IndexContext,\n IndexModule,\n ModuleManifest,\n GlobalManifest,\n FileIndex,\n} from \"../../types\";\nimport {\n DEFAULT_CONFIG,\n loadConfig,\n getModuleIndexPath,\n getModuleManifestPath,\n getGlobalManifestPath,\n getModuleConfig,\n getIndexLocation,\n getRaggrepDir,\n} from \"../../infrastructure/config\";\nimport { registry, registerBuiltInModules } from \"../../modules/registry\";\nimport type { EmbeddingModelName, Logger } from \"../../domain/ports\";\nimport { IntrospectionIndex } from \"../../infrastructure/introspection\";\nimport { createLogger, createSilentLogger } from \"../../infrastructure/logger\";\n\n// ============================================================================\n// Parallel Processing Utilities\n// ============================================================================\n\n/**\n * Process items in parallel with controlled concurrency.\n * Returns results in the same order as input items.\n *\n * @param items - Items to process\n * @param processor - Async function to process each item\n * @param concurrency - Maximum number of concurrent operations\n * @returns Array of results (or errors) in input order\n */\nasync function parallelMap<T, R>(\n items: T[],\n processor: (item: T, index: number) => Promise<R>,\n concurrency: number\n): Promise<\n Array<{ success: true; value: R } | { success: false; error: unknown }>\n> {\n const results: Array<\n { success: true; value: R } | { success: false; error: unknown }\n > = new Array(items.length);\n let nextIndex = 0;\n\n async function worker(): Promise<void> {\n while (nextIndex < items.length) {\n const index = nextIndex++;\n const item = items[index];\n try {\n const value = await processor(item, index);\n results[index] = { success: true, value };\n } catch (error) {\n results[index] = { success: false, error };\n }\n }\n }\n\n // Start workers up to concurrency limit\n const workers = Array(Math.min(concurrency, items.length))\n .fill(null)\n .map(() => worker());\n\n await Promise.all(workers);\n return results;\n}\n\n/**\n * Current index schema version.\n * Increment this when making breaking changes to the index format.\n * This is separate from the package version to allow non-breaking updates.\n *\n * History:\n * - 1.0.0: Initial version\n * - 1.1.0: Changed default embedding model to bge-small-en-v1.5, added nomic-embed-text-v1.5\n */\nconst INDEX_SCHEMA_VERSION = \"1.1.0\";\n\nexport interface IndexResult {\n moduleId: string;\n indexed: number;\n skipped: number;\n errors: number;\n /** Time taken in milliseconds */\n durationMs?: number;\n}\n\n/**\n * Format duration in human-readable format\n */\nfunction formatDuration(ms: number): string {\n if (ms < 1000) {\n return `${ms}ms`;\n }\n const seconds = ms / 1000;\n if (seconds < 60) {\n return `${seconds.toFixed(1)}s`;\n }\n const minutes = Math.floor(seconds / 60);\n const remainingSeconds = seconds % 60;\n return `${minutes}m ${remainingSeconds.toFixed(1)}s`;\n}\n\n/**\n * Get optimal concurrency based on CPU specs.\n *\n * Uses the number of CPU cores with some considerations:\n * - Minimum: 2 (ensure some parallelism)\n * - Maximum: 16 (avoid diminishing returns / memory pressure)\n * - For embedding generation, we leave 1-2 cores free for the system\n *\n * @returns Optimal concurrency value\n */\nfunction getOptimalConcurrency(): number {\n const cpuCount = os.cpus().length;\n\n // Leave some cores for system/other processes\n // For 4 cores: use 3\n // For 8 cores: use 6\n // For 16+ cores: use 12-14\n const optimal = Math.max(2, Math.min(16, Math.floor(cpuCount * 0.75)));\n\n return optimal;\n}\n\n/** Default concurrency for parallel file processing (dynamic based on CPU) */\nconst DEFAULT_CONCURRENCY = getOptimalConcurrency();\n\nexport interface IndexOptions {\n /** Override the embedding model (semantic module) */\n model?: EmbeddingModelName;\n /** Show detailed progress */\n verbose?: boolean;\n /** Suppress most output (for use during query) */\n quiet?: boolean;\n /** Logger for progress reporting. If not provided, uses console by default (quiet mode uses silent logger) */\n logger?: Logger;\n /** Number of files to process in parallel (default: auto based on CPU cores) */\n concurrency?: number;\n}\n\nexport interface EnsureFreshResult {\n /** Number of files indexed (new or modified) */\n indexed: number;\n /** Number of stale entries removed (deleted files) */\n removed: number;\n /** Number of files unchanged (used cache) */\n unchanged: number;\n}\n\nexport interface CleanupResult {\n moduleId: string;\n /** Number of stale entries removed */\n removed: number;\n /** Number of valid entries kept */\n kept: number;\n}\n\nexport interface IndexStatus {\n /** Whether an index exists */\n exists: boolean;\n /** Root directory path */\n rootDir: string;\n /** Index directory path */\n indexDir: string;\n /** Last time the index was updated */\n lastUpdated?: string;\n /** Active modules and their file counts */\n modules: Array<{\n id: string;\n fileCount: number;\n lastUpdated: string;\n }>;\n /** Total number of indexed files */\n totalFiles: number;\n}\n\n/**\n * Index a directory using all enabled modules\n */\nexport async function indexDirectory(\n rootDir: string,\n options: IndexOptions = {}\n): Promise<IndexResult[]> {\n const verbose = options.verbose ?? false;\n const quiet = options.quiet ?? false;\n const concurrency = options.concurrency ?? DEFAULT_CONCURRENCY;\n\n // Create logger based on options\n const logger: Logger = options.logger\n ? options.logger\n : quiet\n ? createSilentLogger()\n : createLogger({ verbose });\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Show index location\n const location = getIndexLocation(rootDir);\n logger.info(`Indexing directory: ${rootDir}`);\n logger.info(`Index location: ${location.indexDir}`);\n logger.debug(`Concurrency: ${concurrency}`);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Initialize introspection\n const introspection = new IntrospectionIndex(rootDir);\n await introspection.initialize();\n const structure = introspection.getStructure();\n if (structure?.isMonorepo) {\n logger.debug(\n `Detected monorepo with ${structure.projects.length} projects`\n );\n }\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Get enabled modules\n const enabledModules = registry.getEnabled(config);\n\n if (enabledModules.length === 0) {\n logger.info(\"No modules enabled. Check your configuration.\");\n return [];\n }\n\n logger.info(`Enabled modules: ${enabledModules.map((m) => m.id).join(\", \")}`);\n\n // Get all files matching extensions\n const files = await findFiles(rootDir, config);\n logger.info(`Found ${files.length} files to index`);\n\n // Track overall timing\n const overallStart = Date.now();\n\n // Index with each module\n const results: IndexResult[] = [];\n\n for (const module of enabledModules) {\n const moduleStart = Date.now();\n logger.info(`\\n[${module.name}] Starting indexing...`);\n\n // Initialize module if needed\n const moduleConfig = getModuleConfig(config, module.id);\n if (module.initialize && moduleConfig) {\n // Apply CLI overrides to module config, including logger\n const configWithOverrides = { ...moduleConfig };\n if (options.model && module.id === \"language/typescript\") {\n configWithOverrides.options = {\n ...configWithOverrides.options,\n embeddingModel: options.model,\n };\n }\n // Pass logger to module via options\n configWithOverrides.options = {\n ...configWithOverrides.options,\n logger,\n };\n await module.initialize(configWithOverrides);\n }\n\n // Pre-filter files that this module supports\n const moduleFiles = module.supportsFile\n ? files.filter((f) => module.supportsFile!(f))\n : files;\n\n logger.info(` Processing ${moduleFiles.length} files...`);\n\n const result = await indexWithModule(\n rootDir,\n moduleFiles,\n module,\n config,\n verbose,\n introspection,\n logger,\n concurrency\n );\n results.push(result);\n\n // Call finalize to build secondary indexes (Tier 1, BM25, etc.)\n if (module.finalize) {\n logger.info(`[${module.name}] Building secondary indexes...`);\n const ctx: IndexContext = {\n rootDir,\n config,\n readFile: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n return fs.readFile(fullPath, \"utf-8\");\n },\n getFileStats: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n const stats = await fs.stat(fullPath);\n return { lastModified: stats.mtime.toISOString() };\n },\n };\n await module.finalize(ctx);\n }\n\n const moduleDuration = Date.now() - moduleStart;\n result.durationMs = moduleDuration;\n\n logger.info(\n `[${module.name}] Complete: ${result.indexed} indexed, ${\n result.skipped\n } skipped, ${result.errors} errors (${formatDuration(moduleDuration)})`\n );\n }\n\n // Save introspection data\n await introspection.save(config);\n\n // Log overall timing\n const overallDuration = Date.now() - overallStart;\n logger.info(`\\nIndexing complete in ${formatDuration(overallDuration)}`);\n\n // Log summary\n const totalIndexed = results.reduce((sum, r) => sum + r.indexed, 0);\n const totalSkipped = results.reduce((sum, r) => sum + r.skipped, 0);\n const totalErrors = results.reduce((sum, r) => sum + r.errors, 0);\n logger.info(\n `Total: ${totalIndexed} indexed, ${totalSkipped} skipped, ${totalErrors} errors`\n );\n\n // Update global manifest\n await updateGlobalManifest(rootDir, enabledModules, config);\n\n return results;\n}\n\n/**\n * Check if the existing index version is compatible with the current schema.\n * Returns true if compatible, false if needs rebuild.\n */\nasync function isIndexVersionCompatible(rootDir: string): Promise<boolean> {\n const config = await loadConfig(rootDir);\n const globalManifestPath = getGlobalManifestPath(rootDir, config);\n\n try {\n const content = await fs.readFile(globalManifestPath, \"utf-8\");\n const manifest: GlobalManifest = JSON.parse(content);\n\n // Check if version matches current schema version\n return manifest.version === INDEX_SCHEMA_VERSION;\n } catch {\n // Can't read manifest - treat as incompatible\n return false;\n }\n}\n\n/**\n * Delete the entire index directory to allow a clean rebuild.\n */\nasync function deleteIndex(rootDir: string): Promise<void> {\n const indexDir = getRaggrepDir(rootDir);\n\n try {\n await fs.rm(indexDir, { recursive: true, force: true });\n } catch {\n // Directory may not exist, that's okay\n }\n}\n\n/**\n * Result of a reset operation\n */\nexport interface ResetResult {\n /** Whether the reset was successful */\n success: boolean;\n /** The index directory that was removed */\n indexDir: string;\n}\n\n/**\n * Reset (delete) the index for a directory.\n *\n * @param rootDir - Root directory of the project\n * @returns ResetResult with success status\n * @throws Error if no index exists\n */\nexport async function resetIndex(rootDir: string): Promise<ResetResult> {\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Check if index exists\n const status = await getIndexStatus(rootDir);\n\n if (!status.exists) {\n throw new Error(`No index found for ${rootDir}`);\n }\n\n // Delete the index\n await deleteIndex(rootDir);\n\n return {\n success: true,\n indexDir: status.indexDir,\n };\n}\n\n/**\n * Ensure the index is fresh by checking for changes and updating incrementally.\n * This function is designed to be called before search to transparently manage the index.\n *\n * - If no index exists, creates a full index\n * - If index version is incompatible, rebuilds from scratch\n * - If files have changed, re-indexes only the modified files\n * - If files have been deleted, removes stale entries\n * - If nothing changed, returns immediately (uses cache)\n *\n * @param rootDir - Root directory of the project\n * @param options - Index options\n * @returns Statistics about what was updated\n */\nexport async function ensureIndexFresh(\n rootDir: string,\n options: IndexOptions = {}\n): Promise<EnsureFreshResult> {\n const verbose = options.verbose ?? false;\n const quiet = options.quiet ?? false;\n\n // Create logger based on options\n const logger: Logger = options.logger\n ? options.logger\n : quiet\n ? createSilentLogger()\n : createLogger({ verbose });\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Check if index exists\n const status = await getIndexStatus(rootDir);\n\n if (!status.exists) {\n // No index exists - do full indexing\n logger.info(\"No index found. Creating index...\\n\");\n const results = await indexDirectory(rootDir, { ...options, logger });\n const totalIndexed = results.reduce((sum, r) => sum + r.indexed, 0);\n return { indexed: totalIndexed, removed: 0, unchanged: 0 };\n }\n\n // Index exists - check if version is compatible\n const versionCompatible = await isIndexVersionCompatible(rootDir);\n if (!versionCompatible) {\n // Incompatible index version - delete and rebuild\n logger.info(\"Index version incompatible. Rebuilding...\\n\");\n await deleteIndex(rootDir);\n const results = await indexDirectory(rootDir, { ...options, logger });\n const totalIndexed = results.reduce((sum, r) => sum + r.indexed, 0);\n return { indexed: totalIndexed, removed: 0, unchanged: 0 };\n }\n\n // Index exists and is compatible - check for changes incrementally\n const config = await loadConfig(rootDir);\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Get enabled modules\n const enabledModules = registry.getEnabled(config);\n\n if (enabledModules.length === 0) {\n return { indexed: 0, removed: 0, unchanged: 0 };\n }\n\n // Initialize introspection\n const introspection = new IntrospectionIndex(rootDir);\n await introspection.initialize();\n\n // Get all current files\n const currentFiles = await findFiles(rootDir, config);\n const currentFileSet = new Set(\n currentFiles.map((f) => path.relative(rootDir, f))\n );\n\n let totalIndexed = 0;\n let totalRemoved = 0;\n let totalUnchanged = 0;\n\n for (const module of enabledModules) {\n // Initialize module if needed\n const moduleConfig = getModuleConfig(config, module.id);\n if (module.initialize && moduleConfig) {\n const configWithOverrides = { ...moduleConfig };\n if (options.model && module.id === \"language/typescript\") {\n configWithOverrides.options = {\n ...configWithOverrides.options,\n embeddingModel: options.model,\n };\n }\n // Pass logger to module\n configWithOverrides.options = {\n ...configWithOverrides.options,\n logger,\n };\n await module.initialize(configWithOverrides);\n }\n\n // Load manifest\n const manifest = await loadModuleManifest(rootDir, module.id, config);\n const indexPath = getModuleIndexPath(rootDir, module.id, config);\n\n // Find files to remove (in manifest but not on disk)\n const filesToRemove: string[] = [];\n for (const filepath of Object.keys(manifest.files)) {\n if (!currentFileSet.has(filepath)) {\n filesToRemove.push(filepath);\n }\n }\n\n // Remove stale entries\n // Also need to track files removed for literal index cleanup\n const removedFilepaths: string[] = [];\n for (const filepath of filesToRemove) {\n logger.debug(` Removing stale: ${filepath}`);\n // Remove main index file\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(indexFilePath);\n } catch {\n // Index file may not exist\n }\n // Remove symbolic index file\n const symbolicFilePath = path.join(\n indexPath,\n \"symbolic\",\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(symbolicFilePath);\n } catch {\n // Symbolic file may not exist\n }\n delete manifest.files[filepath];\n removedFilepaths.push(filepath);\n totalRemoved++;\n }\n\n // Clean up literal index for removed files\n if (removedFilepaths.length > 0) {\n try {\n const { LiteralIndex } = await import(\n \"../../infrastructure/storage/literalIndex\"\n );\n // LiteralIndex expects the base raggrep directory\n const raggrepDir = getRaggrepDir(rootDir, config);\n const literalIndex = new LiteralIndex(raggrepDir, module.id);\n await literalIndex.initialize();\n for (const filepath of removedFilepaths) {\n literalIndex.removeFile(filepath);\n }\n await literalIndex.save();\n } catch {\n // Literal index may not exist yet\n }\n }\n\n // Index new/modified files\n const ctx: IndexContext = {\n rootDir,\n config,\n readFile: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n return fs.readFile(fullPath, \"utf-8\");\n },\n getFileStats: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n const stats = await fs.stat(fullPath);\n return { lastModified: stats.mtime.toISOString() };\n },\n getIntrospection: (filepath: string) => introspection.getFile(filepath),\n };\n\n const totalFiles = currentFiles.length;\n for (let i = 0; i < currentFiles.length; i++) {\n const filepath = currentFiles[i];\n const relativePath = path.relative(rootDir, filepath);\n const progress = `[${i + 1}/${totalFiles}]`;\n\n try {\n const stats = await fs.stat(filepath);\n const lastModified = stats.mtime.toISOString();\n\n // Check if file needs re-indexing\n const existingEntry = manifest.files[relativePath];\n if (existingEntry && existingEntry.lastModified === lastModified) {\n totalUnchanged++;\n continue;\n }\n\n // File is new or modified - index it\n logger.progress(` ${progress} Indexing: ${relativePath}`);\n\n const content = await fs.readFile(filepath, \"utf-8\");\n introspection.addFile(relativePath, content);\n\n const fileIndex = await module.indexFile(relativePath, content, ctx);\n\n if (fileIndex) {\n await writeFileIndex(\n rootDir,\n module.id,\n relativePath,\n fileIndex,\n config\n );\n manifest.files[relativePath] = {\n lastModified,\n chunkCount: fileIndex.chunks.length,\n };\n totalIndexed++;\n }\n } catch (error) {\n logger.clearProgress();\n logger.error(` ${progress} Error indexing ${relativePath}: ${error}`);\n }\n }\n\n // Clear progress line\n logger.clearProgress();\n\n // Update manifest if there were changes\n if (totalIndexed > 0 || totalRemoved > 0) {\n manifest.lastUpdated = new Date().toISOString();\n await writeModuleManifest(rootDir, module.id, manifest, config);\n\n // Call finalize to rebuild secondary indexes\n if (module.finalize) {\n await module.finalize(ctx);\n }\n }\n\n // Clean up empty directories\n if (totalRemoved > 0) {\n await cleanupEmptyDirectories(indexPath);\n }\n }\n\n // Save introspection if there were changes\n if (totalIndexed > 0) {\n await introspection.save(config);\n }\n\n // Update global manifest if needed\n if (totalIndexed > 0 || totalRemoved > 0) {\n await updateGlobalManifest(rootDir, enabledModules, config);\n }\n\n return {\n indexed: totalIndexed,\n removed: totalRemoved,\n unchanged: totalUnchanged,\n };\n}\n\n/**\n * Result of processing a single file\n */\ninterface FileProcessResult {\n relativePath: string;\n status: \"indexed\" | \"skipped\" | \"error\";\n lastModified?: string;\n chunkCount?: number;\n error?: unknown;\n}\n\n/**\n * Index files with a specific module using parallel processing\n */\nasync function indexWithModule(\n rootDir: string,\n files: string[],\n module: IndexModule,\n config: Config,\n verbose: boolean,\n introspection: IntrospectionIndex,\n logger: Logger,\n concurrency: number = DEFAULT_CONCURRENCY\n): Promise<IndexResult> {\n const result: IndexResult = {\n moduleId: module.id,\n indexed: 0,\n skipped: 0,\n errors: 0,\n };\n\n // Load existing manifest for this module\n const manifest = await loadModuleManifest(rootDir, module.id, config);\n const indexPath = getModuleIndexPath(rootDir, module.id, config);\n\n // Build set of current files for quick lookup\n const currentFileSet = new Set(files.map((f) => path.relative(rootDir, f)));\n\n // Clean up stale entries (files in manifest but no longer on disk)\n const filesToRemove: string[] = [];\n for (const filepath of Object.keys(manifest.files)) {\n if (!currentFileSet.has(filepath)) {\n filesToRemove.push(filepath);\n }\n }\n\n if (filesToRemove.length > 0) {\n logger.info(` Removing ${filesToRemove.length} stale entries...`);\n for (const filepath of filesToRemove) {\n logger.debug(` Removing: ${filepath}`);\n // Remove main index file\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(indexFilePath);\n } catch {\n // Index file may not exist\n }\n // Remove symbolic index file\n const symbolicFilePath = path.join(\n indexPath,\n \"symbolic\",\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(symbolicFilePath);\n } catch {\n // Symbolic file may not exist\n }\n delete manifest.files[filepath];\n }\n // Clean up empty directories\n await cleanupEmptyDirectories(indexPath);\n }\n\n // Create index context\n const ctx: IndexContext = {\n rootDir,\n config,\n readFile: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n return fs.readFile(fullPath, \"utf-8\");\n },\n getFileStats: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n const stats = await fs.stat(fullPath);\n return { lastModified: stats.mtime.toISOString() };\n },\n getIntrospection: (filepath: string) => introspection.getFile(filepath),\n };\n\n const totalFiles = files.length;\n\n // Track progress across parallel operations\n let completedCount = 0;\n\n // Process files in parallel with concurrency control\n const processFile = async (\n filepath: string,\n _index: number\n ): Promise<FileProcessResult> => {\n const relativePath = path.relative(rootDir, filepath);\n\n try {\n const stats = await fs.stat(filepath);\n const lastModified = stats.mtime.toISOString();\n\n // Check if file needs re-indexing\n const existingEntry = manifest.files[relativePath];\n if (existingEntry && existingEntry.lastModified === lastModified) {\n completedCount++;\n logger.debug(\n ` [${completedCount}/${totalFiles}] Skipped ${relativePath} (unchanged)`\n );\n return { relativePath, status: \"skipped\" };\n }\n\n // Read and index file\n const content = await fs.readFile(filepath, \"utf-8\");\n\n // Add introspection for this file (thread-safe - just adds to a Map)\n introspection.addFile(relativePath, content);\n\n // Update progress\n completedCount++;\n logger.progress(\n ` [${completedCount}/${totalFiles}] Processing: ${relativePath}`\n );\n\n const fileIndex = await module.indexFile(relativePath, content, ctx);\n\n if (!fileIndex) {\n logger.debug(\n ` [${completedCount}/${totalFiles}] Skipped ${relativePath} (no chunks)`\n );\n return { relativePath, status: \"skipped\" };\n }\n\n // Write index file\n await writeFileIndex(rootDir, module.id, relativePath, fileIndex, config);\n\n return {\n relativePath,\n status: \"indexed\",\n lastModified,\n chunkCount: fileIndex.chunks.length,\n };\n } catch (error) {\n completedCount++;\n return { relativePath, status: \"error\", error };\n }\n };\n\n // Run parallel processing\n logger.debug(` Using concurrency: ${concurrency}`);\n const results = await parallelMap(files, processFile, concurrency);\n\n // Clear progress line\n logger.clearProgress();\n\n // Process results and update manifest\n for (const item of results) {\n if (!item.success) {\n // This shouldn't happen as we catch errors in processFile\n result.errors++;\n continue;\n }\n\n const fileResult = item.value;\n switch (fileResult.status) {\n case \"indexed\":\n manifest.files[fileResult.relativePath] = {\n lastModified: fileResult.lastModified!,\n chunkCount: fileResult.chunkCount!,\n };\n result.indexed++;\n break;\n case \"skipped\":\n result.skipped++;\n break;\n case \"error\":\n logger.error(\n ` Error indexing ${fileResult.relativePath}: ${fileResult.error}`\n );\n result.errors++;\n break;\n }\n }\n\n // Update manifest\n manifest.lastUpdated = new Date().toISOString();\n await writeModuleManifest(rootDir, module.id, manifest, config);\n\n return result;\n}\n\nasync function findFiles(rootDir: string, config: Config): Promise<string[]> {\n const patterns = config.extensions.map((ext) => `**/*${ext}`);\n const ignorePatterns = config.ignorePaths.map((p) => `**/${p}/**`);\n\n const files: string[] = [];\n for (const pattern of patterns) {\n const matches = await glob(pattern, {\n cwd: rootDir,\n absolute: true,\n ignore: ignorePatterns,\n });\n files.push(...matches);\n }\n\n return [...new Set(files)]; // Remove duplicates\n}\n\nasync function loadModuleManifest(\n rootDir: string,\n moduleId: string,\n config: Config\n): Promise<ModuleManifest> {\n const manifestPath = getModuleManifestPath(rootDir, moduleId, config);\n\n try {\n const content = await fs.readFile(manifestPath, \"utf-8\");\n return JSON.parse(content);\n } catch {\n return {\n moduleId,\n version: \"1.0.0\",\n lastUpdated: new Date().toISOString(),\n files: {},\n };\n }\n}\n\nasync function writeModuleManifest(\n rootDir: string,\n moduleId: string,\n manifest: ModuleManifest,\n config: Config\n): Promise<void> {\n const manifestPath = getModuleManifestPath(rootDir, moduleId, config);\n await fs.mkdir(path.dirname(manifestPath), { recursive: true });\n await fs.writeFile(manifestPath, JSON.stringify(manifest, null, 2));\n}\n\nasync function writeFileIndex(\n rootDir: string,\n moduleId: string,\n filepath: string,\n fileIndex: FileIndex,\n config: Config\n): Promise<void> {\n const indexPath = getModuleIndexPath(rootDir, moduleId, config);\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n\n await fs.mkdir(path.dirname(indexFilePath), { recursive: true });\n await fs.writeFile(indexFilePath, JSON.stringify(fileIndex, null, 2));\n}\n\nasync function updateGlobalManifest(\n rootDir: string,\n modules: IndexModule[],\n config: Config\n): Promise<void> {\n const manifestPath = getGlobalManifestPath(rootDir, config);\n\n const manifest: GlobalManifest = {\n version: INDEX_SCHEMA_VERSION,\n lastUpdated: new Date().toISOString(),\n modules: modules.map((m) => m.id),\n };\n\n await fs.mkdir(path.dirname(manifestPath), { recursive: true });\n await fs.writeFile(manifestPath, JSON.stringify(manifest, null, 2));\n}\n\n/**\n * Options for cleanup operation\n */\nexport interface CleanupOptions {\n /** Show detailed progress */\n verbose?: boolean;\n /** Logger for progress reporting */\n logger?: Logger;\n}\n\n/**\n * Clean up stale index entries for files that no longer exist\n * @param rootDir - Root directory of the project\n * @param options - Cleanup options\n * @returns Array of cleanup results per module\n */\nexport async function cleanupIndex(\n rootDir: string,\n options: CleanupOptions = {}\n): Promise<CleanupResult[]> {\n const verbose = options.verbose ?? false;\n\n // Create logger\n const logger: Logger = options.logger ?? createLogger({ verbose });\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n logger.info(`Cleaning up index in: ${rootDir}`);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Get enabled modules\n const enabledModules = registry.getEnabled(config);\n\n if (enabledModules.length === 0) {\n logger.info(\"No modules enabled.\");\n return [];\n }\n\n const results: CleanupResult[] = [];\n\n for (const module of enabledModules) {\n logger.info(`\\n[${module.name}] Checking for stale entries...`);\n\n const result = await cleanupModuleIndex(rootDir, module.id, config, logger);\n results.push(result);\n\n logger.info(\n `[${module.name}] Removed ${result.removed} stale entries, kept ${result.kept} valid entries`\n );\n }\n\n return results;\n}\n\n/**\n * Clean up stale index entries for a specific module\n */\nasync function cleanupModuleIndex(\n rootDir: string,\n moduleId: string,\n config: Config,\n logger: Logger\n): Promise<CleanupResult> {\n const result: CleanupResult = {\n moduleId,\n removed: 0,\n kept: 0,\n };\n\n // Load manifest\n const manifest = await loadModuleManifest(rootDir, moduleId, config);\n const indexPath = getModuleIndexPath(rootDir, moduleId, config);\n\n const filesToRemove: string[] = [];\n const updatedFiles: ModuleManifest[\"files\"] = {};\n\n // Check each indexed file\n for (const [filepath, entry] of Object.entries(manifest.files)) {\n const fullPath = path.join(rootDir, filepath);\n\n try {\n await fs.access(fullPath);\n // File exists, keep it\n updatedFiles[filepath] = entry;\n result.kept++;\n } catch {\n // File doesn't exist, mark for removal\n filesToRemove.push(filepath);\n result.removed++;\n logger.debug(` Removing stale entry: ${filepath}`);\n }\n }\n\n // Remove stale index files\n for (const filepath of filesToRemove) {\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(indexFilePath);\n } catch {\n // Index file may not exist, that's okay\n }\n }\n\n // Update manifest with only valid files\n manifest.files = updatedFiles;\n manifest.lastUpdated = new Date().toISOString();\n await writeModuleManifest(rootDir, moduleId, manifest, config);\n\n // Clean up empty directories in the index\n await cleanupEmptyDirectories(indexPath);\n\n return result;\n}\n\n/**\n * Recursively remove empty directories\n */\nasync function cleanupEmptyDirectories(dir: string): Promise<boolean> {\n try {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n\n // Process subdirectories first\n for (const entry of entries) {\n if (entry.isDirectory()) {\n const subDir = path.join(dir, entry.name);\n await cleanupEmptyDirectories(subDir);\n }\n }\n\n // Check if directory is now empty (re-read after potential subdirectory removal)\n const remainingEntries = await fs.readdir(dir);\n\n // Don't remove the root index directory or manifest files\n if (remainingEntries.length === 0) {\n await fs.rmdir(dir);\n return true;\n }\n\n return false;\n } catch {\n return false;\n }\n}\n\n/**\n * Get the current status of the index\n * @param rootDir - Root directory of the project\n * @returns Index status information\n */\nexport async function getIndexStatus(rootDir: string): Promise<IndexStatus> {\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Get index location (now in temp directory)\n const location = getIndexLocation(rootDir);\n const indexDir = location.indexDir;\n\n const status: IndexStatus = {\n exists: false,\n rootDir,\n indexDir,\n modules: [],\n totalFiles: 0,\n };\n\n // Check if index directory exists\n try {\n await fs.access(indexDir);\n } catch {\n return status;\n }\n\n // Try to load global manifest\n try {\n const globalManifestPath = getGlobalManifestPath(rootDir, config);\n const content = await fs.readFile(globalManifestPath, \"utf-8\");\n const globalManifest: GlobalManifest = JSON.parse(content);\n\n status.exists = true;\n status.lastUpdated = globalManifest.lastUpdated;\n\n // Load each module's manifest\n for (const moduleId of globalManifest.modules) {\n try {\n const manifest = await loadModuleManifest(rootDir, moduleId, config);\n const fileCount = Object.keys(manifest.files).length;\n\n status.modules.push({\n id: moduleId,\n fileCount,\n lastUpdated: manifest.lastUpdated,\n });\n\n status.totalFiles += fileCount;\n } catch {\n // Module manifest doesn't exist or is corrupt\n }\n }\n } catch {\n // Global manifest doesn't exist - check if there's any index data\n try {\n const entries = await fs.readdir(path.join(indexDir, \"index\"));\n if (entries.length > 0) {\n status.exists = true;\n // Try to load manifests for known modules\n for (const entry of entries) {\n try {\n const manifest = await loadModuleManifest(rootDir, entry, config);\n const fileCount = Object.keys(manifest.files).length;\n\n status.modules.push({\n id: entry,\n fileCount,\n lastUpdated: manifest.lastUpdated,\n });\n\n status.totalFiles += fileCount;\n } catch {\n // Skip\n }\n }\n }\n } catch {\n // No index directory\n }\n }\n\n return status;\n}\n\n// Re-export watcher\nexport { watchDirectory, type WatchOptions, type FileWatcher } from \"./watcher\";\n",
47
+ "// Main indexer - coordinates modules for indexing files\nimport { glob } from \"glob\";\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport * as os from \"os\";\nimport * as crypto from \"crypto\";\nimport {\n Config,\n IndexContext,\n IndexModule,\n ModuleManifest,\n GlobalManifest,\n FileIndex,\n} from \"../../types\";\nimport {\n DEFAULT_CONFIG,\n loadConfig,\n getModuleIndexPath,\n getModuleManifestPath,\n getGlobalManifestPath,\n getModuleConfig,\n getIndexLocation,\n getRaggrepDir,\n} from \"../../infrastructure/config\";\nimport { registry, registerBuiltInModules } from \"../../modules/registry\";\nimport type { EmbeddingModelName, Logger } from \"../../domain/ports\";\nimport { IntrospectionIndex } from \"../../infrastructure/introspection\";\nimport { createLogger, createSilentLogger } from \"../../infrastructure/logger\";\n\n// ============================================================================\n// Content Hashing\n// ============================================================================\n\n/**\n * Compute a SHA-256 hash of file content.\n * Used for reliable change detection that's immune to git mtime changes.\n *\n * @param content - File content to hash\n * @returns Hex-encoded SHA-256 hash\n */\nfunction computeContentHash(content: string): string {\n return crypto.createHash(\"sha256\").update(content, \"utf-8\").digest(\"hex\");\n}\n\n// ============================================================================\n// Parallel Processing Utilities\n// ============================================================================\n\n/**\n * Process items in parallel with controlled concurrency.\n * Returns results in the same order as input items.\n *\n * @param items - Items to process\n * @param processor - Async function to process each item\n * @param concurrency - Maximum number of concurrent operations\n * @returns Array of results (or errors) in input order\n */\nasync function parallelMap<T, R>(\n items: T[],\n processor: (item: T, index: number) => Promise<R>,\n concurrency: number\n): Promise<\n Array<{ success: true; value: R } | { success: false; error: unknown }>\n> {\n const results: Array<\n { success: true; value: R } | { success: false; error: unknown }\n > = new Array(items.length);\n let nextIndex = 0;\n\n async function worker(): Promise<void> {\n while (nextIndex < items.length) {\n const index = nextIndex++;\n const item = items[index];\n try {\n const value = await processor(item, index);\n results[index] = { success: true, value };\n } catch (error) {\n results[index] = { success: false, error };\n }\n }\n }\n\n // Start workers up to concurrency limit\n const workers = Array(Math.min(concurrency, items.length))\n .fill(null)\n .map(() => worker());\n\n await Promise.all(workers);\n return results;\n}\n\n/**\n * Current index schema version.\n * Increment this when making breaking changes to the index format.\n * This is separate from the package version to allow non-breaking updates.\n *\n * History:\n * - 1.0.0: Initial version\n * - 1.1.0: Changed default embedding model to bge-small-en-v1.5, added nomic-embed-text-v1.5\n */\nconst INDEX_SCHEMA_VERSION = \"1.1.0\";\n\nexport interface IndexResult {\n moduleId: string;\n indexed: number;\n skipped: number;\n errors: number;\n /** Time taken in milliseconds */\n durationMs?: number;\n}\n\n/**\n * Format duration in human-readable format\n */\nfunction formatDuration(ms: number): string {\n if (ms < 1000) {\n return `${ms}ms`;\n }\n const seconds = ms / 1000;\n if (seconds < 60) {\n return `${seconds.toFixed(1)}s`;\n }\n const minutes = Math.floor(seconds / 60);\n const remainingSeconds = seconds % 60;\n return `${minutes}m ${remainingSeconds.toFixed(1)}s`;\n}\n\n/**\n * Get optimal concurrency based on CPU specs.\n *\n * Uses the number of CPU cores with some considerations:\n * - Minimum: 2 (ensure some parallelism)\n * - Maximum: 16 (avoid diminishing returns / memory pressure)\n * - For embedding generation, we leave 1-2 cores free for the system\n *\n * @returns Optimal concurrency value\n */\nfunction getOptimalConcurrency(): number {\n const cpuCount = os.cpus().length;\n\n // Leave some cores for system/other processes\n // For 4 cores: use 3\n // For 8 cores: use 6\n // For 16+ cores: use 12-14\n const optimal = Math.max(2, Math.min(16, Math.floor(cpuCount * 0.75)));\n\n return optimal;\n}\n\n/** Default concurrency for parallel file processing (dynamic based on CPU) */\nconst DEFAULT_CONCURRENCY = getOptimalConcurrency();\n\nexport interface IndexOptions {\n /** Override the embedding model (semantic module) */\n model?: EmbeddingModelName;\n /** Show detailed progress */\n verbose?: boolean;\n /** Suppress most output (for use during query) */\n quiet?: boolean;\n /** Logger for progress reporting. If not provided, uses console by default (quiet mode uses silent logger) */\n logger?: Logger;\n /** Number of files to process in parallel (default: auto based on CPU cores) */\n concurrency?: number;\n}\n\nexport interface EnsureFreshResult {\n /** Number of files indexed (new or modified) */\n indexed: number;\n /** Number of stale entries removed (deleted files) */\n removed: number;\n /** Number of files unchanged (used cache) */\n unchanged: number;\n}\n\nexport interface CleanupResult {\n moduleId: string;\n /** Number of stale entries removed */\n removed: number;\n /** Number of valid entries kept */\n kept: number;\n}\n\nexport interface IndexStatus {\n /** Whether an index exists */\n exists: boolean;\n /** Root directory path */\n rootDir: string;\n /** Index directory path */\n indexDir: string;\n /** Last time the index was updated */\n lastUpdated?: string;\n /** Active modules and their file counts */\n modules: Array<{\n id: string;\n fileCount: number;\n lastUpdated: string;\n }>;\n /** Total number of indexed files */\n totalFiles: number;\n}\n\n/**\n * Index a directory using all enabled modules\n */\nexport async function indexDirectory(\n rootDir: string,\n options: IndexOptions = {}\n): Promise<IndexResult[]> {\n const verbose = options.verbose ?? false;\n const quiet = options.quiet ?? false;\n const concurrency = options.concurrency ?? DEFAULT_CONCURRENCY;\n\n // Create logger based on options\n const logger: Logger = options.logger\n ? options.logger\n : quiet\n ? createSilentLogger()\n : createLogger({ verbose });\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Show index location\n const location = getIndexLocation(rootDir);\n logger.info(`Indexing directory: ${rootDir}`);\n logger.info(`Index location: ${location.indexDir}`);\n logger.debug(`Concurrency: ${concurrency}`);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Initialize introspection\n const introspection = new IntrospectionIndex(rootDir);\n await introspection.initialize();\n const structure = introspection.getStructure();\n if (structure?.isMonorepo) {\n logger.debug(\n `Detected monorepo with ${structure.projects.length} projects`\n );\n }\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Get enabled modules\n const enabledModules = registry.getEnabled(config);\n\n if (enabledModules.length === 0) {\n logger.info(\"No modules enabled. Check your configuration.\");\n return [];\n }\n\n logger.info(`Enabled modules: ${enabledModules.map((m) => m.id).join(\", \")}`);\n\n // Get all files matching extensions\n const files = await findFiles(rootDir, config);\n logger.info(`Found ${files.length} files to index`);\n\n // Track overall timing\n const overallStart = Date.now();\n\n // Index with each module\n const results: IndexResult[] = [];\n\n for (const module of enabledModules) {\n const moduleStart = Date.now();\n logger.info(`\\n[${module.name}] Starting indexing...`);\n\n // Initialize module if needed\n const moduleConfig = getModuleConfig(config, module.id);\n if (module.initialize && moduleConfig) {\n // Apply CLI overrides to module config, including logger\n const configWithOverrides = { ...moduleConfig };\n if (options.model && module.id === \"language/typescript\") {\n configWithOverrides.options = {\n ...configWithOverrides.options,\n embeddingModel: options.model,\n };\n }\n // Pass logger to module via options\n configWithOverrides.options = {\n ...configWithOverrides.options,\n logger,\n };\n await module.initialize(configWithOverrides);\n }\n\n // Pre-filter files that this module supports\n const moduleFiles = module.supportsFile\n ? files.filter((f) => module.supportsFile!(f))\n : files;\n\n logger.info(` Processing ${moduleFiles.length} files...`);\n\n const result = await indexWithModule(\n rootDir,\n moduleFiles,\n module,\n config,\n verbose,\n introspection,\n logger,\n concurrency\n );\n results.push(result);\n\n // Call finalize to build secondary indexes (Tier 1, BM25, etc.)\n if (module.finalize) {\n logger.info(`[${module.name}] Building secondary indexes...`);\n const ctx: IndexContext = {\n rootDir,\n config,\n readFile: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n return fs.readFile(fullPath, \"utf-8\");\n },\n getFileStats: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n const stats = await fs.stat(fullPath);\n return { lastModified: stats.mtime.toISOString() };\n },\n };\n await module.finalize(ctx);\n }\n\n const moduleDuration = Date.now() - moduleStart;\n result.durationMs = moduleDuration;\n\n logger.info(\n `[${module.name}] Complete: ${result.indexed} indexed, ${\n result.skipped\n } skipped, ${result.errors} errors (${formatDuration(moduleDuration)})`\n );\n }\n\n // Save introspection data\n await introspection.save(config);\n\n // Log overall timing\n const overallDuration = Date.now() - overallStart;\n logger.info(`\\nIndexing complete in ${formatDuration(overallDuration)}`);\n\n // Log summary\n const totalIndexed = results.reduce((sum, r) => sum + r.indexed, 0);\n const totalSkipped = results.reduce((sum, r) => sum + r.skipped, 0);\n const totalErrors = results.reduce((sum, r) => sum + r.errors, 0);\n logger.info(\n `Total: ${totalIndexed} indexed, ${totalSkipped} skipped, ${totalErrors} errors`\n );\n\n // Update global manifest\n await updateGlobalManifest(rootDir, enabledModules, config);\n\n return results;\n}\n\n/**\n * Check if the existing index version is compatible with the current schema.\n * Returns true if compatible, false if needs rebuild.\n */\nasync function isIndexVersionCompatible(rootDir: string): Promise<boolean> {\n const config = await loadConfig(rootDir);\n const globalManifestPath = getGlobalManifestPath(rootDir, config);\n\n try {\n const content = await fs.readFile(globalManifestPath, \"utf-8\");\n const manifest: GlobalManifest = JSON.parse(content);\n\n // Check if version matches current schema version\n return manifest.version === INDEX_SCHEMA_VERSION;\n } catch {\n // Can't read manifest - treat as incompatible\n return false;\n }\n}\n\n/**\n * Delete the entire index directory to allow a clean rebuild.\n */\nasync function deleteIndex(rootDir: string): Promise<void> {\n const indexDir = getRaggrepDir(rootDir);\n\n try {\n await fs.rm(indexDir, { recursive: true, force: true });\n } catch {\n // Directory may not exist, that's okay\n }\n}\n\n/**\n * Result of a reset operation\n */\nexport interface ResetResult {\n /** Whether the reset was successful */\n success: boolean;\n /** The index directory that was removed */\n indexDir: string;\n}\n\n/**\n * Reset (delete) the index for a directory.\n *\n * @param rootDir - Root directory of the project\n * @returns ResetResult with success status\n * @throws Error if no index exists\n */\nexport async function resetIndex(rootDir: string): Promise<ResetResult> {\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Check if index exists\n const status = await getIndexStatus(rootDir);\n\n if (!status.exists) {\n throw new Error(`No index found for ${rootDir}`);\n }\n\n // Delete the index\n await deleteIndex(rootDir);\n\n return {\n success: true,\n indexDir: status.indexDir,\n };\n}\n\n/**\n * Ensure the index is fresh by checking for changes and updating incrementally.\n * This function is designed to be called before search to transparently manage the index.\n *\n * - If no index exists, creates a full index\n * - If index version is incompatible, rebuilds from scratch\n * - If files have changed, re-indexes only the modified files\n * - If files have been deleted, removes stale entries\n * - If nothing changed, returns immediately (uses cache)\n *\n * @param rootDir - Root directory of the project\n * @param options - Index options\n * @returns Statistics about what was updated\n */\nexport async function ensureIndexFresh(\n rootDir: string,\n options: IndexOptions = {}\n): Promise<EnsureFreshResult> {\n const verbose = options.verbose ?? false;\n const quiet = options.quiet ?? false;\n\n // Create logger based on options\n const logger: Logger = options.logger\n ? options.logger\n : quiet\n ? createSilentLogger()\n : createLogger({ verbose });\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Check if index exists\n const status = await getIndexStatus(rootDir);\n\n if (!status.exists) {\n // No index exists - do full indexing\n logger.info(\"No index found. Creating index...\\n\");\n const results = await indexDirectory(rootDir, { ...options, logger });\n const totalIndexed = results.reduce((sum, r) => sum + r.indexed, 0);\n return { indexed: totalIndexed, removed: 0, unchanged: 0 };\n }\n\n // Index exists - check if version is compatible\n const versionCompatible = await isIndexVersionCompatible(rootDir);\n if (!versionCompatible) {\n // Incompatible index version - delete and rebuild\n logger.info(\"Index version incompatible. Rebuilding...\\n\");\n await deleteIndex(rootDir);\n const results = await indexDirectory(rootDir, { ...options, logger });\n const totalIndexed = results.reduce((sum, r) => sum + r.indexed, 0);\n return { indexed: totalIndexed, removed: 0, unchanged: 0 };\n }\n\n // Index exists and is compatible - check for changes incrementally\n const config = await loadConfig(rootDir);\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Get enabled modules\n const enabledModules = registry.getEnabled(config);\n\n if (enabledModules.length === 0) {\n return { indexed: 0, removed: 0, unchanged: 0 };\n }\n\n // Initialize introspection\n const introspection = new IntrospectionIndex(rootDir);\n await introspection.initialize();\n\n // Get all current files\n const currentFiles = await findFiles(rootDir, config);\n const currentFileSet = new Set(\n currentFiles.map((f) => path.relative(rootDir, f))\n );\n\n let totalIndexed = 0;\n let totalRemoved = 0;\n let totalUnchanged = 0;\n\n for (const module of enabledModules) {\n // Initialize module if needed\n const moduleConfig = getModuleConfig(config, module.id);\n if (module.initialize && moduleConfig) {\n const configWithOverrides = { ...moduleConfig };\n if (options.model && module.id === \"language/typescript\") {\n configWithOverrides.options = {\n ...configWithOverrides.options,\n embeddingModel: options.model,\n };\n }\n // Pass logger to module\n configWithOverrides.options = {\n ...configWithOverrides.options,\n logger,\n };\n await module.initialize(configWithOverrides);\n }\n\n // Load manifest\n const manifest = await loadModuleManifest(rootDir, module.id, config);\n const indexPath = getModuleIndexPath(rootDir, module.id, config);\n\n // Find files to remove (in manifest but not on disk)\n const filesToRemove: string[] = [];\n for (const filepath of Object.keys(manifest.files)) {\n if (!currentFileSet.has(filepath)) {\n filesToRemove.push(filepath);\n }\n }\n\n // Remove stale entries\n // Also need to track files removed for literal index cleanup\n const removedFilepaths: string[] = [];\n for (const filepath of filesToRemove) {\n logger.debug(` Removing stale: ${filepath}`);\n // Remove main index file\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(indexFilePath);\n } catch {\n // Index file may not exist\n }\n // Remove symbolic index file\n const symbolicFilePath = path.join(\n indexPath,\n \"symbolic\",\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(symbolicFilePath);\n } catch {\n // Symbolic file may not exist\n }\n delete manifest.files[filepath];\n removedFilepaths.push(filepath);\n totalRemoved++;\n }\n\n // Clean up literal index for removed files\n if (removedFilepaths.length > 0) {\n try {\n const { LiteralIndex } = await import(\n \"../../infrastructure/storage/literalIndex\"\n );\n // LiteralIndex expects the base raggrep directory\n const raggrepDir = getRaggrepDir(rootDir, config);\n const literalIndex = new LiteralIndex(raggrepDir, module.id);\n await literalIndex.initialize();\n for (const filepath of removedFilepaths) {\n literalIndex.removeFile(filepath);\n }\n await literalIndex.save();\n } catch {\n // Literal index may not exist yet\n }\n }\n\n // Index new/modified files\n const ctx: IndexContext = {\n rootDir,\n config,\n readFile: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n return fs.readFile(fullPath, \"utf-8\");\n },\n getFileStats: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n const stats = await fs.stat(fullPath);\n return { lastModified: stats.mtime.toISOString() };\n },\n getIntrospection: (filepath: string) => introspection.getFile(filepath),\n };\n\n const totalFiles = currentFiles.length;\n let completedCount = 0;\n\n // Process files in parallel with concurrency control\n const processIncrementalFile = async (\n filepath: string\n ): Promise<IncrementalFileResult> => {\n const relativePath = path.relative(rootDir, filepath);\n\n try {\n const stats = await fs.stat(filepath);\n const lastModified = stats.mtime.toISOString();\n const existingEntry = manifest.files[relativePath];\n\n // Fast path: if mtime unchanged, skip (no need to read file)\n if (existingEntry && existingEntry.lastModified === lastModified) {\n completedCount++;\n return { relativePath, status: \"unchanged\" };\n }\n\n // Read file content\n const content = await fs.readFile(filepath, \"utf-8\");\n const contentHash = computeContentHash(content);\n\n // Check if content actually changed (handles git branch switches)\n if (existingEntry?.contentHash && existingEntry.contentHash === contentHash) {\n completedCount++;\n // Content unchanged, return with updated mtime\n return {\n relativePath,\n status: \"mtime_updated\",\n lastModified,\n contentHash,\n };\n }\n\n // File is new or content actually changed - index it\n completedCount++;\n logger.progress(\n ` [${completedCount}/${totalFiles}] Indexing: ${relativePath}`\n );\n\n introspection.addFile(relativePath, content);\n\n const fileIndex = await module.indexFile(relativePath, content, ctx);\n\n if (!fileIndex) {\n return { relativePath, status: \"unchanged\" };\n }\n\n await writeFileIndex(\n rootDir,\n module.id,\n relativePath,\n fileIndex,\n config\n );\n\n return {\n relativePath,\n status: \"indexed\",\n lastModified,\n chunkCount: fileIndex.chunks.length,\n contentHash,\n };\n } catch (error) {\n completedCount++;\n return { relativePath, status: \"error\", error };\n }\n };\n\n // Run parallel processing\n const concurrency = options.concurrency ?? DEFAULT_CONCURRENCY;\n const results = await parallelMap(currentFiles, processIncrementalFile, concurrency);\n\n // Clear progress line\n logger.clearProgress();\n\n // Process results and update manifest\n let mtimeUpdates = 0;\n for (const item of results) {\n if (!item.success) {\n continue;\n }\n\n const fileResult = item.value;\n switch (fileResult.status) {\n case \"indexed\":\n manifest.files[fileResult.relativePath] = {\n lastModified: fileResult.lastModified!,\n chunkCount: fileResult.chunkCount!,\n contentHash: fileResult.contentHash,\n };\n totalIndexed++;\n break;\n case \"mtime_updated\":\n // Update mtime without re-indexing\n if (manifest.files[fileResult.relativePath]) {\n manifest.files[fileResult.relativePath] = {\n ...manifest.files[fileResult.relativePath],\n lastModified: fileResult.lastModified!,\n contentHash: fileResult.contentHash,\n };\n mtimeUpdates++;\n }\n totalUnchanged++;\n break;\n case \"unchanged\":\n totalUnchanged++;\n break;\n case \"error\":\n logger.error(\n ` Error indexing ${fileResult.relativePath}: ${fileResult.error}`\n );\n break;\n }\n }\n\n // Update manifest if there were any changes (including mtime-only updates)\n const hasManifestChanges = totalIndexed > 0 || totalRemoved > 0 || mtimeUpdates > 0;\n if (hasManifestChanges) {\n manifest.lastUpdated = new Date().toISOString();\n await writeModuleManifest(rootDir, module.id, manifest, config);\n }\n\n // Only call finalize when there are actual content changes (not just mtime updates)\n const hasContentChanges = totalIndexed > 0 || totalRemoved > 0;\n if (hasContentChanges && module.finalize) {\n await module.finalize(ctx);\n }\n\n // Clean up empty directories\n if (totalRemoved > 0) {\n await cleanupEmptyDirectories(indexPath);\n }\n }\n\n // Save introspection if there were changes\n if (totalIndexed > 0) {\n await introspection.save(config);\n }\n\n // Update global manifest if needed\n if (totalIndexed > 0 || totalRemoved > 0) {\n await updateGlobalManifest(rootDir, enabledModules, config);\n }\n\n return {\n indexed: totalIndexed,\n removed: totalRemoved,\n unchanged: totalUnchanged,\n };\n}\n\n/**\n * Result of processing a single file during full indexing\n */\ninterface FileProcessResult {\n relativePath: string;\n status: \"indexed\" | \"skipped\" | \"error\";\n lastModified?: string;\n chunkCount?: number;\n contentHash?: string;\n error?: unknown;\n}\n\n/**\n * Result of processing a single file during incremental (ensureIndexFresh) indexing\n */\ninterface IncrementalFileResult {\n relativePath: string;\n status: \"indexed\" | \"unchanged\" | \"mtime_updated\" | \"error\";\n lastModified?: string;\n chunkCount?: number;\n contentHash?: string;\n error?: unknown;\n}\n\n/**\n * Index files with a specific module using parallel processing\n */\nasync function indexWithModule(\n rootDir: string,\n files: string[],\n module: IndexModule,\n config: Config,\n verbose: boolean,\n introspection: IntrospectionIndex,\n logger: Logger,\n concurrency: number = DEFAULT_CONCURRENCY\n): Promise<IndexResult> {\n const result: IndexResult = {\n moduleId: module.id,\n indexed: 0,\n skipped: 0,\n errors: 0,\n };\n\n // Load existing manifest for this module\n const manifest = await loadModuleManifest(rootDir, module.id, config);\n const indexPath = getModuleIndexPath(rootDir, module.id, config);\n\n // Build set of current files for quick lookup\n const currentFileSet = new Set(files.map((f) => path.relative(rootDir, f)));\n\n // Clean up stale entries (files in manifest but no longer on disk)\n const filesToRemove: string[] = [];\n for (const filepath of Object.keys(manifest.files)) {\n if (!currentFileSet.has(filepath)) {\n filesToRemove.push(filepath);\n }\n }\n\n if (filesToRemove.length > 0) {\n logger.info(` Removing ${filesToRemove.length} stale entries...`);\n for (const filepath of filesToRemove) {\n logger.debug(` Removing: ${filepath}`);\n // Remove main index file\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(indexFilePath);\n } catch {\n // Index file may not exist\n }\n // Remove symbolic index file\n const symbolicFilePath = path.join(\n indexPath,\n \"symbolic\",\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(symbolicFilePath);\n } catch {\n // Symbolic file may not exist\n }\n delete manifest.files[filepath];\n }\n // Clean up empty directories\n await cleanupEmptyDirectories(indexPath);\n }\n\n // Create index context\n const ctx: IndexContext = {\n rootDir,\n config,\n readFile: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n return fs.readFile(fullPath, \"utf-8\");\n },\n getFileStats: async (filepath: string) => {\n const fullPath = path.isAbsolute(filepath)\n ? filepath\n : path.join(rootDir, filepath);\n const stats = await fs.stat(fullPath);\n return { lastModified: stats.mtime.toISOString() };\n },\n getIntrospection: (filepath: string) => introspection.getFile(filepath),\n };\n\n const totalFiles = files.length;\n\n // Track progress across parallel operations\n let completedCount = 0;\n\n // Process files in parallel with concurrency control\n const processFile = async (\n filepath: string,\n _index: number\n ): Promise<FileProcessResult> => {\n const relativePath = path.relative(rootDir, filepath);\n\n try {\n const stats = await fs.stat(filepath);\n const lastModified = stats.mtime.toISOString();\n const existingEntry = manifest.files[relativePath];\n\n // Fast path: if mtime unchanged, skip (no need to read file)\n if (existingEntry && existingEntry.lastModified === lastModified) {\n completedCount++;\n logger.debug(\n ` [${completedCount}/${totalFiles}] Skipped ${relativePath} (unchanged)`\n );\n return { relativePath, status: \"skipped\" };\n }\n\n // Read and index file\n const content = await fs.readFile(filepath, \"utf-8\");\n const contentHash = computeContentHash(content);\n\n // Check if content actually changed (handles git branch switches)\n if (existingEntry?.contentHash && existingEntry.contentHash === contentHash) {\n completedCount++;\n logger.debug(\n ` [${completedCount}/${totalFiles}] Skipped ${relativePath} (content unchanged)`\n );\n // Return with updated mtime but mark as skipped since content is same\n return {\n relativePath,\n status: \"skipped\",\n lastModified,\n contentHash,\n };\n }\n\n // Add introspection for this file (thread-safe - just adds to a Map)\n introspection.addFile(relativePath, content);\n\n // Update progress\n completedCount++;\n logger.progress(\n ` [${completedCount}/${totalFiles}] Processing: ${relativePath}`\n );\n\n const fileIndex = await module.indexFile(relativePath, content, ctx);\n\n if (!fileIndex) {\n logger.debug(\n ` [${completedCount}/${totalFiles}] Skipped ${relativePath} (no chunks)`\n );\n return { relativePath, status: \"skipped\" };\n }\n\n // Write index file\n await writeFileIndex(rootDir, module.id, relativePath, fileIndex, config);\n\n return {\n relativePath,\n status: \"indexed\",\n lastModified,\n chunkCount: fileIndex.chunks.length,\n contentHash,\n };\n } catch (error) {\n completedCount++;\n return { relativePath, status: \"error\", error };\n }\n };\n\n // Run parallel processing\n logger.debug(` Using concurrency: ${concurrency}`);\n const results = await parallelMap(files, processFile, concurrency);\n\n // Clear progress line\n logger.clearProgress();\n\n // Process results and update manifest\n for (const item of results) {\n if (!item.success) {\n // This shouldn't happen as we catch errors in processFile\n result.errors++;\n continue;\n }\n\n const fileResult = item.value;\n switch (fileResult.status) {\n case \"indexed\":\n manifest.files[fileResult.relativePath] = {\n lastModified: fileResult.lastModified!,\n chunkCount: fileResult.chunkCount!,\n contentHash: fileResult.contentHash,\n };\n result.indexed++;\n break;\n case \"skipped\":\n // If skipped due to content hash match but mtime changed, update mtime\n if (fileResult.lastModified && fileResult.contentHash) {\n const existingEntry = manifest.files[fileResult.relativePath];\n if (existingEntry) {\n manifest.files[fileResult.relativePath] = {\n ...existingEntry,\n lastModified: fileResult.lastModified,\n contentHash: fileResult.contentHash,\n };\n }\n }\n result.skipped++;\n break;\n case \"error\":\n logger.error(\n ` Error indexing ${fileResult.relativePath}: ${fileResult.error}`\n );\n result.errors++;\n break;\n }\n }\n\n // Update manifest\n manifest.lastUpdated = new Date().toISOString();\n await writeModuleManifest(rootDir, module.id, manifest, config);\n\n return result;\n}\n\nasync function findFiles(rootDir: string, config: Config): Promise<string[]> {\n const patterns = config.extensions.map((ext) => `**/*${ext}`);\n const ignorePatterns = config.ignorePaths.map((p) => `**/${p}/**`);\n\n const files: string[] = [];\n for (const pattern of patterns) {\n const matches = await glob(pattern, {\n cwd: rootDir,\n absolute: true,\n ignore: ignorePatterns,\n });\n files.push(...matches);\n }\n\n return [...new Set(files)]; // Remove duplicates\n}\n\nasync function loadModuleManifest(\n rootDir: string,\n moduleId: string,\n config: Config\n): Promise<ModuleManifest> {\n const manifestPath = getModuleManifestPath(rootDir, moduleId, config);\n\n try {\n const content = await fs.readFile(manifestPath, \"utf-8\");\n return JSON.parse(content);\n } catch {\n return {\n moduleId,\n version: \"1.0.0\",\n lastUpdated: new Date().toISOString(),\n files: {},\n };\n }\n}\n\nasync function writeModuleManifest(\n rootDir: string,\n moduleId: string,\n manifest: ModuleManifest,\n config: Config\n): Promise<void> {\n const manifestPath = getModuleManifestPath(rootDir, moduleId, config);\n await fs.mkdir(path.dirname(manifestPath), { recursive: true });\n await fs.writeFile(manifestPath, JSON.stringify(manifest, null, 2));\n}\n\nasync function writeFileIndex(\n rootDir: string,\n moduleId: string,\n filepath: string,\n fileIndex: FileIndex,\n config: Config\n): Promise<void> {\n const indexPath = getModuleIndexPath(rootDir, moduleId, config);\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n\n await fs.mkdir(path.dirname(indexFilePath), { recursive: true });\n await fs.writeFile(indexFilePath, JSON.stringify(fileIndex, null, 2));\n}\n\nasync function updateGlobalManifest(\n rootDir: string,\n modules: IndexModule[],\n config: Config\n): Promise<void> {\n const manifestPath = getGlobalManifestPath(rootDir, config);\n\n const manifest: GlobalManifest = {\n version: INDEX_SCHEMA_VERSION,\n lastUpdated: new Date().toISOString(),\n modules: modules.map((m) => m.id),\n };\n\n await fs.mkdir(path.dirname(manifestPath), { recursive: true });\n await fs.writeFile(manifestPath, JSON.stringify(manifest, null, 2));\n}\n\n/**\n * Options for cleanup operation\n */\nexport interface CleanupOptions {\n /** Show detailed progress */\n verbose?: boolean;\n /** Logger for progress reporting */\n logger?: Logger;\n}\n\n/**\n * Clean up stale index entries for files that no longer exist\n * @param rootDir - Root directory of the project\n * @param options - Cleanup options\n * @returns Array of cleanup results per module\n */\nexport async function cleanupIndex(\n rootDir: string,\n options: CleanupOptions = {}\n): Promise<CleanupResult[]> {\n const verbose = options.verbose ?? false;\n\n // Create logger\n const logger: Logger = options.logger ?? createLogger({ verbose });\n\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n logger.info(`Cleaning up index in: ${rootDir}`);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Get enabled modules\n const enabledModules = registry.getEnabled(config);\n\n if (enabledModules.length === 0) {\n logger.info(\"No modules enabled.\");\n return [];\n }\n\n const results: CleanupResult[] = [];\n\n for (const module of enabledModules) {\n logger.info(`\\n[${module.name}] Checking for stale entries...`);\n\n const result = await cleanupModuleIndex(rootDir, module.id, config, logger);\n results.push(result);\n\n logger.info(\n `[${module.name}] Removed ${result.removed} stale entries, kept ${result.kept} valid entries`\n );\n }\n\n return results;\n}\n\n/**\n * Clean up stale index entries for a specific module\n */\nasync function cleanupModuleIndex(\n rootDir: string,\n moduleId: string,\n config: Config,\n logger: Logger\n): Promise<CleanupResult> {\n const result: CleanupResult = {\n moduleId,\n removed: 0,\n kept: 0,\n };\n\n // Load manifest\n const manifest = await loadModuleManifest(rootDir, moduleId, config);\n const indexPath = getModuleIndexPath(rootDir, moduleId, config);\n\n const filesToRemove: string[] = [];\n const updatedFiles: ModuleManifest[\"files\"] = {};\n\n // Check each indexed file\n for (const [filepath, entry] of Object.entries(manifest.files)) {\n const fullPath = path.join(rootDir, filepath);\n\n try {\n await fs.access(fullPath);\n // File exists, keep it\n updatedFiles[filepath] = entry;\n result.kept++;\n } catch {\n // File doesn't exist, mark for removal\n filesToRemove.push(filepath);\n result.removed++;\n logger.debug(` Removing stale entry: ${filepath}`);\n }\n }\n\n // Remove stale index files\n for (const filepath of filesToRemove) {\n const indexFilePath = path.join(\n indexPath,\n filepath.replace(/\\.[^.]+$/, \".json\")\n );\n try {\n await fs.unlink(indexFilePath);\n } catch {\n // Index file may not exist, that's okay\n }\n }\n\n // Update manifest with only valid files\n manifest.files = updatedFiles;\n manifest.lastUpdated = new Date().toISOString();\n await writeModuleManifest(rootDir, moduleId, manifest, config);\n\n // Clean up empty directories in the index\n await cleanupEmptyDirectories(indexPath);\n\n return result;\n}\n\n/**\n * Recursively remove empty directories\n */\nasync function cleanupEmptyDirectories(dir: string): Promise<boolean> {\n try {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n\n // Process subdirectories first\n for (const entry of entries) {\n if (entry.isDirectory()) {\n const subDir = path.join(dir, entry.name);\n await cleanupEmptyDirectories(subDir);\n }\n }\n\n // Check if directory is now empty (re-read after potential subdirectory removal)\n const remainingEntries = await fs.readdir(dir);\n\n // Don't remove the root index directory or manifest files\n if (remainingEntries.length === 0) {\n await fs.rmdir(dir);\n return true;\n }\n\n return false;\n } catch {\n return false;\n }\n}\n\n/**\n * Get the current status of the index\n * @param rootDir - Root directory of the project\n * @returns Index status information\n */\nexport async function getIndexStatus(rootDir: string): Promise<IndexStatus> {\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Get index location (now in temp directory)\n const location = getIndexLocation(rootDir);\n const indexDir = location.indexDir;\n\n const status: IndexStatus = {\n exists: false,\n rootDir,\n indexDir,\n modules: [],\n totalFiles: 0,\n };\n\n // Check if index directory exists\n try {\n await fs.access(indexDir);\n } catch {\n return status;\n }\n\n // Try to load global manifest\n try {\n const globalManifestPath = getGlobalManifestPath(rootDir, config);\n const content = await fs.readFile(globalManifestPath, \"utf-8\");\n const globalManifest: GlobalManifest = JSON.parse(content);\n\n status.exists = true;\n status.lastUpdated = globalManifest.lastUpdated;\n\n // Load each module's manifest\n for (const moduleId of globalManifest.modules) {\n try {\n const manifest = await loadModuleManifest(rootDir, moduleId, config);\n const fileCount = Object.keys(manifest.files).length;\n\n status.modules.push({\n id: moduleId,\n fileCount,\n lastUpdated: manifest.lastUpdated,\n });\n\n status.totalFiles += fileCount;\n } catch {\n // Module manifest doesn't exist or is corrupt\n }\n }\n } catch {\n // Global manifest doesn't exist - check if there's any index data\n try {\n const entries = await fs.readdir(path.join(indexDir, \"index\"));\n if (entries.length > 0) {\n status.exists = true;\n // Try to load manifests for known modules\n for (const entry of entries) {\n try {\n const manifest = await loadModuleManifest(rootDir, entry, config);\n const fileCount = Object.keys(manifest.files).length;\n\n status.modules.push({\n id: entry,\n fileCount,\n lastUpdated: manifest.lastUpdated,\n });\n\n status.totalFiles += fileCount;\n } catch {\n // Skip\n }\n }\n }\n } catch {\n // No index directory\n }\n }\n\n return status;\n}\n\n// Re-export watcher\nexport { watchDirectory, type WatchOptions, type FileWatcher } from \"./watcher\";\n",
48
48
  "'use strict';\nmodule.exports = balanced;\nfunction balanced(a, b, str) {\n if (a instanceof RegExp) a = maybeMatch(a, str);\n if (b instanceof RegExp) b = maybeMatch(b, str);\n\n var r = range(a, b, str);\n\n return r && {\n start: r[0],\n end: r[1],\n pre: str.slice(0, r[0]),\n body: str.slice(r[0] + a.length, r[1]),\n post: str.slice(r[1] + b.length)\n };\n}\n\nfunction maybeMatch(reg, str) {\n var m = str.match(reg);\n return m ? m[0] : null;\n}\n\nbalanced.range = range;\nfunction range(a, b, str) {\n var begs, beg, left, right, result;\n var ai = str.indexOf(a);\n var bi = str.indexOf(b, ai + 1);\n var i = ai;\n\n if (ai >= 0 && bi > 0) {\n if(a===b) {\n return [ai, bi];\n }\n begs = [];\n left = str.length;\n\n while (i >= 0 && !result) {\n if (i == ai) {\n begs.push(i);\n ai = str.indexOf(a, i + 1);\n } else if (begs.length == 1) {\n result = [ begs.pop(), bi ];\n } else {\n beg = begs.pop();\n if (beg < left) {\n left = beg;\n right = bi;\n }\n\n bi = str.indexOf(b, i + 1);\n }\n\n i = ai < bi && ai >= 0 ? ai : bi;\n }\n\n if (begs.length) {\n result = [ left, right ];\n }\n }\n\n return result;\n}\n",
49
49
  "var balanced = require('balanced-match');\n\nmodule.exports = expandTop;\n\nvar escSlash = '\\0SLASH'+Math.random()+'\\0';\nvar escOpen = '\\0OPEN'+Math.random()+'\\0';\nvar escClose = '\\0CLOSE'+Math.random()+'\\0';\nvar escComma = '\\0COMMA'+Math.random()+'\\0';\nvar escPeriod = '\\0PERIOD'+Math.random()+'\\0';\n\nfunction numeric(str) {\n return parseInt(str, 10) == str\n ? parseInt(str, 10)\n : str.charCodeAt(0);\n}\n\nfunction escapeBraces(str) {\n return str.split('\\\\\\\\').join(escSlash)\n .split('\\\\{').join(escOpen)\n .split('\\\\}').join(escClose)\n .split('\\\\,').join(escComma)\n .split('\\\\.').join(escPeriod);\n}\n\nfunction unescapeBraces(str) {\n return str.split(escSlash).join('\\\\')\n .split(escOpen).join('{')\n .split(escClose).join('}')\n .split(escComma).join(',')\n .split(escPeriod).join('.');\n}\n\n\n// Basically just str.split(\",\"), but handling cases\n// where we have nested braced sections, which should be\n// treated as individual members, like {a,{b,c},d}\nfunction parseCommaParts(str) {\n if (!str)\n return [''];\n\n var parts = [];\n var m = balanced('{', '}', str);\n\n if (!m)\n return str.split(',');\n\n var pre = m.pre;\n var body = m.body;\n var post = m.post;\n var p = pre.split(',');\n\n p[p.length-1] += '{' + body + '}';\n var postParts = parseCommaParts(post);\n if (post.length) {\n p[p.length-1] += postParts.shift();\n p.push.apply(p, postParts);\n }\n\n parts.push.apply(parts, p);\n\n return parts;\n}\n\nfunction expandTop(str) {\n if (!str)\n return [];\n\n // I don't know why Bash 4.3 does this, but it does.\n // Anything starting with {} will have the first two bytes preserved\n // but *only* at the top level, so {},a}b will not expand to anything,\n // but a{},b}c will be expanded to [a}c,abc].\n // One could argue that this is a bug in Bash, but since the goal of\n // this module is to match Bash's rules, we escape a leading {}\n if (str.substr(0, 2) === '{}') {\n str = '\\\\{\\\\}' + str.substr(2);\n }\n\n return expand(escapeBraces(str), true).map(unescapeBraces);\n}\n\nfunction embrace(str) {\n return '{' + str + '}';\n}\nfunction isPadded(el) {\n return /^-?0\\d/.test(el);\n}\n\nfunction lte(i, y) {\n return i <= y;\n}\nfunction gte(i, y) {\n return i >= y;\n}\n\nfunction expand(str, isTop) {\n var expansions = [];\n\n var m = balanced('{', '}', str);\n if (!m) return [str];\n\n // no need to expand pre, since it is guaranteed to be free of brace-sets\n var pre = m.pre;\n var post = m.post.length\n ? expand(m.post, false)\n : [''];\n\n if (/\\$$/.test(m.pre)) { \n for (var k = 0; k < post.length; k++) {\n var expansion = pre+ '{' + m.body + '}' + post[k];\n expansions.push(expansion);\n }\n } else {\n var isNumericSequence = /^-?\\d+\\.\\.-?\\d+(?:\\.\\.-?\\d+)?$/.test(m.body);\n var isAlphaSequence = /^[a-zA-Z]\\.\\.[a-zA-Z](?:\\.\\.-?\\d+)?$/.test(m.body);\n var isSequence = isNumericSequence || isAlphaSequence;\n var isOptions = m.body.indexOf(',') >= 0;\n if (!isSequence && !isOptions) {\n // {a},b}\n if (m.post.match(/,(?!,).*\\}/)) {\n str = m.pre + '{' + m.body + escClose + m.post;\n return expand(str);\n }\n return [str];\n }\n\n var n;\n if (isSequence) {\n n = m.body.split(/\\.\\./);\n } else {\n n = parseCommaParts(m.body);\n if (n.length === 1) {\n // x{{a,b}}y ==> x{a}y x{b}y\n n = expand(n[0], false).map(embrace);\n if (n.length === 1) {\n return post.map(function(p) {\n return m.pre + n[0] + p;\n });\n }\n }\n }\n\n // at this point, n is the parts, and we know it's not a comma set\n // with a single entry.\n var N;\n\n if (isSequence) {\n var x = numeric(n[0]);\n var y = numeric(n[1]);\n var width = Math.max(n[0].length, n[1].length)\n var incr = n.length == 3\n ? Math.abs(numeric(n[2]))\n : 1;\n var test = lte;\n var reverse = y < x;\n if (reverse) {\n incr *= -1;\n test = gte;\n }\n var pad = n.some(isPadded);\n\n N = [];\n\n for (var i = x; test(i, y); i += incr) {\n var c;\n if (isAlphaSequence) {\n c = String.fromCharCode(i);\n if (c === '\\\\')\n c = '';\n } else {\n c = String(i);\n if (pad) {\n var need = width - c.length;\n if (need > 0) {\n var z = new Array(need + 1).join('0');\n if (i < 0)\n c = '-' + z + c.slice(1);\n else\n c = z + c;\n }\n }\n }\n N.push(c);\n }\n } else {\n N = [];\n\n for (var j = 0; j < n.length; j++) {\n N.push.apply(N, expand(n[j], false));\n }\n }\n\n for (var j = 0; j < N.length; j++) {\n for (var k = 0; k < post.length; k++) {\n var expansion = pre + N[j] + post[k];\n if (!isTop || isSequence || expansion)\n expansions.push(expansion);\n }\n }\n }\n\n return expansions;\n}\n\n",
50
50
  "const MAX_PATTERN_LENGTH = 1024 * 64;\nexport const assertValidPattern = (pattern) => {\n if (typeof pattern !== 'string') {\n throw new TypeError('invalid pattern');\n }\n if (pattern.length > MAX_PATTERN_LENGTH) {\n throw new TypeError('pattern is too long');\n }\n};\n//# sourceMappingURL=assert-valid-pattern.js.map",
@@ -57,7 +57,7 @@
57
57
  "// Search module - queries across all enabled modules\nimport * as fs from \"fs/promises\";\nimport * as path from \"path\";\nimport { minimatch } from \"minimatch\";\nimport {\n Config,\n SearchContext,\n SearchOptions,\n SearchResult,\n FileIndex,\n IndexModule,\n GlobalManifest,\n DEFAULT_SEARCH_OPTIONS,\n} from \"../../types\";\nimport {\n loadConfig,\n getModuleIndexPath,\n getGlobalManifestPath,\n getModuleConfig,\n} from \"../../infrastructure/config\";\nimport { registry, registerBuiltInModules } from \"../../modules/registry\";\nimport { ensureIndexFresh } from \"../indexer\";\n\n/**\n * Search across all enabled modules\n */\nexport async function search(\n rootDir: string,\n query: string,\n options: SearchOptions = {}\n): Promise<SearchResult[]> {\n // Ensure absolute path\n rootDir = path.resolve(rootDir);\n\n // Ensure index is fresh before searching (unless explicitly disabled)\n const ensureFresh = options.ensureFresh ?? DEFAULT_SEARCH_OPTIONS.ensureFresh;\n if (ensureFresh) {\n await ensureIndexFresh(rootDir, { quiet: true });\n }\n\n console.log(`Searching for: \"${query}\"`);\n\n // Load config\n const config = await loadConfig(rootDir);\n\n // Register built-in modules\n await registerBuiltInModules();\n\n // Check which modules have indexes\n const globalManifest = await loadGlobalManifest(rootDir, config);\n\n if (!globalManifest || globalManifest.modules.length === 0) {\n console.log('No index found. Run \"raggrep index\" first.');\n return [];\n }\n\n // Get modules that are both enabled and have indexes\n const modulesToSearch: IndexModule[] = [];\n\n for (const moduleId of globalManifest.modules) {\n const module = registry.get(moduleId);\n const moduleConfig = getModuleConfig(config, moduleId);\n\n if (module && moduleConfig?.enabled) {\n // Initialize module if needed\n if (module.initialize) {\n await module.initialize(moduleConfig);\n }\n modulesToSearch.push(module);\n }\n }\n\n if (modulesToSearch.length === 0) {\n console.log(\"No enabled modules with indexes found.\");\n return [];\n }\n\n // Search with each module and aggregate results\n const allResults: SearchResult[] = [];\n\n for (const module of modulesToSearch) {\n const ctx = createSearchContext(rootDir, module.id, config);\n const moduleResults = await module.search(query, ctx, options);\n allResults.push(...moduleResults);\n }\n\n // Apply path filter if specified\n let filteredResults = allResults;\n if (options.pathFilter && options.pathFilter.length > 0) {\n const normalizedFilters = options.pathFilter.map((p) =>\n p.replace(/\\\\/g, \"/\").replace(/^\\//, \"\").replace(/\\/$/, \"\")\n );\n filteredResults = allResults.filter((result) => {\n const normalizedPath = result.filepath.replace(/\\\\/g, \"/\");\n return normalizedFilters.some((filter) => {\n // Check if the filter is a glob pattern\n const isGlobPattern = /[*?[\\]{}!]/.test(filter);\n\n if (isGlobPattern) {\n // Use minimatch for glob patterns\n // Support patterns like \"*.ts\", \"src/**/*.ts\", \"**/*.md\"\n const pattern = filter.startsWith(\"**/\") ? filter : `**/${filter}`;\n return minimatch(normalizedPath, pattern, { matchBase: true });\n } else {\n // Fall back to path prefix matching for non-glob patterns\n return (\n normalizedPath.startsWith(filter + \"/\") ||\n normalizedPath === filter ||\n normalizedPath.startsWith(\"./\" + filter + \"/\") ||\n normalizedPath === \"./\" + filter\n );\n }\n });\n });\n }\n\n // Sort all results by score\n filteredResults.sort((a, b) => b.score - a.score);\n\n // Return top K\n const topK = options.topK ?? 10;\n return filteredResults.slice(0, topK);\n}\n\n/**\n * Create a search context for a specific module\n */\nfunction createSearchContext(\n rootDir: string,\n moduleId: string,\n config: Config\n): SearchContext {\n const indexPath = getModuleIndexPath(rootDir, moduleId, config);\n\n return {\n rootDir,\n config,\n\n loadFileIndex: async (filepath: string): Promise<FileIndex | null> => {\n // filepath may or may not have an extension\n // If it has an extension, replace it with .json; otherwise append .json\n const hasExtension = /\\.[^./]+$/.test(filepath);\n const indexFilePath = hasExtension\n ? path.join(indexPath, filepath.replace(/\\.[^.]+$/, \".json\"))\n : path.join(indexPath, filepath + \".json\");\n\n try {\n const content = await fs.readFile(indexFilePath, \"utf-8\");\n return JSON.parse(content);\n } catch {\n return null;\n }\n },\n\n listIndexedFiles: async (): Promise<string[]> => {\n const files: string[] = [];\n await traverseDirectory(indexPath, files, indexPath);\n\n // Convert index file paths back to source file paths\n return files\n .filter((f) => f.endsWith(\".json\") && !f.endsWith(\"manifest.json\"))\n .map((f) => {\n const relative = path.relative(indexPath, f);\n // Convert .json back to original extension (we'll handle this generically)\n return relative.replace(/\\.json$/, \"\");\n });\n },\n };\n}\n\nasync function traverseDirectory(\n dir: string,\n files: string[],\n basePath: string\n): Promise<void> {\n try {\n const entries = await fs.readdir(dir, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n\n if (entry.isDirectory()) {\n await traverseDirectory(fullPath, files, basePath);\n } else if (entry.isFile()) {\n files.push(fullPath);\n }\n }\n } catch {\n // Directory doesn't exist\n }\n}\n\nasync function loadGlobalManifest(\n rootDir: string,\n config: Config\n): Promise<GlobalManifest | null> {\n const manifestPath = getGlobalManifestPath(rootDir, config);\n\n try {\n const content = await fs.readFile(manifestPath, \"utf-8\");\n return JSON.parse(content);\n } catch {\n return null;\n }\n}\n\n/**\n * Get a human-friendly name for a module ID\n */\nfunction formatModuleName(moduleId: string): string {\n switch (moduleId) {\n case \"core\":\n return \"Core\";\n case \"language/typescript\":\n return \"TypeScript\";\n default:\n // Handle future modules: \"language/python\" -> \"Python\"\n if (moduleId.startsWith(\"language/\")) {\n const lang = moduleId.replace(\"language/\", \"\");\n return lang.charAt(0).toUpperCase() + lang.slice(1);\n }\n return moduleId;\n }\n}\n\n/**\n * Format search results for display\n * @param results - Array of search results to format\n * @returns Formatted string for console output\n */\nexport function formatSearchResults(results: SearchResult[]): string {\n if (results.length === 0) {\n return \"No results found.\";\n }\n\n let output = `Found ${results.length} results:\\n\\n`;\n\n for (let i = 0; i < results.length; i++) {\n const result = results[i];\n const { chunk } = result;\n\n // Format location with optional name\n const location = `${result.filepath}:${chunk.startLine}-${chunk.endLine}`;\n const nameInfo = chunk.name ? ` (${chunk.name})` : \"\";\n\n output += `${i + 1}. ${location}${nameInfo}\\n`;\n output += ` Score: ${(result.score * 100).toFixed(1)}% | Type: ${\n chunk.type\n }`;\n\n // Show which module contributed this result\n output += ` | via ${formatModuleName(result.moduleId)}`;\n\n // Add export indicator\n if (chunk.isExported) {\n output += \" | exported\";\n }\n output += \"\\n\";\n\n // Show preview (first 3 lines)\n const lines = chunk.content.split(\"\\n\").slice(0, 3);\n for (const line of lines) {\n const trimmedLine = line.substring(0, 80);\n output += ` ${trimmedLine}${line.length > 80 ? \"...\" : \"\"}\\n`;\n }\n\n output += \"\\n\";\n }\n\n return output;\n}\n",
58
58
  "// Main CLI entry point for raggrep\n\nimport { EMBEDDING_MODELS, getCacheDir } from \"../../infrastructure/embeddings\";\nimport {\n createInlineLogger,\n createSilentLogger,\n} from \"../../infrastructure/logger\";\nimport type { EmbeddingModelName } from \"../../domain/ports\";\n// @ts-ignore - JSON import inlined by Bun at build time\nimport pkg from \"../../../package.json\";\n\nconst VERSION = pkg.version;\n\nconst args = process.argv.slice(2);\nconst command = args[0];\n\n// Handle --version / -v at top level (before any command)\nif (command === \"--version\" || command === \"-v\") {\n console.log(`raggrep v${VERSION}`);\n process.exit(0);\n}\n\n/**\n * Format a date as a human-readable \"time ago\" string\n */\nfunction formatTimeAgo(date: Date): string {\n const now = new Date();\n const diffMs = now.getTime() - date.getTime();\n const diffSecs = Math.floor(diffMs / 1000);\n const diffMins = Math.floor(diffSecs / 60);\n const diffHours = Math.floor(diffMins / 60);\n const diffDays = Math.floor(diffHours / 24);\n\n if (diffSecs < 60) return \"just now\";\n if (diffMins < 60) return `${diffMins}m ago`;\n if (diffHours < 24) return `${diffHours}h ago`;\n if (diffDays < 7) return `${diffDays}d ago`;\n\n // For older dates, show the actual date\n return date.toLocaleDateString();\n}\n\n/**\n * Parsed CLI flags from command line arguments\n */\ninterface ParsedFlags {\n /** Embedding model to use */\n model?: EmbeddingModelName;\n /** Number of results to return */\n topK?: number;\n /** Minimum similarity score threshold (0-1) */\n minScore?: number;\n /** File extension filter (e.g., 'ts', 'tsx') */\n fileType?: string;\n /** Path filter for search (e.g., 'src/auth') */\n pathFilter?: string[];\n /** Show help message */\n help: boolean;\n /** Show detailed progress */\n verbose: boolean;\n /** Watch mode for continuous indexing */\n watch: boolean;\n /** Number of files to process in parallel */\n concurrency?: number;\n /** Remaining positional arguments */\n remaining: string[];\n}\n\n/**\n * Parse CLI flags from command line arguments\n * @param args - Array of command line arguments (excluding command name)\n * @returns Parsed flags object\n */\nfunction parseFlags(args: string[]): ParsedFlags {\n const flags: ParsedFlags = {\n help: false,\n verbose: false,\n watch: false,\n remaining: [],\n };\n\n for (let i = 0; i < args.length; i++) {\n const arg = args[i];\n\n if (arg === \"--help\" || arg === \"-h\") {\n flags.help = true;\n } else if (arg === \"--verbose\" || arg === \"-v\") {\n flags.verbose = true;\n } else if (arg === \"--watch\" || arg === \"-w\") {\n flags.watch = true;\n } else if (arg === \"--model\" || arg === \"-m\") {\n const modelName = args[++i];\n if (modelName && modelName in EMBEDDING_MODELS) {\n flags.model = modelName as EmbeddingModelName;\n } else {\n console.error(`Invalid model: ${modelName}`);\n console.error(\n `Available models: ${Object.keys(EMBEDDING_MODELS).join(\", \")}`\n );\n process.exit(1);\n }\n } else if (arg === \"--top\" || arg === \"-k\") {\n const k = parseInt(args[++i], 10);\n if (!isNaN(k) && k > 0) {\n flags.topK = k;\n }\n } else if (arg === \"--min-score\" || arg === \"-s\") {\n const score = parseFloat(args[++i]);\n if (!isNaN(score) && score >= 0 && score <= 1) {\n flags.minScore = score;\n } else {\n console.error(\n `Invalid min-score: ${args[i]}. Must be a number between 0 and 1.`\n );\n process.exit(1);\n }\n } else if (arg === \"--type\" || arg === \"-t\") {\n const type = args[++i];\n if (type) {\n // Normalize: remove leading dot if present\n flags.fileType = type.startsWith(\".\") ? type.slice(1) : type;\n } else {\n console.error(\"--type requires a file extension (e.g., ts, tsx, js)\");\n process.exit(1);\n }\n } else if (arg === \"--concurrency\" || arg === \"-c\") {\n const c = parseInt(args[++i], 10);\n if (!isNaN(c) && c > 0) {\n flags.concurrency = c;\n } else {\n console.error(\n `Invalid concurrency: ${args[i]}. Must be a positive integer.`\n );\n process.exit(1);\n }\n } else if (arg === \"--filter\" || arg === \"-f\") {\n const filterPath = args[++i];\n if (filterPath) {\n if (!flags.pathFilter) {\n flags.pathFilter = [];\n }\n flags.pathFilter.push(filterPath);\n } else {\n console.error(\n '--filter requires a path or glob pattern (e.g., src/auth, \"*.ts\")'\n );\n process.exit(1);\n }\n } else if (!arg.startsWith(\"-\")) {\n flags.remaining.push(arg);\n }\n }\n\n return flags;\n}\n\nasync function main() {\n const flags = parseFlags(args.slice(1)); // Skip the command itself\n\n switch (command) {\n case \"index\": {\n if (flags.help) {\n const models = Object.keys(EMBEDDING_MODELS).join(\", \");\n console.log(`\nraggrep index - Index the current directory for semantic search\n\nUsage:\n raggrep index [options]\n\nOptions:\n -w, --watch Watch for file changes and re-index automatically\n -m, --model <name> Embedding model to use (default: bge-small-en-v1.5)\n -c, --concurrency <n> Number of files to process in parallel (default: auto)\n -v, --verbose Show detailed progress\n -h, --help Show this help message\n\nAvailable Models:\n ${models}\n\nModel Cache: ${getCacheDir()}\n\nExamples:\n raggrep index\n raggrep index --watch\n raggrep index --model bge-small-en-v1.5\n raggrep index --concurrency 8\n raggrep index --verbose\n`);\n process.exit(0);\n }\n\n const { indexDirectory, watchDirectory } = await import(\"../indexer\");\n\n // Create inline logger for CLI (progress replaces current line)\n const logger = createInlineLogger({ verbose: flags.verbose });\n\n // Initial indexing\n console.log(\"RAGgrep Indexer\");\n console.log(\"================\\n\");\n try {\n const results = await indexDirectory(process.cwd(), {\n model: flags.model,\n verbose: flags.verbose,\n concurrency: flags.concurrency,\n logger,\n });\n console.log(\"\\n================\");\n console.log(\"Summary:\");\n for (const result of results) {\n console.log(\n ` ${result.moduleId}: ${result.indexed} indexed, ${result.skipped} skipped, ${result.errors} errors`\n );\n }\n } catch (error) {\n console.error(\"Error during indexing:\", error);\n process.exit(1);\n }\n\n // Watch mode\n if (flags.watch) {\n console.log(\"\\n┌─────────────────────────────────────────┐\");\n console.log(\"│ Watching for changes... (Ctrl+C to stop) │\");\n console.log(\"└─────────────────────────────────────────┘\\n\");\n\n try {\n const watcher = await watchDirectory(process.cwd(), {\n model: flags.model,\n verbose: flags.verbose,\n onFileChange: (event, filepath) => {\n if (flags.verbose) {\n const symbol =\n event === \"add\" ? \"+\" : event === \"unlink\" ? \"-\" : \"~\";\n console.log(` ${symbol} ${filepath}`);\n }\n },\n });\n\n // Handle graceful shutdown\n const shutdown = async () => {\n console.log(\"\\n\\nStopping watcher...\");\n await watcher.stop();\n console.log(\"Done.\");\n process.exit(0);\n };\n\n process.on(\"SIGINT\", shutdown);\n process.on(\"SIGTERM\", shutdown);\n\n // Keep the process running\n await new Promise(() => {}); // Never resolves\n } catch (error) {\n console.error(\"Error starting watcher:\", error);\n process.exit(1);\n }\n }\n break;\n }\n\n case \"query\": {\n if (flags.help) {\n console.log(`\nraggrep query - Search the indexed codebase\n\nUsage:\n raggrep query <search query> [options]\n\nOptions:\n -k, --top <n> Number of results to return (default: 10)\n -s, --min-score <n> Minimum similarity score 0-1 (default: 0.15)\n -t, --type <ext> Filter by file extension (e.g., ts, tsx, js)\n -f, --filter <path> Filter by path or glob pattern (can be used multiple times)\n -h, --help Show this help message\n\nNote:\n The index is managed automatically like a cache:\n - First query creates the index\n - Changed files are re-indexed automatically\n - Deleted files are cleaned up automatically\n - Unchanged files use the cached index (instant)\n\nFilter Patterns:\n Path prefix: --filter src/auth (matches src/auth/*)\n Glob pattern: --filter \"*.ts\" (matches all .ts files)\n Glob pattern: --filter \"*.md\" (matches all .md files)\n Glob pattern: --filter \"src/**/*.test.ts\" (matches test files in src/)\n\nMultiple Filters (OR logic):\n Use multiple --filter flags to match files that match ANY of the patterns.\n raggrep query \"api\" --filter \"*.ts\" --filter \"*.tsx\" (matches .ts OR .tsx)\n raggrep query \"docs\" --filter \"*.md\" --filter docs/ (matches .md OR docs/)\n\nExamples:\n raggrep query \"user authentication\"\n raggrep query \"handle errors\" --top 5\n raggrep query \"database\" --min-score 0.1\n raggrep query \"interface\" --type ts\n raggrep query \"login\" --filter src/auth\n raggrep query \"api\" --filter src/api --filter src/routes\n\n # Search only source code files\n raggrep query \"service controller\" --filter \"*.ts\"\n raggrep query \"component state\" --filter \"*.tsx\"\n\n # Search only documentation\n raggrep query \"deployment workflow\" --filter \"*.md\"\n\n # Search specific patterns\n raggrep query \"test helpers\" --filter \"*.test.ts\"\n`);\n process.exit(0);\n }\n\n const { search, formatSearchResults } = await import(\"../search\");\n const { ensureIndexFresh } = await import(\"../indexer\");\n const query = flags.remaining[0];\n\n if (!query) {\n console.error(\"Usage: raggrep query <search query>\");\n console.error('Run \"raggrep query --help\" for more information.');\n process.exit(1);\n }\n\n try {\n // Create silent logger for background indexing during query\n const silentLogger = createSilentLogger();\n\n // Ensure index is fresh (creates if needed, updates if changed)\n const freshStats = await ensureIndexFresh(process.cwd(), {\n model: flags.model,\n quiet: true, // Suppress detailed indexing output\n logger: silentLogger,\n });\n\n console.log(\"RAGgrep Search\");\n console.log(\"==============\\n\");\n\n // Show brief index status summary\n if (freshStats.indexed > 0 || freshStats.removed > 0) {\n const parts: string[] = [];\n if (freshStats.indexed > 0) {\n parts.push(`${freshStats.indexed} indexed`);\n }\n if (freshStats.removed > 0) {\n parts.push(`${freshStats.removed} removed`);\n }\n console.log(`Using updated index: ${parts.join(\", \")}\\n`);\n } else {\n console.log(\"Using cached index (no changes detected).\\n\");\n }\n\n // Build file patterns if type filter specified\n const filePatterns = flags.fileType\n ? [`*.${flags.fileType}`]\n : undefined;\n\n const results = await search(process.cwd(), query, {\n topK: flags.topK ?? 10,\n minScore: flags.minScore,\n filePatterns,\n pathFilter: flags.pathFilter,\n // Skip automatic freshness check since we already called ensureIndexFresh above\n ensureFresh: false,\n });\n console.log(formatSearchResults(results));\n } catch (error) {\n console.error(\"Error during search:\", error);\n process.exit(1);\n }\n break;\n }\n\n case \"reset\": {\n if (flags.help) {\n console.log(`\nraggrep reset - Clear the index for the current directory\n\nUsage:\n raggrep reset [options]\n\nOptions:\n -h, --help Show this help message\n\nDescription:\n Completely removes the index for the current directory.\n The next 'raggrep index' or 'raggrep query' will rebuild from scratch.\n\nExamples:\n raggrep reset\n`);\n process.exit(0);\n }\n\n const { resetIndex } = await import(\"../indexer\");\n\n try {\n const result = await resetIndex(process.cwd());\n console.log(\"Index cleared successfully.\");\n console.log(` Removed: ${result.indexDir}`);\n } catch (error) {\n if (\n error instanceof Error &&\n error.message.includes(\"No index found\")\n ) {\n console.error(\"Error: No index found for this directory.\");\n process.exit(1);\n }\n console.error(\"Error during reset:\", error);\n process.exit(1);\n }\n break;\n }\n\n case \"status\": {\n if (flags.help) {\n console.log(`\nraggrep status - Show the current state of the index\n\nUsage:\n raggrep status [options]\n\nOptions:\n -h, --help Show this help message\n\nDescription:\n Displays information about the index in the current directory,\n including whether it exists, how many files are indexed, and\n when it was last updated.\n\nExamples:\n raggrep status\n`);\n process.exit(0);\n }\n\n const { getIndexStatus } = await import(\"../indexer\");\n try {\n const status = await getIndexStatus(process.cwd());\n\n if (!status.exists) {\n console.log(`\n┌─────────────────────────────────────────┐\n│ RAGgrep Status │\n├─────────────────────────────────────────┤\n│ ○ Not indexed │\n└─────────────────────────────────────────┘\n\n Directory: ${status.rootDir}\n\n Run \"raggrep index\" to create an index.\n`);\n } else {\n const date = status.lastUpdated ? new Date(status.lastUpdated) : null;\n const timeAgo = date ? formatTimeAgo(date) : \"unknown\";\n\n console.log(`\n┌─────────────────────────────────────────┐\n│ RAGgrep Status │\n├─────────────────────────────────────────┤\n│ ● Indexed │\n└─────────────────────────────────────────┘\n\n Files: ${status.totalFiles.toString().padEnd(10)} Updated: ${timeAgo}\n Location: ${status.indexDir}\n`);\n if (status.modules.length > 0) {\n console.log(\" Modules:\");\n for (const mod of status.modules) {\n console.log(` └─ ${mod.id} (${mod.fileCount} files)`);\n }\n console.log(\"\");\n }\n }\n } catch (error) {\n console.error(\"Error getting status:\", error);\n process.exit(1);\n }\n break;\n }\n\n case \"opencode\": {\n const subcommand = flags.remaining[0];\n\n if (flags.help || !subcommand) {\n console.log(`\nraggrep opencode - Manage opencode integration\n\nUsage:\n raggrep opencode <subcommand>\n\nSubcommands:\n install Install or update the raggrep tool for opencode\n\nDescription:\n Installs the raggrep tool to ~/.config/opencode/tool/raggrep.ts\n This allows opencode to use raggrep for semantic code search.\n\nExamples:\n raggrep opencode install\n`);\n process.exit(0);\n }\n\n if (subcommand === \"install\") {\n const os = await import(\"os\");\n const fs = await import(\"fs/promises\");\n const path = await import(\"path\");\n\n const homeDir = os.homedir();\n const toolDir = path.join(homeDir, \".config\", \"opencode\", \"tool\");\n const toolPath = path.join(toolDir, \"raggrep.ts\");\n\n const toolContent = `import { tool } from \"@opencode-ai/plugin\";\n\nexport default tool({\n description:\n \"Search the codebase using semantic RAG (Retrieval-Augmented Generation). Uses raggrep to find relevant code snippets based on natural language queries. The index is managed automatically - first query creates it, changed files are re-indexed, and unchanged files use cached index.\",\n args: {\n query: tool.schema\n .string()\n .describe(\n \"Natural language search query (e.g., 'user authentication', 'handle errors')\"\n ),\n top: tool.schema\n .number()\n .optional()\n .describe(\"Number of results to return (default: 10)\"),\n minScore: tool.schema\n .number()\n .optional()\n .describe(\"Minimum similarity score 0-1 (default: 0.15)\"),\n type: tool.schema\n .string()\n .optional()\n .describe(\"Filter by file extension (e.g., ts, tsx, js)\"),\n filter: tool.schema\n .array(tool.schema.string())\n .optional()\n .describe(\n \"Filter by path prefix or glob pattern. Multiple filters use OR logic. Examples: 'src/auth', '*.ts', '*.md', 'src/**/*.test.ts'\"\n ),\n },\n async execute(args) {\n const cmdArgs = [args.query];\n\n if (args.top !== undefined) {\n cmdArgs.push(\"--top\", String(args.top));\n }\n if (args.minScore !== undefined) {\n cmdArgs.push(\"--min-score\", String(args.minScore));\n }\n if (args.type !== undefined) {\n cmdArgs.push(\"--type\", args.type);\n }\n if (args.filter !== undefined && args.filter.length > 0) {\n for (const f of args.filter) {\n cmdArgs.push(\"--filter\", f);\n }\n }\n\n const result = await Bun.$\\`raggrep query \\${cmdArgs}\\`.text();\n return result.trim();\n },\n});\n`;\n\n try {\n // Create directory if it doesn't exist\n await fs.mkdir(toolDir, { recursive: true });\n\n // Check if file exists and backup if it does\n let action = \"Installed\";\n const backupPath = toolPath + \".backup\";\n try {\n await fs.access(toolPath);\n // File exists, create backup before updating\n await fs.copyFile(toolPath, backupPath);\n action = \"Updated\";\n } catch {\n // File doesn't exist, will be created\n }\n\n // Write the tool file\n await fs.writeFile(toolPath, toolContent, \"utf-8\");\n\n console.log(`${action} raggrep tool for opencode.`);\n console.log(` Location: ${toolPath}`);\n if (action === \"Updated\") {\n console.log(` Backup: ${backupPath}`);\n }\n console.log(`\\nThe raggrep tool is now available in opencode.`);\n } catch (error) {\n console.error(\"Error installing opencode tool:\", error);\n process.exit(1);\n }\n } else {\n console.error(`Unknown subcommand: ${subcommand}`);\n console.error('Run \"raggrep opencode --help\" for usage.');\n process.exit(1);\n }\n break;\n }\n\n default:\n console.log(`\nraggrep v${VERSION} - Local filesystem-based RAG system for codebases\n\nUsage:\n raggrep <command> [options]\n\nCommands:\n index Index the current directory\n query Search the indexed codebase\n status Show the current state of the index\n reset Clear the index for the current directory\n opencode Manage opencode integration\n\nOptions:\n -h, --help Show help for a command\n -v, --version Show version number\n\nExamples:\n raggrep index\n raggrep query \"user login\"\n raggrep status\n raggrep reset\n raggrep opencode install\n\nRun 'raggrep <command> --help' for more information.\n`);\n if (command && command !== \"--help\" && command !== \"-h\") {\n console.error(`Unknown command: ${command}`);\n process.exit(1);\n }\n }\n}\n\nmain();\n"
59
59
  ],
60
- "mappings": "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",
61
- "debugId": "96F7EF5714B8338A64756E2164756E21",
60
+ "mappings": "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",
61
+ "debugId": "94148A85E332DDBC64756E2164756E21",
62
62
  "names": []
63
63
  }