@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,40 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CLI commands for the Phase 4 versioned graph store.
|
|
3
|
+
*
|
|
4
|
+
* Read-only surface so far: `codragraph log`, `codragraph branch list`,
|
|
5
|
+
* `codragraph diff <from> <to>`. The mutating commands (`commit`,
|
|
6
|
+
* `branch <name>`, `checkout`) are scoped for Phase 4.5 — `commit` and
|
|
7
|
+
* branch creation already happen implicitly inside `codragraph analyze`,
|
|
8
|
+
* so the read-only commands are enough to inspect what landed.
|
|
9
|
+
*/
|
|
10
|
+
import { DEFAULT_BRANCH } from '@codragraph/graphstore';
|
|
11
|
+
export declare const logCommand: (opts?: {
|
|
12
|
+
limit?: string;
|
|
13
|
+
}) => Promise<void>;
|
|
14
|
+
export declare const branchListCommand: () => Promise<void>;
|
|
15
|
+
export declare const diffCommand: (from: string, to: string) => Promise<void>;
|
|
16
|
+
export declare const commitCommand: (opts?: {
|
|
17
|
+
message?: string;
|
|
18
|
+
}) => Promise<void>;
|
|
19
|
+
export declare const branchCreateCommand: (name: string, opts?: {
|
|
20
|
+
from?: string;
|
|
21
|
+
}) => Promise<void>;
|
|
22
|
+
export declare const checkoutCommand: (target: string, opts?: {
|
|
23
|
+
materialize?: boolean;
|
|
24
|
+
}) => Promise<void>;
|
|
25
|
+
export declare const materializeCommand: (target: string, opts: {
|
|
26
|
+
into: string;
|
|
27
|
+
}) => Promise<void>;
|
|
28
|
+
export declare const blameCommand: (symbolId: string, opts?: {
|
|
29
|
+
table?: string;
|
|
30
|
+
limit?: string;
|
|
31
|
+
}) => Promise<void>;
|
|
32
|
+
export declare const branchDeleteCommand: (name: string) => Promise<void>;
|
|
33
|
+
export declare const mergeCommand: (target: string, opts?: {
|
|
34
|
+
message?: string;
|
|
35
|
+
}) => Promise<void>;
|
|
36
|
+
export declare const gcCommand: (opts?: {
|
|
37
|
+
dryRun?: boolean;
|
|
38
|
+
}) => Promise<void>;
|
|
39
|
+
export declare const diffSemanticCommand: (from: string, to: string) => Promise<void>;
|
|
40
|
+
export { DEFAULT_BRANCH };
|
|
@@ -0,0 +1,639 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* CLI commands for the Phase 4 versioned graph store.
|
|
3
|
+
*
|
|
4
|
+
* Read-only surface so far: `codragraph log`, `codragraph branch list`,
|
|
5
|
+
* `codragraph diff <from> <to>`. The mutating commands (`commit`,
|
|
6
|
+
* `branch <name>`, `checkout`) are scoped for Phase 4.5 — `commit` and
|
|
7
|
+
* branch creation already happen implicitly inside `codragraph analyze`,
|
|
8
|
+
* so the read-only commands are enough to inspect what landed.
|
|
9
|
+
*/
|
|
10
|
+
import path from 'node:path';
|
|
11
|
+
import fs from 'node:fs/promises';
|
|
12
|
+
import { FsCAS, createBranch, createCommit, DEFAULT_BRANCH, deleteBranch, diffSemantic, diffSnapshots, gc as runGc, getJson, listBranches, materializeSnapshot, parseObjectId, readCommit, readHead, resolveHeadCommit, setHead, threeWayMerge, walkCommits, writeHeadBranch, writeHeadDetached, } from '@codragraph/graphstore';
|
|
13
|
+
import { findRepo, loadMeta, saveMeta } from '../storage/repo-manager.js';
|
|
14
|
+
import { GRAPHSTORE_SUBDIR } from '../core/graphstore/index.js';
|
|
15
|
+
import { initLbug, closeLbug } from '../core/lbug/lbug-adapter.js';
|
|
16
|
+
import { recordAnalysisSnapshot } from '../core/graphstore/index.js';
|
|
17
|
+
import { getCurrentCommit, hasGitDir } from '../storage/git.js';
|
|
18
|
+
const resolveGraphstore = async (cwd) => {
|
|
19
|
+
const repo = await findRepo(cwd);
|
|
20
|
+
if (!repo) {
|
|
21
|
+
throw new Error(`No CodraGraph index found at or above ${cwd}. Run \`codragraph analyze\` first.`);
|
|
22
|
+
}
|
|
23
|
+
const graphstoreRoot = path.join(repo.storagePath, GRAPHSTORE_SUBDIR);
|
|
24
|
+
return {
|
|
25
|
+
repoPath: repo.repoPath,
|
|
26
|
+
graphstoreRoot,
|
|
27
|
+
cas: new FsCAS({ root: graphstoreRoot }),
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Resolve a user-supplied target (branch name or commit id) into a commit id.
|
|
32
|
+
* Path: branch ref first, fall back to literal commit id parsing.
|
|
33
|
+
*/
|
|
34
|
+
const resolveCommitTarget = async (ctx, target) => {
|
|
35
|
+
// Branch ref?
|
|
36
|
+
const branches = await listBranches({ root: ctx.graphstoreRoot });
|
|
37
|
+
const match = branches.find((b) => b.name === target);
|
|
38
|
+
if (match)
|
|
39
|
+
return match.head;
|
|
40
|
+
// Otherwise treat as a literal commit id.
|
|
41
|
+
return parseObjectId(target);
|
|
42
|
+
};
|
|
43
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
44
|
+
// codragraph log
|
|
45
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
46
|
+
export const logCommand = async (opts = {}) => {
|
|
47
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
48
|
+
const head = await resolveHeadCommit({ root: ctx.graphstoreRoot });
|
|
49
|
+
if (head === null) {
|
|
50
|
+
console.error('No commits yet. Run `codragraph analyze` to create the first snapshot.');
|
|
51
|
+
process.exitCode = 1;
|
|
52
|
+
return;
|
|
53
|
+
}
|
|
54
|
+
const limit = opts.limit !== undefined ? Number.parseInt(opts.limit, 10) : 50;
|
|
55
|
+
const headState = await readHead({ root: ctx.graphstoreRoot });
|
|
56
|
+
if (headState.kind === 'branch') {
|
|
57
|
+
process.stdout.write(`On branch ${headState.branch}\n`);
|
|
58
|
+
}
|
|
59
|
+
else if (headState.kind === 'detached') {
|
|
60
|
+
process.stdout.write(`HEAD detached at ${headState.commit.slice(0, 19)}\n`);
|
|
61
|
+
}
|
|
62
|
+
for await (const entry of walkCommits({ cas: ctx.cas, from: head, limit })) {
|
|
63
|
+
const shortId = entry.id.slice(7, 7 + 12);
|
|
64
|
+
process.stdout.write(`${shortId} ${entry.commit.ts} ${entry.commit.author.name} ${entry.commit.message}\n`);
|
|
65
|
+
}
|
|
66
|
+
};
|
|
67
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
68
|
+
// codragraph branch [list]
|
|
69
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
70
|
+
export const branchListCommand = async () => {
|
|
71
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
72
|
+
const branches = await listBranches({ root: ctx.graphstoreRoot });
|
|
73
|
+
if (branches.length === 0) {
|
|
74
|
+
console.error('No branches yet. Run `codragraph analyze` to create the first snapshot.');
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
const headState = await readHead({ root: ctx.graphstoreRoot });
|
|
78
|
+
const currentBranch = headState.kind === 'branch' ? headState.branch : null;
|
|
79
|
+
for (const branch of branches) {
|
|
80
|
+
const marker = branch.name === currentBranch ? '*' : ' ';
|
|
81
|
+
process.stdout.write(`${marker} ${branch.name} ${branch.head.slice(7, 7 + 12)}\n`);
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
85
|
+
// codragraph diff <from> <to>
|
|
86
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
87
|
+
export const diffCommand = async (from, to) => {
|
|
88
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
89
|
+
const fromCommitId = await resolveCommitTarget(ctx, from);
|
|
90
|
+
const toCommitId = await resolveCommitTarget(ctx, to);
|
|
91
|
+
const fromCommit = await readCommit(ctx.cas, fromCommitId);
|
|
92
|
+
const toCommit = await readCommit(ctx.cas, toCommitId);
|
|
93
|
+
const diff = await diffSnapshots({
|
|
94
|
+
cas: ctx.cas,
|
|
95
|
+
from: fromCommit.snapshot,
|
|
96
|
+
to: toCommit.snapshot,
|
|
97
|
+
});
|
|
98
|
+
process.stdout.write(`From: ${fromCommitId.slice(7, 7 + 12)} ${fromCommit.message}\n`);
|
|
99
|
+
process.stdout.write(`To: ${toCommitId.slice(7, 7 + 12)} ${toCommit.message}\n\n`);
|
|
100
|
+
let totalAdded = 0;
|
|
101
|
+
let totalRemoved = 0;
|
|
102
|
+
for (const [table, ids] of Object.entries(diff.addedNodes)) {
|
|
103
|
+
if (ids.length === 0)
|
|
104
|
+
continue;
|
|
105
|
+
process.stdout.write(`+ ${table}: ${ids.length}\n`);
|
|
106
|
+
totalAdded += ids.length;
|
|
107
|
+
}
|
|
108
|
+
for (const [table, ids] of Object.entries(diff.removedNodes)) {
|
|
109
|
+
if (ids.length === 0)
|
|
110
|
+
continue;
|
|
111
|
+
process.stdout.write(`- ${table}: ${ids.length}\n`);
|
|
112
|
+
totalRemoved += ids.length;
|
|
113
|
+
}
|
|
114
|
+
if (diff.addedEdges.length > 0) {
|
|
115
|
+
process.stdout.write(`+ edges: ${diff.addedEdges.length}\n`);
|
|
116
|
+
}
|
|
117
|
+
if (diff.removedEdges.length > 0) {
|
|
118
|
+
process.stdout.write(`- edges: ${diff.removedEdges.length}\n`);
|
|
119
|
+
}
|
|
120
|
+
if (diff.modifiedSymbols.length > 0) {
|
|
121
|
+
process.stdout.write(`~ modified symbols: ${diff.modifiedSymbols.length}\n`);
|
|
122
|
+
for (const m of diff.modifiedSymbols.slice(0, 20)) {
|
|
123
|
+
process.stdout.write(` ${m.table} ${m.id}\n`);
|
|
124
|
+
}
|
|
125
|
+
if (diff.modifiedSymbols.length > 20) {
|
|
126
|
+
process.stdout.write(` … and ${diff.modifiedSymbols.length - 20} more\n`);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
if (totalAdded === 0 &&
|
|
130
|
+
totalRemoved === 0 &&
|
|
131
|
+
diff.addedEdges.length === 0 &&
|
|
132
|
+
diff.removedEdges.length === 0 &&
|
|
133
|
+
diff.modifiedSymbols.length === 0) {
|
|
134
|
+
process.stdout.write('(no graph changes)\n');
|
|
135
|
+
}
|
|
136
|
+
};
|
|
137
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
138
|
+
// codragraph commit -m <message>
|
|
139
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
140
|
+
//
|
|
141
|
+
// Re-snapshots the live LadybugDB and creates an explicit commit on top
|
|
142
|
+
// of the current branch. If the graph hasn't changed since the last
|
|
143
|
+
// snapshot the snapshot id is identical (canonical hashing) but the
|
|
144
|
+
// commit id differs because the message and timestamp diverge — useful
|
|
145
|
+
// as an explicit checkpoint marker (e.g. "before refactor").
|
|
146
|
+
export const commitCommand = async (opts = {}) => {
|
|
147
|
+
if (!opts.message || opts.message.trim() === '') {
|
|
148
|
+
console.error('Usage: codragraph commit -m <message>');
|
|
149
|
+
process.exitCode = 1;
|
|
150
|
+
return;
|
|
151
|
+
}
|
|
152
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
153
|
+
const repo = await findRepo(process.cwd());
|
|
154
|
+
if (!repo)
|
|
155
|
+
throw new Error('No CodraGraph index found');
|
|
156
|
+
await initLbug(repo.lbugPath);
|
|
157
|
+
try {
|
|
158
|
+
const result = await recordAnalysisSnapshot({
|
|
159
|
+
storagePath: repo.storagePath,
|
|
160
|
+
indexedRepoCommit: hasGitDir(repo.repoPath) ? getCurrentCommit(repo.repoPath) : undefined,
|
|
161
|
+
message: opts.message,
|
|
162
|
+
onSkipTable: (table, err) => {
|
|
163
|
+
process.stderr.write(` skipped ${table}: ${err instanceof Error ? err.message : String(err)}\n`);
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
if (!result) {
|
|
167
|
+
console.error('commit: snapshot failed (graphstore disabled or empty graph)');
|
|
168
|
+
process.exitCode = 1;
|
|
169
|
+
return;
|
|
170
|
+
}
|
|
171
|
+
process.stdout.write(`committed ${result.commitId.slice(7, 7 + 12)} on branch ${result.branch}\n` +
|
|
172
|
+
`snapshot ${result.snapshotId.slice(7, 7 + 12)} ` +
|
|
173
|
+
`nodes ${result.stats.totalNodeRows} edges ${result.stats.edgeRowCount}\n`);
|
|
174
|
+
// Mirror into meta.json so `codragraph status` and the registry stay accurate.
|
|
175
|
+
const meta = await loadMeta(repo.storagePath);
|
|
176
|
+
if (meta) {
|
|
177
|
+
meta.currentBranch = result.branch;
|
|
178
|
+
meta.headCommit = result.commitId;
|
|
179
|
+
await saveMeta(repo.storagePath, meta);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
finally {
|
|
183
|
+
await closeLbug();
|
|
184
|
+
}
|
|
185
|
+
// Avoid unused warnings while keeping the import live for future callers.
|
|
186
|
+
void ctx;
|
|
187
|
+
};
|
|
188
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
189
|
+
// codragraph branch create <name>
|
|
190
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
191
|
+
export const branchCreateCommand = async (name, opts = {}) => {
|
|
192
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
193
|
+
let head;
|
|
194
|
+
if (opts.from !== undefined) {
|
|
195
|
+
head = await resolveCommitTarget(ctx, opts.from);
|
|
196
|
+
}
|
|
197
|
+
else {
|
|
198
|
+
head = await resolveHeadCommit({ root: ctx.graphstoreRoot });
|
|
199
|
+
}
|
|
200
|
+
if (head === null) {
|
|
201
|
+
console.error('No commit to branch from. Run `codragraph analyze` (or `codragraph commit -m`) first.');
|
|
202
|
+
process.exitCode = 1;
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
const branch = await createBranch({ root: ctx.graphstoreRoot, name, commit: head });
|
|
206
|
+
process.stdout.write(`created branch ${branch.name} at ${branch.head.slice(7, 7 + 12)}\n`);
|
|
207
|
+
};
|
|
208
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
209
|
+
// codragraph checkout <target>
|
|
210
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
211
|
+
//
|
|
212
|
+
// Two modes:
|
|
213
|
+
// - default : just move HEAD (no lbug rewrite). Cheap; good for
|
|
214
|
+
// log/diff inspection from a different vantage point.
|
|
215
|
+
// - --materialize : also rebuild the live LadybugDB from the target
|
|
216
|
+
// snapshot. Destructive of the current lbug state —
|
|
217
|
+
// run `commit` first if you have unsaved changes.
|
|
218
|
+
export const checkoutCommand = async (target, opts = {}) => {
|
|
219
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
220
|
+
const branches = await listBranches({ root: ctx.graphstoreRoot });
|
|
221
|
+
const branchHit = branches.find((b) => b.name === target);
|
|
222
|
+
let commitId;
|
|
223
|
+
if (branchHit) {
|
|
224
|
+
commitId = branchHit.head;
|
|
225
|
+
await writeHeadBranch({ root: ctx.graphstoreRoot, branch: target });
|
|
226
|
+
process.stdout.write(`switched to branch ${target} (${commitId.slice(7, 7 + 12)})\n`);
|
|
227
|
+
}
|
|
228
|
+
else {
|
|
229
|
+
commitId = parseObjectId(target);
|
|
230
|
+
await writeHeadDetached({ root: ctx.graphstoreRoot, commit: commitId });
|
|
231
|
+
process.stdout.write(`HEAD detached at ${commitId.slice(7, 7 + 12)}\n`);
|
|
232
|
+
}
|
|
233
|
+
if (opts.materialize) {
|
|
234
|
+
const repo = await findRepo(process.cwd());
|
|
235
|
+
if (!repo)
|
|
236
|
+
throw new Error('No CodraGraph index found');
|
|
237
|
+
const commit = await readCommit(ctx.cas, commitId);
|
|
238
|
+
process.stdout.write(`materializing snapshot ${commit.snapshot.slice(7, 7 + 12)}...\n`);
|
|
239
|
+
// Wipe and reinit lbug.
|
|
240
|
+
await closeLbug();
|
|
241
|
+
for (const f of [repo.lbugPath, `${repo.lbugPath}.wal`, `${repo.lbugPath}.lock`]) {
|
|
242
|
+
try {
|
|
243
|
+
await fs.rm(f, { recursive: true, force: true });
|
|
244
|
+
}
|
|
245
|
+
catch {
|
|
246
|
+
/* swallow */
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
await initLbug(repo.lbugPath);
|
|
250
|
+
try {
|
|
251
|
+
const sink = await createLbugRowSinkForCheckout(repo.lbugPath);
|
|
252
|
+
const result = await materializeSnapshot({
|
|
253
|
+
cas: ctx.cas,
|
|
254
|
+
snapshotId: commit.snapshot,
|
|
255
|
+
sink,
|
|
256
|
+
});
|
|
257
|
+
process.stdout.write(`materialized ${Object.keys(result.stats.nodeRowsByTable).length} tables, ` +
|
|
258
|
+
`${result.stats.edgeRowCount} edges\n`);
|
|
259
|
+
}
|
|
260
|
+
finally {
|
|
261
|
+
await closeLbug();
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
};
|
|
265
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
266
|
+
// codragraph materialize <target> --into <path>
|
|
267
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
268
|
+
// Read-only inspection: rebuild a snapshot into a fresh sibling lbug
|
|
269
|
+
// without touching the live one. Useful for "let me query the graph as
|
|
270
|
+
// it was at commit X" without disturbing current work.
|
|
271
|
+
export const materializeCommand = async (target, opts) => {
|
|
272
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
273
|
+
const commitId = await resolveCommitTarget(ctx, target);
|
|
274
|
+
const commit = await readCommit(ctx.cas, commitId);
|
|
275
|
+
const into = path.resolve(opts.into);
|
|
276
|
+
await fs.mkdir(path.dirname(into), { recursive: true });
|
|
277
|
+
// Refuse to overwrite an existing file silently.
|
|
278
|
+
try {
|
|
279
|
+
await fs.access(into);
|
|
280
|
+
console.error(`Refusing to overwrite ${into}. Pick a fresh path or delete the existing file first.`);
|
|
281
|
+
process.exitCode = 1;
|
|
282
|
+
return;
|
|
283
|
+
}
|
|
284
|
+
catch {
|
|
285
|
+
/* doesn't exist, good */
|
|
286
|
+
}
|
|
287
|
+
await initLbug(into);
|
|
288
|
+
try {
|
|
289
|
+
const sink = await createLbugRowSinkForCheckout(into);
|
|
290
|
+
const result = await materializeSnapshot({
|
|
291
|
+
cas: ctx.cas,
|
|
292
|
+
snapshotId: commit.snapshot,
|
|
293
|
+
sink,
|
|
294
|
+
});
|
|
295
|
+
process.stdout.write(`materialized ${commitId.slice(7, 7 + 12)} into ${into}\n` +
|
|
296
|
+
`tables: ${Object.entries(result.stats.nodeRowsByTable)
|
|
297
|
+
.map(([t, n]) => `${t}=${n}`)
|
|
298
|
+
.join(' ')}\n` +
|
|
299
|
+
`edges: ${result.stats.edgeRowCount}\n`);
|
|
300
|
+
}
|
|
301
|
+
finally {
|
|
302
|
+
await closeLbug();
|
|
303
|
+
}
|
|
304
|
+
};
|
|
305
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
306
|
+
// codragraph blame <symbolId>
|
|
307
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
308
|
+
//
|
|
309
|
+
// Walk history newest-first. For each pair of adjacent commits, ask the
|
|
310
|
+
// structural diff whether the symbol's row hash changed. The first
|
|
311
|
+
// "changed" hit is the symbol's most-recent change commit; we keep
|
|
312
|
+
// walking to surface its full change history.
|
|
313
|
+
export const blameCommand = async (symbolId, opts = {}) => {
|
|
314
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
315
|
+
const head = await resolveHeadCommit({ root: ctx.graphstoreRoot });
|
|
316
|
+
if (head === null) {
|
|
317
|
+
console.error('No commits yet. Run `codragraph analyze` first.');
|
|
318
|
+
process.exitCode = 1;
|
|
319
|
+
return;
|
|
320
|
+
}
|
|
321
|
+
const limit = opts.limit !== undefined ? Number.parseInt(opts.limit, 10) : 20;
|
|
322
|
+
const tableHint = opts.table;
|
|
323
|
+
const history = [];
|
|
324
|
+
for await (const entry of walkCommits({ cas: ctx.cas, from: head })) {
|
|
325
|
+
history.push(entry);
|
|
326
|
+
}
|
|
327
|
+
if (history.length === 0) {
|
|
328
|
+
console.error('No history.');
|
|
329
|
+
return;
|
|
330
|
+
}
|
|
331
|
+
process.stdout.write(`Blame: ${symbolId}${tableHint ? ` (table=${tableHint})` : ''}\n\n`);
|
|
332
|
+
let lastHash = null;
|
|
333
|
+
let surfaced = 0;
|
|
334
|
+
// Iterate newest → oldest, comparing each commit's row hash for the symbol
|
|
335
|
+
// against the next-older one.
|
|
336
|
+
for (let i = 0; i < history.length; i++) {
|
|
337
|
+
const entry = history[i];
|
|
338
|
+
const snapshot = await getJson(ctx.cas, entry.commit.snapshot);
|
|
339
|
+
const manifest = await getJson(ctx.cas, parseObjectId(snapshot.manifestId));
|
|
340
|
+
const found = locateSymbolHash(manifest, symbolId, tableHint);
|
|
341
|
+
if (!found) {
|
|
342
|
+
if (lastHash !== null) {
|
|
343
|
+
// Symbol existed in the newer commit but not here → introduced
|
|
344
|
+
// in commit history[i-1].
|
|
345
|
+
const introducedAt = history[i - 1];
|
|
346
|
+
if (introducedAt !== undefined) {
|
|
347
|
+
process.stdout.write(` introduced ${introducedAt.id.slice(7, 7 + 12)} ${introducedAt.commit.ts} ` +
|
|
348
|
+
`${introducedAt.commit.message}\n`);
|
|
349
|
+
}
|
|
350
|
+
return;
|
|
351
|
+
}
|
|
352
|
+
continue;
|
|
353
|
+
}
|
|
354
|
+
if (lastHash === null || found.hash !== lastHash) {
|
|
355
|
+
process.stdout.write(` ${found.hash === lastHash ? ' ' : 'CHG'} ${entry.id.slice(7, 7 + 12)} ` +
|
|
356
|
+
`${entry.commit.ts} ${found.table} ${entry.commit.message}\n`);
|
|
357
|
+
surfaced++;
|
|
358
|
+
if (surfaced >= limit)
|
|
359
|
+
return;
|
|
360
|
+
}
|
|
361
|
+
lastHash = found.hash;
|
|
362
|
+
}
|
|
363
|
+
};
|
|
364
|
+
const locateSymbolHash = (manifest, symbolId, tableHint) => {
|
|
365
|
+
if (tableHint !== undefined) {
|
|
366
|
+
const t = manifest.nodeTables[tableHint];
|
|
367
|
+
const h = t?.rows[symbolId];
|
|
368
|
+
return h ? { table: tableHint, hash: h } : null;
|
|
369
|
+
}
|
|
370
|
+
for (const [table, t] of Object.entries(manifest.nodeTables)) {
|
|
371
|
+
const h = t.rows[symbolId];
|
|
372
|
+
if (h)
|
|
373
|
+
return { table, hash: h };
|
|
374
|
+
}
|
|
375
|
+
return null;
|
|
376
|
+
};
|
|
377
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
378
|
+
// LbugRowSink — used by checkout --materialize and `materialize` command.
|
|
379
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
380
|
+
//
|
|
381
|
+
// Bulk-loads rows back into a fresh LadybugDB instance. Phase 4 keeps it
|
|
382
|
+
// simple: per-row CREATE statements through the existing
|
|
383
|
+
// `executeWithReusedStatement` helper. For typical repos (≤100k rows)
|
|
384
|
+
// this finishes in seconds; CSV-based bulk loading is a Phase 4.5
|
|
385
|
+
// optimization once we measure where the bottleneck actually is.
|
|
386
|
+
const createLbugRowSinkForCheckout = async (lbugPath) => {
|
|
387
|
+
const { executeQuery } = await import('../core/lbug/lbug-adapter.js');
|
|
388
|
+
const { SCHEMA_QUERIES } = await import('../core/lbug/schema.js');
|
|
389
|
+
// Recreate the schema; the path was just wiped, so this is a clean install.
|
|
390
|
+
for (const ddl of SCHEMA_QUERIES) {
|
|
391
|
+
try {
|
|
392
|
+
await executeQuery(ddl);
|
|
393
|
+
}
|
|
394
|
+
catch (err) {
|
|
395
|
+
// Schema queries are idempotent at the SQL level (CREATE NODE TABLE
|
|
396
|
+
// IF NOT EXISTS isn't supported, but the reload happens on a fresh
|
|
397
|
+
// db so duplicates can't happen). Surface anything weird.
|
|
398
|
+
throw new Error(`Failed to create schema while materializing checkout: ${err instanceof Error ? err.message : String(err)}`);
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
const sink = {
|
|
402
|
+
beginTable: async () => { },
|
|
403
|
+
writeRows: async (tableName, rows) => {
|
|
404
|
+
for (const row of rows)
|
|
405
|
+
await insertNode(executeQuery, tableName, row);
|
|
406
|
+
},
|
|
407
|
+
endTable: async () => { },
|
|
408
|
+
beginEdges: async () => { },
|
|
409
|
+
writeEdgeRows: async (rows) => {
|
|
410
|
+
for (const row of rows)
|
|
411
|
+
await insertEdge(executeQuery, row);
|
|
412
|
+
},
|
|
413
|
+
endEdges: async () => { },
|
|
414
|
+
finalize: async () => { },
|
|
415
|
+
};
|
|
416
|
+
void lbugPath;
|
|
417
|
+
return sink;
|
|
418
|
+
};
|
|
419
|
+
const insertNode = async (executeQuery, table, row) => {
|
|
420
|
+
// Build a property map literal — Cypher CREATE syntax. We escape
|
|
421
|
+
// strings via JSON.stringify (handles quotes/newlines/unicode) and
|
|
422
|
+
// pass through scalar primitives unchanged.
|
|
423
|
+
const props = Object.entries(row)
|
|
424
|
+
.map(([k, v]) => `${k}: ${cypherLiteral(v)}`)
|
|
425
|
+
.join(', ');
|
|
426
|
+
try {
|
|
427
|
+
await executeQuery(`CREATE (n:${table} { ${props} })`);
|
|
428
|
+
}
|
|
429
|
+
catch {
|
|
430
|
+
// Best-effort: skip rows that fail (e.g. schema mismatch on
|
|
431
|
+
// historical snapshots after a NODE_TABLES extension). Phase 4.5
|
|
432
|
+
// will surface these via the sink's stats.
|
|
433
|
+
}
|
|
434
|
+
};
|
|
435
|
+
const insertEdge = async (executeQuery, row) => {
|
|
436
|
+
const from = String(row['from'] ?? '');
|
|
437
|
+
const to = String(row['to'] ?? '');
|
|
438
|
+
const type = String(row['type'] ?? '');
|
|
439
|
+
if (!from || !to || !type)
|
|
440
|
+
return;
|
|
441
|
+
const extras = Object.entries(row)
|
|
442
|
+
.filter(([k]) => k !== 'from' && k !== 'to' && k !== 'type')
|
|
443
|
+
.map(([k, v]) => `${k}: ${cypherLiteral(v)}`)
|
|
444
|
+
.join(', ');
|
|
445
|
+
try {
|
|
446
|
+
await executeQuery(`MATCH (a {id: ${cypherLiteral(from)}}), (b {id: ${cypherLiteral(to)}}) ` +
|
|
447
|
+
`CREATE (a)-[:CodeRelation { type: ${cypherLiteral(type)}${extras ? `, ${extras}` : ''} }]->(b)`);
|
|
448
|
+
}
|
|
449
|
+
catch {
|
|
450
|
+
/* best-effort */
|
|
451
|
+
}
|
|
452
|
+
};
|
|
453
|
+
const cypherLiteral = (v) => {
|
|
454
|
+
if (v === null || v === undefined)
|
|
455
|
+
return 'NULL';
|
|
456
|
+
if (typeof v === 'string')
|
|
457
|
+
return JSON.stringify(v);
|
|
458
|
+
if (typeof v === 'number' || typeof v === 'boolean')
|
|
459
|
+
return String(v);
|
|
460
|
+
// Fall back to JSON for arrays / nested objects; the underlying lbug
|
|
461
|
+
// schema is mostly scalar so this is rare.
|
|
462
|
+
return JSON.stringify(v);
|
|
463
|
+
};
|
|
464
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
465
|
+
// codragraph branch delete <name>
|
|
466
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
467
|
+
export const branchDeleteCommand = async (name) => {
|
|
468
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
469
|
+
try {
|
|
470
|
+
const removed = await deleteBranch({ root: ctx.graphstoreRoot, name });
|
|
471
|
+
if (removed) {
|
|
472
|
+
process.stdout.write(`deleted branch ${name}\n`);
|
|
473
|
+
}
|
|
474
|
+
else {
|
|
475
|
+
console.error(`No branch named ${name}`);
|
|
476
|
+
process.exitCode = 1;
|
|
477
|
+
}
|
|
478
|
+
}
|
|
479
|
+
catch (err) {
|
|
480
|
+
console.error(err instanceof Error ? err.message : String(err));
|
|
481
|
+
process.exitCode = 1;
|
|
482
|
+
}
|
|
483
|
+
};
|
|
484
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
485
|
+
// codragraph merge <branch>
|
|
486
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
487
|
+
export const mergeCommand = async (target, opts = {}) => {
|
|
488
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
489
|
+
const headState = await readHead({ root: ctx.graphstoreRoot });
|
|
490
|
+
if (headState.kind !== 'branch') {
|
|
491
|
+
console.error('Refusing to merge from a detached HEAD. Run `codragraph checkout <branch>` first.');
|
|
492
|
+
process.exitCode = 1;
|
|
493
|
+
return;
|
|
494
|
+
}
|
|
495
|
+
const ours = await resolveHeadCommit({ root: ctx.graphstoreRoot });
|
|
496
|
+
if (ours === null) {
|
|
497
|
+
console.error('Current branch has no commits yet — nothing to merge into.');
|
|
498
|
+
process.exitCode = 1;
|
|
499
|
+
return;
|
|
500
|
+
}
|
|
501
|
+
const theirs = await resolveCommitTarget(ctx, target);
|
|
502
|
+
const result = await threeWayMerge({ cas: ctx.cas, ours, theirs });
|
|
503
|
+
switch (result.kind) {
|
|
504
|
+
case 'already-up-to-date':
|
|
505
|
+
process.stdout.write(`Already up to date with ${target}.\n`);
|
|
506
|
+
return;
|
|
507
|
+
case 'fast-forward':
|
|
508
|
+
await setHead({ root: ctx.graphstoreRoot, branch: headState.branch, commit: result.to });
|
|
509
|
+
process.stdout.write(`Fast-forwarded ${headState.branch} → ${result.to.slice(7, 7 + 12)}\n`);
|
|
510
|
+
return;
|
|
511
|
+
case 'conflicts': {
|
|
512
|
+
if (result.base === null) {
|
|
513
|
+
console.error(`merge: ${target} has no common ancestor with ${headState.branch} (orphan branches).`);
|
|
514
|
+
}
|
|
515
|
+
else {
|
|
516
|
+
console.error(`merge: ${result.conflicts.length} conflict(s) between ` +
|
|
517
|
+
`${headState.branch} and ${target} (base ${result.base.slice(7, 7 + 12)}):`);
|
|
518
|
+
for (const c of result.conflicts.slice(0, 30)) {
|
|
519
|
+
console.error(` ${c.kind} ${c.id} ${c.reason}`);
|
|
520
|
+
}
|
|
521
|
+
if (result.conflicts.length > 30) {
|
|
522
|
+
console.error(` … and ${result.conflicts.length - 30} more`);
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
process.exitCode = 1;
|
|
526
|
+
return;
|
|
527
|
+
}
|
|
528
|
+
case 'merged': {
|
|
529
|
+
const message = opts.message ?? `Merge ${target} into ${headState.branch}`;
|
|
530
|
+
const commit = await createCommit({
|
|
531
|
+
cas: ctx.cas,
|
|
532
|
+
snapshot: result.snapshotId,
|
|
533
|
+
parents: [ours, theirs],
|
|
534
|
+
author: { name: '@codragraph/cli', email: 'noreply@codragraph.local' },
|
|
535
|
+
message,
|
|
536
|
+
});
|
|
537
|
+
await setHead({
|
|
538
|
+
root: ctx.graphstoreRoot,
|
|
539
|
+
branch: headState.branch,
|
|
540
|
+
commit: commit.commitId,
|
|
541
|
+
});
|
|
542
|
+
const tableSummary = Object.entries(result.stats.tables)
|
|
543
|
+
.filter(([, s]) => s.takenFromOurs + s.takenFromTheirs > 0)
|
|
544
|
+
.map(([t, s]) => `${t}=+${s.takenFromTheirs}/${s.takenFromOurs}`)
|
|
545
|
+
.join(' ');
|
|
546
|
+
process.stdout.write(`Merged ${target} into ${headState.branch} (${commit.commitId.slice(7, 7 + 12)})\n` +
|
|
547
|
+
(tableSummary ? ` ${tableSummary}\n` : ''));
|
|
548
|
+
return;
|
|
549
|
+
}
|
|
550
|
+
}
|
|
551
|
+
};
|
|
552
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
553
|
+
// codragraph gc
|
|
554
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
555
|
+
export const gcCommand = async (opts = {}) => {
|
|
556
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
557
|
+
const result = await runGc({
|
|
558
|
+
cas: ctx.cas,
|
|
559
|
+
graphstoreRoot: ctx.graphstoreRoot,
|
|
560
|
+
dryRun: opts.dryRun,
|
|
561
|
+
});
|
|
562
|
+
const verb = result.dryRun ? 'would sweep' : 'swept';
|
|
563
|
+
process.stdout.write(`${verb} ${result.swept.length} object(s) (${formatBytes(result.bytesFreed)}); ` +
|
|
564
|
+
`${result.reachable} reachable.\n`);
|
|
565
|
+
if (result.dryRun && result.swept.length > 0) {
|
|
566
|
+
process.stdout.write(`(re-run without --dry-run to actually delete)\n`);
|
|
567
|
+
}
|
|
568
|
+
};
|
|
569
|
+
const formatBytes = (n) => {
|
|
570
|
+
if (n < 1024)
|
|
571
|
+
return `${n} B`;
|
|
572
|
+
if (n < 1024 * 1024)
|
|
573
|
+
return `${(n / 1024).toFixed(1)} KB`;
|
|
574
|
+
return `${(n / 1024 / 1024).toFixed(1)} MB`;
|
|
575
|
+
};
|
|
576
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
577
|
+
// codragraph diff --semantic
|
|
578
|
+
// ──────────────────────────────────────────────────────────────────────
|
|
579
|
+
//
|
|
580
|
+
// Promote the existing diff command with a --semantic flag that surfaces
|
|
581
|
+
// classified modifications, added/removed APIs, and process changes. We
|
|
582
|
+
// expose it as a separate module-local helper so the CLI handler can
|
|
583
|
+
// dispatch on the flag.
|
|
584
|
+
export const diffSemanticCommand = async (from, to) => {
|
|
585
|
+
const ctx = await resolveGraphstore(process.cwd());
|
|
586
|
+
const fromCommit = await readCommit(ctx.cas, await resolveCommitTarget(ctx, from));
|
|
587
|
+
const toCommit = await readCommit(ctx.cas, await resolveCommitTarget(ctx, to));
|
|
588
|
+
const d = await diffSemantic({
|
|
589
|
+
cas: ctx.cas,
|
|
590
|
+
from: fromCommit.snapshot,
|
|
591
|
+
to: toCommit.snapshot,
|
|
592
|
+
});
|
|
593
|
+
process.stdout.write(`From: ${from} (${fromCommit.message})\n`);
|
|
594
|
+
process.stdout.write(`To: ${to} (${toCommit.message})\n\n`);
|
|
595
|
+
if (d.addedAPIs.length > 0) {
|
|
596
|
+
process.stdout.write(`Added APIs (${d.addedAPIs.length}):\n`);
|
|
597
|
+
for (const r of d.addedAPIs) {
|
|
598
|
+
process.stdout.write(` + ${r.table} ${r.id}${r.name ? ` (${r.name})` : ''}\n`);
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
if (d.removedAPIs.length > 0) {
|
|
602
|
+
process.stdout.write(`Removed APIs (${d.removedAPIs.length}):\n`);
|
|
603
|
+
for (const r of d.removedAPIs) {
|
|
604
|
+
process.stdout.write(` - ${r.table} ${r.id}${r.name ? ` (${r.name})` : ''}\n`);
|
|
605
|
+
}
|
|
606
|
+
}
|
|
607
|
+
if (d.addedProcesses.length > 0 || d.removedProcesses.length > 0) {
|
|
608
|
+
process.stdout.write(`\nProcesses:\n`);
|
|
609
|
+
for (const r of d.addedProcesses) {
|
|
610
|
+
process.stdout.write(` + ${r.id}${r.name ? ` (${r.name})` : ''}\n`);
|
|
611
|
+
}
|
|
612
|
+
for (const r of d.removedProcesses) {
|
|
613
|
+
process.stdout.write(` - ${r.id}${r.name ? ` (${r.name})` : ''}\n`);
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
if (d.classifiedModifications.length > 0) {
|
|
617
|
+
process.stdout.write(`\nModified (${d.classifiedModifications.length}):\n`);
|
|
618
|
+
for (const m of d.classifiedModifications.slice(0, 30)) {
|
|
619
|
+
process.stdout.write(` ~ ${m.table} ${m.id} [${m.changes.join(', ')}]` +
|
|
620
|
+
(m.signatureChange?.parameterCountChanged
|
|
621
|
+
? ` params ${m.signatureChange.parameterCountChanged.from}→${m.signatureChange.parameterCountChanged.to}`
|
|
622
|
+
: '') +
|
|
623
|
+
(m.visibilityFlip ? ` exported ${m.visibilityFlip.from}→${m.visibilityFlip.to}` : '') +
|
|
624
|
+
'\n');
|
|
625
|
+
}
|
|
626
|
+
if (d.classifiedModifications.length > 30) {
|
|
627
|
+
process.stdout.write(` … and ${d.classifiedModifications.length - 30} more\n`);
|
|
628
|
+
}
|
|
629
|
+
}
|
|
630
|
+
if (d.addedAPIs.length === 0 &&
|
|
631
|
+
d.removedAPIs.length === 0 &&
|
|
632
|
+
d.addedProcesses.length === 0 &&
|
|
633
|
+
d.removedProcesses.length === 0 &&
|
|
634
|
+
d.classifiedModifications.length === 0) {
|
|
635
|
+
process.stdout.write('(no semantic changes)\n');
|
|
636
|
+
}
|
|
637
|
+
};
|
|
638
|
+
// Default-branch helper exposed for tests.
|
|
639
|
+
export { DEFAULT_BRANCH };
|