agentic-qe 2.5.10 → 2.6.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/agents/qe-code-intelligence.md +359 -0
- package/CHANGELOG.md +146 -0
- package/README.md +3 -2
- package/dist/agents/BaseAgent.d.ts +48 -0
- package/dist/agents/BaseAgent.d.ts.map +1 -1
- package/dist/agents/BaseAgent.js +126 -0
- package/dist/agents/BaseAgent.js.map +1 -1
- package/dist/agents/CodeIntelligenceAgent.d.ts +133 -0
- package/dist/agents/CodeIntelligenceAgent.d.ts.map +1 -0
- package/dist/agents/CodeIntelligenceAgent.js +473 -0
- package/dist/agents/CodeIntelligenceAgent.js.map +1 -0
- package/dist/agents/context/ContextCache.d.ts +105 -0
- package/dist/agents/context/ContextCache.d.ts.map +1 -0
- package/dist/agents/context/ContextCache.js +235 -0
- package/dist/agents/context/ContextCache.js.map +1 -0
- package/dist/agents/context/ContextFormatter.d.ts +92 -0
- package/dist/agents/context/ContextFormatter.d.ts.map +1 -0
- package/dist/agents/context/ContextFormatter.js +338 -0
- package/dist/agents/context/ContextFormatter.js.map +1 -0
- package/dist/agents/context/GraphExpander.d.ts +87 -0
- package/dist/agents/context/GraphExpander.d.ts.map +1 -0
- package/dist/agents/context/GraphExpander.js +215 -0
- package/dist/agents/context/GraphExpander.js.map +1 -0
- package/dist/agents/context/KnowledgeGraphContextBuilder.d.ts +160 -0
- package/dist/agents/context/KnowledgeGraphContextBuilder.d.ts.map +1 -0
- package/dist/agents/context/KnowledgeGraphContextBuilder.js +300 -0
- package/dist/agents/context/KnowledgeGraphContextBuilder.js.map +1 -0
- package/dist/agents/context/index.d.ts +15 -0
- package/dist/agents/context/index.d.ts.map +1 -0
- package/dist/agents/context/index.js +18 -0
- package/dist/agents/context/index.js.map +1 -0
- package/dist/agents/index.d.ts +1 -0
- package/dist/agents/index.d.ts.map +1 -1
- package/dist/agents/index.js +67 -3
- package/dist/agents/index.js.map +1 -1
- package/dist/agents/pool/AgentPool.d.ts +112 -0
- package/dist/agents/pool/AgentPool.d.ts.map +1 -0
- package/dist/agents/pool/AgentPool.js +573 -0
- package/dist/agents/pool/AgentPool.js.map +1 -0
- package/dist/agents/pool/QEAgentPoolFactory.d.ts +118 -0
- package/dist/agents/pool/QEAgentPoolFactory.d.ts.map +1 -0
- package/dist/agents/pool/QEAgentPoolFactory.js +251 -0
- package/dist/agents/pool/QEAgentPoolFactory.js.map +1 -0
- package/dist/agents/pool/index.d.ts +34 -0
- package/dist/agents/pool/index.d.ts.map +1 -0
- package/dist/agents/pool/index.js +44 -0
- package/dist/agents/pool/index.js.map +1 -0
- package/dist/agents/pool/types.d.ts +227 -0
- package/dist/agents/pool/types.d.ts.map +1 -0
- package/dist/agents/pool/types.js +28 -0
- package/dist/agents/pool/types.js.map +1 -0
- package/dist/cli/commands/knowledge-graph.d.ts +112 -0
- package/dist/cli/commands/knowledge-graph.d.ts.map +1 -0
- package/dist/cli/commands/knowledge-graph.js +466 -0
- package/dist/cli/commands/knowledge-graph.js.map +1 -0
- package/dist/cli/formatters/KGOutputFormatter.d.ts +50 -0
- package/dist/cli/formatters/KGOutputFormatter.d.ts.map +1 -0
- package/dist/cli/formatters/KGOutputFormatter.js +237 -0
- package/dist/cli/formatters/KGOutputFormatter.js.map +1 -0
- package/dist/cli/index-working.js +138 -0
- package/dist/cli/index-working.js.map +1 -1
- package/dist/cli/init/claude-config.d.ts +13 -1
- package/dist/cli/init/claude-config.d.ts.map +1 -1
- package/dist/cli/init/claude-config.js +70 -8
- package/dist/cli/init/claude-config.js.map +1 -1
- package/dist/cli/init/code-intelligence-init.d.ts +52 -0
- package/dist/cli/init/code-intelligence-init.d.ts.map +1 -0
- package/dist/cli/init/code-intelligence-init.js +250 -0
- package/dist/cli/init/code-intelligence-init.js.map +1 -0
- package/dist/cli/init/index.d.ts +2 -2
- package/dist/cli/init/index.d.ts.map +1 -1
- package/dist/cli/init/index.js +10 -1
- package/dist/cli/init/index.js.map +1 -1
- package/dist/code-intelligence/chunking/ASTChunker.d.ts +64 -0
- package/dist/code-intelligence/chunking/ASTChunker.d.ts.map +1 -0
- package/dist/code-intelligence/chunking/ASTChunker.js +344 -0
- package/dist/code-intelligence/chunking/ASTChunker.js.map +1 -0
- package/dist/code-intelligence/chunking/ChunkSplitter.d.ts +48 -0
- package/dist/code-intelligence/chunking/ChunkSplitter.d.ts.map +1 -0
- package/dist/code-intelligence/chunking/ChunkSplitter.js +278 -0
- package/dist/code-intelligence/chunking/ChunkSplitter.js.map +1 -0
- package/dist/code-intelligence/chunking/index.d.ts +8 -0
- package/dist/code-intelligence/chunking/index.d.ts.map +1 -0
- package/dist/code-intelligence/chunking/index.js +13 -0
- package/dist/code-intelligence/chunking/index.js.map +1 -0
- package/dist/code-intelligence/chunking/types.d.ts +52 -0
- package/dist/code-intelligence/chunking/types.d.ts.map +1 -0
- package/dist/code-intelligence/chunking/types.js +6 -0
- package/dist/code-intelligence/chunking/types.js.map +1 -0
- package/dist/code-intelligence/config/database-schema.d.ts +245 -0
- package/dist/code-intelligence/config/database-schema.d.ts.map +1 -0
- package/dist/code-intelligence/config/database-schema.js +110 -0
- package/dist/code-intelligence/config/database-schema.js.map +1 -0
- package/dist/code-intelligence/config/environment.d.ts +53 -0
- package/dist/code-intelligence/config/environment.d.ts.map +1 -0
- package/dist/code-intelligence/config/environment.js +86 -0
- package/dist/code-intelligence/config/environment.js.map +1 -0
- package/dist/code-intelligence/config/index.d.ts +10 -0
- package/dist/code-intelligence/config/index.d.ts.map +1 -0
- package/dist/code-intelligence/config/index.js +36 -0
- package/dist/code-intelligence/config/index.js.map +1 -0
- package/dist/code-intelligence/embeddings/EmbeddingCache.d.ts +81 -0
- package/dist/code-intelligence/embeddings/EmbeddingCache.d.ts.map +1 -0
- package/dist/code-intelligence/embeddings/EmbeddingCache.js +168 -0
- package/dist/code-intelligence/embeddings/EmbeddingCache.js.map +1 -0
- package/dist/code-intelligence/embeddings/NomicEmbedder.d.ts +82 -0
- package/dist/code-intelligence/embeddings/NomicEmbedder.d.ts.map +1 -0
- package/dist/code-intelligence/embeddings/NomicEmbedder.js +233 -0
- package/dist/code-intelligence/embeddings/NomicEmbedder.js.map +1 -0
- package/dist/code-intelligence/embeddings/OllamaClient.d.ts +42 -0
- package/dist/code-intelligence/embeddings/OllamaClient.d.ts.map +1 -0
- package/dist/code-intelligence/embeddings/OllamaClient.js +142 -0
- package/dist/code-intelligence/embeddings/OllamaClient.js.map +1 -0
- package/dist/code-intelligence/embeddings/index.d.ts +33 -0
- package/dist/code-intelligence/embeddings/index.d.ts.map +1 -0
- package/dist/code-intelligence/embeddings/index.js +39 -0
- package/dist/code-intelligence/embeddings/index.js.map +1 -0
- package/dist/code-intelligence/embeddings/types.d.ts +84 -0
- package/dist/code-intelligence/embeddings/types.d.ts.map +1 -0
- package/dist/code-intelligence/embeddings/types.js +19 -0
- package/dist/code-intelligence/embeddings/types.js.map +1 -0
- package/dist/code-intelligence/graph/GraphBuilder.d.ts +126 -0
- package/dist/code-intelligence/graph/GraphBuilder.d.ts.map +1 -0
- package/dist/code-intelligence/graph/GraphBuilder.js +416 -0
- package/dist/code-intelligence/graph/GraphBuilder.js.map +1 -0
- package/dist/code-intelligence/graph/ImportParser.d.ts +72 -0
- package/dist/code-intelligence/graph/ImportParser.d.ts.map +1 -0
- package/dist/code-intelligence/graph/ImportParser.js +422 -0
- package/dist/code-intelligence/graph/ImportParser.js.map +1 -0
- package/dist/code-intelligence/graph/RelationshipExtractor.d.ts +74 -0
- package/dist/code-intelligence/graph/RelationshipExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/graph/RelationshipExtractor.js +310 -0
- package/dist/code-intelligence/graph/RelationshipExtractor.js.map +1 -0
- package/dist/code-intelligence/graph/TestMapper.d.ts +99 -0
- package/dist/code-intelligence/graph/TestMapper.d.ts.map +1 -0
- package/dist/code-intelligence/graph/TestMapper.js +335 -0
- package/dist/code-intelligence/graph/TestMapper.js.map +1 -0
- package/dist/code-intelligence/graph/index.d.ts +14 -0
- package/dist/code-intelligence/graph/index.d.ts.map +1 -0
- package/dist/code-intelligence/graph/index.js +19 -0
- package/dist/code-intelligence/graph/index.js.map +1 -0
- package/dist/code-intelligence/graph/types.d.ts +141 -0
- package/dist/code-intelligence/graph/types.d.ts.map +1 -0
- package/dist/code-intelligence/graph/types.js +18 -0
- package/dist/code-intelligence/graph/types.js.map +1 -0
- package/dist/code-intelligence/indexing/FileWatcher.d.ts +90 -0
- package/dist/code-intelligence/indexing/FileWatcher.d.ts.map +1 -0
- package/dist/code-intelligence/indexing/FileWatcher.js +304 -0
- package/dist/code-intelligence/indexing/FileWatcher.js.map +1 -0
- package/dist/code-intelligence/indexing/GitChangeDetector.d.ts +76 -0
- package/dist/code-intelligence/indexing/GitChangeDetector.d.ts.map +1 -0
- package/dist/code-intelligence/indexing/GitChangeDetector.js +347 -0
- package/dist/code-intelligence/indexing/GitChangeDetector.js.map +1 -0
- package/dist/code-intelligence/indexing/IncrementalIndexer.d.ts +108 -0
- package/dist/code-intelligence/indexing/IncrementalIndexer.d.ts.map +1 -0
- package/dist/code-intelligence/indexing/IncrementalIndexer.js +269 -0
- package/dist/code-intelligence/indexing/IncrementalIndexer.js.map +1 -0
- package/dist/code-intelligence/indexing/index.d.ts +11 -0
- package/dist/code-intelligence/indexing/index.d.ts.map +1 -0
- package/dist/code-intelligence/indexing/index.js +18 -0
- package/dist/code-intelligence/indexing/index.js.map +1 -0
- package/dist/code-intelligence/indexing/types.d.ts +133 -0
- package/dist/code-intelligence/indexing/types.d.ts.map +1 -0
- package/dist/code-intelligence/indexing/types.js +27 -0
- package/dist/code-intelligence/indexing/types.js.map +1 -0
- package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.d.ts +150 -0
- package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.d.ts.map +1 -0
- package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.js +806 -0
- package/dist/code-intelligence/orchestrator/CodeIntelligenceOrchestrator.js.map +1 -0
- package/dist/code-intelligence/orchestrator/index.d.ts +8 -0
- package/dist/code-intelligence/orchestrator/index.d.ts.map +1 -0
- package/dist/code-intelligence/orchestrator/index.js +24 -0
- package/dist/code-intelligence/orchestrator/index.js.map +1 -0
- package/dist/code-intelligence/orchestrator/types.d.ts +164 -0
- package/dist/code-intelligence/orchestrator/types.d.ts.map +1 -0
- package/dist/code-intelligence/orchestrator/types.js +18 -0
- package/dist/code-intelligence/orchestrator/types.js.map +1 -0
- package/dist/code-intelligence/parser/LanguageRegistry.d.ts +13 -0
- package/dist/code-intelligence/parser/LanguageRegistry.d.ts.map +1 -0
- package/dist/code-intelligence/parser/LanguageRegistry.js +150 -0
- package/dist/code-intelligence/parser/LanguageRegistry.js.map +1 -0
- package/dist/code-intelligence/parser/TreeSitterParser.d.ts +98 -0
- package/dist/code-intelligence/parser/TreeSitterParser.d.ts.map +1 -0
- package/dist/code-intelligence/parser/TreeSitterParser.js +530 -0
- package/dist/code-intelligence/parser/TreeSitterParser.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/BaseExtractor.d.ts +36 -0
- package/dist/code-intelligence/parser/extractors/BaseExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/BaseExtractor.js +31 -0
- package/dist/code-intelligence/parser/extractors/BaseExtractor.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/GoExtractor.d.ts +21 -0
- package/dist/code-intelligence/parser/extractors/GoExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/GoExtractor.js +249 -0
- package/dist/code-intelligence/parser/extractors/GoExtractor.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.d.ts +21 -0
- package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.js +217 -0
- package/dist/code-intelligence/parser/extractors/JavaScriptExtractor.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/PythonExtractor.d.ts +20 -0
- package/dist/code-intelligence/parser/extractors/PythonExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/PythonExtractor.js +237 -0
- package/dist/code-intelligence/parser/extractors/PythonExtractor.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/RustExtractor.d.ts +21 -0
- package/dist/code-intelligence/parser/extractors/RustExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/RustExtractor.js +234 -0
- package/dist/code-intelligence/parser/extractors/RustExtractor.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.d.ts +23 -0
- package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.js +247 -0
- package/dist/code-intelligence/parser/extractors/TypeScriptExtractor.js.map +1 -0
- package/dist/code-intelligence/parser/extractors/index.d.ts +7 -0
- package/dist/code-intelligence/parser/extractors/index.d.ts.map +1 -0
- package/dist/code-intelligence/parser/extractors/index.js +16 -0
- package/dist/code-intelligence/parser/extractors/index.js.map +1 -0
- package/dist/code-intelligence/parser/index.d.ts +8 -0
- package/dist/code-intelligence/parser/index.d.ts.map +1 -0
- package/dist/code-intelligence/parser/index.js +12 -0
- package/dist/code-intelligence/parser/index.js.map +1 -0
- package/dist/code-intelligence/parser/types.d.ts +60 -0
- package/dist/code-intelligence/parser/types.d.ts.map +1 -0
- package/dist/code-intelligence/parser/types.js +6 -0
- package/dist/code-intelligence/parser/types.js.map +1 -0
- package/dist/code-intelligence/rag/ContextBuilder.d.ts +82 -0
- package/dist/code-intelligence/rag/ContextBuilder.d.ts.map +1 -0
- package/dist/code-intelligence/rag/ContextBuilder.js +242 -0
- package/dist/code-intelligence/rag/ContextBuilder.js.map +1 -0
- package/dist/code-intelligence/rag/GraphExpander.d.ts +95 -0
- package/dist/code-intelligence/rag/GraphExpander.d.ts.map +1 -0
- package/dist/code-intelligence/rag/GraphExpander.js +250 -0
- package/dist/code-intelligence/rag/GraphExpander.js.map +1 -0
- package/dist/code-intelligence/rag/index.d.ts +9 -0
- package/dist/code-intelligence/rag/index.d.ts.map +1 -0
- package/dist/code-intelligence/rag/index.js +25 -0
- package/dist/code-intelligence/rag/index.js.map +1 -0
- package/dist/code-intelligence/rag/types.d.ts +121 -0
- package/dist/code-intelligence/rag/types.d.ts.map +1 -0
- package/dist/code-intelligence/rag/types.js +50 -0
- package/dist/code-intelligence/rag/types.js.map +1 -0
- package/dist/code-intelligence/retrieval/SemanticRetriever.d.ts +62 -0
- package/dist/code-intelligence/retrieval/SemanticRetriever.d.ts.map +1 -0
- package/dist/code-intelligence/retrieval/SemanticRetriever.js +174 -0
- package/dist/code-intelligence/retrieval/SemanticRetriever.js.map +1 -0
- package/dist/code-intelligence/retrieval/index.d.ts +9 -0
- package/dist/code-intelligence/retrieval/index.d.ts.map +1 -0
- package/dist/code-intelligence/retrieval/index.js +16 -0
- package/dist/code-intelligence/retrieval/index.js.map +1 -0
- package/dist/code-intelligence/retrieval/types.d.ts +118 -0
- package/dist/code-intelligence/retrieval/types.d.ts.map +1 -0
- package/dist/code-intelligence/retrieval/types.js +46 -0
- package/dist/code-intelligence/retrieval/types.js.map +1 -0
- package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.d.ts +167 -0
- package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.d.ts.map +1 -0
- package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.js +365 -0
- package/dist/code-intelligence/router/CodeIntelligenceHybridRouter.js.map +1 -0
- package/dist/code-intelligence/router/index.d.ts +7 -0
- package/dist/code-intelligence/router/index.d.ts.map +1 -0
- package/dist/code-intelligence/router/index.js +14 -0
- package/dist/code-intelligence/router/index.js.map +1 -0
- package/dist/code-intelligence/search/BM25Search.d.ts +74 -0
- package/dist/code-intelligence/search/BM25Search.d.ts.map +1 -0
- package/dist/code-intelligence/search/BM25Search.js +233 -0
- package/dist/code-intelligence/search/BM25Search.js.map +1 -0
- package/dist/code-intelligence/search/HybridSearchEngine.d.ts +94 -0
- package/dist/code-intelligence/search/HybridSearchEngine.d.ts.map +1 -0
- package/dist/code-intelligence/search/HybridSearchEngine.js +168 -0
- package/dist/code-intelligence/search/HybridSearchEngine.js.map +1 -0
- package/dist/code-intelligence/search/RRFFusion.d.ts +46 -0
- package/dist/code-intelligence/search/RRFFusion.d.ts.map +1 -0
- package/dist/code-intelligence/search/RRFFusion.js +223 -0
- package/dist/code-intelligence/search/RRFFusion.js.map +1 -0
- package/dist/code-intelligence/search/VectorSearch.d.ts +157 -0
- package/dist/code-intelligence/search/VectorSearch.d.ts.map +1 -0
- package/dist/code-intelligence/search/VectorSearch.js +301 -0
- package/dist/code-intelligence/search/VectorSearch.js.map +1 -0
- package/dist/code-intelligence/search/index.d.ts +14 -0
- package/dist/code-intelligence/search/index.d.ts.map +1 -0
- package/dist/code-intelligence/search/index.js +23 -0
- package/dist/code-intelligence/search/index.js.map +1 -0
- package/dist/code-intelligence/search/types.d.ts +201 -0
- package/dist/code-intelligence/search/types.d.ts.map +1 -0
- package/dist/code-intelligence/search/types.js +35 -0
- package/dist/code-intelligence/search/types.js.map +1 -0
- package/dist/code-intelligence/service/CodeIntelligenceService.d.ts +171 -0
- package/dist/code-intelligence/service/CodeIntelligenceService.d.ts.map +1 -0
- package/dist/code-intelligence/service/CodeIntelligenceService.js +325 -0
- package/dist/code-intelligence/service/CodeIntelligenceService.js.map +1 -0
- package/dist/code-intelligence/service/index.d.ts +7 -0
- package/dist/code-intelligence/service/index.d.ts.map +1 -0
- package/dist/code-intelligence/service/index.js +14 -0
- package/dist/code-intelligence/service/index.js.map +1 -0
- package/dist/code-intelligence/storage/CodeChunkStore.d.ts +213 -0
- package/dist/code-intelligence/storage/CodeChunkStore.d.ts.map +1 -0
- package/dist/code-intelligence/storage/CodeChunkStore.js +542 -0
- package/dist/code-intelligence/storage/CodeChunkStore.js.map +1 -0
- package/dist/code-intelligence/storage/index.d.ts +7 -0
- package/dist/code-intelligence/storage/index.d.ts.map +1 -0
- package/dist/code-intelligence/storage/index.js +13 -0
- package/dist/code-intelligence/storage/index.js.map +1 -0
- package/dist/code-intelligence/visualization/ClassDiagramBuilder.d.ts +51 -0
- package/dist/code-intelligence/visualization/ClassDiagramBuilder.d.ts.map +1 -0
- package/dist/code-intelligence/visualization/ClassDiagramBuilder.js +180 -0
- package/dist/code-intelligence/visualization/ClassDiagramBuilder.js.map +1 -0
- package/dist/code-intelligence/visualization/DependencyGraphBuilder.d.ts +66 -0
- package/dist/code-intelligence/visualization/DependencyGraphBuilder.d.ts.map +1 -0
- package/dist/code-intelligence/visualization/DependencyGraphBuilder.js +203 -0
- package/dist/code-intelligence/visualization/DependencyGraphBuilder.js.map +1 -0
- package/dist/code-intelligence/visualization/MermaidGenerator.d.ts +76 -0
- package/dist/code-intelligence/visualization/MermaidGenerator.d.ts.map +1 -0
- package/dist/code-intelligence/visualization/MermaidGenerator.js +368 -0
- package/dist/code-intelligence/visualization/MermaidGenerator.js.map +1 -0
- package/dist/code-intelligence/visualization/index.d.ts +9 -0
- package/dist/code-intelligence/visualization/index.d.ts.map +1 -0
- package/dist/code-intelligence/visualization/index.js +15 -0
- package/dist/code-intelligence/visualization/index.js.map +1 -0
- package/dist/core/FleetManager.d.ts +27 -0
- package/dist/core/FleetManager.d.ts.map +1 -1
- package/dist/core/FleetManager.js +84 -0
- package/dist/core/FleetManager.js.map +1 -1
- package/dist/core/memory/HNSWVectorMemory.js +1 -1
- package/dist/core/memory/HNSWVectorMemory.js.map +1 -1
- package/dist/mcp/handlers/agent-spawn.d.ts +71 -5
- package/dist/mcp/handlers/agent-spawn.d.ts.map +1 -1
- package/dist/mcp/handlers/agent-spawn.js +336 -110
- package/dist/mcp/handlers/agent-spawn.js.map +1 -1
- package/dist/mcp/handlers/fleet-init.d.ts +24 -0
- package/dist/mcp/handlers/fleet-init.d.ts.map +1 -1
- package/dist/mcp/handlers/fleet-init.js +56 -4
- package/dist/mcp/handlers/fleet-init.js.map +1 -1
- package/dist/mcp/server-instructions.d.ts +1 -1
- package/dist/mcp/server-instructions.d.ts.map +1 -1
- package/dist/mcp/server-instructions.js +1 -1
- package/dist/mcp/server-instructions.js.map +1 -1
- package/dist/memory/HNSWPatternStore.d.ts.map +1 -1
- package/dist/memory/HNSWPatternStore.js.map +1 -1
- package/dist/plugins/BasePlugin.d.ts +111 -0
- package/dist/plugins/BasePlugin.d.ts.map +1 -0
- package/dist/plugins/BasePlugin.js +154 -0
- package/dist/plugins/BasePlugin.js.map +1 -0
- package/dist/plugins/PluginManager.d.ts +145 -0
- package/dist/plugins/PluginManager.d.ts.map +1 -0
- package/dist/plugins/PluginManager.js +862 -0
- package/dist/plugins/PluginManager.js.map +1 -0
- package/dist/plugins/adapters/McpToolsPlugin.d.ts +98 -0
- package/dist/plugins/adapters/McpToolsPlugin.d.ts.map +1 -0
- package/dist/plugins/adapters/McpToolsPlugin.js +518 -0
- package/dist/plugins/adapters/McpToolsPlugin.js.map +1 -0
- package/dist/plugins/adapters/PlaywrightPlugin.d.ts +63 -0
- package/dist/plugins/adapters/PlaywrightPlugin.d.ts.map +1 -0
- package/dist/plugins/adapters/PlaywrightPlugin.js +451 -0
- package/dist/plugins/adapters/PlaywrightPlugin.js.map +1 -0
- package/dist/plugins/adapters/VitestPlugin.d.ts +74 -0
- package/dist/plugins/adapters/VitestPlugin.d.ts.map +1 -0
- package/dist/plugins/adapters/VitestPlugin.js +589 -0
- package/dist/plugins/adapters/VitestPlugin.js.map +1 -0
- package/dist/plugins/adapters/index.d.ts +8 -0
- package/dist/plugins/adapters/index.d.ts.map +1 -0
- package/dist/plugins/adapters/index.js +17 -0
- package/dist/plugins/adapters/index.js.map +1 -0
- package/dist/plugins/index.d.ts +32 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +48 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/types.d.ts +528 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +61 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/types/index.d.ts +2 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -1
- package/docs/reference/agents.md +44 -1
- package/package.json +15 -1
|
@@ -0,0 +1,126 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Code Graph Builder
|
|
3
|
+
*
|
|
4
|
+
* Constructs a knowledge graph of code relationships:
|
|
5
|
+
* - Import/export dependencies
|
|
6
|
+
* - Class inheritance hierarchies
|
|
7
|
+
* - Function call graphs
|
|
8
|
+
* - Type usage relationships
|
|
9
|
+
*
|
|
10
|
+
* Integrates with AST parsing for accurate extraction.
|
|
11
|
+
*/
|
|
12
|
+
import { GraphNode, GraphEdge, GraphBuilderConfig, GraphStats, GraphQuery, GraphQueryResult, NodeType, EdgeType } from './types.js';
|
|
13
|
+
export declare class GraphBuilder {
|
|
14
|
+
private config;
|
|
15
|
+
private graph;
|
|
16
|
+
private nodeIdCounter;
|
|
17
|
+
private edgeIdCounter;
|
|
18
|
+
constructor(config?: Partial<GraphBuilderConfig>);
|
|
19
|
+
/**
|
|
20
|
+
* Add a node to the graph.
|
|
21
|
+
*/
|
|
22
|
+
addNode(type: NodeType, label: string, filePath: string, startLine: number, endLine: number, language: string, properties?: Record<string, unknown>): GraphNode;
|
|
23
|
+
/**
|
|
24
|
+
* Add an edge between nodes.
|
|
25
|
+
*/
|
|
26
|
+
addEdge(sourceId: string, targetId: string, type: EdgeType, weight?: number, properties?: Record<string, unknown>): GraphEdge | null;
|
|
27
|
+
/**
|
|
28
|
+
* Find or create a node by label and file.
|
|
29
|
+
*/
|
|
30
|
+
findOrCreateNode(type: NodeType, label: string, filePath: string, startLine?: number, endLine?: number, language?: string): GraphNode;
|
|
31
|
+
/**
|
|
32
|
+
* Find a node by label and optional filters.
|
|
33
|
+
*/
|
|
34
|
+
findNode(label: string, filePath?: string, type?: NodeType): GraphNode | undefined;
|
|
35
|
+
/**
|
|
36
|
+
* Find nodes by type.
|
|
37
|
+
*/
|
|
38
|
+
findNodesByType(type: NodeType): GraphNode[];
|
|
39
|
+
/**
|
|
40
|
+
* Find nodes in a file.
|
|
41
|
+
*/
|
|
42
|
+
findNodesInFile(filePath: string): GraphNode[];
|
|
43
|
+
/**
|
|
44
|
+
* Get outgoing edges for a node.
|
|
45
|
+
*/
|
|
46
|
+
getOutgoingEdges(nodeId: string): GraphEdge[];
|
|
47
|
+
/**
|
|
48
|
+
* Get incoming edges for a node.
|
|
49
|
+
*/
|
|
50
|
+
getIncomingEdges(nodeId: string): GraphEdge[];
|
|
51
|
+
/**
|
|
52
|
+
* Get neighbors of a node.
|
|
53
|
+
*/
|
|
54
|
+
getNeighbors(nodeId: string, direction?: 'outgoing' | 'incoming' | 'both'): GraphNode[];
|
|
55
|
+
/**
|
|
56
|
+
* Query the graph with traversal.
|
|
57
|
+
*/
|
|
58
|
+
query(query: GraphQuery): GraphQueryResult;
|
|
59
|
+
/**
|
|
60
|
+
* Find path between two nodes.
|
|
61
|
+
*/
|
|
62
|
+
findPath(startId: string, endId: string, maxDepth?: number): GraphNode[] | null;
|
|
63
|
+
/**
|
|
64
|
+
* Remove a node and its edges.
|
|
65
|
+
*/
|
|
66
|
+
removeNode(nodeId: string): boolean;
|
|
67
|
+
/**
|
|
68
|
+
* Remove all nodes from a file.
|
|
69
|
+
*/
|
|
70
|
+
removeFile(filePath: string): number;
|
|
71
|
+
/**
|
|
72
|
+
* Get graph statistics.
|
|
73
|
+
*/
|
|
74
|
+
getStats(): GraphStats;
|
|
75
|
+
/**
|
|
76
|
+
* Get node by ID.
|
|
77
|
+
*/
|
|
78
|
+
getNode(id: string): GraphNode | undefined;
|
|
79
|
+
/**
|
|
80
|
+
* Get edge by ID.
|
|
81
|
+
*/
|
|
82
|
+
getEdge(id: string): GraphEdge | undefined;
|
|
83
|
+
/**
|
|
84
|
+
* Get all nodes.
|
|
85
|
+
*/
|
|
86
|
+
getAllNodes(): GraphNode[];
|
|
87
|
+
/**
|
|
88
|
+
* Get all edges.
|
|
89
|
+
*/
|
|
90
|
+
getAllEdges(): GraphEdge[];
|
|
91
|
+
/**
|
|
92
|
+
* Clear the graph.
|
|
93
|
+
*/
|
|
94
|
+
clear(): void;
|
|
95
|
+
/**
|
|
96
|
+
* Get configuration.
|
|
97
|
+
*/
|
|
98
|
+
getConfig(): GraphBuilderConfig;
|
|
99
|
+
/**
|
|
100
|
+
* Export graph for persistence.
|
|
101
|
+
*/
|
|
102
|
+
exportGraph(): {
|
|
103
|
+
nodes: GraphNode[];
|
|
104
|
+
edges: GraphEdge[];
|
|
105
|
+
};
|
|
106
|
+
/**
|
|
107
|
+
* Import graph from persistence.
|
|
108
|
+
*/
|
|
109
|
+
importGraph(data: {
|
|
110
|
+
nodes: GraphNode[];
|
|
111
|
+
edges: GraphEdge[];
|
|
112
|
+
}): void;
|
|
113
|
+
/**
|
|
114
|
+
* Create empty graph structure.
|
|
115
|
+
*/
|
|
116
|
+
private createEmptyGraph;
|
|
117
|
+
/**
|
|
118
|
+
* Generate unique node ID.
|
|
119
|
+
*/
|
|
120
|
+
private generateNodeId;
|
|
121
|
+
/**
|
|
122
|
+
* Generate unique edge ID.
|
|
123
|
+
*/
|
|
124
|
+
private generateEdgeId;
|
|
125
|
+
}
|
|
126
|
+
//# sourceMappingURL=GraphBuilder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GraphBuilder.d.ts","sourceRoot":"","sources":["../../../src/code-intelligence/graph/GraphBuilder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,416 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Code Graph Builder
|
|
4
|
+
*
|
|
5
|
+
* Constructs a knowledge graph of code relationships:
|
|
6
|
+
* - Import/export dependencies
|
|
7
|
+
* - Class inheritance hierarchies
|
|
8
|
+
* - Function call graphs
|
|
9
|
+
* - Type usage relationships
|
|
10
|
+
*
|
|
11
|
+
* Integrates with AST parsing for accurate extraction.
|
|
12
|
+
*/
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
exports.GraphBuilder = void 0;
|
|
15
|
+
const types_js_1 = require("./types.js");
|
|
16
|
+
class GraphBuilder {
|
|
17
|
+
constructor(config = {}) {
|
|
18
|
+
this.nodeIdCounter = 0;
|
|
19
|
+
this.edgeIdCounter = 0;
|
|
20
|
+
this.config = { ...types_js_1.DEFAULT_GRAPH_BUILDER_CONFIG, ...config };
|
|
21
|
+
this.graph = this.createEmptyGraph();
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Add a node to the graph.
|
|
25
|
+
*/
|
|
26
|
+
addNode(type, label, filePath, startLine, endLine, language, properties = {}) {
|
|
27
|
+
const id = this.generateNodeId();
|
|
28
|
+
const node = {
|
|
29
|
+
id,
|
|
30
|
+
type,
|
|
31
|
+
label,
|
|
32
|
+
filePath,
|
|
33
|
+
startLine,
|
|
34
|
+
endLine,
|
|
35
|
+
language,
|
|
36
|
+
properties,
|
|
37
|
+
};
|
|
38
|
+
this.graph.nodes.set(id, node);
|
|
39
|
+
// Update file index
|
|
40
|
+
const fileNodes = this.graph.fileNodes.get(filePath) || [];
|
|
41
|
+
fileNodes.push(id);
|
|
42
|
+
this.graph.fileNodes.set(filePath, fileNodes);
|
|
43
|
+
// Initialize edge lists
|
|
44
|
+
this.graph.outgoingEdges.set(id, []);
|
|
45
|
+
this.graph.incomingEdges.set(id, []);
|
|
46
|
+
return node;
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Add an edge between nodes.
|
|
50
|
+
*/
|
|
51
|
+
addEdge(sourceId, targetId, type, weight = 1.0, properties = {}) {
|
|
52
|
+
// Verify nodes exist
|
|
53
|
+
if (!this.graph.nodes.has(sourceId) || !this.graph.nodes.has(targetId)) {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
const id = this.generateEdgeId();
|
|
57
|
+
const edge = {
|
|
58
|
+
id,
|
|
59
|
+
source: sourceId,
|
|
60
|
+
target: targetId,
|
|
61
|
+
type,
|
|
62
|
+
weight,
|
|
63
|
+
properties,
|
|
64
|
+
};
|
|
65
|
+
this.graph.edges.set(id, edge);
|
|
66
|
+
// Update indices
|
|
67
|
+
const outgoing = this.graph.outgoingEdges.get(sourceId) || [];
|
|
68
|
+
outgoing.push(id);
|
|
69
|
+
this.graph.outgoingEdges.set(sourceId, outgoing);
|
|
70
|
+
const incoming = this.graph.incomingEdges.get(targetId) || [];
|
|
71
|
+
incoming.push(id);
|
|
72
|
+
this.graph.incomingEdges.set(targetId, incoming);
|
|
73
|
+
return edge;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Find or create a node by label and file.
|
|
77
|
+
*/
|
|
78
|
+
findOrCreateNode(type, label, filePath, startLine = 0, endLine = 0, language = 'unknown') {
|
|
79
|
+
// Try to find existing node
|
|
80
|
+
const existing = this.findNode(label, filePath, type);
|
|
81
|
+
if (existing)
|
|
82
|
+
return existing;
|
|
83
|
+
// Create new node
|
|
84
|
+
return this.addNode(type, label, filePath, startLine, endLine, language);
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Find a node by label and optional filters.
|
|
88
|
+
*/
|
|
89
|
+
findNode(label, filePath, type) {
|
|
90
|
+
for (const node of this.graph.nodes.values()) {
|
|
91
|
+
if (node.label !== label)
|
|
92
|
+
continue;
|
|
93
|
+
if (filePath && node.filePath !== filePath)
|
|
94
|
+
continue;
|
|
95
|
+
if (type && node.type !== type)
|
|
96
|
+
continue;
|
|
97
|
+
return node;
|
|
98
|
+
}
|
|
99
|
+
return undefined;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Find nodes by type.
|
|
103
|
+
*/
|
|
104
|
+
findNodesByType(type) {
|
|
105
|
+
return Array.from(this.graph.nodes.values())
|
|
106
|
+
.filter(n => n.type === type);
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Find nodes in a file.
|
|
110
|
+
*/
|
|
111
|
+
findNodesInFile(filePath) {
|
|
112
|
+
const nodeIds = this.graph.fileNodes.get(filePath) || [];
|
|
113
|
+
return nodeIds
|
|
114
|
+
.map(id => this.graph.nodes.get(id))
|
|
115
|
+
.filter((n) => n !== undefined);
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Get outgoing edges for a node.
|
|
119
|
+
*/
|
|
120
|
+
getOutgoingEdges(nodeId) {
|
|
121
|
+
const edgeIds = this.graph.outgoingEdges.get(nodeId) || [];
|
|
122
|
+
return edgeIds
|
|
123
|
+
.map(id => this.graph.edges.get(id))
|
|
124
|
+
.filter((e) => e !== undefined);
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Get incoming edges for a node.
|
|
128
|
+
*/
|
|
129
|
+
getIncomingEdges(nodeId) {
|
|
130
|
+
const edgeIds = this.graph.incomingEdges.get(nodeId) || [];
|
|
131
|
+
return edgeIds
|
|
132
|
+
.map(id => this.graph.edges.get(id))
|
|
133
|
+
.filter((e) => e !== undefined);
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Get neighbors of a node.
|
|
137
|
+
*/
|
|
138
|
+
getNeighbors(nodeId, direction = 'both') {
|
|
139
|
+
const neighbors = [];
|
|
140
|
+
const seen = new Set();
|
|
141
|
+
if (direction === 'outgoing' || direction === 'both') {
|
|
142
|
+
for (const edge of this.getOutgoingEdges(nodeId)) {
|
|
143
|
+
if (!seen.has(edge.target)) {
|
|
144
|
+
const node = this.graph.nodes.get(edge.target);
|
|
145
|
+
if (node) {
|
|
146
|
+
neighbors.push(node);
|
|
147
|
+
seen.add(edge.target);
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
if (direction === 'incoming' || direction === 'both') {
|
|
153
|
+
for (const edge of this.getIncomingEdges(nodeId)) {
|
|
154
|
+
if (!seen.has(edge.source)) {
|
|
155
|
+
const node = this.graph.nodes.get(edge.source);
|
|
156
|
+
if (node) {
|
|
157
|
+
neighbors.push(node);
|
|
158
|
+
seen.add(edge.source);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
return neighbors;
|
|
164
|
+
}
|
|
165
|
+
/**
|
|
166
|
+
* Query the graph with traversal.
|
|
167
|
+
*/
|
|
168
|
+
query(query) {
|
|
169
|
+
const startTime = Date.now();
|
|
170
|
+
const resultNodes = [];
|
|
171
|
+
const resultEdges = [];
|
|
172
|
+
const visited = new Set();
|
|
173
|
+
// Get starting nodes
|
|
174
|
+
let startNodes = [];
|
|
175
|
+
if (query.startNode) {
|
|
176
|
+
const node = this.graph.nodes.get(query.startNode);
|
|
177
|
+
if (node)
|
|
178
|
+
startNodes = [node];
|
|
179
|
+
}
|
|
180
|
+
else if (query.nodeType) {
|
|
181
|
+
startNodes = this.findNodesByType(query.nodeType);
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
startNodes = Array.from(this.graph.nodes.values());
|
|
185
|
+
}
|
|
186
|
+
// BFS traversal
|
|
187
|
+
const queue = startNodes.map(n => ({ node: n, depth: 0 }));
|
|
188
|
+
while (queue.length > 0 && resultNodes.length < query.limit) {
|
|
189
|
+
const { node, depth } = queue.shift();
|
|
190
|
+
if (visited.has(node.id))
|
|
191
|
+
continue;
|
|
192
|
+
visited.add(node.id);
|
|
193
|
+
// Check node type filter
|
|
194
|
+
if (!query.nodeType || node.type === query.nodeType) {
|
|
195
|
+
resultNodes.push(node);
|
|
196
|
+
}
|
|
197
|
+
// Continue traversal if within depth
|
|
198
|
+
if (depth < query.maxDepth) {
|
|
199
|
+
const edges = query.direction === 'incoming'
|
|
200
|
+
? this.getIncomingEdges(node.id)
|
|
201
|
+
: query.direction === 'outgoing'
|
|
202
|
+
? this.getOutgoingEdges(node.id)
|
|
203
|
+
: [...this.getOutgoingEdges(node.id), ...this.getIncomingEdges(node.id)];
|
|
204
|
+
for (const edge of edges) {
|
|
205
|
+
// Check edge type filter
|
|
206
|
+
if (query.edgeType && edge.type !== query.edgeType)
|
|
207
|
+
continue;
|
|
208
|
+
resultEdges.push(edge);
|
|
209
|
+
const nextId = edge.source === node.id ? edge.target : edge.source;
|
|
210
|
+
const nextNode = this.graph.nodes.get(nextId);
|
|
211
|
+
if (nextNode && !visited.has(nextId)) {
|
|
212
|
+
queue.push({ node: nextNode, depth: depth + 1 });
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
return {
|
|
218
|
+
nodes: resultNodes.slice(0, query.limit),
|
|
219
|
+
edges: resultEdges,
|
|
220
|
+
executionTimeMs: Date.now() - startTime,
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Find path between two nodes.
|
|
225
|
+
*/
|
|
226
|
+
findPath(startId, endId, maxDepth = 5) {
|
|
227
|
+
if (!this.graph.nodes.has(startId) || !this.graph.nodes.has(endId)) {
|
|
228
|
+
return null;
|
|
229
|
+
}
|
|
230
|
+
const visited = new Set();
|
|
231
|
+
const queue = [
|
|
232
|
+
{ nodeId: startId, path: [startId] }
|
|
233
|
+
];
|
|
234
|
+
while (queue.length > 0) {
|
|
235
|
+
const { nodeId, path } = queue.shift();
|
|
236
|
+
if (nodeId === endId) {
|
|
237
|
+
return path.map(id => this.graph.nodes.get(id));
|
|
238
|
+
}
|
|
239
|
+
if (visited.has(nodeId) || path.length > maxDepth)
|
|
240
|
+
continue;
|
|
241
|
+
visited.add(nodeId);
|
|
242
|
+
for (const edge of this.getOutgoingEdges(nodeId)) {
|
|
243
|
+
if (!visited.has(edge.target)) {
|
|
244
|
+
queue.push({
|
|
245
|
+
nodeId: edge.target,
|
|
246
|
+
path: [...path, edge.target],
|
|
247
|
+
});
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
return null;
|
|
252
|
+
}
|
|
253
|
+
/**
|
|
254
|
+
* Remove a node and its edges.
|
|
255
|
+
*/
|
|
256
|
+
removeNode(nodeId) {
|
|
257
|
+
const node = this.graph.nodes.get(nodeId);
|
|
258
|
+
if (!node)
|
|
259
|
+
return false;
|
|
260
|
+
// Remove all edges
|
|
261
|
+
for (const edgeId of this.graph.outgoingEdges.get(nodeId) || []) {
|
|
262
|
+
this.graph.edges.delete(edgeId);
|
|
263
|
+
}
|
|
264
|
+
for (const edgeId of this.graph.incomingEdges.get(nodeId) || []) {
|
|
265
|
+
this.graph.edges.delete(edgeId);
|
|
266
|
+
}
|
|
267
|
+
// Remove from file index
|
|
268
|
+
const fileNodes = this.graph.fileNodes.get(node.filePath) || [];
|
|
269
|
+
const index = fileNodes.indexOf(nodeId);
|
|
270
|
+
if (index !== -1)
|
|
271
|
+
fileNodes.splice(index, 1);
|
|
272
|
+
// Remove node
|
|
273
|
+
this.graph.nodes.delete(nodeId);
|
|
274
|
+
this.graph.outgoingEdges.delete(nodeId);
|
|
275
|
+
this.graph.incomingEdges.delete(nodeId);
|
|
276
|
+
return true;
|
|
277
|
+
}
|
|
278
|
+
/**
|
|
279
|
+
* Remove all nodes from a file.
|
|
280
|
+
*/
|
|
281
|
+
removeFile(filePath) {
|
|
282
|
+
const nodeIds = this.graph.fileNodes.get(filePath) || [];
|
|
283
|
+
let removed = 0;
|
|
284
|
+
for (const nodeId of [...nodeIds]) {
|
|
285
|
+
if (this.removeNode(nodeId))
|
|
286
|
+
removed++;
|
|
287
|
+
}
|
|
288
|
+
this.graph.fileNodes.delete(filePath);
|
|
289
|
+
return removed;
|
|
290
|
+
}
|
|
291
|
+
/**
|
|
292
|
+
* Get graph statistics.
|
|
293
|
+
*/
|
|
294
|
+
getStats() {
|
|
295
|
+
const nodesByType = {};
|
|
296
|
+
const edgesByType = {};
|
|
297
|
+
const edgeCounts = [];
|
|
298
|
+
for (const node of this.graph.nodes.values()) {
|
|
299
|
+
nodesByType[node.type] = (nodesByType[node.type] || 0) + 1;
|
|
300
|
+
const edgeCount = (this.graph.outgoingEdges.get(node.id)?.length || 0) +
|
|
301
|
+
(this.graph.incomingEdges.get(node.id)?.length || 0);
|
|
302
|
+
edgeCounts.push({ nodeId: node.id, edgeCount });
|
|
303
|
+
}
|
|
304
|
+
for (const edge of this.graph.edges.values()) {
|
|
305
|
+
edgesByType[edge.type] = (edgesByType[edge.type] || 0) + 1;
|
|
306
|
+
}
|
|
307
|
+
edgeCounts.sort((a, b) => b.edgeCount - a.edgeCount);
|
|
308
|
+
return {
|
|
309
|
+
nodeCount: this.graph.nodes.size,
|
|
310
|
+
edgeCount: this.graph.edges.size,
|
|
311
|
+
nodesByType: nodesByType,
|
|
312
|
+
edgesByType: edgesByType,
|
|
313
|
+
fileCount: this.graph.fileNodes.size,
|
|
314
|
+
avgEdgesPerNode: this.graph.nodes.size > 0
|
|
315
|
+
? this.graph.edges.size * 2 / this.graph.nodes.size
|
|
316
|
+
: 0,
|
|
317
|
+
mostConnected: edgeCounts.slice(0, 10),
|
|
318
|
+
};
|
|
319
|
+
}
|
|
320
|
+
/**
|
|
321
|
+
* Get node by ID.
|
|
322
|
+
*/
|
|
323
|
+
getNode(id) {
|
|
324
|
+
return this.graph.nodes.get(id);
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* Get edge by ID.
|
|
328
|
+
*/
|
|
329
|
+
getEdge(id) {
|
|
330
|
+
return this.graph.edges.get(id);
|
|
331
|
+
}
|
|
332
|
+
/**
|
|
333
|
+
* Get all nodes.
|
|
334
|
+
*/
|
|
335
|
+
getAllNodes() {
|
|
336
|
+
return Array.from(this.graph.nodes.values());
|
|
337
|
+
}
|
|
338
|
+
/**
|
|
339
|
+
* Get all edges.
|
|
340
|
+
*/
|
|
341
|
+
getAllEdges() {
|
|
342
|
+
return Array.from(this.graph.edges.values());
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* Clear the graph.
|
|
346
|
+
*/
|
|
347
|
+
clear() {
|
|
348
|
+
this.graph = this.createEmptyGraph();
|
|
349
|
+
this.nodeIdCounter = 0;
|
|
350
|
+
this.edgeIdCounter = 0;
|
|
351
|
+
}
|
|
352
|
+
/**
|
|
353
|
+
* Get configuration.
|
|
354
|
+
*/
|
|
355
|
+
getConfig() {
|
|
356
|
+
return { ...this.config };
|
|
357
|
+
}
|
|
358
|
+
/**
|
|
359
|
+
* Export graph for persistence.
|
|
360
|
+
*/
|
|
361
|
+
exportGraph() {
|
|
362
|
+
return {
|
|
363
|
+
nodes: Array.from(this.graph.nodes.values()),
|
|
364
|
+
edges: Array.from(this.graph.edges.values()),
|
|
365
|
+
};
|
|
366
|
+
}
|
|
367
|
+
/**
|
|
368
|
+
* Import graph from persistence.
|
|
369
|
+
*/
|
|
370
|
+
importGraph(data) {
|
|
371
|
+
this.clear();
|
|
372
|
+
for (const node of data.nodes) {
|
|
373
|
+
this.graph.nodes.set(node.id, node);
|
|
374
|
+
const fileNodes = this.graph.fileNodes.get(node.filePath) || [];
|
|
375
|
+
fileNodes.push(node.id);
|
|
376
|
+
this.graph.fileNodes.set(node.filePath, fileNodes);
|
|
377
|
+
this.graph.outgoingEdges.set(node.id, []);
|
|
378
|
+
this.graph.incomingEdges.set(node.id, []);
|
|
379
|
+
}
|
|
380
|
+
for (const edge of data.edges) {
|
|
381
|
+
this.graph.edges.set(edge.id, edge);
|
|
382
|
+
const outgoing = this.graph.outgoingEdges.get(edge.source) || [];
|
|
383
|
+
outgoing.push(edge.id);
|
|
384
|
+
this.graph.outgoingEdges.set(edge.source, outgoing);
|
|
385
|
+
const incoming = this.graph.incomingEdges.get(edge.target) || [];
|
|
386
|
+
incoming.push(edge.id);
|
|
387
|
+
this.graph.incomingEdges.set(edge.target, incoming);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* Create empty graph structure.
|
|
392
|
+
*/
|
|
393
|
+
createEmptyGraph() {
|
|
394
|
+
return {
|
|
395
|
+
nodes: new Map(),
|
|
396
|
+
edges: new Map(),
|
|
397
|
+
outgoingEdges: new Map(),
|
|
398
|
+
incomingEdges: new Map(),
|
|
399
|
+
fileNodes: new Map(),
|
|
400
|
+
};
|
|
401
|
+
}
|
|
402
|
+
/**
|
|
403
|
+
* Generate unique node ID.
|
|
404
|
+
*/
|
|
405
|
+
generateNodeId() {
|
|
406
|
+
return `node_${++this.nodeIdCounter}`;
|
|
407
|
+
}
|
|
408
|
+
/**
|
|
409
|
+
* Generate unique edge ID.
|
|
410
|
+
*/
|
|
411
|
+
generateEdgeId() {
|
|
412
|
+
return `edge_${++this.edgeIdCounter}`;
|
|
413
|
+
}
|
|
414
|
+
}
|
|
415
|
+
exports.GraphBuilder = GraphBuilder;
|
|
416
|
+
//# sourceMappingURL=GraphBuilder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GraphBuilder.js","sourceRoot":"","sources":["../../../src/code-intelligence/graph/GraphBuilder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Import Parser
|
|
3
|
+
*
|
|
4
|
+
* Parses import/require statements from source code
|
|
5
|
+
* to build the IMPORTS relationship in the graph.
|
|
6
|
+
*/
|
|
7
|
+
export interface ParsedImport {
|
|
8
|
+
/** Import type */
|
|
9
|
+
type: 'named' | 'default' | 'namespace' | 'side-effect' | 'require' | 'dynamic';
|
|
10
|
+
/** Module specifier (e.g., './utils' or 'lodash') */
|
|
11
|
+
moduleSpecifier: string;
|
|
12
|
+
/** Imported names (for named imports) */
|
|
13
|
+
importedNames: string[];
|
|
14
|
+
/** Local alias (for default/namespace imports) */
|
|
15
|
+
localName?: string;
|
|
16
|
+
/** Whether this is a type-only import (TypeScript) */
|
|
17
|
+
isTypeOnly: boolean;
|
|
18
|
+
/** Line number in source */
|
|
19
|
+
line: number;
|
|
20
|
+
}
|
|
21
|
+
export interface ResolvedImport extends ParsedImport {
|
|
22
|
+
/** Resolved absolute file path */
|
|
23
|
+
resolvedPath?: string;
|
|
24
|
+
/** Whether the import is external (node_modules) */
|
|
25
|
+
isExternal: boolean;
|
|
26
|
+
/** Whether the import is relative */
|
|
27
|
+
isRelative: boolean;
|
|
28
|
+
}
|
|
29
|
+
export declare class ImportParser {
|
|
30
|
+
private readonly patterns;
|
|
31
|
+
/**
|
|
32
|
+
* Parse imports from source code.
|
|
33
|
+
*/
|
|
34
|
+
parseImports(content: string, language: string): ParsedImport[];
|
|
35
|
+
/**
|
|
36
|
+
* Resolve import path to absolute file path.
|
|
37
|
+
*/
|
|
38
|
+
resolveImportPath(imp: ParsedImport, sourceFilePath: string, projectRoot?: string): string | null;
|
|
39
|
+
/**
|
|
40
|
+
* Check if a module specifier is an external package.
|
|
41
|
+
*/
|
|
42
|
+
isExternalPackage(moduleSpecifier: string): boolean;
|
|
43
|
+
/**
|
|
44
|
+
* Parse JavaScript/TypeScript imports.
|
|
45
|
+
*/
|
|
46
|
+
private parseJavaScriptImports;
|
|
47
|
+
/**
|
|
48
|
+
* Parse Python imports.
|
|
49
|
+
*/
|
|
50
|
+
private parsePythonImports;
|
|
51
|
+
/**
|
|
52
|
+
* Parse Go imports.
|
|
53
|
+
*/
|
|
54
|
+
private parseGoImports;
|
|
55
|
+
/**
|
|
56
|
+
* Parse Rust use statements.
|
|
57
|
+
*/
|
|
58
|
+
private parseRustImports;
|
|
59
|
+
/**
|
|
60
|
+
* Parse named import list (e.g., "foo, bar as baz").
|
|
61
|
+
*/
|
|
62
|
+
private parseNamedImportList;
|
|
63
|
+
/**
|
|
64
|
+
* Get line number from character index.
|
|
65
|
+
*/
|
|
66
|
+
private getLineNumber;
|
|
67
|
+
/**
|
|
68
|
+
* Get line content from character index.
|
|
69
|
+
*/
|
|
70
|
+
private getLine;
|
|
71
|
+
}
|
|
72
|
+
//# sourceMappingURL=ImportParser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ImportParser.d.ts","sourceRoot":"","sources":["../../../src/code-intelligence/graph/ImportParser.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,MAAM,WAAW,YAAY;IAC3B,kBAAkB;IAClB,IAAI,EAAE,OAAO,GAAG,SAAS,GAAG,WAAW,GAAG,aAAa,GAAG,SAAS,GAAG,SAAS,CAAC;IAEhF,qDAAqD;IACrD,eAAe,EAAE,MAAM,CAAC;IAExB,yCAAyC;IACzC,aAAa,EAAE,MAAM,EAAE,CAAC;IAExB,kDAAkD;IAClD,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,sDAAsD;IACtD,UAAU,EAAE,OAAO,CAAC;IAEpB,4BAA4B;IAC5B,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,cAAe,SAAQ,YAAY;IAClD,kCAAkC;IAClC,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB,oDAAoD;IACpD,UAAU,EAAE,OAAO,CAAC;IAEpB,qCAAqC;IACrC,UAAU,EAAE,OAAO,CAAC;CACrB;AAED,qBAAa,YAAY;IAEvB,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAuCvB;IAEF;;OAEG;IACH,YAAY,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,YAAY,EAAE;IAuB/D;;OAEG;IACH,iBAAiB,CACf,GAAG,EAAE,YAAY,EACjB,cAAc,EAAE,MAAM,EACtB,WAAW,GAAE,MAAY,GACxB,MAAM,GAAG,IAAI;IAoChB;;OAEG;IACH,iBAAiB,CAAC,eAAe,EAAE,MAAM,GAAG,OAAO;IAkCnD;;OAEG;IACH,OAAO,CAAC,sBAAsB;IA+I9B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IA8C1B;;OAEG;IACH,OAAO,CAAC,cAAc;IAoCtB;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAsBxB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAY5B;;OAEG;IACH,OAAO,CAAC,aAAa;IAIrB;;OAEG;IACH,OAAO,CAAC,OAAO;CAKhB"}
|