@codragraph/cli 1.6.2
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/README.md +341 -0
- package/dist/_shared/graph/types.d.ts +81 -0
- package/dist/_shared/graph/types.d.ts.map +1 -0
- package/dist/_shared/graph/types.js +8 -0
- package/dist/_shared/graph/types.js.map +1 -0
- package/dist/_shared/index.d.ts +55 -0
- package/dist/_shared/index.d.ts.map +1 -0
- package/dist/_shared/index.js +39 -0
- package/dist/_shared/index.js.map +1 -0
- package/dist/_shared/language-detection.d.ts +23 -0
- package/dist/_shared/language-detection.d.ts.map +1 -0
- package/dist/_shared/language-detection.js +139 -0
- package/dist/_shared/language-detection.js.map +1 -0
- package/dist/_shared/languages.d.ts +26 -0
- package/dist/_shared/languages.d.ts.map +1 -0
- package/dist/_shared/languages.js +27 -0
- package/dist/_shared/languages.js.map +1 -0
- package/dist/_shared/lbug/schema-constants.d.ts +16 -0
- package/dist/_shared/lbug/schema-constants.d.ts.map +1 -0
- package/dist/_shared/lbug/schema-constants.js +67 -0
- package/dist/_shared/lbug/schema-constants.js.map +1 -0
- package/dist/_shared/mro-strategy.d.ts +41 -0
- package/dist/_shared/mro-strategy.d.ts.map +1 -0
- package/dist/_shared/mro-strategy.js +2 -0
- package/dist/_shared/mro-strategy.js.map +1 -0
- package/dist/_shared/pipeline.d.ts +16 -0
- package/dist/_shared/pipeline.d.ts.map +1 -0
- package/dist/_shared/pipeline.js +5 -0
- package/dist/_shared/pipeline.js.map +1 -0
- package/dist/_shared/scope-resolution/def-index.d.ts +36 -0
- package/dist/_shared/scope-resolution/def-index.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/def-index.js +51 -0
- package/dist/_shared/scope-resolution/def-index.js.map +1 -0
- package/dist/_shared/scope-resolution/evidence-weights.d.ts +69 -0
- package/dist/_shared/scope-resolution/evidence-weights.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/evidence-weights.js +84 -0
- package/dist/_shared/scope-resolution/evidence-weights.js.map +1 -0
- package/dist/_shared/scope-resolution/finalize-algorithm.d.ts +139 -0
- package/dist/_shared/scope-resolution/finalize-algorithm.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/finalize-algorithm.js +479 -0
- package/dist/_shared/scope-resolution/finalize-algorithm.js.map +1 -0
- package/dist/_shared/scope-resolution/language-classification.d.ts +26 -0
- package/dist/_shared/scope-resolution/language-classification.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/language-classification.js +44 -0
- package/dist/_shared/scope-resolution/language-classification.js.map +1 -0
- package/dist/_shared/scope-resolution/method-dispatch-index.d.ts +80 -0
- package/dist/_shared/scope-resolution/method-dispatch-index.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/method-dispatch-index.js +79 -0
- package/dist/_shared/scope-resolution/method-dispatch-index.js.map +1 -0
- package/dist/_shared/scope-resolution/module-scope-index.d.ts +46 -0
- package/dist/_shared/scope-resolution/module-scope-index.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/module-scope-index.js +58 -0
- package/dist/_shared/scope-resolution/module-scope-index.js.map +1 -0
- package/dist/_shared/scope-resolution/origin-priority.d.ts +14 -0
- package/dist/_shared/scope-resolution/origin-priority.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/origin-priority.js +21 -0
- package/dist/_shared/scope-resolution/origin-priority.js.map +1 -0
- package/dist/_shared/scope-resolution/parsed-file.d.ts +76 -0
- package/dist/_shared/scope-resolution/parsed-file.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/parsed-file.js +54 -0
- package/dist/_shared/scope-resolution/parsed-file.js.map +1 -0
- package/dist/_shared/scope-resolution/position-index.d.ts +62 -0
- package/dist/_shared/scope-resolution/position-index.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/position-index.js +134 -0
- package/dist/_shared/scope-resolution/position-index.js.map +1 -0
- package/dist/_shared/scope-resolution/qualified-name-index.d.ts +44 -0
- package/dist/_shared/scope-resolution/qualified-name-index.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/qualified-name-index.js +75 -0
- package/dist/_shared/scope-resolution/qualified-name-index.js.map +1 -0
- package/dist/_shared/scope-resolution/reference-site.d.ts +75 -0
- package/dist/_shared/scope-resolution/reference-site.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/reference-site.js +24 -0
- package/dist/_shared/scope-resolution/reference-site.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/class-registry.d.ts +27 -0
- package/dist/_shared/scope-resolution/registries/class-registry.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/class-registry.js +30 -0
- package/dist/_shared/scope-resolution/registries/class-registry.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/context.d.ts +69 -0
- package/dist/_shared/scope-resolution/registries/context.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/context.js +44 -0
- package/dist/_shared/scope-resolution/registries/context.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/evidence.d.ts +56 -0
- package/dist/_shared/scope-resolution/registries/evidence.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/evidence.js +150 -0
- package/dist/_shared/scope-resolution/registries/evidence.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/field-registry.d.ts +26 -0
- package/dist/_shared/scope-resolution/registries/field-registry.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/field-registry.js +31 -0
- package/dist/_shared/scope-resolution/registries/field-registry.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/lookup-core.d.ts +81 -0
- package/dist/_shared/scope-resolution/registries/lookup-core.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/lookup-core.js +332 -0
- package/dist/_shared/scope-resolution/registries/lookup-core.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/lookup-qualified.d.ts +33 -0
- package/dist/_shared/scope-resolution/registries/lookup-qualified.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/lookup-qualified.js +56 -0
- package/dist/_shared/scope-resolution/registries/lookup-qualified.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/method-registry.d.ts +36 -0
- package/dist/_shared/scope-resolution/registries/method-registry.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/method-registry.js +32 -0
- package/dist/_shared/scope-resolution/registries/method-registry.js.map +1 -0
- package/dist/_shared/scope-resolution/registries/tie-breaks.d.ts +43 -0
- package/dist/_shared/scope-resolution/registries/tie-breaks.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/registries/tie-breaks.js +60 -0
- package/dist/_shared/scope-resolution/registries/tie-breaks.js.map +1 -0
- package/dist/_shared/scope-resolution/resolve-type-ref.d.ts +53 -0
- package/dist/_shared/scope-resolution/resolve-type-ref.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/resolve-type-ref.js +126 -0
- package/dist/_shared/scope-resolution/resolve-type-ref.js.map +1 -0
- package/dist/_shared/scope-resolution/scope-id.d.ts +43 -0
- package/dist/_shared/scope-resolution/scope-id.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/scope-id.js +46 -0
- package/dist/_shared/scope-resolution/scope-id.js.map +1 -0
- package/dist/_shared/scope-resolution/scope-tree.d.ts +61 -0
- package/dist/_shared/scope-resolution/scope-tree.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/scope-tree.js +186 -0
- package/dist/_shared/scope-resolution/scope-tree.js.map +1 -0
- package/dist/_shared/scope-resolution/shadow/aggregate.d.ts +63 -0
- package/dist/_shared/scope-resolution/shadow/aggregate.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/shadow/aggregate.js +122 -0
- package/dist/_shared/scope-resolution/shadow/aggregate.js.map +1 -0
- package/dist/_shared/scope-resolution/shadow/diff.d.ts +59 -0
- package/dist/_shared/scope-resolution/shadow/diff.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/shadow/diff.js +79 -0
- package/dist/_shared/scope-resolution/shadow/diff.js.map +1 -0
- package/dist/_shared/scope-resolution/symbol-definition.d.ts +34 -0
- package/dist/_shared/scope-resolution/symbol-definition.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/symbol-definition.js +12 -0
- package/dist/_shared/scope-resolution/symbol-definition.js.map +1 -0
- package/dist/_shared/scope-resolution/types.d.ts +356 -0
- package/dist/_shared/scope-resolution/types.d.ts.map +1 -0
- package/dist/_shared/scope-resolution/types.js +17 -0
- package/dist/_shared/scope-resolution/types.js.map +1 -0
- package/dist/cli/ai-context.d.ts +27 -0
- package/dist/cli/ai-context.js +270 -0
- package/dist/cli/analyze.d.ts +43 -0
- package/dist/cli/analyze.js +312 -0
- package/dist/cli/augment.d.ts +13 -0
- package/dist/cli/augment.js +33 -0
- package/dist/cli/clean.d.ts +10 -0
- package/dist/cli/clean.js +78 -0
- package/dist/cli/config.d.ts +27 -0
- package/dist/cli/config.js +106 -0
- package/dist/cli/eval-server.d.ts +37 -0
- package/dist/cli/eval-server.js +398 -0
- package/dist/cli/graphstore.d.ts +40 -0
- package/dist/cli/graphstore.js +639 -0
- package/dist/cli/group.d.ts +2 -0
- package/dist/cli/group.js +306 -0
- package/dist/cli/index-repo.d.ts +15 -0
- package/dist/cli/index-repo.js +120 -0
- package/dist/cli/index.d.ts +2 -0
- package/dist/cli/index.js +236 -0
- package/dist/cli/lazy-action.d.ts +6 -0
- package/dist/cli/lazy-action.js +18 -0
- package/dist/cli/list.d.ts +6 -0
- package/dist/cli/list.js +40 -0
- package/dist/cli/mcp.d.ts +8 -0
- package/dist/cli/mcp.js +36 -0
- package/dist/cli/remove.d.ts +30 -0
- package/dist/cli/remove.js +99 -0
- package/dist/cli/serve.d.ts +4 -0
- package/dist/cli/serve.js +37 -0
- package/dist/cli/setup.d.ts +8 -0
- package/dist/cli/setup.js +543 -0
- package/dist/cli/skill-gen.d.ts +26 -0
- package/dist/cli/skill-gen.js +555 -0
- package/dist/cli/status.d.ts +6 -0
- package/dist/cli/status.js +36 -0
- package/dist/cli/tool.d.ts +43 -0
- package/dist/cli/tool.js +168 -0
- package/dist/cli/wiki.d.ts +21 -0
- package/dist/cli/wiki.js +579 -0
- package/dist/config/ignore-service.d.ts +35 -0
- package/dist/config/ignore-service.js +436 -0
- package/dist/config/supported-languages.d.ts +13 -0
- package/dist/config/supported-languages.js +13 -0
- package/dist/core/augmentation/engine.d.ts +26 -0
- package/dist/core/augmentation/engine.js +252 -0
- package/dist/core/embeddings/ast-utils.d.ts +22 -0
- package/dist/core/embeddings/ast-utils.js +105 -0
- package/dist/core/embeddings/character-chunk.d.ts +12 -0
- package/dist/core/embeddings/character-chunk.js +43 -0
- package/dist/core/embeddings/chunker.d.ts +14 -0
- package/dist/core/embeddings/chunker.js +239 -0
- package/dist/core/embeddings/embedder.d.ts +65 -0
- package/dist/core/embeddings/embedder.js +320 -0
- package/dist/core/embeddings/embedding-pipeline.d.ts +62 -0
- package/dist/core/embeddings/embedding-pipeline.js +486 -0
- package/dist/core/embeddings/http-client.d.ts +31 -0
- package/dist/core/embeddings/http-client.js +179 -0
- package/dist/core/embeddings/index.d.ts +10 -0
- package/dist/core/embeddings/index.js +10 -0
- package/dist/core/embeddings/line-index.d.ts +7 -0
- package/dist/core/embeddings/line-index.js +42 -0
- package/dist/core/embeddings/server-mapping.d.ts +15 -0
- package/dist/core/embeddings/server-mapping.js +33 -0
- package/dist/core/embeddings/structural-extractor.d.ts +15 -0
- package/dist/core/embeddings/structural-extractor.js +58 -0
- package/dist/core/embeddings/text-generator.d.ts +31 -0
- package/dist/core/embeddings/text-generator.js +208 -0
- package/dist/core/embeddings/types.d.ts +207 -0
- package/dist/core/embeddings/types.js +200 -0
- package/dist/core/git-staleness.d.ts +31 -0
- package/dist/core/git-staleness.js +137 -0
- package/dist/core/graph/graph.d.ts +2 -0
- package/dist/core/graph/graph.js +173 -0
- package/dist/core/graph/types.d.ts +36 -0
- package/dist/core/graph/types.js +1 -0
- package/dist/core/graphstore/index.d.ts +46 -0
- package/dist/core/graphstore/index.js +80 -0
- package/dist/core/graphstore/lbug-row-source.d.ts +19 -0
- package/dist/core/graphstore/lbug-row-source.js +141 -0
- package/dist/core/group/bridge-db.d.ts +82 -0
- package/dist/core/group/bridge-db.js +460 -0
- package/dist/core/group/bridge-schema.d.ts +27 -0
- package/dist/core/group/bridge-schema.js +55 -0
- package/dist/core/group/config-parser.d.ts +7 -0
- package/dist/core/group/config-parser.js +100 -0
- package/dist/core/group/contract-extractor.d.ts +7 -0
- package/dist/core/group/contract-extractor.js +1 -0
- package/dist/core/group/cross-impact.d.ts +41 -0
- package/dist/core/group/cross-impact.js +441 -0
- package/dist/core/group/extractors/fs-utils.d.ts +10 -0
- package/dist/core/group/extractors/fs-utils.js +24 -0
- package/dist/core/group/extractors/grpc-extractor.d.ts +25 -0
- package/dist/core/group/extractors/grpc-extractor.js +401 -0
- package/dist/core/group/extractors/grpc-patterns/go.d.ts +2 -0
- package/dist/core/group/extractors/grpc-patterns/go.js +97 -0
- package/dist/core/group/extractors/grpc-patterns/index.d.ts +19 -0
- package/dist/core/group/extractors/grpc-patterns/index.js +46 -0
- package/dist/core/group/extractors/grpc-patterns/java.d.ts +2 -0
- package/dist/core/group/extractors/grpc-patterns/java.js +173 -0
- package/dist/core/group/extractors/grpc-patterns/node.d.ts +4 -0
- package/dist/core/group/extractors/grpc-patterns/node.js +290 -0
- package/dist/core/group/extractors/grpc-patterns/proto.d.ts +9 -0
- package/dist/core/group/extractors/grpc-patterns/proto.js +134 -0
- package/dist/core/group/extractors/grpc-patterns/python.d.ts +2 -0
- package/dist/core/group/extractors/grpc-patterns/python.js +67 -0
- package/dist/core/group/extractors/grpc-patterns/types.d.ts +50 -0
- package/dist/core/group/extractors/grpc-patterns/types.js +1 -0
- package/dist/core/group/extractors/http-patterns/go.d.ts +2 -0
- package/dist/core/group/extractors/http-patterns/go.js +215 -0
- package/dist/core/group/extractors/http-patterns/index.d.ts +17 -0
- package/dist/core/group/extractors/http-patterns/index.js +44 -0
- package/dist/core/group/extractors/http-patterns/java.d.ts +2 -0
- package/dist/core/group/extractors/http-patterns/java.js +253 -0
- package/dist/core/group/extractors/http-patterns/node.d.ts +4 -0
- package/dist/core/group/extractors/http-patterns/node.js +484 -0
- package/dist/core/group/extractors/http-patterns/php.d.ts +2 -0
- package/dist/core/group/extractors/http-patterns/php.js +178 -0
- package/dist/core/group/extractors/http-patterns/python.d.ts +2 -0
- package/dist/core/group/extractors/http-patterns/python.js +133 -0
- package/dist/core/group/extractors/http-patterns/types.d.ts +61 -0
- package/dist/core/group/extractors/http-patterns/types.js +1 -0
- package/dist/core/group/extractors/http-route-extractor.d.ts +21 -0
- package/dist/core/group/extractors/http-route-extractor.js +421 -0
- package/dist/core/group/extractors/manifest-extractor.d.ts +54 -0
- package/dist/core/group/extractors/manifest-extractor.js +292 -0
- package/dist/core/group/extractors/topic-extractor.d.ts +8 -0
- package/dist/core/group/extractors/topic-extractor.js +97 -0
- package/dist/core/group/extractors/topic-patterns/go.d.ts +2 -0
- package/dist/core/group/extractors/topic-patterns/go.js +120 -0
- package/dist/core/group/extractors/topic-patterns/index.d.ts +14 -0
- package/dist/core/group/extractors/topic-patterns/index.js +38 -0
- package/dist/core/group/extractors/topic-patterns/java.d.ts +2 -0
- package/dist/core/group/extractors/topic-patterns/java.js +80 -0
- package/dist/core/group/extractors/topic-patterns/node.d.ts +4 -0
- package/dist/core/group/extractors/topic-patterns/node.js +155 -0
- package/dist/core/group/extractors/topic-patterns/python.d.ts +2 -0
- package/dist/core/group/extractors/topic-patterns/python.js +116 -0
- package/dist/core/group/extractors/topic-patterns/types.d.ts +25 -0
- package/dist/core/group/extractors/topic-patterns/types.js +10 -0
- package/dist/core/group/extractors/tree-sitter-scanner.d.ts +113 -0
- package/dist/core/group/extractors/tree-sitter-scanner.js +94 -0
- package/dist/core/group/group-path-utils.d.ts +17 -0
- package/dist/core/group/group-path-utils.js +40 -0
- package/dist/core/group/matching.d.ts +13 -0
- package/dist/core/group/matching.js +198 -0
- package/dist/core/group/normalization.d.ts +3 -0
- package/dist/core/group/normalization.js +115 -0
- package/dist/core/group/resolve-at-member.d.ts +10 -0
- package/dist/core/group/resolve-at-member.js +31 -0
- package/dist/core/group/service-boundary-detector.d.ts +8 -0
- package/dist/core/group/service-boundary-detector.js +155 -0
- package/dist/core/group/service.d.ts +55 -0
- package/dist/core/group/service.js +394 -0
- package/dist/core/group/storage.d.ts +9 -0
- package/dist/core/group/storage.js +91 -0
- package/dist/core/group/sync.d.ts +21 -0
- package/dist/core/group/sync.js +196 -0
- package/dist/core/group/types.d.ts +160 -0
- package/dist/core/group/types.js +1 -0
- package/dist/core/ingestion/ast-cache.d.ts +26 -0
- package/dist/core/ingestion/ast-cache.js +47 -0
- package/dist/core/ingestion/binding-accumulator.d.ts +212 -0
- package/dist/core/ingestion/binding-accumulator.js +336 -0
- package/dist/core/ingestion/call-extractors/configs/c-cpp.d.ts +3 -0
- package/dist/core/ingestion/call-extractors/configs/c-cpp.js +8 -0
- package/dist/core/ingestion/call-extractors/configs/csharp.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/csharp.js +6 -0
- package/dist/core/ingestion/call-extractors/configs/dart.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/dart.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/go.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/go.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/jvm.d.ts +3 -0
- package/dist/core/ingestion/call-extractors/configs/jvm.js +51 -0
- package/dist/core/ingestion/call-extractors/configs/php.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/php.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/python.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/python.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/ruby.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/ruby.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/rust.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/rust.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/swift.d.ts +2 -0
- package/dist/core/ingestion/call-extractors/configs/swift.js +5 -0
- package/dist/core/ingestion/call-extractors/configs/typescript-javascript.d.ts +3 -0
- package/dist/core/ingestion/call-extractors/configs/typescript-javascript.js +8 -0
- package/dist/core/ingestion/call-extractors/generic.d.ts +5 -0
- package/dist/core/ingestion/call-extractors/generic.js +59 -0
- package/dist/core/ingestion/call-processor.d.ts +235 -0
- package/dist/core/ingestion/call-processor.js +2639 -0
- package/dist/core/ingestion/call-routing.d.ts +55 -0
- package/dist/core/ingestion/call-routing.js +95 -0
- package/dist/core/ingestion/call-types.d.ts +135 -0
- package/dist/core/ingestion/call-types.js +2 -0
- package/dist/core/ingestion/class-extractors/configs/c-cpp.d.ts +3 -0
- package/dist/core/ingestion/class-extractors/configs/c-cpp.js +11 -0
- package/dist/core/ingestion/class-extractors/configs/csharp.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/csharp.js +21 -0
- package/dist/core/ingestion/class-extractors/configs/dart.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/dart.js +7 -0
- package/dist/core/ingestion/class-extractors/configs/go.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/go.js +20 -0
- package/dist/core/ingestion/class-extractors/configs/jvm.d.ts +3 -0
- package/dist/core/ingestion/class-extractors/configs/jvm.js +35 -0
- package/dist/core/ingestion/class-extractors/configs/php.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/php.js +7 -0
- package/dist/core/ingestion/class-extractors/configs/python.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/python.js +7 -0
- package/dist/core/ingestion/class-extractors/configs/ruby.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/ruby.js +7 -0
- package/dist/core/ingestion/class-extractors/configs/rust.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/rust.js +7 -0
- package/dist/core/ingestion/class-extractors/configs/swift.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/configs/swift.js +18 -0
- package/dist/core/ingestion/class-extractors/configs/typescript-javascript.d.ts +4 -0
- package/dist/core/ingestion/class-extractors/configs/typescript-javascript.js +28 -0
- package/dist/core/ingestion/class-extractors/generic.d.ts +2 -0
- package/dist/core/ingestion/class-extractors/generic.js +135 -0
- package/dist/core/ingestion/class-types.d.ts +34 -0
- package/dist/core/ingestion/class-types.js +1 -0
- package/dist/core/ingestion/cluster-enricher.d.ts +38 -0
- package/dist/core/ingestion/cluster-enricher.js +168 -0
- package/dist/core/ingestion/cobol/cobol-copy-expander.d.ts +57 -0
- package/dist/core/ingestion/cobol/cobol-copy-expander.js +392 -0
- package/dist/core/ingestion/cobol/cobol-preprocessor.d.ts +210 -0
- package/dist/core/ingestion/cobol/cobol-preprocessor.js +1715 -0
- package/dist/core/ingestion/cobol/jcl-parser.d.ts +68 -0
- package/dist/core/ingestion/cobol/jcl-parser.js +217 -0
- package/dist/core/ingestion/cobol/jcl-processor.d.ts +33 -0
- package/dist/core/ingestion/cobol/jcl-processor.js +229 -0
- package/dist/core/ingestion/cobol-processor.d.ts +54 -0
- package/dist/core/ingestion/cobol-processor.js +1232 -0
- package/dist/core/ingestion/community-processor.d.ts +39 -0
- package/dist/core/ingestion/community-processor.js +318 -0
- package/dist/core/ingestion/constants.d.ts +16 -0
- package/dist/core/ingestion/constants.js +16 -0
- package/dist/core/ingestion/emit-references.d.ts +88 -0
- package/dist/core/ingestion/emit-references.js +229 -0
- package/dist/core/ingestion/entry-point-scoring.d.ts +58 -0
- package/dist/core/ingestion/entry-point-scoring.js +380 -0
- package/dist/core/ingestion/export-detection.d.ts +57 -0
- package/dist/core/ingestion/export-detection.js +233 -0
- package/dist/core/ingestion/field-extractor.d.ts +29 -0
- package/dist/core/ingestion/field-extractor.js +25 -0
- package/dist/core/ingestion/field-extractors/configs/c-cpp.d.ts +3 -0
- package/dist/core/ingestion/field-extractors/configs/c-cpp.js +104 -0
- package/dist/core/ingestion/field-extractors/configs/csharp.d.ts +8 -0
- package/dist/core/ingestion/field-extractors/configs/csharp.js +116 -0
- package/dist/core/ingestion/field-extractors/configs/dart.d.ts +8 -0
- package/dist/core/ingestion/field-extractors/configs/dart.js +78 -0
- package/dist/core/ingestion/field-extractors/configs/go.d.ts +11 -0
- package/dist/core/ingestion/field-extractors/configs/go.js +60 -0
- package/dist/core/ingestion/field-extractors/configs/helpers.d.ts +53 -0
- package/dist/core/ingestion/field-extractors/configs/helpers.js +158 -0
- package/dist/core/ingestion/field-extractors/configs/jvm.d.ts +3 -0
- package/dist/core/ingestion/field-extractors/configs/jvm.js +118 -0
- package/dist/core/ingestion/field-extractors/configs/php.d.ts +8 -0
- package/dist/core/ingestion/field-extractors/configs/php.js +65 -0
- package/dist/core/ingestion/field-extractors/configs/python.d.ts +12 -0
- package/dist/core/ingestion/field-extractors/configs/python.js +91 -0
- package/dist/core/ingestion/field-extractors/configs/ruby.d.ts +16 -0
- package/dist/core/ingestion/field-extractors/configs/ruby.js +76 -0
- package/dist/core/ingestion/field-extractors/configs/rust.d.ts +9 -0
- package/dist/core/ingestion/field-extractors/configs/rust.js +52 -0
- package/dist/core/ingestion/field-extractors/configs/swift.d.ts +8 -0
- package/dist/core/ingestion/field-extractors/configs/swift.js +65 -0
- package/dist/core/ingestion/field-extractors/configs/typescript-javascript.d.ts +3 -0
- package/dist/core/ingestion/field-extractors/configs/typescript-javascript.js +56 -0
- package/dist/core/ingestion/field-extractors/generic.d.ts +49 -0
- package/dist/core/ingestion/field-extractors/generic.js +117 -0
- package/dist/core/ingestion/field-extractors/typescript.d.ts +77 -0
- package/dist/core/ingestion/field-extractors/typescript.js +291 -0
- package/dist/core/ingestion/field-types.d.ts +61 -0
- package/dist/core/ingestion/field-types.js +2 -0
- package/dist/core/ingestion/filesystem-walker.d.ts +28 -0
- package/dist/core/ingestion/filesystem-walker.js +91 -0
- package/dist/core/ingestion/finalize-orchestrator.d.ts +63 -0
- package/dist/core/ingestion/finalize-orchestrator.js +139 -0
- package/dist/core/ingestion/framework-detection.d.ts +150 -0
- package/dist/core/ingestion/framework-detection.js +786 -0
- package/dist/core/ingestion/heritage-extractors/configs/go.d.ts +13 -0
- package/dist/core/ingestion/heritage-extractors/configs/go.js +20 -0
- package/dist/core/ingestion/heritage-extractors/configs/ruby.d.ts +18 -0
- package/dist/core/ingestion/heritage-extractors/configs/ruby.js +65 -0
- package/dist/core/ingestion/heritage-extractors/generic.d.ts +23 -0
- package/dist/core/ingestion/heritage-extractors/generic.js +47 -0
- package/dist/core/ingestion/heritage-processor.d.ts +54 -0
- package/dist/core/ingestion/heritage-processor.js +360 -0
- package/dist/core/ingestion/heritage-types.d.ts +73 -0
- package/dist/core/ingestion/heritage-types.js +2 -0
- package/dist/core/ingestion/import-processor.d.ts +23 -0
- package/dist/core/ingestion/import-processor.js +373 -0
- package/dist/core/ingestion/import-resolvers/configs/c-cpp.d.ts +7 -0
- package/dist/core/ingestion/import-resolvers/configs/c-cpp.js +14 -0
- package/dist/core/ingestion/import-resolvers/configs/csharp.d.ts +8 -0
- package/dist/core/ingestion/import-resolvers/configs/csharp.js +27 -0
- package/dist/core/ingestion/import-resolvers/configs/dart.d.ts +17 -0
- package/dist/core/ingestion/import-resolvers/configs/dart.js +54 -0
- package/dist/core/ingestion/import-resolvers/configs/go.d.ts +8 -0
- package/dist/core/ingestion/import-resolvers/configs/go.js +26 -0
- package/dist/core/ingestion/import-resolvers/configs/jvm.d.ts +13 -0
- package/dist/core/ingestion/import-resolvers/configs/jvm.js +68 -0
- package/dist/core/ingestion/import-resolvers/configs/php.d.ts +8 -0
- package/dist/core/ingestion/import-resolvers/configs/php.js +15 -0
- package/dist/core/ingestion/import-resolvers/configs/python.d.ts +12 -0
- package/dist/core/ingestion/import-resolvers/configs/python.js +41 -0
- package/dist/core/ingestion/import-resolvers/configs/ruby.d.ts +8 -0
- package/dist/core/ingestion/import-resolvers/configs/ruby.js +16 -0
- package/dist/core/ingestion/import-resolvers/configs/rust.d.ts +8 -0
- package/dist/core/ingestion/import-resolvers/configs/rust.js +54 -0
- package/dist/core/ingestion/import-resolvers/configs/swift.d.ts +8 -0
- package/dist/core/ingestion/import-resolvers/configs/swift.js +29 -0
- package/dist/core/ingestion/import-resolvers/configs/typescript-javascript.d.ts +9 -0
- package/dist/core/ingestion/import-resolvers/configs/typescript-javascript.js +23 -0
- package/dist/core/ingestion/import-resolvers/csharp.d.ts +18 -0
- package/dist/core/ingestion/import-resolvers/csharp.js +115 -0
- package/dist/core/ingestion/import-resolvers/go.d.ts +17 -0
- package/dist/core/ingestion/import-resolvers/go.js +46 -0
- package/dist/core/ingestion/import-resolvers/jvm.d.ts +27 -0
- package/dist/core/ingestion/import-resolvers/jvm.js +106 -0
- package/dist/core/ingestion/import-resolvers/php.d.ts +24 -0
- package/dist/core/ingestion/import-resolvers/php.js +77 -0
- package/dist/core/ingestion/import-resolvers/python.d.ts +22 -0
- package/dist/core/ingestion/import-resolvers/python.js +72 -0
- package/dist/core/ingestion/import-resolvers/resolver-factory.d.ts +24 -0
- package/dist/core/ingestion/import-resolvers/resolver-factory.js +33 -0
- package/dist/core/ingestion/import-resolvers/ruby.d.ts +14 -0
- package/dist/core/ingestion/import-resolvers/ruby.js +17 -0
- package/dist/core/ingestion/import-resolvers/rust.d.ts +17 -0
- package/dist/core/ingestion/import-resolvers/rust.js +75 -0
- package/dist/core/ingestion/import-resolvers/standard.d.ts +30 -0
- package/dist/core/ingestion/import-resolvers/standard.js +142 -0
- package/dist/core/ingestion/import-resolvers/types.d.ts +68 -0
- package/dist/core/ingestion/import-resolvers/types.js +6 -0
- package/dist/core/ingestion/import-resolvers/utils.d.ts +35 -0
- package/dist/core/ingestion/import-resolvers/utils.js +149 -0
- package/dist/core/ingestion/import-target-adapter.d.ts +73 -0
- package/dist/core/ingestion/import-target-adapter.js +95 -0
- package/dist/core/ingestion/language-config.d.ts +52 -0
- package/dist/core/ingestion/language-config.js +181 -0
- package/dist/core/ingestion/language-provider.d.ts +410 -0
- package/dist/core/ingestion/language-provider.js +24 -0
- package/dist/core/ingestion/languages/c-cpp.d.ts +12 -0
- package/dist/core/ingestion/languages/c-cpp.js +329 -0
- package/dist/core/ingestion/languages/cobol.d.ts +1 -0
- package/dist/core/ingestion/languages/cobol.js +26 -0
- package/dist/core/ingestion/languages/csharp/accessor-unwrap.d.ts +21 -0
- package/dist/core/ingestion/languages/csharp/accessor-unwrap.js +56 -0
- package/dist/core/ingestion/languages/csharp/arity-metadata.d.ts +26 -0
- package/dist/core/ingestion/languages/csharp/arity-metadata.js +46 -0
- package/dist/core/ingestion/languages/csharp/arity.d.ts +23 -0
- package/dist/core/ingestion/languages/csharp/arity.js +37 -0
- package/dist/core/ingestion/languages/csharp/cache-stats.d.ts +15 -0
- package/dist/core/ingestion/languages/csharp/cache-stats.js +26 -0
- package/dist/core/ingestion/languages/csharp/captures.d.ts +19 -0
- package/dist/core/ingestion/languages/csharp/captures.js +249 -0
- package/dist/core/ingestion/languages/csharp/import-decomposer.d.ts +19 -0
- package/dist/core/ingestion/languages/csharp/import-decomposer.js +93 -0
- package/dist/core/ingestion/languages/csharp/import-target.d.ts +25 -0
- package/dist/core/ingestion/languages/csharp/import-target.js +123 -0
- package/dist/core/ingestion/languages/csharp/index.d.ts +82 -0
- package/dist/core/ingestion/languages/csharp/index.js +82 -0
- package/dist/core/ingestion/languages/csharp/interpret.d.ts +15 -0
- package/dist/core/ingestion/languages/csharp/interpret.js +132 -0
- package/dist/core/ingestion/languages/csharp/merge-bindings.d.ts +27 -0
- package/dist/core/ingestion/languages/csharp/merge-bindings.js +55 -0
- package/dist/core/ingestion/languages/csharp/namespace-siblings.d.ts +50 -0
- package/dist/core/ingestion/languages/csharp/namespace-siblings.js +374 -0
- package/dist/core/ingestion/languages/csharp/query.d.ts +35 -0
- package/dist/core/ingestion/languages/csharp/query.js +515 -0
- package/dist/core/ingestion/languages/csharp/receiver-binding.d.ts +31 -0
- package/dist/core/ingestion/languages/csharp/receiver-binding.js +135 -0
- package/dist/core/ingestion/languages/csharp/scope-resolver.d.ts +10 -0
- package/dist/core/ingestion/languages/csharp/scope-resolver.js +63 -0
- package/dist/core/ingestion/languages/csharp/simple-hooks.d.ts +53 -0
- package/dist/core/ingestion/languages/csharp/simple-hooks.js +76 -0
- package/dist/core/ingestion/languages/csharp.d.ts +8 -0
- package/dist/core/ingestion/languages/csharp.js +152 -0
- package/dist/core/ingestion/languages/dart.d.ts +12 -0
- package/dist/core/ingestion/languages/dart.js +102 -0
- package/dist/core/ingestion/languages/go.d.ts +11 -0
- package/dist/core/ingestion/languages/go.js +44 -0
- package/dist/core/ingestion/languages/index.d.ts +39 -0
- package/dist/core/ingestion/languages/index.js +64 -0
- package/dist/core/ingestion/languages/java.d.ts +9 -0
- package/dist/core/ingestion/languages/java.js +44 -0
- package/dist/core/ingestion/languages/kotlin.d.ts +9 -0
- package/dist/core/ingestion/languages/kotlin.js +123 -0
- package/dist/core/ingestion/languages/php.d.ts +8 -0
- package/dist/core/ingestion/languages/php.js +240 -0
- package/dist/core/ingestion/languages/python/arity-metadata.d.ts +24 -0
- package/dist/core/ingestion/languages/python/arity-metadata.js +45 -0
- package/dist/core/ingestion/languages/python/arity.d.ts +22 -0
- package/dist/core/ingestion/languages/python/arity.js +38 -0
- package/dist/core/ingestion/languages/python/cache-stats.d.ts +17 -0
- package/dist/core/ingestion/languages/python/cache-stats.js +28 -0
- package/dist/core/ingestion/languages/python/captures.d.ts +19 -0
- package/dist/core/ingestion/languages/python/captures.js +106 -0
- package/dist/core/ingestion/languages/python/import-decomposer.d.ts +15 -0
- package/dist/core/ingestion/languages/python/import-decomposer.js +112 -0
- package/dist/core/ingestion/languages/python/import-target.d.ts +21 -0
- package/dist/core/ingestion/languages/python/import-target.js +99 -0
- package/dist/core/ingestion/languages/python/index.d.ts +80 -0
- package/dist/core/ingestion/languages/python/index.js +80 -0
- package/dist/core/ingestion/languages/python/interpret.d.ts +15 -0
- package/dist/core/ingestion/languages/python/interpret.js +191 -0
- package/dist/core/ingestion/languages/python/merge-bindings.d.ts +16 -0
- package/dist/core/ingestion/languages/python/merge-bindings.js +44 -0
- package/dist/core/ingestion/languages/python/query.d.ts +9 -0
- package/dist/core/ingestion/languages/python/query.js +267 -0
- package/dist/core/ingestion/languages/python/receiver-binding.d.ts +21 -0
- package/dist/core/ingestion/languages/python/receiver-binding.js +116 -0
- package/dist/core/ingestion/languages/python/scope-resolver.d.ts +16 -0
- package/dist/core/ingestion/languages/python/scope-resolver.js +53 -0
- package/dist/core/ingestion/languages/python/simple-hooks.d.ts +23 -0
- package/dist/core/ingestion/languages/python/simple-hooks.js +35 -0
- package/dist/core/ingestion/languages/python.d.ts +12 -0
- package/dist/core/ingestion/languages/python.js +91 -0
- package/dist/core/ingestion/languages/ruby.d.ts +9 -0
- package/dist/core/ingestion/languages/ruby.js +210 -0
- package/dist/core/ingestion/languages/rust.d.ts +12 -0
- package/dist/core/ingestion/languages/rust.js +132 -0
- package/dist/core/ingestion/languages/swift.d.ts +12 -0
- package/dist/core/ingestion/languages/swift.js +244 -0
- package/dist/core/ingestion/languages/typescript.d.ts +11 -0
- package/dist/core/ingestion/languages/typescript.js +184 -0
- package/dist/core/ingestion/languages/vue.d.ts +13 -0
- package/dist/core/ingestion/languages/vue.js +77 -0
- package/dist/core/ingestion/markdown-processor.d.ts +17 -0
- package/dist/core/ingestion/markdown-processor.js +124 -0
- package/dist/core/ingestion/method-extractors/configs/c-cpp.d.ts +3 -0
- package/dist/core/ingestion/method-extractors/configs/c-cpp.js +387 -0
- package/dist/core/ingestion/method-extractors/configs/csharp.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/csharp.js +287 -0
- package/dist/core/ingestion/method-extractors/configs/dart.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/dart.js +376 -0
- package/dist/core/ingestion/method-extractors/configs/go.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/go.js +176 -0
- package/dist/core/ingestion/method-extractors/configs/jvm.d.ts +3 -0
- package/dist/core/ingestion/method-extractors/configs/jvm.js +336 -0
- package/dist/core/ingestion/method-extractors/configs/php.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/php.js +304 -0
- package/dist/core/ingestion/method-extractors/configs/python.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/python.js +309 -0
- package/dist/core/ingestion/method-extractors/configs/ruby.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/ruby.js +286 -0
- package/dist/core/ingestion/method-extractors/configs/rust.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/rust.js +195 -0
- package/dist/core/ingestion/method-extractors/configs/swift.d.ts +2 -0
- package/dist/core/ingestion/method-extractors/configs/swift.js +277 -0
- package/dist/core/ingestion/method-extractors/configs/typescript-javascript.d.ts +3 -0
- package/dist/core/ingestion/method-extractors/configs/typescript-javascript.js +338 -0
- package/dist/core/ingestion/method-extractors/generic.d.ts +11 -0
- package/dist/core/ingestion/method-extractors/generic.js +204 -0
- package/dist/core/ingestion/method-types.d.ts +90 -0
- package/dist/core/ingestion/method-types.js +2 -0
- package/dist/core/ingestion/model/field-registry.d.ts +18 -0
- package/dist/core/ingestion/model/field-registry.js +22 -0
- package/dist/core/ingestion/model/heritage-map.d.ts +105 -0
- package/dist/core/ingestion/model/heritage-map.js +260 -0
- package/dist/core/ingestion/model/index.d.ts +20 -0
- package/dist/core/ingestion/model/index.js +43 -0
- package/dist/core/ingestion/model/method-registry.d.ts +71 -0
- package/dist/core/ingestion/model/method-registry.js +134 -0
- package/dist/core/ingestion/model/registration-table.d.ts +138 -0
- package/dist/core/ingestion/model/registration-table.js +224 -0
- package/dist/core/ingestion/model/resolution-context.d.ts +93 -0
- package/dist/core/ingestion/model/resolution-context.js +337 -0
- package/dist/core/ingestion/model/resolve.d.ts +61 -0
- package/dist/core/ingestion/model/resolve.js +381 -0
- package/dist/core/ingestion/model/scope-resolution-indexes.d.ts +59 -0
- package/dist/core/ingestion/model/scope-resolution-indexes.js +42 -0
- package/dist/core/ingestion/model/semantic-model.d.ts +150 -0
- package/dist/core/ingestion/model/semantic-model.js +175 -0
- package/dist/core/ingestion/model/symbol-table.d.ts +200 -0
- package/dist/core/ingestion/model/symbol-table.js +206 -0
- package/dist/core/ingestion/model/type-registry.d.ts +39 -0
- package/dist/core/ingestion/model/type-registry.js +62 -0
- package/dist/core/ingestion/mro-processor.d.ts +46 -0
- package/dist/core/ingestion/mro-processor.js +597 -0
- package/dist/core/ingestion/named-bindings/csharp.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/csharp.js +37 -0
- package/dist/core/ingestion/named-bindings/java.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/java.js +29 -0
- package/dist/core/ingestion/named-bindings/kotlin.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/kotlin.js +36 -0
- package/dist/core/ingestion/named-bindings/php.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/php.js +61 -0
- package/dist/core/ingestion/named-bindings/python.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/python.js +49 -0
- package/dist/core/ingestion/named-bindings/rust.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/rust.js +66 -0
- package/dist/core/ingestion/named-bindings/types.d.ts +16 -0
- package/dist/core/ingestion/named-bindings/types.js +6 -0
- package/dist/core/ingestion/named-bindings/typescript.d.ts +3 -0
- package/dist/core/ingestion/named-bindings/typescript.js +58 -0
- package/dist/core/ingestion/parsing-processor.d.ts +40 -0
- package/dist/core/ingestion/parsing-processor.js +576 -0
- package/dist/core/ingestion/pipeline-phases/cobol.d.ts +16 -0
- package/dist/core/ingestion/pipeline-phases/cobol.js +45 -0
- package/dist/core/ingestion/pipeline-phases/communities.d.ts +16 -0
- package/dist/core/ingestion/pipeline-phases/communities.js +62 -0
- package/dist/core/ingestion/pipeline-phases/cross-file-impl.d.ts +17 -0
- package/dist/core/ingestion/pipeline-phases/cross-file-impl.js +156 -0
- package/dist/core/ingestion/pipeline-phases/cross-file.d.ts +37 -0
- package/dist/core/ingestion/pipeline-phases/cross-file.js +63 -0
- package/dist/core/ingestion/pipeline-phases/index.d.ts +22 -0
- package/dist/core/ingestion/pipeline-phases/index.js +23 -0
- package/dist/core/ingestion/pipeline-phases/markdown.d.ts +17 -0
- package/dist/core/ingestion/pipeline-phases/markdown.js +33 -0
- package/dist/core/ingestion/pipeline-phases/mro.d.ts +18 -0
- package/dist/core/ingestion/pipeline-phases/mro.js +36 -0
- package/dist/core/ingestion/pipeline-phases/orm-extraction.d.ts +22 -0
- package/dist/core/ingestion/pipeline-phases/orm-extraction.js +92 -0
- package/dist/core/ingestion/pipeline-phases/orm.d.ts +15 -0
- package/dist/core/ingestion/pipeline-phases/orm.js +74 -0
- package/dist/core/ingestion/pipeline-phases/parse-impl.d.ts +58 -0
- package/dist/core/ingestion/pipeline-phases/parse-impl.js +458 -0
- package/dist/core/ingestion/pipeline-phases/parse.d.ts +74 -0
- package/dist/core/ingestion/pipeline-phases/parse.js +33 -0
- package/dist/core/ingestion/pipeline-phases/processes.d.ts +16 -0
- package/dist/core/ingestion/pipeline-phases/processes.js +143 -0
- package/dist/core/ingestion/pipeline-phases/routes.d.ts +21 -0
- package/dist/core/ingestion/pipeline-phases/routes.js +243 -0
- package/dist/core/ingestion/pipeline-phases/runner.d.ts +22 -0
- package/dist/core/ingestion/pipeline-phases/runner.js +203 -0
- package/dist/core/ingestion/pipeline-phases/scan.d.ts +21 -0
- package/dist/core/ingestion/pipeline-phases/scan.js +46 -0
- package/dist/core/ingestion/pipeline-phases/structure.d.ts +27 -0
- package/dist/core/ingestion/pipeline-phases/structure.js +35 -0
- package/dist/core/ingestion/pipeline-phases/tools.d.ts +20 -0
- package/dist/core/ingestion/pipeline-phases/tools.js +79 -0
- package/dist/core/ingestion/pipeline-phases/types.d.ts +79 -0
- package/dist/core/ingestion/pipeline-phases/types.js +37 -0
- package/dist/core/ingestion/pipeline-phases/wildcard-synthesis.d.ts +70 -0
- package/dist/core/ingestion/pipeline-phases/wildcard-synthesis.js +312 -0
- package/dist/core/ingestion/pipeline.d.ts +36 -0
- package/dist/core/ingestion/pipeline.js +89 -0
- package/dist/core/ingestion/process-processor.d.ts +51 -0
- package/dist/core/ingestion/process-processor.js +317 -0
- package/dist/core/ingestion/registry-primary-flag.d.ts +86 -0
- package/dist/core/ingestion/registry-primary-flag.js +111 -0
- package/dist/core/ingestion/resolve-references.d.ts +63 -0
- package/dist/core/ingestion/resolve-references.js +175 -0
- package/dist/core/ingestion/route-extractors/expo.d.ts +1 -0
- package/dist/core/ingestion/route-extractors/expo.js +36 -0
- package/dist/core/ingestion/route-extractors/middleware.d.ts +47 -0
- package/dist/core/ingestion/route-extractors/middleware.js +167 -0
- package/dist/core/ingestion/route-extractors/nextjs.d.ts +3 -0
- package/dist/core/ingestion/route-extractors/nextjs.js +76 -0
- package/dist/core/ingestion/route-extractors/php.d.ts +7 -0
- package/dist/core/ingestion/route-extractors/php.js +22 -0
- package/dist/core/ingestion/route-extractors/response-shapes.d.ts +20 -0
- package/dist/core/ingestion/route-extractors/response-shapes.js +294 -0
- package/dist/core/ingestion/scope-extractor-bridge.d.ts +32 -0
- package/dist/core/ingestion/scope-extractor-bridge.js +44 -0
- package/dist/core/ingestion/scope-extractor.d.ts +86 -0
- package/dist/core/ingestion/scope-extractor.js +758 -0
- package/dist/core/ingestion/scope-resolution/contract/scope-resolver.d.ts +372 -0
- package/dist/core/ingestion/scope-resolution/contract/scope-resolver.js +212 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/edges.d.ts +43 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/edges.js +79 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/ids.d.ts +57 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/ids.js +112 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/imports-to-edges.d.ts +17 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/imports-to-edges.js +46 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/method-dispatch.d.ts +19 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/method-dispatch.js +30 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/node-lookup.d.ts +37 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/node-lookup.js +113 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/references-to-edges.d.ts +38 -0
- package/dist/core/ingestion/scope-resolution/graph-bridge/references-to-edges.js +73 -0
- package/dist/core/ingestion/scope-resolution/passes/compound-receiver.d.ts +42 -0
- package/dist/core/ingestion/scope-resolution/passes/compound-receiver.js +198 -0
- package/dist/core/ingestion/scope-resolution/passes/free-call-fallback.d.ts +27 -0
- package/dist/core/ingestion/scope-resolution/passes/free-call-fallback.js +131 -0
- package/dist/core/ingestion/scope-resolution/passes/imported-return-types.d.ts +48 -0
- package/dist/core/ingestion/scope-resolution/passes/imported-return-types.js +130 -0
- package/dist/core/ingestion/scope-resolution/passes/mro.d.ts +42 -0
- package/dist/core/ingestion/scope-resolution/passes/mro.js +99 -0
- package/dist/core/ingestion/scope-resolution/passes/overload-narrowing.d.ts +26 -0
- package/dist/core/ingestion/scope-resolution/passes/overload-narrowing.js +61 -0
- package/dist/core/ingestion/scope-resolution/passes/receiver-bound-calls.d.ts +46 -0
- package/dist/core/ingestion/scope-resolution/passes/receiver-bound-calls.js +327 -0
- package/dist/core/ingestion/scope-resolution/pipeline/phase.d.ts +47 -0
- package/dist/core/ingestion/scope-resolution/pipeline/phase.js +130 -0
- package/dist/core/ingestion/scope-resolution/pipeline/reconcile-ownership.d.ts +68 -0
- package/dist/core/ingestion/scope-resolution/pipeline/reconcile-ownership.js +125 -0
- package/dist/core/ingestion/scope-resolution/pipeline/registry.d.ts +17 -0
- package/dist/core/ingestion/scope-resolution/pipeline/registry.js +21 -0
- package/dist/core/ingestion/scope-resolution/pipeline/run.d.ts +66 -0
- package/dist/core/ingestion/scope-resolution/pipeline/run.js +157 -0
- package/dist/core/ingestion/scope-resolution/scope/namespace-targets.d.ts +36 -0
- package/dist/core/ingestion/scope-resolution/scope/namespace-targets.js +52 -0
- package/dist/core/ingestion/scope-resolution/scope/walkers.d.ts +127 -0
- package/dist/core/ingestion/scope-resolution/scope/walkers.js +349 -0
- package/dist/core/ingestion/scope-resolution/workspace-index.d.ts +52 -0
- package/dist/core/ingestion/scope-resolution/workspace-index.js +61 -0
- package/dist/core/ingestion/shadow-harness.d.ts +113 -0
- package/dist/core/ingestion/shadow-harness.js +148 -0
- package/dist/core/ingestion/structure-processor.d.ts +2 -0
- package/dist/core/ingestion/structure-processor.js +36 -0
- package/dist/core/ingestion/tree-sitter-queries.d.ts +16 -0
- package/dist/core/ingestion/tree-sitter-queries.js +1338 -0
- package/dist/core/ingestion/type-env.d.ts +86 -0
- package/dist/core/ingestion/type-env.js +1128 -0
- package/dist/core/ingestion/type-extractors/c-cpp.d.ts +7 -0
- package/dist/core/ingestion/type-extractors/c-cpp.js +532 -0
- package/dist/core/ingestion/type-extractors/csharp.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/csharp.js +583 -0
- package/dist/core/ingestion/type-extractors/dart.d.ts +15 -0
- package/dist/core/ingestion/type-extractors/dart.js +369 -0
- package/dist/core/ingestion/type-extractors/go.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/go.js +513 -0
- package/dist/core/ingestion/type-extractors/jvm.d.ts +3 -0
- package/dist/core/ingestion/type-extractors/jvm.js +856 -0
- package/dist/core/ingestion/type-extractors/php.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/php.js +534 -0
- package/dist/core/ingestion/type-extractors/python.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/python.js +474 -0
- package/dist/core/ingestion/type-extractors/ruby.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/ruby.js +377 -0
- package/dist/core/ingestion/type-extractors/rust.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/rust.js +515 -0
- package/dist/core/ingestion/type-extractors/shared.d.ts +131 -0
- package/dist/core/ingestion/type-extractors/shared.js +796 -0
- package/dist/core/ingestion/type-extractors/swift.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/swift.js +484 -0
- package/dist/core/ingestion/type-extractors/types.d.ts +172 -0
- package/dist/core/ingestion/type-extractors/types.js +1 -0
- package/dist/core/ingestion/type-extractors/typescript.d.ts +2 -0
- package/dist/core/ingestion/type-extractors/typescript.js +661 -0
- package/dist/core/ingestion/utils/ast-helpers.d.ts +89 -0
- package/dist/core/ingestion/utils/ast-helpers.js +535 -0
- package/dist/core/ingestion/utils/call-analysis.d.ts +75 -0
- package/dist/core/ingestion/utils/call-analysis.js +574 -0
- package/dist/core/ingestion/utils/env.d.ts +10 -0
- package/dist/core/ingestion/utils/env.js +10 -0
- package/dist/core/ingestion/utils/event-loop.d.ts +5 -0
- package/dist/core/ingestion/utils/event-loop.js +5 -0
- package/dist/core/ingestion/utils/graph-sort.d.ts +58 -0
- package/dist/core/ingestion/utils/graph-sort.js +100 -0
- package/dist/core/ingestion/utils/max-file-size.d.ts +20 -0
- package/dist/core/ingestion/utils/max-file-size.js +52 -0
- package/dist/core/ingestion/utils/method-props.d.ts +32 -0
- package/dist/core/ingestion/utils/method-props.js +147 -0
- package/dist/core/ingestion/utils/ruby-self-call.d.ts +52 -0
- package/dist/core/ingestion/utils/ruby-self-call.js +59 -0
- package/dist/core/ingestion/utils/verbose.d.ts +1 -0
- package/dist/core/ingestion/utils/verbose.js +7 -0
- package/dist/core/ingestion/variable-extractors/configs/c-cpp.d.ts +3 -0
- package/dist/core/ingestion/variable-extractors/configs/c-cpp.js +81 -0
- package/dist/core/ingestion/variable-extractors/configs/csharp.d.ts +9 -0
- package/dist/core/ingestion/variable-extractors/configs/csharp.js +63 -0
- package/dist/core/ingestion/variable-extractors/configs/dart.d.ts +2 -0
- package/dist/core/ingestion/variable-extractors/configs/dart.js +94 -0
- package/dist/core/ingestion/variable-extractors/configs/go.d.ts +2 -0
- package/dist/core/ingestion/variable-extractors/configs/go.js +83 -0
- package/dist/core/ingestion/variable-extractors/configs/jvm.d.ts +18 -0
- package/dist/core/ingestion/variable-extractors/configs/jvm.js +115 -0
- package/dist/core/ingestion/variable-extractors/configs/php.d.ts +14 -0
- package/dist/core/ingestion/variable-extractors/configs/php.js +58 -0
- package/dist/core/ingestion/variable-extractors/configs/python.d.ts +2 -0
- package/dist/core/ingestion/variable-extractors/configs/python.js +101 -0
- package/dist/core/ingestion/variable-extractors/configs/ruby.d.ts +11 -0
- package/dist/core/ingestion/variable-extractors/configs/ruby.js +52 -0
- package/dist/core/ingestion/variable-extractors/configs/rust.d.ts +2 -0
- package/dist/core/ingestion/variable-extractors/configs/rust.js +76 -0
- package/dist/core/ingestion/variable-extractors/configs/swift.d.ts +2 -0
- package/dist/core/ingestion/variable-extractors/configs/swift.js +88 -0
- package/dist/core/ingestion/variable-extractors/configs/typescript-javascript.d.ts +3 -0
- package/dist/core/ingestion/variable-extractors/configs/typescript-javascript.js +83 -0
- package/dist/core/ingestion/variable-extractors/generic.d.ts +5 -0
- package/dist/core/ingestion/variable-extractors/generic.js +80 -0
- package/dist/core/ingestion/variable-types.d.ts +82 -0
- package/dist/core/ingestion/variable-types.js +2 -0
- package/dist/core/ingestion/vue-sfc-extractor.d.ts +44 -0
- package/dist/core/ingestion/vue-sfc-extractor.js +94 -0
- package/dist/core/ingestion/workers/parse-worker.d.ts +198 -0
- package/dist/core/ingestion/workers/parse-worker.js +1928 -0
- package/dist/core/ingestion/workers/worker-pool.d.ts +16 -0
- package/dist/core/ingestion/workers/worker-pool.js +126 -0
- package/dist/core/lbug/csv-generator.d.ts +33 -0
- package/dist/core/lbug/csv-generator.js +459 -0
- package/dist/core/lbug/lbug-adapter.d.ts +173 -0
- package/dist/core/lbug/lbug-adapter.js +1188 -0
- package/dist/core/lbug/pool-adapter.d.ts +93 -0
- package/dist/core/lbug/pool-adapter.js +543 -0
- package/dist/core/lbug/schema.d.ts +62 -0
- package/dist/core/lbug/schema.js +484 -0
- package/dist/core/run-analyze.d.ts +72 -0
- package/dist/core/run-analyze.js +315 -0
- package/dist/core/search/bm25-index.d.ts +41 -0
- package/dist/core/search/bm25-index.js +209 -0
- package/dist/core/search/hybrid-search.d.ts +49 -0
- package/dist/core/search/hybrid-search.js +118 -0
- package/dist/core/search/phase-timer.d.ts +72 -0
- package/dist/core/search/phase-timer.js +106 -0
- package/dist/core/tree-sitter/parser-loader.d.ts +8 -0
- package/dist/core/tree-sitter/parser-loader.js +84 -0
- package/dist/core/wiki/cursor-client.d.ts +31 -0
- package/dist/core/wiki/cursor-client.js +122 -0
- package/dist/core/wiki/generator.d.ts +129 -0
- package/dist/core/wiki/generator.js +898 -0
- package/dist/core/wiki/graph-queries.d.ts +84 -0
- package/dist/core/wiki/graph-queries.js +244 -0
- package/dist/core/wiki/html-viewer.d.ts +10 -0
- package/dist/core/wiki/html-viewer.js +303 -0
- package/dist/core/wiki/llm-client.d.ts +63 -0
- package/dist/core/wiki/llm-client.js +234 -0
- package/dist/core/wiki/prompts.d.ts +53 -0
- package/dist/core/wiki/prompts.js +181 -0
- package/dist/lib/utils.d.ts +1 -0
- package/dist/lib/utils.js +3 -0
- package/dist/mcp/compatible-stdio-transport.d.ts +25 -0
- package/dist/mcp/compatible-stdio-transport.js +200 -0
- package/dist/mcp/core/embedder.d.ts +27 -0
- package/dist/mcp/core/embedder.js +122 -0
- package/dist/mcp/core/lbug-adapter.d.ts +5 -0
- package/dist/mcp/core/lbug-adapter.js +5 -0
- package/dist/mcp/local/graphstore-handler.d.ts +214 -0
- package/dist/mcp/local/graphstore-handler.js +272 -0
- package/dist/mcp/local/local-backend.d.ts +347 -0
- package/dist/mcp/local/local-backend.js +3218 -0
- package/dist/mcp/resources.d.ts +62 -0
- package/dist/mcp/resources.js +696 -0
- package/dist/mcp/server.d.ts +23 -0
- package/dist/mcp/server.js +533 -0
- package/dist/mcp/staleness.d.ts +5 -0
- package/dist/mcp/staleness.js +4 -0
- package/dist/mcp/tools.d.ts +27 -0
- package/dist/mcp/tools.js +823 -0
- package/dist/server/analyze-job.d.ts +55 -0
- package/dist/server/analyze-job.js +150 -0
- package/dist/server/analyze-worker.d.ts +13 -0
- package/dist/server/analyze-worker.js +59 -0
- package/dist/server/api.d.ts +47 -0
- package/dist/server/api.js +1727 -0
- package/dist/server/git-clone.d.ts +26 -0
- package/dist/server/git-clone.js +184 -0
- package/dist/server/mcp-http.d.ts +13 -0
- package/dist/server/mcp-http.js +100 -0
- package/dist/storage/git.d.ts +80 -0
- package/dist/storage/git.js +190 -0
- package/dist/storage/repo-manager.d.ts +458 -0
- package/dist/storage/repo-manager.js +766 -0
- package/dist/types/pipeline.d.ts +18 -0
- package/dist/types/pipeline.js +1 -0
- package/hooks/claude/codragraph-hook.cjs +268 -0
- package/hooks/claude/pre-tool-use.sh +79 -0
- package/hooks/claude/session-start.sh +42 -0
- package/package.json +127 -0
- package/scripts/bench-scope-resolution.ts +134 -0
- package/scripts/build-tree-sitter-proto.cjs +82 -0
- package/scripts/build.js +90 -0
- package/scripts/ci-list-migrated-languages.ts +24 -0
- package/scripts/patch-tree-sitter-swift.cjs +78 -0
- package/skills/codragraph-cli.md +82 -0
- package/skills/codragraph-debugging.md +89 -0
- package/skills/codragraph-exploring.md +78 -0
- package/skills/codragraph-guide.md +64 -0
- package/skills/codragraph-impact-analysis.md +97 -0
- package/skills/codragraph-pr-review.md +163 -0
- package/skills/codragraph-refactoring.md +121 -0
- package/vendor/leiden/index.cjs +355 -0
- package/vendor/leiden/utils.cjs +392 -0
- package/vendor/tree-sitter-proto/binding.gyp +30 -0
- package/vendor/tree-sitter-proto/bindings/node/binding.cc +20 -0
- package/vendor/tree-sitter-proto/bindings/node/index.d.ts +28 -0
- package/vendor/tree-sitter-proto/bindings/node/index.js +7 -0
- package/vendor/tree-sitter-proto/package.json +12 -0
- package/vendor/tree-sitter-proto/src/node-types.json +1145 -0
- package/vendor/tree-sitter-proto/src/parser.c +10149 -0
- package/vendor/tree-sitter-proto/src/tree_sitter/alloc.h +54 -0
- package/vendor/tree-sitter-proto/src/tree_sitter/array.h +291 -0
- package/vendor/tree-sitter-proto/src/tree_sitter/parser.h +266 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase: parse
|
|
3
|
+
*
|
|
4
|
+
* Chunked parse + resolve loop: reads source in byte-budget chunks,
|
|
5
|
+
* parses via worker pool (or sequential fallback), resolves imports,
|
|
6
|
+
* heritage, and calls, synthesizes wildcard bindings.
|
|
7
|
+
*
|
|
8
|
+
* This phase encapsulates the entire `runChunkedParseAndResolve` function
|
|
9
|
+
* from the original pipeline. The chunk loop is a memory optimization
|
|
10
|
+
* internal to this phase, not a phase boundary.
|
|
11
|
+
*
|
|
12
|
+
* @deps structure, markdown, cobol
|
|
13
|
+
* @reads scannedFiles, allPaths, totalFiles (from structure)
|
|
14
|
+
* @writes graph (Symbol nodes, IMPORTS/CALLS/EXTENDS/IMPLEMENTS/ACCESSES edges)
|
|
15
|
+
* @output exportedTypeMap, allFetchCalls, allExtractedRoutes, allDecoratorRoutes,
|
|
16
|
+
* allToolDefs, allORMQueries, bindingAccumulator
|
|
17
|
+
*/
|
|
18
|
+
import { getPhaseOutput } from './types.js';
|
|
19
|
+
import { runChunkedParseAndResolve } from './parse-impl.js';
|
|
20
|
+
export const parsePhase = {
|
|
21
|
+
name: 'parse',
|
|
22
|
+
deps: ['structure', 'markdown', 'cobol'],
|
|
23
|
+
async execute(ctx, deps) {
|
|
24
|
+
const { scannedFiles, allPaths, allPathSet, totalFiles } = getPhaseOutput(deps, 'structure');
|
|
25
|
+
const result = await runChunkedParseAndResolve(ctx.graph, scannedFiles, allPaths, totalFiles, ctx.repoPath, ctx.pipelineStart, ctx.onProgress, ctx.options);
|
|
26
|
+
return {
|
|
27
|
+
...result,
|
|
28
|
+
allPaths,
|
|
29
|
+
allPathSet,
|
|
30
|
+
totalFiles,
|
|
31
|
+
};
|
|
32
|
+
},
|
|
33
|
+
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase: processes
|
|
3
|
+
*
|
|
4
|
+
* Detects execution flows (processes) and creates Process nodes +
|
|
5
|
+
* STEP_IN_PROCESS edges. Also links Route/Tool nodes to processes.
|
|
6
|
+
*
|
|
7
|
+
* @deps communities, routes, tools
|
|
8
|
+
* @reads graph (all nodes and relationships), communityResult, routeRegistry, toolDefs
|
|
9
|
+
* @writes graph (Process nodes, STEP_IN_PROCESS edges, ENTRY_POINT_OF edges)
|
|
10
|
+
*/
|
|
11
|
+
import type { PipelinePhase } from './types.js';
|
|
12
|
+
import { type ProcessDetectionResult } from '../process-processor.js';
|
|
13
|
+
export interface ProcessesOutput {
|
|
14
|
+
processResult: ProcessDetectionResult;
|
|
15
|
+
}
|
|
16
|
+
export declare const processesPhase: PipelinePhase<ProcessesOutput>;
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase: processes
|
|
3
|
+
*
|
|
4
|
+
* Detects execution flows (processes) and creates Process nodes +
|
|
5
|
+
* STEP_IN_PROCESS edges. Also links Route/Tool nodes to processes.
|
|
6
|
+
*
|
|
7
|
+
* @deps communities, routes, tools
|
|
8
|
+
* @reads graph (all nodes and relationships), communityResult, routeRegistry, toolDefs
|
|
9
|
+
* @writes graph (Process nodes, STEP_IN_PROCESS edges, ENTRY_POINT_OF edges)
|
|
10
|
+
*/
|
|
11
|
+
import { getPhaseOutput } from './types.js';
|
|
12
|
+
import { processProcesses } from '../process-processor.js';
|
|
13
|
+
import { generateId } from '../../../lib/utils.js';
|
|
14
|
+
import { isDev } from '../utils/env.js';
|
|
15
|
+
export const processesPhase = {
|
|
16
|
+
name: 'processes',
|
|
17
|
+
// `structure` supplies `totalFiles` (progress counter) without the spurious
|
|
18
|
+
// structural data dependency on `parse`.
|
|
19
|
+
deps: ['communities', 'routes', 'tools', 'structure'],
|
|
20
|
+
async execute(ctx, deps) {
|
|
21
|
+
const { totalFiles } = getPhaseOutput(deps, 'structure');
|
|
22
|
+
const { communityResult } = getPhaseOutput(deps, 'communities');
|
|
23
|
+
const { routeRegistry } = getPhaseOutput(deps, 'routes');
|
|
24
|
+
const { toolDefs } = getPhaseOutput(deps, 'tools');
|
|
25
|
+
ctx.onProgress({
|
|
26
|
+
phase: 'processes',
|
|
27
|
+
percent: 94,
|
|
28
|
+
message: 'Detecting execution flows...',
|
|
29
|
+
stats: { filesProcessed: totalFiles, totalFiles, nodesCreated: ctx.graph.nodeCount },
|
|
30
|
+
});
|
|
31
|
+
let symbolCount = 0;
|
|
32
|
+
ctx.graph.forEachNode((n) => {
|
|
33
|
+
if (n.label !== 'File')
|
|
34
|
+
symbolCount++;
|
|
35
|
+
});
|
|
36
|
+
const dynamicMaxProcesses = Math.max(20, Math.min(300, Math.round(symbolCount / 10)));
|
|
37
|
+
const processResult = await processProcesses(ctx.graph, communityResult.memberships, (message, progress) => {
|
|
38
|
+
const processProgress = 94 + progress * 0.05;
|
|
39
|
+
ctx.onProgress({
|
|
40
|
+
phase: 'processes',
|
|
41
|
+
percent: Math.round(processProgress),
|
|
42
|
+
message,
|
|
43
|
+
stats: { filesProcessed: totalFiles, totalFiles, nodesCreated: ctx.graph.nodeCount },
|
|
44
|
+
});
|
|
45
|
+
}, { maxProcesses: dynamicMaxProcesses, minSteps: 3 });
|
|
46
|
+
if (isDev) {
|
|
47
|
+
console.log(`🔄 Process detection: ${processResult.stats.totalProcesses} processes found (${processResult.stats.crossCommunityCount} cross-community)`);
|
|
48
|
+
}
|
|
49
|
+
processResult.processes.forEach((proc) => {
|
|
50
|
+
ctx.graph.addNode({
|
|
51
|
+
id: proc.id,
|
|
52
|
+
label: 'Process',
|
|
53
|
+
properties: {
|
|
54
|
+
name: proc.label,
|
|
55
|
+
filePath: '',
|
|
56
|
+
heuristicLabel: proc.heuristicLabel,
|
|
57
|
+
processType: proc.processType,
|
|
58
|
+
stepCount: proc.stepCount,
|
|
59
|
+
communities: proc.communities,
|
|
60
|
+
entryPointId: proc.entryPointId,
|
|
61
|
+
terminalId: proc.terminalId,
|
|
62
|
+
},
|
|
63
|
+
});
|
|
64
|
+
});
|
|
65
|
+
processResult.steps.forEach((step) => {
|
|
66
|
+
ctx.graph.addRelationship({
|
|
67
|
+
id: `${step.nodeId}_step_${step.step}_${step.processId}`,
|
|
68
|
+
type: 'STEP_IN_PROCESS',
|
|
69
|
+
sourceId: step.nodeId,
|
|
70
|
+
targetId: step.processId,
|
|
71
|
+
confidence: 1.0,
|
|
72
|
+
reason: 'trace-detection',
|
|
73
|
+
step: step.step,
|
|
74
|
+
});
|
|
75
|
+
});
|
|
76
|
+
// Link Route and Tool nodes to Processes
|
|
77
|
+
if (routeRegistry.size > 0 || toolDefs.length > 0) {
|
|
78
|
+
const routesByFile = new Map();
|
|
79
|
+
for (const [url, entry] of routeRegistry) {
|
|
80
|
+
let list = routesByFile.get(entry.filePath);
|
|
81
|
+
if (!list) {
|
|
82
|
+
list = [];
|
|
83
|
+
routesByFile.set(entry.filePath, list);
|
|
84
|
+
}
|
|
85
|
+
list.push(url);
|
|
86
|
+
}
|
|
87
|
+
const toolsByFile = new Map();
|
|
88
|
+
for (const td of toolDefs) {
|
|
89
|
+
let list = toolsByFile.get(td.filePath);
|
|
90
|
+
if (!list) {
|
|
91
|
+
list = [];
|
|
92
|
+
toolsByFile.set(td.filePath, list);
|
|
93
|
+
}
|
|
94
|
+
list.push(td.name);
|
|
95
|
+
}
|
|
96
|
+
let linked = 0;
|
|
97
|
+
for (const proc of processResult.processes) {
|
|
98
|
+
if (!proc.entryPointId)
|
|
99
|
+
continue;
|
|
100
|
+
const entryNode = ctx.graph.getNode(proc.entryPointId);
|
|
101
|
+
if (!entryNode)
|
|
102
|
+
continue;
|
|
103
|
+
const entryFile = entryNode.properties.filePath;
|
|
104
|
+
if (!entryFile)
|
|
105
|
+
continue;
|
|
106
|
+
const routeURLs = routesByFile.get(entryFile);
|
|
107
|
+
if (routeURLs) {
|
|
108
|
+
for (const routeURL of routeURLs) {
|
|
109
|
+
const routeNodeId = generateId('Route', routeURL);
|
|
110
|
+
ctx.graph.addRelationship({
|
|
111
|
+
id: generateId('ENTRY_POINT_OF', `${routeNodeId}->${proc.id}`),
|
|
112
|
+
sourceId: routeNodeId,
|
|
113
|
+
targetId: proc.id,
|
|
114
|
+
type: 'ENTRY_POINT_OF',
|
|
115
|
+
confidence: 0.85,
|
|
116
|
+
reason: 'route-handler-entry-point',
|
|
117
|
+
});
|
|
118
|
+
linked++;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
const toolNames = toolsByFile.get(entryFile);
|
|
122
|
+
if (toolNames) {
|
|
123
|
+
for (const toolName of toolNames) {
|
|
124
|
+
const toolNodeId = generateId('Tool', toolName);
|
|
125
|
+
ctx.graph.addRelationship({
|
|
126
|
+
id: generateId('ENTRY_POINT_OF', `${toolNodeId}->${proc.id}`),
|
|
127
|
+
sourceId: toolNodeId,
|
|
128
|
+
targetId: proc.id,
|
|
129
|
+
type: 'ENTRY_POINT_OF',
|
|
130
|
+
confidence: 0.85,
|
|
131
|
+
reason: 'tool-handler-entry-point',
|
|
132
|
+
});
|
|
133
|
+
linked++;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
if (isDev && linked > 0) {
|
|
138
|
+
console.log(`🔗 Linked ${linked} Route/Tool nodes to execution flows`);
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
return { processResult };
|
|
142
|
+
},
|
|
143
|
+
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase: routes
|
|
3
|
+
*
|
|
4
|
+
* Builds the route registry (Next.js, Expo, PHP, Laravel, decorator-based)
|
|
5
|
+
* and creates Route graph nodes + HANDLES_ROUTE edges.
|
|
6
|
+
* Also links middleware, processes fetch() calls, and scans HTML templates.
|
|
7
|
+
*
|
|
8
|
+
* @deps parse
|
|
9
|
+
* @reads allPaths, allExtractedRoutes, allDecoratorRoutes, allFetchCalls
|
|
10
|
+
* @writes graph (Route nodes, HANDLES_ROUTE, FETCHES_FROM edges)
|
|
11
|
+
* @output routeRegistry, handlerContents
|
|
12
|
+
*/
|
|
13
|
+
import type { PipelinePhase } from './types.js';
|
|
14
|
+
export interface RouteEntry {
|
|
15
|
+
filePath: string;
|
|
16
|
+
source: string;
|
|
17
|
+
}
|
|
18
|
+
export interface RoutesOutput {
|
|
19
|
+
routeRegistry: Map<string, RouteEntry>;
|
|
20
|
+
}
|
|
21
|
+
export declare const routesPhase: PipelinePhase<RoutesOutput>;
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Phase: routes
|
|
3
|
+
*
|
|
4
|
+
* Builds the route registry (Next.js, Expo, PHP, Laravel, decorator-based)
|
|
5
|
+
* and creates Route graph nodes + HANDLES_ROUTE edges.
|
|
6
|
+
* Also links middleware, processes fetch() calls, and scans HTML templates.
|
|
7
|
+
*
|
|
8
|
+
* @deps parse
|
|
9
|
+
* @reads allPaths, allExtractedRoutes, allDecoratorRoutes, allFetchCalls
|
|
10
|
+
* @writes graph (Route nodes, HANDLES_ROUTE, FETCHES_FROM edges)
|
|
11
|
+
* @output routeRegistry, handlerContents
|
|
12
|
+
*/
|
|
13
|
+
import { getPhaseOutput } from './types.js';
|
|
14
|
+
import { nextjsFileToRouteURL, normalizeFetchURL } from '../route-extractors/nextjs.js';
|
|
15
|
+
import { expoFileToRouteURL } from '../route-extractors/expo.js';
|
|
16
|
+
import { phpFileToRouteURL } from '../route-extractors/php.js';
|
|
17
|
+
import { extractResponseShapes, extractPHPResponseShapes, } from '../route-extractors/response-shapes.js';
|
|
18
|
+
import { extractMiddlewareChain, extractNextjsMiddlewareConfig, compileMatcher, compiledMatcherMatchesRoute, } from '../route-extractors/middleware.js';
|
|
19
|
+
import { processNextjsFetchRoutes } from '../call-processor.js';
|
|
20
|
+
import { generateId } from '../../../lib/utils.js';
|
|
21
|
+
import { readFileContents } from '../filesystem-walker.js';
|
|
22
|
+
import { isDev } from '../utils/env.js';
|
|
23
|
+
const EXPO_NAV_PATTERNS = [
|
|
24
|
+
/router\.(push|replace|navigate)\(\s*['"`]([^'"`]+)['"`]/g,
|
|
25
|
+
/<Link\s+[^>]*href=\s*['"`]([^'"`]+)['"`]/g,
|
|
26
|
+
];
|
|
27
|
+
export const routesPhase = {
|
|
28
|
+
name: 'routes',
|
|
29
|
+
deps: ['parse'],
|
|
30
|
+
async execute(ctx, deps) {
|
|
31
|
+
const { allPaths, allFetchCalls: parseFetchCalls, allExtractedRoutes, allDecoratorRoutes, } = getPhaseOutput(deps, 'parse');
|
|
32
|
+
// Local copy — routes phase must not mutate upstream ParseOutput
|
|
33
|
+
const allFetchCalls = [...parseFetchCalls];
|
|
34
|
+
const routeRegistry = new Map();
|
|
35
|
+
// Detect Expo Router app/ roots vs Next.js app/ roots (monorepo-safe)
|
|
36
|
+
const expoAppRoots = new Set();
|
|
37
|
+
const nextjsAppRoots = new Set();
|
|
38
|
+
const expoAppPaths = new Set();
|
|
39
|
+
for (const p of allPaths) {
|
|
40
|
+
const norm = p.replace(/\\/g, '/');
|
|
41
|
+
const appIdx = norm.lastIndexOf('app/');
|
|
42
|
+
if (appIdx < 0)
|
|
43
|
+
continue;
|
|
44
|
+
const root = norm.slice(0, appIdx + 4);
|
|
45
|
+
if (/\/_layout\.(tsx?|jsx?)$/.test(norm))
|
|
46
|
+
expoAppRoots.add(root);
|
|
47
|
+
if (/\/page\.(tsx?|jsx?)$/.test(norm))
|
|
48
|
+
nextjsAppRoots.add(root);
|
|
49
|
+
}
|
|
50
|
+
for (const root of nextjsAppRoots)
|
|
51
|
+
expoAppRoots.delete(root);
|
|
52
|
+
if (expoAppRoots.size > 0) {
|
|
53
|
+
for (const p of allPaths) {
|
|
54
|
+
const norm = p.replace(/\\/g, '/');
|
|
55
|
+
const appIdx = norm.lastIndexOf('app/');
|
|
56
|
+
if (appIdx >= 0 && expoAppRoots.has(norm.slice(0, appIdx + 4)))
|
|
57
|
+
expoAppPaths.add(p);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
for (const p of allPaths) {
|
|
61
|
+
if (expoAppPaths.has(p)) {
|
|
62
|
+
const expoURL = expoFileToRouteURL(p);
|
|
63
|
+
if (expoURL && !routeRegistry.has(expoURL)) {
|
|
64
|
+
routeRegistry.set(expoURL, { filePath: p, source: 'expo-filesystem-route' });
|
|
65
|
+
continue;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
const nextjsURL = nextjsFileToRouteURL(p);
|
|
69
|
+
if (nextjsURL && !routeRegistry.has(nextjsURL)) {
|
|
70
|
+
routeRegistry.set(nextjsURL, { filePath: p, source: 'nextjs-filesystem-route' });
|
|
71
|
+
continue;
|
|
72
|
+
}
|
|
73
|
+
if (p.endsWith('.php')) {
|
|
74
|
+
const phpURL = phpFileToRouteURL(p);
|
|
75
|
+
if (phpURL && !routeRegistry.has(phpURL)) {
|
|
76
|
+
routeRegistry.set(phpURL, { filePath: p, source: 'php-file-route' });
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
const ensureSlash = (path) => (path.startsWith('/') ? path : '/' + path);
|
|
81
|
+
let duplicateRoutes = 0;
|
|
82
|
+
const addRoute = (url, entry) => {
|
|
83
|
+
if (routeRegistry.has(url)) {
|
|
84
|
+
duplicateRoutes++;
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
routeRegistry.set(url, entry);
|
|
88
|
+
};
|
|
89
|
+
for (const route of allExtractedRoutes) {
|
|
90
|
+
if (!route.routePath)
|
|
91
|
+
continue;
|
|
92
|
+
addRoute(ensureSlash(route.routePath), {
|
|
93
|
+
filePath: route.filePath,
|
|
94
|
+
source: 'framework-route',
|
|
95
|
+
});
|
|
96
|
+
}
|
|
97
|
+
for (const dr of allDecoratorRoutes) {
|
|
98
|
+
addRoute(ensureSlash(dr.routePath), {
|
|
99
|
+
filePath: dr.filePath,
|
|
100
|
+
source: `decorator-${dr.decoratorName}`,
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
let handlerContents;
|
|
104
|
+
if (routeRegistry.size > 0) {
|
|
105
|
+
const handlerPaths = [...routeRegistry.values()].map((e) => e.filePath);
|
|
106
|
+
handlerContents = await readFileContents(ctx.repoPath, handlerPaths);
|
|
107
|
+
for (const [routeURL, entry] of routeRegistry) {
|
|
108
|
+
const { filePath: handlerPath, source: routeSource } = entry;
|
|
109
|
+
const content = handlerContents.get(handlerPath);
|
|
110
|
+
const { responseKeys, errorKeys } = content
|
|
111
|
+
? handlerPath.endsWith('.php')
|
|
112
|
+
? extractPHPResponseShapes(content)
|
|
113
|
+
: extractResponseShapes(content)
|
|
114
|
+
: { responseKeys: undefined, errorKeys: undefined };
|
|
115
|
+
const mwResult = content ? extractMiddlewareChain(content) : undefined;
|
|
116
|
+
const middleware = mwResult?.chain;
|
|
117
|
+
const routeNodeId = generateId('Route', routeURL);
|
|
118
|
+
ctx.graph.addNode({
|
|
119
|
+
id: routeNodeId,
|
|
120
|
+
label: 'Route',
|
|
121
|
+
properties: {
|
|
122
|
+
name: routeURL,
|
|
123
|
+
filePath: handlerPath,
|
|
124
|
+
...(responseKeys ? { responseKeys } : {}),
|
|
125
|
+
...(errorKeys ? { errorKeys } : {}),
|
|
126
|
+
...(middleware && middleware.length > 0 ? { middleware } : {}),
|
|
127
|
+
},
|
|
128
|
+
});
|
|
129
|
+
const handlerFileId = generateId('File', handlerPath);
|
|
130
|
+
ctx.graph.addRelationship({
|
|
131
|
+
id: generateId('HANDLES_ROUTE', `${handlerFileId}->${routeNodeId}`),
|
|
132
|
+
sourceId: handlerFileId,
|
|
133
|
+
targetId: routeNodeId,
|
|
134
|
+
type: 'HANDLES_ROUTE',
|
|
135
|
+
confidence: 1.0,
|
|
136
|
+
reason: routeSource,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
if (isDev) {
|
|
140
|
+
console.log(`🗺️ Route registry: ${routeRegistry.size} routes${duplicateRoutes > 0 ? ` (${duplicateRoutes} duplicate URLs skipped)` : ''}`);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
// ── Link Next.js project-level middleware.ts to routes ──
|
|
144
|
+
if (routeRegistry.size > 0) {
|
|
145
|
+
const middlewareCandidates = allPaths.filter((p) => p === 'middleware.ts' ||
|
|
146
|
+
p === 'middleware.js' ||
|
|
147
|
+
p === 'middleware.tsx' ||
|
|
148
|
+
p === 'middleware.jsx' ||
|
|
149
|
+
p === 'src/middleware.ts' ||
|
|
150
|
+
p === 'src/middleware.js' ||
|
|
151
|
+
p === 'src/middleware.tsx' ||
|
|
152
|
+
p === 'src/middleware.jsx');
|
|
153
|
+
if (middlewareCandidates.length > 0) {
|
|
154
|
+
const mwContents = await readFileContents(ctx.repoPath, middlewareCandidates);
|
|
155
|
+
for (const [mwPath, mwContent] of mwContents) {
|
|
156
|
+
const config = extractNextjsMiddlewareConfig(mwContent);
|
|
157
|
+
if (!config)
|
|
158
|
+
continue;
|
|
159
|
+
const mwLabel = config.wrappedFunctions.length > 0 ? config.wrappedFunctions : [config.exportedName];
|
|
160
|
+
const compiled = config.matchers
|
|
161
|
+
.map(compileMatcher)
|
|
162
|
+
.filter((m) => m !== null);
|
|
163
|
+
let linkedCount = 0;
|
|
164
|
+
for (const [routeURL] of routeRegistry) {
|
|
165
|
+
const matches = compiled.length === 0 ||
|
|
166
|
+
compiled.some((cm) => compiledMatcherMatchesRoute(cm, routeURL));
|
|
167
|
+
if (!matches)
|
|
168
|
+
continue;
|
|
169
|
+
const routeNodeId = generateId('Route', routeURL);
|
|
170
|
+
const existing = ctx.graph.getNode(routeNodeId);
|
|
171
|
+
if (!existing)
|
|
172
|
+
continue;
|
|
173
|
+
const currentMw = existing.properties.middleware ?? [];
|
|
174
|
+
existing.properties.middleware = [
|
|
175
|
+
...mwLabel,
|
|
176
|
+
...currentMw.filter((m) => !mwLabel.includes(m)),
|
|
177
|
+
];
|
|
178
|
+
linkedCount++;
|
|
179
|
+
}
|
|
180
|
+
if (isDev && linkedCount > 0) {
|
|
181
|
+
console.log(`🛡️ Linked ${mwPath} middleware [${mwLabel.join(', ')}] to ${linkedCount} routes`);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
// Scan HTML/template files for form action and AJAX url patterns
|
|
187
|
+
const htmlCandidates = allPaths.filter((p) => p.endsWith('.html') ||
|
|
188
|
+
p.endsWith('.htm') ||
|
|
189
|
+
p.endsWith('.ejs') ||
|
|
190
|
+
p.endsWith('.hbs') ||
|
|
191
|
+
p.endsWith('.blade.php'));
|
|
192
|
+
if (htmlCandidates.length > 0 && routeRegistry.size > 0) {
|
|
193
|
+
const htmlContents = await readFileContents(ctx.repoPath, htmlCandidates);
|
|
194
|
+
const htmlPatterns = [/action=["']([^"']+)["']/g, /url:\s*["']([^"']+)["']/g];
|
|
195
|
+
for (const [filePath, content] of htmlContents) {
|
|
196
|
+
for (const pattern of htmlPatterns) {
|
|
197
|
+
pattern.lastIndex = 0;
|
|
198
|
+
let match;
|
|
199
|
+
while ((match = pattern.exec(content)) !== null) {
|
|
200
|
+
const normalized = normalizeFetchURL(match[1]);
|
|
201
|
+
if (normalized) {
|
|
202
|
+
allFetchCalls.push({ filePath, fetchURL: normalized, lineNumber: 0 });
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
// ── Extract Expo Router navigation patterns ──
|
|
209
|
+
if (expoAppPaths.size > 0 && routeRegistry.size > 0) {
|
|
210
|
+
const unreadExpoPaths = [...expoAppPaths].filter((p) => !handlerContents?.has(p));
|
|
211
|
+
const extraContents = unreadExpoPaths.length > 0
|
|
212
|
+
? await readFileContents(ctx.repoPath, unreadExpoPaths)
|
|
213
|
+
: new Map();
|
|
214
|
+
const allExpoContents = new Map([...(handlerContents ?? new Map()), ...extraContents]);
|
|
215
|
+
for (const [filePath, content] of allExpoContents) {
|
|
216
|
+
if (!expoAppPaths.has(filePath))
|
|
217
|
+
continue;
|
|
218
|
+
for (const pattern of EXPO_NAV_PATTERNS) {
|
|
219
|
+
pattern.lastIndex = 0;
|
|
220
|
+
let match;
|
|
221
|
+
while ((match = pattern.exec(content)) !== null) {
|
|
222
|
+
const url = match[2] ?? match[1];
|
|
223
|
+
if (url && url.startsWith('/')) {
|
|
224
|
+
allFetchCalls.push({ filePath, fetchURL: url, lineNumber: 0 });
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
if (routeRegistry.size > 0 && allFetchCalls.length > 0) {
|
|
231
|
+
const routeURLToFile = new Map();
|
|
232
|
+
for (const [url, entry] of routeRegistry)
|
|
233
|
+
routeURLToFile.set(url, entry.filePath);
|
|
234
|
+
const consumerPaths = [...new Set(allFetchCalls.map((c) => c.filePath))];
|
|
235
|
+
const consumerContents = await readFileContents(ctx.repoPath, consumerPaths);
|
|
236
|
+
processNextjsFetchRoutes(ctx.graph, allFetchCalls, routeURLToFile, consumerContents);
|
|
237
|
+
if (isDev) {
|
|
238
|
+
console.log(`🔗 Processed ${allFetchCalls.length} fetch() calls against ${routeRegistry.size} routes`);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
return { routeRegistry };
|
|
242
|
+
},
|
|
243
|
+
};
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Pipeline Phase Runner
|
|
3
|
+
*
|
|
4
|
+
* Executes pipeline phases in dependency order using Kahn's topological sort.
|
|
5
|
+
* Each phase receives typed outputs from its upstream dependencies.
|
|
6
|
+
*
|
|
7
|
+
* The runner is intentionally simple:
|
|
8
|
+
* - No dynamic phase loading
|
|
9
|
+
* - No plugin system
|
|
10
|
+
* - Static phase graph, compile-time type safety
|
|
11
|
+
* - Sequential execution (parallel support is architecturally possible
|
|
12
|
+
* but most phases have linear dependencies)
|
|
13
|
+
*/
|
|
14
|
+
import type { PipelinePhase, PipelineContext, PhaseResult } from './types.js';
|
|
15
|
+
/**
|
|
16
|
+
* Execute a set of pipeline phases in dependency order.
|
|
17
|
+
*
|
|
18
|
+
* @param phases All phases to execute (order doesn't matter — sorted internally)
|
|
19
|
+
* @param ctx Shared pipeline context
|
|
20
|
+
* @returns Map of phase name → PhaseResult (all completed phases)
|
|
21
|
+
*/
|
|
22
|
+
export declare function runPipeline(phases: readonly PipelinePhase[], ctx: PipelineContext): Promise<ReadonlyMap<string, PhaseResult<unknown>>>;
|
|
@@ -0,0 +1,203 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Pipeline Phase Runner
|
|
3
|
+
*
|
|
4
|
+
* Executes pipeline phases in dependency order using Kahn's topological sort.
|
|
5
|
+
* Each phase receives typed outputs from its upstream dependencies.
|
|
6
|
+
*
|
|
7
|
+
* The runner is intentionally simple:
|
|
8
|
+
* - No dynamic phase loading
|
|
9
|
+
* - No plugin system
|
|
10
|
+
* - Static phase graph, compile-time type safety
|
|
11
|
+
* - Sequential execution (parallel support is architecturally possible
|
|
12
|
+
* but most phases have linear dependencies)
|
|
13
|
+
*/
|
|
14
|
+
import { isDev } from '../utils/env.js';
|
|
15
|
+
/**
|
|
16
|
+
* Validate that the phases form a valid dependency graph (no cycles, all deps present).
|
|
17
|
+
* Returns phases in topological execution order.
|
|
18
|
+
*/
|
|
19
|
+
function topologicalSort(phases) {
|
|
20
|
+
const phaseMap = new Map();
|
|
21
|
+
for (const phase of phases) {
|
|
22
|
+
if (phaseMap.has(phase.name)) {
|
|
23
|
+
throw new Error(`Duplicate phase name: '${phase.name}'`);
|
|
24
|
+
}
|
|
25
|
+
phaseMap.set(phase.name, phase);
|
|
26
|
+
}
|
|
27
|
+
// Validate all deps exist
|
|
28
|
+
for (const phase of phases) {
|
|
29
|
+
for (const dep of phase.deps) {
|
|
30
|
+
if (!phaseMap.has(dep)) {
|
|
31
|
+
throw new Error(`Phase '${phase.name}' depends on '${dep}', which is not registered`);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
// Kahn's algorithm
|
|
36
|
+
const inDegree = new Map();
|
|
37
|
+
const reverseDeps = new Map();
|
|
38
|
+
for (const phase of phases) {
|
|
39
|
+
inDegree.set(phase.name, phase.deps.length);
|
|
40
|
+
for (const dep of phase.deps) {
|
|
41
|
+
let rev = reverseDeps.get(dep);
|
|
42
|
+
if (!rev) {
|
|
43
|
+
rev = [];
|
|
44
|
+
reverseDeps.set(dep, rev);
|
|
45
|
+
}
|
|
46
|
+
rev.push(phase.name);
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
const sorted = [];
|
|
50
|
+
const queue = [...inDegree.entries()].filter(([, d]) => d === 0).map(([name]) => name);
|
|
51
|
+
while (queue.length > 0) {
|
|
52
|
+
const name = queue.shift();
|
|
53
|
+
sorted.push(phaseMap.get(name));
|
|
54
|
+
for (const dependent of reverseDeps.get(name) ?? []) {
|
|
55
|
+
const newDeg = (inDegree.get(dependent) ?? 1) - 1;
|
|
56
|
+
inDegree.set(dependent, newDeg);
|
|
57
|
+
if (newDeg === 0)
|
|
58
|
+
queue.push(dependent);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
if (sorted.length !== phases.length) {
|
|
62
|
+
const remaining = new Set([...inDegree.entries()].filter(([, d]) => d > 0).map(([name]) => name));
|
|
63
|
+
const cyclePath = findCyclePath(remaining, phaseMap);
|
|
64
|
+
const dependentsBlocked = remaining.size - new Set(cyclePath).size;
|
|
65
|
+
let message = `Cycle detected in pipeline phases: ${cyclePath.join(' -> ')}`;
|
|
66
|
+
if (dependentsBlocked > 0) {
|
|
67
|
+
message += ` (and ${dependentsBlocked} transitive dependent${dependentsBlocked === 1 ? '' : 's'} blocked)`;
|
|
68
|
+
}
|
|
69
|
+
throw new Error(message);
|
|
70
|
+
}
|
|
71
|
+
return sorted;
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Find a concrete cycle path among the phases that Kahn's algorithm could not drain.
|
|
75
|
+
*
|
|
76
|
+
* Kahn's leftovers include both true cycle members AND phases transitively dependent
|
|
77
|
+
* on them. To produce an actionable error message, we DFS over the leftovers (using
|
|
78
|
+
* each leftover's `deps` as edges) until we hit a back-edge — that closes the cycle.
|
|
79
|
+
* The returned list is the cycle in order with the entry node repeated at the end:
|
|
80
|
+
* `[A, B, C, A]` for `A -> B -> C -> A`.
|
|
81
|
+
*
|
|
82
|
+
* Falls back to the raw remaining set (sorted) if no back-edge is found, which
|
|
83
|
+
* should be unreachable but keeps the error informative.
|
|
84
|
+
*/
|
|
85
|
+
function findCyclePath(remaining, phaseMap) {
|
|
86
|
+
for (const start of remaining) {
|
|
87
|
+
const stack = [];
|
|
88
|
+
const onStack = new Set();
|
|
89
|
+
const visited = new Set();
|
|
90
|
+
const dfs = (name) => {
|
|
91
|
+
stack.push(name);
|
|
92
|
+
onStack.add(name);
|
|
93
|
+
visited.add(name);
|
|
94
|
+
const phase = phaseMap.get(name);
|
|
95
|
+
if (phase) {
|
|
96
|
+
for (const dep of phase.deps) {
|
|
97
|
+
if (!remaining.has(dep))
|
|
98
|
+
continue; // dep already drained — not part of cycle
|
|
99
|
+
if (onStack.has(dep)) {
|
|
100
|
+
// Back-edge — slice from the first occurrence of `dep` and close the loop.
|
|
101
|
+
const cycleStart = stack.indexOf(dep);
|
|
102
|
+
return [...stack.slice(cycleStart), dep];
|
|
103
|
+
}
|
|
104
|
+
if (!visited.has(dep)) {
|
|
105
|
+
const found = dfs(dep);
|
|
106
|
+
if (found)
|
|
107
|
+
return found;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
stack.pop();
|
|
112
|
+
onStack.delete(name);
|
|
113
|
+
return null;
|
|
114
|
+
};
|
|
115
|
+
const cycle = dfs(start);
|
|
116
|
+
if (cycle)
|
|
117
|
+
return cycle;
|
|
118
|
+
}
|
|
119
|
+
// Unreachable in practice (Kahn proved a cycle exists), but stay defensive.
|
|
120
|
+
return [...remaining].sort();
|
|
121
|
+
}
|
|
122
|
+
/**
|
|
123
|
+
* Execute a set of pipeline phases in dependency order.
|
|
124
|
+
*
|
|
125
|
+
* @param phases All phases to execute (order doesn't matter — sorted internally)
|
|
126
|
+
* @param ctx Shared pipeline context
|
|
127
|
+
* @returns Map of phase name → PhaseResult (all completed phases)
|
|
128
|
+
*/
|
|
129
|
+
export async function runPipeline(phases, ctx) {
|
|
130
|
+
let sorted;
|
|
131
|
+
try {
|
|
132
|
+
sorted = topologicalSort(phases);
|
|
133
|
+
}
|
|
134
|
+
catch (err) {
|
|
135
|
+
// Emit a terminal 'error' progress event for graph-validation failures
|
|
136
|
+
// (cycle detected, duplicate phase, missing dep) so CLI/MCP consumers see
|
|
137
|
+
// the failure before the rejection propagates. Symmetric with the
|
|
138
|
+
// per-phase error path below. Best-effort: a throwing handler must not
|
|
139
|
+
// mask the underlying validation error.
|
|
140
|
+
const message = err instanceof Error ? err.message : String(err);
|
|
141
|
+
try {
|
|
142
|
+
ctx.onProgress({
|
|
143
|
+
phase: 'error',
|
|
144
|
+
percent: 100,
|
|
145
|
+
message: 'Pipeline graph validation failed',
|
|
146
|
+
detail: message,
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
catch {
|
|
150
|
+
// Swallow handler errors — preserving the original cause is more important.
|
|
151
|
+
}
|
|
152
|
+
throw err;
|
|
153
|
+
}
|
|
154
|
+
const results = new Map();
|
|
155
|
+
for (const phase of sorted) {
|
|
156
|
+
const start = Date.now();
|
|
157
|
+
if (isDev) {
|
|
158
|
+
console.log(`▶ Phase: ${phase.name}`);
|
|
159
|
+
}
|
|
160
|
+
// Only expose declared dependencies — prevents hidden coupling to undeclared phases.
|
|
161
|
+
const declaredDeps = new Map();
|
|
162
|
+
for (const depName of phase.deps) {
|
|
163
|
+
const depResult = results.get(depName);
|
|
164
|
+
if (depResult)
|
|
165
|
+
declaredDeps.set(depName, depResult);
|
|
166
|
+
}
|
|
167
|
+
let output;
|
|
168
|
+
try {
|
|
169
|
+
output = await phase.execute(ctx, declaredDeps);
|
|
170
|
+
}
|
|
171
|
+
catch (err) {
|
|
172
|
+
const originalMessage = err instanceof Error ? err.message : String(err);
|
|
173
|
+
const wrapped = new Error(`Phase '${phase.name}' failed: ${originalMessage}`, {
|
|
174
|
+
cause: err,
|
|
175
|
+
});
|
|
176
|
+
// Emit a terminal 'error' progress event so CLI/MCP consumers see the failure
|
|
177
|
+
// before the rejection propagates. Best-effort: a throwing handler must not
|
|
178
|
+
// mask the underlying phase error.
|
|
179
|
+
try {
|
|
180
|
+
ctx.onProgress({
|
|
181
|
+
phase: 'error',
|
|
182
|
+
percent: 100,
|
|
183
|
+
message: `Phase '${phase.name}' failed`,
|
|
184
|
+
detail: originalMessage,
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
catch {
|
|
188
|
+
// Swallow handler errors — preserving the original cause is more important.
|
|
189
|
+
}
|
|
190
|
+
throw wrapped;
|
|
191
|
+
}
|
|
192
|
+
const durationMs = Date.now() - start;
|
|
193
|
+
results.set(phase.name, {
|
|
194
|
+
phaseName: phase.name,
|
|
195
|
+
output,
|
|
196
|
+
durationMs,
|
|
197
|
+
});
|
|
198
|
+
if (isDev) {
|
|
199
|
+
console.log(`✓ Phase: ${phase.name} (${durationMs}ms)`);
|
|
200
|
+
}
|
|
201
|
+
}
|
|
202
|
+
return results;
|
|
203
|
+
}
|