@opencodehub/ingestion 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +202 -0
- package/README.md +69 -0
- package/dist/extract/index.d.ts +8 -0
- package/dist/extract/index.d.ts.map +1 -0
- package/dist/extract/index.js +6 -0
- package/dist/extract/index.js.map +1 -0
- package/dist/extract/orm-detector.d.ts +19 -0
- package/dist/extract/orm-detector.d.ts.map +1 -0
- package/dist/extract/orm-detector.js +209 -0
- package/dist/extract/orm-detector.js.map +1 -0
- package/dist/extract/property-access.d.ts +76 -0
- package/dist/extract/property-access.d.ts.map +1 -0
- package/dist/extract/property-access.js +260 -0
- package/dist/extract/property-access.js.map +1 -0
- package/dist/extract/receiver-resolver.d.ts +86 -0
- package/dist/extract/receiver-resolver.d.ts.map +1 -0
- package/dist/extract/receiver-resolver.js +77 -0
- package/dist/extract/receiver-resolver.js.map +1 -0
- package/dist/extract/route-detector-java.d.ts +29 -0
- package/dist/extract/route-detector-java.d.ts.map +1 -0
- package/dist/extract/route-detector-java.js +190 -0
- package/dist/extract/route-detector-java.js.map +1 -0
- package/dist/extract/route-detector-nestjs.d.ts +30 -0
- package/dist/extract/route-detector-nestjs.d.ts.map +1 -0
- package/dist/extract/route-detector-nestjs.js +134 -0
- package/dist/extract/route-detector-nestjs.js.map +1 -0
- package/dist/extract/route-detector-python.d.ts +28 -0
- package/dist/extract/route-detector-python.d.ts.map +1 -0
- package/dist/extract/route-detector-python.js +100 -0
- package/dist/extract/route-detector-python.js.map +1 -0
- package/dist/extract/route-detector-rails.d.ts +28 -0
- package/dist/extract/route-detector-rails.d.ts.map +1 -0
- package/dist/extract/route-detector-rails.js +162 -0
- package/dist/extract/route-detector-rails.js.map +1 -0
- package/dist/extract/route-detector.d.ts +45 -0
- package/dist/extract/route-detector.d.ts.map +1 -0
- package/dist/extract/route-detector.js +467 -0
- package/dist/extract/route-detector.js.map +1 -0
- package/dist/extract/tool-detector.d.ts +26 -0
- package/dist/extract/tool-detector.d.ts.map +1 -0
- package/dist/extract/tool-detector.js +364 -0
- package/dist/extract/tool-detector.js.map +1 -0
- package/dist/extract/types.d.ts +89 -0
- package/dist/extract/types.d.ts.map +1 -0
- package/dist/extract/types.js +11 -0
- package/dist/extract/types.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +10 -0
- package/dist/index.js.map +1 -0
- package/dist/parse/cobol-regex.d.ts +85 -0
- package/dist/parse/cobol-regex.d.ts.map +1 -0
- package/dist/parse/cobol-regex.js +355 -0
- package/dist/parse/cobol-regex.js.map +1 -0
- package/dist/parse/grammar-registry.d.ts +115 -0
- package/dist/parse/grammar-registry.d.ts.map +1 -0
- package/dist/parse/grammar-registry.js +278 -0
- package/dist/parse/grammar-registry.js.map +1 -0
- package/dist/parse/index.d.ts +14 -0
- package/dist/parse/index.d.ts.map +1 -0
- package/dist/parse/index.js +10 -0
- package/dist/parse/index.js.map +1 -0
- package/dist/parse/language-detector.d.ts +17 -0
- package/dist/parse/language-detector.d.ts.map +1 -0
- package/dist/parse/language-detector.js +104 -0
- package/dist/parse/language-detector.js.map +1 -0
- package/dist/parse/parse-worker.d.ts +24 -0
- package/dist/parse/parse-worker.d.ts.map +1 -0
- package/dist/parse/parse-worker.js +230 -0
- package/dist/parse/parse-worker.js.map +1 -0
- package/dist/parse/types.d.ts +49 -0
- package/dist/parse/types.d.ts.map +1 -0
- package/dist/parse/types.js +11 -0
- package/dist/parse/types.js.map +1 -0
- package/dist/parse/unified-queries.d.ts +37 -0
- package/dist/parse/unified-queries.d.ts.map +1 -0
- package/dist/parse/unified-queries.js +623 -0
- package/dist/parse/unified-queries.js.map +1 -0
- package/dist/parse/wasm-fallback.d.ts +88 -0
- package/dist/parse/wasm-fallback.d.ts.map +1 -0
- package/dist/parse/wasm-fallback.js +258 -0
- package/dist/parse/wasm-fallback.js.map +1 -0
- package/dist/parse/worker-pool.d.ts +48 -0
- package/dist/parse/worker-pool.d.ts.map +1 -0
- package/dist/parse/worker-pool.js +97 -0
- package/dist/parse/worker-pool.js.map +1 -0
- package/dist/pipeline/dep-parsers/go.d.ts +25 -0
- package/dist/pipeline/dep-parsers/go.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/go.js +146 -0
- package/dist/pipeline/dep-parsers/go.js.map +1 -0
- package/dist/pipeline/dep-parsers/index.d.ts +17 -0
- package/dist/pipeline/dep-parsers/index.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/index.js +16 -0
- package/dist/pipeline/dep-parsers/index.js.map +1 -0
- package/dist/pipeline/dep-parsers/maven.d.ts +24 -0
- package/dist/pipeline/dep-parsers/maven.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/maven.js +131 -0
- package/dist/pipeline/dep-parsers/maven.js.map +1 -0
- package/dist/pipeline/dep-parsers/npm.d.ts +30 -0
- package/dist/pipeline/dep-parsers/npm.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/npm.js +309 -0
- package/dist/pipeline/dep-parsers/npm.js.map +1 -0
- package/dist/pipeline/dep-parsers/nuget.d.ts +24 -0
- package/dist/pipeline/dep-parsers/nuget.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/nuget.js +178 -0
- package/dist/pipeline/dep-parsers/nuget.js.map +1 -0
- package/dist/pipeline/dep-parsers/python.d.ts +21 -0
- package/dist/pipeline/dep-parsers/python.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/python.js +369 -0
- package/dist/pipeline/dep-parsers/python.js.map +1 -0
- package/dist/pipeline/dep-parsers/rust.d.ts +18 -0
- package/dist/pipeline/dep-parsers/rust.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/rust.js +134 -0
- package/dist/pipeline/dep-parsers/rust.js.map +1 -0
- package/dist/pipeline/dep-parsers/spdx-normalize.d.ts +15 -0
- package/dist/pipeline/dep-parsers/spdx-normalize.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/spdx-normalize.js +31 -0
- package/dist/pipeline/dep-parsers/spdx-normalize.js.map +1 -0
- package/dist/pipeline/dep-parsers/types.d.ts +63 -0
- package/dist/pipeline/dep-parsers/types.d.ts.map +1 -0
- package/dist/pipeline/dep-parsers/types.js +56 -0
- package/dist/pipeline/dep-parsers/types.js.map +1 -0
- package/dist/pipeline/gitignore-stack.d.ts +44 -0
- package/dist/pipeline/gitignore-stack.d.ts.map +1 -0
- package/dist/pipeline/gitignore-stack.js +69 -0
- package/dist/pipeline/gitignore-stack.js.map +1 -0
- package/dist/pipeline/gitignore.d.ts +67 -0
- package/dist/pipeline/gitignore.d.ts.map +1 -0
- package/dist/pipeline/gitignore.js +210 -0
- package/dist/pipeline/gitignore.js.map +1 -0
- package/dist/pipeline/index.d.ts +53 -0
- package/dist/pipeline/index.d.ts.map +1 -0
- package/dist/pipeline/index.js +29 -0
- package/dist/pipeline/index.js.map +1 -0
- package/dist/pipeline/orchestrator.d.ts +105 -0
- package/dist/pipeline/orchestrator.d.ts.map +1 -0
- package/dist/pipeline/orchestrator.js +175 -0
- package/dist/pipeline/orchestrator.js.map +1 -0
- package/dist/pipeline/ownership-helpers/drift.d.ts +41 -0
- package/dist/pipeline/ownership-helpers/drift.d.ts.map +1 -0
- package/dist/pipeline/ownership-helpers/drift.js +122 -0
- package/dist/pipeline/ownership-helpers/drift.js.map +1 -0
- package/dist/pipeline/ownership-helpers/gini-community.d.ts +24 -0
- package/dist/pipeline/ownership-helpers/gini-community.d.ts.map +1 -0
- package/dist/pipeline/ownership-helpers/gini-community.js +32 -0
- package/dist/pipeline/ownership-helpers/gini-community.js.map +1 -0
- package/dist/pipeline/ownership-helpers/git-blame-batcher.d.ts +71 -0
- package/dist/pipeline/ownership-helpers/git-blame-batcher.d.ts.map +1 -0
- package/dist/pipeline/ownership-helpers/git-blame-batcher.js +178 -0
- package/dist/pipeline/ownership-helpers/git-blame-batcher.js.map +1 -0
- package/dist/pipeline/ownership-helpers/line-overlap.d.ts +35 -0
- package/dist/pipeline/ownership-helpers/line-overlap.d.ts.map +1 -0
- package/dist/pipeline/ownership-helpers/line-overlap.js +62 -0
- package/dist/pipeline/ownership-helpers/line-overlap.js.map +1 -0
- package/dist/pipeline/ownership-helpers/orphan.d.ts +73 -0
- package/dist/pipeline/ownership-helpers/orphan.d.ts.map +1 -0
- package/dist/pipeline/ownership-helpers/orphan.js +117 -0
- package/dist/pipeline/ownership-helpers/orphan.js.map +1 -0
- package/dist/pipeline/phases/accesses.d.ts +44 -0
- package/dist/pipeline/phases/accesses.d.ts.map +1 -0
- package/dist/pipeline/phases/accesses.js +194 -0
- package/dist/pipeline/phases/accesses.js.map +1 -0
- package/dist/pipeline/phases/annotate.d.ts +28 -0
- package/dist/pipeline/phases/annotate.d.ts.map +1 -0
- package/dist/pipeline/phases/annotate.js +60 -0
- package/dist/pipeline/phases/annotate.js.map +1 -0
- package/dist/pipeline/phases/cochange.d.ts +42 -0
- package/dist/pipeline/phases/cochange.d.ts.map +1 -0
- package/dist/pipeline/phases/cochange.js +0 -0
- package/dist/pipeline/phases/cochange.js.map +1 -0
- package/dist/pipeline/phases/communities.d.ts +34 -0
- package/dist/pipeline/phases/communities.d.ts.map +1 -0
- package/dist/pipeline/phases/communities.js +412 -0
- package/dist/pipeline/phases/communities.js.map +1 -0
- package/dist/pipeline/phases/complexity.d.ts +50 -0
- package/dist/pipeline/phases/complexity.d.ts.map +1 -0
- package/dist/pipeline/phases/complexity.js +794 -0
- package/dist/pipeline/phases/complexity.js.map +1 -0
- package/dist/pipeline/phases/confidence-demote.d.ts +23 -0
- package/dist/pipeline/phases/confidence-demote.d.ts.map +1 -0
- package/dist/pipeline/phases/confidence-demote.js +113 -0
- package/dist/pipeline/phases/confidence-demote.js.map +1 -0
- package/dist/pipeline/phases/content-cache.d.ts +166 -0
- package/dist/pipeline/phases/content-cache.d.ts.map +1 -0
- package/dist/pipeline/phases/content-cache.js +323 -0
- package/dist/pipeline/phases/content-cache.js.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/cobertura.d.ts +25 -0
- package/dist/pipeline/phases/coverage-parsers/cobertura.d.ts.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/cobertura.js +139 -0
- package/dist/pipeline/phases/coverage-parsers/cobertura.js.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/coverage-py.d.ts +25 -0
- package/dist/pipeline/phases/coverage-parsers/coverage-py.d.ts.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/coverage-py.js +51 -0
- package/dist/pipeline/phases/coverage-parsers/coverage-py.js.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/jacoco.d.ts +32 -0
- package/dist/pipeline/phases/coverage-parsers/jacoco.d.ts.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/jacoco.js +98 -0
- package/dist/pipeline/phases/coverage-parsers/jacoco.js.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/lcov.d.ts +21 -0
- package/dist/pipeline/phases/coverage-parsers/lcov.d.ts.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/lcov.js +104 -0
- package/dist/pipeline/phases/coverage-parsers/lcov.js.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/types.d.ts +27 -0
- package/dist/pipeline/phases/coverage-parsers/types.d.ts.map +1 -0
- package/dist/pipeline/phases/coverage-parsers/types.js +39 -0
- package/dist/pipeline/phases/coverage-parsers/types.js.map +1 -0
- package/dist/pipeline/phases/coverage.d.ts +39 -0
- package/dist/pipeline/phases/coverage.d.ts.map +1 -0
- package/dist/pipeline/phases/coverage.js +154 -0
- package/dist/pipeline/phases/coverage.js.map +1 -0
- package/dist/pipeline/phases/cross-file.d.ts +40 -0
- package/dist/pipeline/phases/cross-file.d.ts.map +1 -0
- package/dist/pipeline/phases/cross-file.js +411 -0
- package/dist/pipeline/phases/cross-file.js.map +1 -0
- package/dist/pipeline/phases/dead-code.d.ts +28 -0
- package/dist/pipeline/phases/dead-code.d.ts.map +1 -0
- package/dist/pipeline/phases/dead-code.js +157 -0
- package/dist/pipeline/phases/dead-code.js.map +1 -0
- package/dist/pipeline/phases/default-set.d.ts +24 -0
- package/dist/pipeline/phases/default-set.d.ts.map +1 -0
- package/dist/pipeline/phases/default-set.js +133 -0
- package/dist/pipeline/phases/default-set.js.map +1 -0
- package/dist/pipeline/phases/dependencies.d.ts +59 -0
- package/dist/pipeline/phases/dependencies.d.ts.map +1 -0
- package/dist/pipeline/phases/dependencies.js +281 -0
- package/dist/pipeline/phases/dependencies.js.map +1 -0
- package/dist/pipeline/phases/embedder-pool.d.ts +31 -0
- package/dist/pipeline/phases/embedder-pool.d.ts.map +1 -0
- package/dist/pipeline/phases/embedder-pool.js +79 -0
- package/dist/pipeline/phases/embedder-pool.js.map +1 -0
- package/dist/pipeline/phases/embedder-worker.d.ts +28 -0
- package/dist/pipeline/phases/embedder-worker.d.ts.map +1 -0
- package/dist/pipeline/phases/embedder-worker.js +43 -0
- package/dist/pipeline/phases/embedder-worker.js.map +1 -0
- package/dist/pipeline/phases/embeddings.d.ts +117 -0
- package/dist/pipeline/phases/embeddings.d.ts.map +1 -0
- package/dist/pipeline/phases/embeddings.js +697 -0
- package/dist/pipeline/phases/embeddings.js.map +1 -0
- package/dist/pipeline/phases/fetches.d.ts +47 -0
- package/dist/pipeline/phases/fetches.d.ts.map +1 -0
- package/dist/pipeline/phases/fetches.js +207 -0
- package/dist/pipeline/phases/fetches.js.map +1 -0
- package/dist/pipeline/phases/incremental-helper.d.ts +96 -0
- package/dist/pipeline/phases/incremental-helper.d.ts.map +1 -0
- package/dist/pipeline/phases/incremental-helper.js +125 -0
- package/dist/pipeline/phases/incremental-helper.js.map +1 -0
- package/dist/pipeline/phases/incremental-scope.d.ts +67 -0
- package/dist/pipeline/phases/incremental-scope.d.ts.map +1 -0
- package/dist/pipeline/phases/incremental-scope.js +225 -0
- package/dist/pipeline/phases/incremental-scope.js.map +1 -0
- package/dist/pipeline/phases/markdown.d.ts +29 -0
- package/dist/pipeline/phases/markdown.d.ts.map +1 -0
- package/dist/pipeline/phases/markdown.js +298 -0
- package/dist/pipeline/phases/markdown.js.map +1 -0
- package/dist/pipeline/phases/mro.d.ts +24 -0
- package/dist/pipeline/phases/mro.d.ts.map +1 -0
- package/dist/pipeline/phases/mro.js +303 -0
- package/dist/pipeline/phases/mro.js.map +1 -0
- package/dist/pipeline/phases/openapi.d.ts +52 -0
- package/dist/pipeline/phases/openapi.d.ts.map +1 -0
- package/dist/pipeline/phases/openapi.js +285 -0
- package/dist/pipeline/phases/openapi.js.map +1 -0
- package/dist/pipeline/phases/orm.d.ts +26 -0
- package/dist/pipeline/phases/orm.d.ts.map +1 -0
- package/dist/pipeline/phases/orm.js +183 -0
- package/dist/pipeline/phases/orm.js.map +1 -0
- package/dist/pipeline/phases/ownership.d.ts +88 -0
- package/dist/pipeline/phases/ownership.d.ts.map +1 -0
- package/dist/pipeline/phases/ownership.js +479 -0
- package/dist/pipeline/phases/ownership.js.map +1 -0
- package/dist/pipeline/phases/parse.d.ts +63 -0
- package/dist/pipeline/phases/parse.d.ts.map +1 -0
- package/dist/pipeline/phases/parse.js +994 -0
- package/dist/pipeline/phases/parse.js.map +1 -0
- package/dist/pipeline/phases/processes.d.ts +47 -0
- package/dist/pipeline/phases/processes.d.ts.map +1 -0
- package/dist/pipeline/phases/processes.js +620 -0
- package/dist/pipeline/phases/processes.js.map +1 -0
- package/dist/pipeline/phases/profile.d.ts +33 -0
- package/dist/pipeline/phases/profile.d.ts.map +1 -0
- package/dist/pipeline/phases/profile.js +91 -0
- package/dist/pipeline/phases/profile.js.map +1 -0
- package/dist/pipeline/phases/repo-node.d.ts +112 -0
- package/dist/pipeline/phases/repo-node.d.ts.map +1 -0
- package/dist/pipeline/phases/repo-node.js +272 -0
- package/dist/pipeline/phases/repo-node.js.map +1 -0
- package/dist/pipeline/phases/risk-snapshot.d.ts +34 -0
- package/dist/pipeline/phases/risk-snapshot.d.ts.map +1 -0
- package/dist/pipeline/phases/risk-snapshot.js +63 -0
- package/dist/pipeline/phases/risk-snapshot.js.map +1 -0
- package/dist/pipeline/phases/routes.d.ts +31 -0
- package/dist/pipeline/phases/routes.d.ts.map +1 -0
- package/dist/pipeline/phases/routes.js +262 -0
- package/dist/pipeline/phases/routes.js.map +1 -0
- package/dist/pipeline/phases/sbom.d.ts +45 -0
- package/dist/pipeline/phases/sbom.d.ts.map +1 -0
- package/dist/pipeline/phases/sbom.js +289 -0
- package/dist/pipeline/phases/sbom.js.map +1 -0
- package/dist/pipeline/phases/scan.d.ts +54 -0
- package/dist/pipeline/phases/scan.d.ts.map +1 -0
- package/dist/pipeline/phases/scan.js +340 -0
- package/dist/pipeline/phases/scan.js.map +1 -0
- package/dist/pipeline/phases/scip-index.d.ts +54 -0
- package/dist/pipeline/phases/scip-index.d.ts.map +1 -0
- package/dist/pipeline/phases/scip-index.js +469 -0
- package/dist/pipeline/phases/scip-index.js.map +1 -0
- package/dist/pipeline/phases/structure.d.ts +21 -0
- package/dist/pipeline/phases/structure.d.ts.map +1 -0
- package/dist/pipeline/phases/structure.js +115 -0
- package/dist/pipeline/phases/structure.js.map +1 -0
- package/dist/pipeline/phases/summarize.d.ts +126 -0
- package/dist/pipeline/phases/summarize.d.ts.map +1 -0
- package/dist/pipeline/phases/summarize.js +401 -0
- package/dist/pipeline/phases/summarize.js.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/branch-divergence.d.ts +42 -0
- package/dist/pipeline/phases/temporal-helpers/branch-divergence.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/branch-divergence.js +96 -0
- package/dist/pipeline/phases/temporal-helpers/branch-divergence.js.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/churn-decay.d.ts +22 -0
- package/dist/pipeline/phases/temporal-helpers/churn-decay.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/churn-decay.js +32 -0
- package/dist/pipeline/phases/temporal-helpers/churn-decay.js.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/conventional-commits.d.ts +21 -0
- package/dist/pipeline/phases/temporal-helpers/conventional-commits.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/conventional-commits.js +37 -0
- package/dist/pipeline/phases/temporal-helpers/conventional-commits.js.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/gini.d.ts +32 -0
- package/dist/pipeline/phases/temporal-helpers/gini.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/gini.js +78 -0
- package/dist/pipeline/phases/temporal-helpers/gini.js.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/revert-detect.d.ts +14 -0
- package/dist/pipeline/phases/temporal-helpers/revert-detect.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/revert-detect.js +25 -0
- package/dist/pipeline/phases/temporal-helpers/revert-detect.js.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/test-pair.d.ts +18 -0
- package/dist/pipeline/phases/temporal-helpers/test-pair.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal-helpers/test-pair.js +119 -0
- package/dist/pipeline/phases/temporal-helpers/test-pair.js.map +1 -0
- package/dist/pipeline/phases/temporal.d.ts +65 -0
- package/dist/pipeline/phases/temporal.d.ts.map +1 -0
- package/dist/pipeline/phases/temporal.js +621 -0
- package/dist/pipeline/phases/temporal.js.map +1 -0
- package/dist/pipeline/phases/tools.d.ts +21 -0
- package/dist/pipeline/phases/tools.d.ts.map +1 -0
- package/dist/pipeline/phases/tools.js +118 -0
- package/dist/pipeline/phases/tools.js.map +1 -0
- package/dist/pipeline/profile-detectors/api-contracts.d.ts +18 -0
- package/dist/pipeline/profile-detectors/api-contracts.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/api-contracts.js +78 -0
- package/dist/pipeline/profile-detectors/api-contracts.js.map +1 -0
- package/dist/pipeline/profile-detectors/framework-detector.d.ts +11 -0
- package/dist/pipeline/profile-detectors/framework-detector.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/framework-detector.js +11 -0
- package/dist/pipeline/profile-detectors/framework-detector.js.map +1 -0
- package/dist/pipeline/profile-detectors/frameworks-catalog.d.ts +7 -0
- package/dist/pipeline/profile-detectors/frameworks-catalog.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/frameworks-catalog.js +7 -0
- package/dist/pipeline/profile-detectors/frameworks-catalog.js.map +1 -0
- package/dist/pipeline/profile-detectors/frameworks.d.ts +7 -0
- package/dist/pipeline/profile-detectors/frameworks.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/frameworks.js +7 -0
- package/dist/pipeline/profile-detectors/frameworks.js.map +1 -0
- package/dist/pipeline/profile-detectors/iac.d.ts +22 -0
- package/dist/pipeline/profile-detectors/iac.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/iac.js +97 -0
- package/dist/pipeline/profile-detectors/iac.js.map +1 -0
- package/dist/pipeline/profile-detectors/languages.d.ts +18 -0
- package/dist/pipeline/profile-detectors/languages.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/languages.js +60 -0
- package/dist/pipeline/profile-detectors/languages.js.map +1 -0
- package/dist/pipeline/profile-detectors/manifests.d.ts +7 -0
- package/dist/pipeline/profile-detectors/manifests.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/manifests.js +7 -0
- package/dist/pipeline/profile-detectors/manifests.js.map +1 -0
- package/dist/pipeline/profile-detectors/src-dirs.d.ts +17 -0
- package/dist/pipeline/profile-detectors/src-dirs.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/src-dirs.js +89 -0
- package/dist/pipeline/profile-detectors/src-dirs.js.map +1 -0
- package/dist/pipeline/profile-detectors/variant-detectors.d.ts +7 -0
- package/dist/pipeline/profile-detectors/variant-detectors.d.ts.map +1 -0
- package/dist/pipeline/profile-detectors/variant-detectors.js +7 -0
- package/dist/pipeline/profile-detectors/variant-detectors.js.map +1 -0
- package/dist/pipeline/runner.d.ts +54 -0
- package/dist/pipeline/runner.d.ts.map +1 -0
- package/dist/pipeline/runner.js +247 -0
- package/dist/pipeline/runner.js.map +1 -0
- package/dist/pipeline/types.d.ts +235 -0
- package/dist/pipeline/types.d.ts.map +1 -0
- package/dist/pipeline/types.js +15 -0
- package/dist/pipeline/types.js.map +1 -0
- package/dist/providers/c.d.ts +3 -0
- package/dist/providers/c.d.ts.map +1 -0
- package/dist/providers/c.js +162 -0
- package/dist/providers/c.js.map +1 -0
- package/dist/providers/cobol.d.ts +19 -0
- package/dist/providers/cobol.d.ts.map +1 -0
- package/dist/providers/cobol.js +44 -0
- package/dist/providers/cobol.js.map +1 -0
- package/dist/providers/cpp.d.ts +3 -0
- package/dist/providers/cpp.d.ts.map +1 -0
- package/dist/providers/cpp.js +200 -0
- package/dist/providers/cpp.js.map +1 -0
- package/dist/providers/csharp.d.ts +3 -0
- package/dist/providers/csharp.d.ts.map +1 -0
- package/dist/providers/csharp.js +292 -0
- package/dist/providers/csharp.js.map +1 -0
- package/dist/providers/dart.d.ts +3 -0
- package/dist/providers/dart.d.ts.map +1 -0
- package/dist/providers/dart.js +214 -0
- package/dist/providers/dart.js.map +1 -0
- package/dist/providers/definition-ids.d.ts +18 -0
- package/dist/providers/definition-ids.d.ts.map +1 -0
- package/dist/providers/definition-ids.js +23 -0
- package/dist/providers/definition-ids.js.map +1 -0
- package/dist/providers/extract-helpers.d.ts +60 -0
- package/dist/providers/extract-helpers.d.ts.map +1 -0
- package/dist/providers/extract-helpers.js +296 -0
- package/dist/providers/extract-helpers.js.map +1 -0
- package/dist/providers/extraction-types.d.ts +85 -0
- package/dist/providers/extraction-types.d.ts.map +1 -0
- package/dist/providers/extraction-types.js +13 -0
- package/dist/providers/extraction-types.js.map +1 -0
- package/dist/providers/go.d.ts +3 -0
- package/dist/providers/go.d.ts.map +1 -0
- package/dist/providers/go.js +359 -0
- package/dist/providers/go.js.map +1 -0
- package/dist/providers/http-detect.d.ts +44 -0
- package/dist/providers/http-detect.d.ts.map +1 -0
- package/dist/providers/http-detect.js +307 -0
- package/dist/providers/http-detect.js.map +1 -0
- package/dist/providers/index.d.ts +38 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +33 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/java.d.ts +3 -0
- package/dist/providers/java.d.ts.map +1 -0
- package/dist/providers/java.js +259 -0
- package/dist/providers/java.js.map +1 -0
- package/dist/providers/javascript.d.ts +3 -0
- package/dist/providers/javascript.d.ts.map +1 -0
- package/dist/providers/javascript.js +139 -0
- package/dist/providers/javascript.js.map +1 -0
- package/dist/providers/kotlin.d.ts +3 -0
- package/dist/providers/kotlin.d.ts.map +1 -0
- package/dist/providers/kotlin.js +175 -0
- package/dist/providers/kotlin.js.map +1 -0
- package/dist/providers/php.d.ts +3 -0
- package/dist/providers/php.d.ts.map +1 -0
- package/dist/providers/php.js +218 -0
- package/dist/providers/php.js.map +1 -0
- package/dist/providers/python-accesses.d.ts +9 -0
- package/dist/providers/python-accesses.d.ts.map +1 -0
- package/dist/providers/python-accesses.js +22 -0
- package/dist/providers/python-accesses.js.map +1 -0
- package/dist/providers/python.d.ts +3 -0
- package/dist/providers/python.d.ts.map +1 -0
- package/dist/providers/python.js +323 -0
- package/dist/providers/python.js.map +1 -0
- package/dist/providers/registry.d.ts +4 -0
- package/dist/providers/registry.d.ts.map +1 -0
- package/dist/providers/registry.js +46 -0
- package/dist/providers/registry.js.map +1 -0
- package/dist/providers/resolution/c3.d.ts +6 -0
- package/dist/providers/resolution/c3.d.ts.map +1 -0
- package/dist/providers/resolution/c3.js +76 -0
- package/dist/providers/resolution/c3.js.map +1 -0
- package/dist/providers/resolution/context.d.ts +38 -0
- package/dist/providers/resolution/context.d.ts.map +1 -0
- package/dist/providers/resolution/context.js +45 -0
- package/dist/providers/resolution/context.js.map +1 -0
- package/dist/providers/resolution/first-wins.d.ts +3 -0
- package/dist/providers/resolution/first-wins.d.ts.map +1 -0
- package/dist/providers/resolution/first-wins.js +27 -0
- package/dist/providers/resolution/first-wins.js.map +1 -0
- package/dist/providers/resolution/mro.d.ts +16 -0
- package/dist/providers/resolution/mro.d.ts.map +1 -0
- package/dist/providers/resolution/mro.js +14 -0
- package/dist/providers/resolution/mro.js.map +1 -0
- package/dist/providers/resolution/none.d.ts +3 -0
- package/dist/providers/resolution/none.d.ts.map +1 -0
- package/dist/providers/resolution/none.js +11 -0
- package/dist/providers/resolution/none.js.map +1 -0
- package/dist/providers/resolution/python-all-filter.d.ts +25 -0
- package/dist/providers/resolution/python-all-filter.d.ts.map +1 -0
- package/dist/providers/resolution/python-all-filter.js +64 -0
- package/dist/providers/resolution/python-all-filter.js.map +1 -0
- package/dist/providers/resolution/resolver-strategy.d.ts +42 -0
- package/dist/providers/resolution/resolver-strategy.d.ts.map +1 -0
- package/dist/providers/resolution/resolver-strategy.js +50 -0
- package/dist/providers/resolution/resolver-strategy.js.map +1 -0
- package/dist/providers/resolution/single-inheritance.d.ts +3 -0
- package/dist/providers/resolution/single-inheritance.d.ts.map +1 -0
- package/dist/providers/resolution/single-inheritance.js +21 -0
- package/dist/providers/resolution/single-inheritance.js.map +1 -0
- package/dist/providers/resolution/stack-graphs/__fixtures__/mock-tree.d.ts +16 -0
- package/dist/providers/resolution/stack-graphs/__fixtures__/mock-tree.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs/__fixtures__/mock-tree.js +50 -0
- package/dist/providers/resolution/stack-graphs/__fixtures__/mock-tree.js.map +1 -0
- package/dist/providers/resolution/stack-graphs/glue.d.ts +15 -0
- package/dist/providers/resolution/stack-graphs/glue.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs/glue.js +44 -0
- package/dist/providers/resolution/stack-graphs/glue.js.map +1 -0
- package/dist/providers/resolution/stack-graphs/node-edge-builder.d.ts +30 -0
- package/dist/providers/resolution/stack-graphs/node-edge-builder.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs/node-edge-builder.js +366 -0
- package/dist/providers/resolution/stack-graphs/node-edge-builder.js.map +1 -0
- package/dist/providers/resolution/stack-graphs/partial-path-engine.d.ts +9 -0
- package/dist/providers/resolution/stack-graphs/partial-path-engine.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs/partial-path-engine.js +152 -0
- package/dist/providers/resolution/stack-graphs/partial-path-engine.js.map +1 -0
- package/dist/providers/resolution/stack-graphs/rule-parser.d.ts +11 -0
- package/dist/providers/resolution/stack-graphs/rule-parser.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs/rule-parser.js +247 -0
- package/dist/providers/resolution/stack-graphs/rule-parser.js.map +1 -0
- package/dist/providers/resolution/stack-graphs/types.d.ts +93 -0
- package/dist/providers/resolution/stack-graphs/types.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs/types.js +11 -0
- package/dist/providers/resolution/stack-graphs/types.js.map +1 -0
- package/dist/providers/resolution/stack-graphs-python.d.ts +27 -0
- package/dist/providers/resolution/stack-graphs-python.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs-python.js +104 -0
- package/dist/providers/resolution/stack-graphs-python.js.map +1 -0
- package/dist/providers/resolution/stack-graphs-ts.d.ts +134 -0
- package/dist/providers/resolution/stack-graphs-ts.d.ts.map +1 -0
- package/dist/providers/resolution/stack-graphs-ts.js +372 -0
- package/dist/providers/resolution/stack-graphs-ts.js.map +1 -0
- package/dist/providers/ruby.d.ts +3 -0
- package/dist/providers/ruby.d.ts.map +1 -0
- package/dist/providers/ruby.js +259 -0
- package/dist/providers/ruby.js.map +1 -0
- package/dist/providers/rust.d.ts +3 -0
- package/dist/providers/rust.d.ts.map +1 -0
- package/dist/providers/rust.js +318 -0
- package/dist/providers/rust.js.map +1 -0
- package/dist/providers/swift.d.ts +3 -0
- package/dist/providers/swift.d.ts.map +1 -0
- package/dist/providers/swift.js +177 -0
- package/dist/providers/swift.js.map +1 -0
- package/dist/providers/test-helpers.d.ts +24 -0
- package/dist/providers/test-helpers.d.ts.map +1 -0
- package/dist/providers/test-helpers.js +33 -0
- package/dist/providers/test-helpers.js.map +1 -0
- package/dist/providers/ts-shared.d.ts +30 -0
- package/dist/providers/ts-shared.d.ts.map +1 -0
- package/dist/providers/ts-shared.js +328 -0
- package/dist/providers/ts-shared.js.map +1 -0
- package/dist/providers/tsx.d.ts +7 -0
- package/dist/providers/tsx.d.ts.map +1 -0
- package/dist/providers/tsx.js +79 -0
- package/dist/providers/tsx.js.map +1 -0
- package/dist/providers/types.d.ts +166 -0
- package/dist/providers/types.d.ts.map +1 -0
- package/dist/providers/types.js +7 -0
- package/dist/providers/types.js.map +1 -0
- package/dist/providers/typescript-family-accesses.d.ts +14 -0
- package/dist/providers/typescript-family-accesses.d.ts.map +1 -0
- package/dist/providers/typescript-family-accesses.js +27 -0
- package/dist/providers/typescript-family-accesses.js.map +1 -0
- package/dist/providers/typescript.d.ts +9 -0
- package/dist/providers/typescript.d.ts.map +1 -0
- package/dist/providers/typescript.js +84 -0
- package/dist/providers/typescript.js.map +1 -0
- package/package.json +108 -0
|
@@ -0,0 +1,366 @@
|
|
|
1
|
+
// Python-targeted stack-graph builder.
|
|
2
|
+
//
|
|
3
|
+
// Given a tree-sitter CST for a Python file this module produces a stack
|
|
4
|
+
// graph whose structure mirrors the intent of the vendored Python tsg rules
|
|
5
|
+
// without reusing their implementation. We inspect the parsed rule file
|
|
6
|
+
// only to guard our visitor: if the rule file lacks a pattern for a given
|
|
7
|
+
// Python construct (e.g. `module`) we skip synthesising nodes for it, so
|
|
8
|
+
// our graph never claims more structure than the vendored rules authorise.
|
|
9
|
+
//
|
|
10
|
+
// The graph we emit captures four shapes that drive Python re-export
|
|
11
|
+
// resolution:
|
|
12
|
+
// 1. module root scope + root entry/exit
|
|
13
|
+
// 2. top-level definitions (function / class / const) as pop nodes
|
|
14
|
+
// 3. import forms (import, from-import, wildcard) producing push/pop
|
|
15
|
+
// chains and ROOT edges
|
|
16
|
+
// 4. reference sites inside function bodies (call / attribute) as push
|
|
17
|
+
// nodes keyed by (line, column) so the resolver can look them up
|
|
18
|
+
//
|
|
19
|
+
// We intentionally do not model function-local scope machinery or scoped
|
|
20
|
+
// symbols — Python's class/method resolution in OpenCodeHub is handled by
|
|
21
|
+
// the C3 MRO walker; stack-graphs here specifically targets cross-module
|
|
22
|
+
// and re-export resolution.
|
|
23
|
+
function nextId(g, kind) {
|
|
24
|
+
g.seq++;
|
|
25
|
+
return `${g.file}#${kind}-${g.seq}`;
|
|
26
|
+
}
|
|
27
|
+
function addNode(g, kind, opts = {}) {
|
|
28
|
+
const id = nextId(g, kind);
|
|
29
|
+
const base = { id, kind, file: g.file };
|
|
30
|
+
const node = {
|
|
31
|
+
...base,
|
|
32
|
+
...(opts.symbol !== undefined ? { symbol: opts.symbol } : {}),
|
|
33
|
+
...(opts.definitionTarget !== undefined ? { definitionTarget: opts.definitionTarget } : {}),
|
|
34
|
+
...(opts.line !== undefined ? { line: opts.line } : {}),
|
|
35
|
+
};
|
|
36
|
+
g.nodes.set(id, node);
|
|
37
|
+
return id;
|
|
38
|
+
}
|
|
39
|
+
function addEdge(g, source, target, precedence = 0) {
|
|
40
|
+
g.edges.push({ source, target, precedence });
|
|
41
|
+
}
|
|
42
|
+
/** Iterate every named descendant breadth-first. Stable order. */
|
|
43
|
+
function* walkNamed(root) {
|
|
44
|
+
const queue = [root];
|
|
45
|
+
while (queue.length > 0) {
|
|
46
|
+
const cur = queue.shift();
|
|
47
|
+
if (cur === undefined)
|
|
48
|
+
continue;
|
|
49
|
+
yield cur;
|
|
50
|
+
for (let i = 0; i < cur.namedChildCount; i++) {
|
|
51
|
+
const c = cur.namedChild(i);
|
|
52
|
+
if (c !== null)
|
|
53
|
+
queue.push(c);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
function positionKey(line, column) {
|
|
58
|
+
return `${line}:${column}`;
|
|
59
|
+
}
|
|
60
|
+
/** Build a graph for a single Python file. */
|
|
61
|
+
export function buildStackGraph(file, tree, rules) {
|
|
62
|
+
const rootNodeId = `${file}#root`;
|
|
63
|
+
const moduleScopeId = `${file}#module-scope`;
|
|
64
|
+
const graph = {
|
|
65
|
+
file,
|
|
66
|
+
nodes: new Map(),
|
|
67
|
+
edges: [],
|
|
68
|
+
referenceIndex: new Map(),
|
|
69
|
+
rootNodeId,
|
|
70
|
+
moduleScopeId,
|
|
71
|
+
seq: 0,
|
|
72
|
+
};
|
|
73
|
+
graph.nodes.set(rootNodeId, { id: rootNodeId, kind: "root", file });
|
|
74
|
+
graph.nodes.set(moduleScopeId, { id: moduleScopeId, kind: "scope", file });
|
|
75
|
+
addEdge(graph, rootNodeId, moduleScopeId, 0);
|
|
76
|
+
// Gate visitors on the parsed rule set. A rule firing on `module` means
|
|
77
|
+
// the vendored ruleset authorises us to walk modules; missing the rule
|
|
78
|
+
// disables our synthesiser for that kind.
|
|
79
|
+
const authorised = new Set();
|
|
80
|
+
for (const rule of rules) {
|
|
81
|
+
for (const pat of rule.patterns)
|
|
82
|
+
authorised.add(pat.nodeType);
|
|
83
|
+
}
|
|
84
|
+
const root = tree.rootNode;
|
|
85
|
+
if (!authorised.has("module") && root.type !== "module") {
|
|
86
|
+
// Unknown rule set — return an empty graph so callers can fall back.
|
|
87
|
+
return finalise(graph);
|
|
88
|
+
}
|
|
89
|
+
visitTopLevel(root, graph, authorised);
|
|
90
|
+
return finalise(graph);
|
|
91
|
+
}
|
|
92
|
+
function finalise(g) {
|
|
93
|
+
return {
|
|
94
|
+
file: g.file,
|
|
95
|
+
nodes: new Map(g.nodes),
|
|
96
|
+
edges: g.edges.slice(),
|
|
97
|
+
rootNodeId: g.rootNodeId,
|
|
98
|
+
referenceIndex: new Map(g.referenceIndex),
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
/** Module-level walk — definitions, imports, and function bodies. */
|
|
102
|
+
function visitTopLevel(moduleNode, g, authorised) {
|
|
103
|
+
for (let i = 0; i < moduleNode.namedChildCount; i++) {
|
|
104
|
+
const child = moduleNode.namedChild(i);
|
|
105
|
+
if (child === null)
|
|
106
|
+
continue;
|
|
107
|
+
dispatchStatement(child, g, authorised);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
function dispatchStatement(node, g, authorised) {
|
|
111
|
+
switch (node.type) {
|
|
112
|
+
case "import_statement":
|
|
113
|
+
if (authorised.has("import_statement"))
|
|
114
|
+
handleImport(node, g);
|
|
115
|
+
break;
|
|
116
|
+
case "import_from_statement":
|
|
117
|
+
if (authorised.has("import_from_statement"))
|
|
118
|
+
handleFromImport(node, g);
|
|
119
|
+
break;
|
|
120
|
+
case "function_definition":
|
|
121
|
+
if (authorised.has("function_definition"))
|
|
122
|
+
handleFunctionDef(node, g, authorised);
|
|
123
|
+
break;
|
|
124
|
+
case "class_definition":
|
|
125
|
+
if (authorised.has("class_definition"))
|
|
126
|
+
handleClassDef(node, g, authorised);
|
|
127
|
+
break;
|
|
128
|
+
case "expression_statement":
|
|
129
|
+
// Assignment targets like `__all__ = [...]` are interpreted by the
|
|
130
|
+
// post-processor; we don't add stack-graph nodes for them.
|
|
131
|
+
break;
|
|
132
|
+
default: {
|
|
133
|
+
// Recurse into decorated defs, if statements, etc., so we still reach
|
|
134
|
+
// function/class definitions and reference sites living inside them.
|
|
135
|
+
for (const named of walkNamed(node)) {
|
|
136
|
+
if (named === node)
|
|
137
|
+
continue;
|
|
138
|
+
if (named.type === "function_definition" ||
|
|
139
|
+
named.type === "class_definition" ||
|
|
140
|
+
named.type === "import_statement" ||
|
|
141
|
+
named.type === "import_from_statement") {
|
|
142
|
+
dispatchStatement(named, g, authorised);
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
function dottedNameSegments(node) {
|
|
149
|
+
if (node.type === "identifier")
|
|
150
|
+
return [node.text];
|
|
151
|
+
if (node.type === "dotted_name") {
|
|
152
|
+
const out = [];
|
|
153
|
+
for (let i = 0; i < node.namedChildCount; i++) {
|
|
154
|
+
const c = node.namedChild(i);
|
|
155
|
+
if (c === null)
|
|
156
|
+
continue;
|
|
157
|
+
if (c.type === "identifier")
|
|
158
|
+
out.push(c.text);
|
|
159
|
+
}
|
|
160
|
+
return out;
|
|
161
|
+
}
|
|
162
|
+
return [node.text];
|
|
163
|
+
}
|
|
164
|
+
function handleImport(node, g) {
|
|
165
|
+
// `import foo.bar [as baz]` — bind `foo` (or alias) to the module path.
|
|
166
|
+
for (let i = 0; i < node.namedChildCount; i++) {
|
|
167
|
+
const child = node.namedChild(i);
|
|
168
|
+
if (child === null)
|
|
169
|
+
continue;
|
|
170
|
+
if (child.type === "dotted_name") {
|
|
171
|
+
const segments = dottedNameSegments(child);
|
|
172
|
+
if (segments.length === 0)
|
|
173
|
+
continue;
|
|
174
|
+
const head = segments[0];
|
|
175
|
+
if (head === undefined)
|
|
176
|
+
continue;
|
|
177
|
+
bindModuleAlias(g, head, segments, node.startPosition.row + 1);
|
|
178
|
+
}
|
|
179
|
+
else if (child.type === "aliased_import") {
|
|
180
|
+
const nameChild = child.childForFieldName("name");
|
|
181
|
+
const aliasChild = child.childForFieldName("alias");
|
|
182
|
+
if (nameChild === null)
|
|
183
|
+
continue;
|
|
184
|
+
const segments = dottedNameSegments(nameChild);
|
|
185
|
+
const alias = aliasChild?.text ?? segments[0];
|
|
186
|
+
if (alias === undefined)
|
|
187
|
+
continue;
|
|
188
|
+
bindModuleAlias(g, alias, segments, node.startPosition.row + 1);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
function bindModuleAlias(g, alias, targetSegments, line) {
|
|
193
|
+
// A local definition that pops the alias symbol and points to ROOT via
|
|
194
|
+
// a push chain of the target segments — so when a reference later pushes
|
|
195
|
+
// `alias`, the path lands on ROOT with `segments` still to pop.
|
|
196
|
+
const defNode = addNode(g, "pop", {
|
|
197
|
+
symbol: alias,
|
|
198
|
+
definitionTarget: targetSegments.join("."),
|
|
199
|
+
line,
|
|
200
|
+
});
|
|
201
|
+
addEdge(g, g.moduleScopeId, defNode, 1);
|
|
202
|
+
// Push chain: each segment becomes a push node in reverse order so the
|
|
203
|
+
// final edge lands on ROOT.
|
|
204
|
+
let cursor = defNode;
|
|
205
|
+
for (const segment of targetSegments) {
|
|
206
|
+
const pushNode = addNode(g, "push", { symbol: segment, line });
|
|
207
|
+
addEdge(g, cursor, pushNode, 0);
|
|
208
|
+
cursor = pushNode;
|
|
209
|
+
}
|
|
210
|
+
addEdge(g, cursor, g.rootNodeId, 0);
|
|
211
|
+
}
|
|
212
|
+
function handleFromImport(node, g) {
|
|
213
|
+
const moduleField = node.childForFieldName("module_name");
|
|
214
|
+
if (moduleField === null)
|
|
215
|
+
return;
|
|
216
|
+
const modulePath = resolveModulePath(moduleField);
|
|
217
|
+
if (modulePath === null)
|
|
218
|
+
return;
|
|
219
|
+
const names = collectImportedNames(node);
|
|
220
|
+
const line = node.startPosition.row + 1;
|
|
221
|
+
for (const binding of names) {
|
|
222
|
+
if (binding.kind === "wildcard") {
|
|
223
|
+
// Wildcard: every symbol reachable from the target module's scope
|
|
224
|
+
// becomes reachable from ours. We model this with a precedence-1
|
|
225
|
+
// edge from module-scope through a push chain to ROOT.
|
|
226
|
+
emitFromImportChain(g, null, modulePath, line, /*precedence*/ 1);
|
|
227
|
+
continue;
|
|
228
|
+
}
|
|
229
|
+
emitFromImportChain(g, binding, modulePath, line, /*precedence*/ 2);
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
function collectImportedNames(node) {
|
|
233
|
+
const out = [];
|
|
234
|
+
for (let i = 0; i < node.namedChildCount; i++) {
|
|
235
|
+
const c = node.namedChild(i);
|
|
236
|
+
if (c === null)
|
|
237
|
+
continue;
|
|
238
|
+
if (c.type === "wildcard_import") {
|
|
239
|
+
out.push({ kind: "wildcard" });
|
|
240
|
+
continue;
|
|
241
|
+
}
|
|
242
|
+
// Skip the module_name child — it appears as a named child too.
|
|
243
|
+
const moduleField = node.childForFieldName("module_name");
|
|
244
|
+
if (moduleField !== null && c === moduleField)
|
|
245
|
+
continue;
|
|
246
|
+
if (c.type === "dotted_name") {
|
|
247
|
+
const segs = dottedNameSegments(c);
|
|
248
|
+
const name = segs[0];
|
|
249
|
+
if (name !== undefined)
|
|
250
|
+
out.push({ kind: "named", local: name, imported: name });
|
|
251
|
+
}
|
|
252
|
+
else if (c.type === "aliased_import") {
|
|
253
|
+
const nameChild = c.childForFieldName("name");
|
|
254
|
+
const aliasChild = c.childForFieldName("alias");
|
|
255
|
+
if (nameChild === null)
|
|
256
|
+
continue;
|
|
257
|
+
const imported = dottedNameSegments(nameChild)[0];
|
|
258
|
+
const local = aliasChild?.text ?? imported;
|
|
259
|
+
if (imported !== undefined && local !== undefined) {
|
|
260
|
+
out.push({ kind: "named", local, imported });
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
return out;
|
|
265
|
+
}
|
|
266
|
+
function resolveModulePath(field) {
|
|
267
|
+
if (field.type === "dotted_name")
|
|
268
|
+
return dottedNameSegments(field);
|
|
269
|
+
if (field.type === "relative_import") {
|
|
270
|
+
// `from . import x` or `from ..pkg import y` — we flatten dots into
|
|
271
|
+
// leading empty segments so the resolver can interpret them later.
|
|
272
|
+
const segments = [];
|
|
273
|
+
for (let i = 0; i < field.namedChildCount; i++) {
|
|
274
|
+
const c = field.namedChild(i);
|
|
275
|
+
if (c === null)
|
|
276
|
+
continue;
|
|
277
|
+
if (c.type === "import_prefix") {
|
|
278
|
+
for (const _ of c.text)
|
|
279
|
+
segments.push("");
|
|
280
|
+
}
|
|
281
|
+
else if (c.type === "dotted_name") {
|
|
282
|
+
segments.push(...dottedNameSegments(c));
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
return segments;
|
|
286
|
+
}
|
|
287
|
+
return null;
|
|
288
|
+
}
|
|
289
|
+
function emitFromImportChain(g, binding, modulePath, line, precedence) {
|
|
290
|
+
// Definition (pop) for the locally-bound name, or a scope junction for
|
|
291
|
+
// wildcards so every push that reaches the module scope forwards on.
|
|
292
|
+
const defNode = binding === null
|
|
293
|
+
? addNode(g, "scope", { line })
|
|
294
|
+
: addNode(g, "pop", {
|
|
295
|
+
symbol: binding.local,
|
|
296
|
+
definitionTarget: `${modulePath.join(".")}.${binding.imported}`,
|
|
297
|
+
line,
|
|
298
|
+
});
|
|
299
|
+
addEdge(g, g.moduleScopeId, defNode, precedence);
|
|
300
|
+
// Emit the push chain: imported-name then each module segment in reverse.
|
|
301
|
+
let cursor = defNode;
|
|
302
|
+
if (binding !== null) {
|
|
303
|
+
const pushImported = addNode(g, "push", { symbol: binding.imported, line });
|
|
304
|
+
addEdge(g, cursor, pushImported, 0);
|
|
305
|
+
cursor = pushImported;
|
|
306
|
+
}
|
|
307
|
+
for (const segment of modulePath) {
|
|
308
|
+
if (segment === "")
|
|
309
|
+
continue; // skip relative-prefix placeholders
|
|
310
|
+
const pushSegment = addNode(g, "push", { symbol: segment, line });
|
|
311
|
+
addEdge(g, cursor, pushSegment, 0);
|
|
312
|
+
cursor = pushSegment;
|
|
313
|
+
}
|
|
314
|
+
addEdge(g, cursor, g.rootNodeId, 0);
|
|
315
|
+
}
|
|
316
|
+
function handleFunctionDef(node, g, authorised) {
|
|
317
|
+
const nameChild = node.childForFieldName("name");
|
|
318
|
+
if (nameChild === null)
|
|
319
|
+
return;
|
|
320
|
+
const line = node.startPosition.row + 1;
|
|
321
|
+
const defNode = addNode(g, "pop", {
|
|
322
|
+
symbol: nameChild.text,
|
|
323
|
+
definitionTarget: nameChild.text,
|
|
324
|
+
line,
|
|
325
|
+
});
|
|
326
|
+
addEdge(g, g.moduleScopeId, defNode, 2);
|
|
327
|
+
// Walk the body to index reference sites.
|
|
328
|
+
const body = node.childForFieldName("body");
|
|
329
|
+
if (body !== null)
|
|
330
|
+
indexReferences(body, g, authorised);
|
|
331
|
+
}
|
|
332
|
+
function handleClassDef(node, g, authorised) {
|
|
333
|
+
const nameChild = node.childForFieldName("name");
|
|
334
|
+
if (nameChild === null)
|
|
335
|
+
return;
|
|
336
|
+
const line = node.startPosition.row + 1;
|
|
337
|
+
const defNode = addNode(g, "pop", {
|
|
338
|
+
symbol: nameChild.text,
|
|
339
|
+
definitionTarget: nameChild.text,
|
|
340
|
+
line,
|
|
341
|
+
});
|
|
342
|
+
addEdge(g, g.moduleScopeId, defNode, 2);
|
|
343
|
+
const body = node.childForFieldName("body");
|
|
344
|
+
if (body !== null)
|
|
345
|
+
indexReferences(body, g, authorised);
|
|
346
|
+
}
|
|
347
|
+
function indexReferences(root, g, authorised) {
|
|
348
|
+
for (const node of walkNamed(root)) {
|
|
349
|
+
if (node.type === "identifier") {
|
|
350
|
+
if (!authorised.has("identifier"))
|
|
351
|
+
continue;
|
|
352
|
+
// Skip identifiers that are themselves names of nested defs.
|
|
353
|
+
// Heuristic: we index every identifier and rely on the resolver to
|
|
354
|
+
// filter — position-keyed lookup means false-positives are harmless.
|
|
355
|
+
const line = node.startPosition.row + 1;
|
|
356
|
+
const col = node.startPosition.column;
|
|
357
|
+
const key = positionKey(line, col);
|
|
358
|
+
if (g.referenceIndex.has(key))
|
|
359
|
+
continue;
|
|
360
|
+
const pushNode = addNode(g, "push", { symbol: node.text, line });
|
|
361
|
+
addEdge(g, pushNode, g.moduleScopeId, 0);
|
|
362
|
+
g.referenceIndex.set(key, pushNode);
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
//# sourceMappingURL=node-edge-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"node-edge-builder.js","sourceRoot":"","sources":["../../../../src/providers/resolution/stack-graphs/node-edge-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { NodeId, PartialPathResult, StackGraph } from "./types.js";
|
|
2
|
+
/** Map a graph by file path so the traversal can hop across graphs. */
|
|
3
|
+
export type GraphIndex = ReadonlyMap<string, StackGraph>;
|
|
4
|
+
/**
|
|
5
|
+
* Resolve a reference within a per-file graph. `startGraphFile` is the key
|
|
6
|
+
* into `graphs` at which the search begins.
|
|
7
|
+
*/
|
|
8
|
+
export declare function resolveReference(graphs: GraphIndex, startGraphFile: string, referenceNodeId: NodeId): PartialPathResult;
|
|
9
|
+
//# sourceMappingURL=partial-path-engine.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"partial-path-engine.d.ts","sourceRoot":"","sources":["../../../../src/providers/resolution/stack-graphs/partial-path-engine.ts"],"names":[],"mappings":"AAqBA,OAAO,KAAK,EACV,MAAM,EACN,iBAAiB,EAEjB,UAAU,EAEX,MAAM,YAAY,CAAC;AAGpB,uEAAuE;AACvE,MAAM,MAAM,UAAU,GAAG,WAAW,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;AA8BzD;;;GAGG;AACH,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,UAAU,EAClB,cAAc,EAAE,MAAM,EACtB,eAAe,EAAE,MAAM,GACtB,iBAAiB,CAwGnB"}
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
// Partial-path search engine.
|
|
2
|
+
//
|
|
3
|
+
// Given one or more stack graphs (per-file) and a starting reference node,
|
|
4
|
+
// enumerate paths whose symbol stack eventually empties at a pop node that
|
|
5
|
+
// carries a `definitionTarget`. We use BFS rather than DFS so the first
|
|
6
|
+
// result found is also the shortest — a natural ranking signal when several
|
|
7
|
+
// alternative definitions exist (e.g. conditional imports).
|
|
8
|
+
//
|
|
9
|
+
// Semantics (simplified, intentionally narrower than the full model):
|
|
10
|
+
// * Every `push` node appends its symbol to the current stack.
|
|
11
|
+
// * Every `pop` node must match the top of the stack; path is pruned if
|
|
12
|
+
// the top differs.
|
|
13
|
+
// * A path terminates successfully when it lands on a pop node whose
|
|
14
|
+
// `definitionTarget` is set and the remaining stack is empty.
|
|
15
|
+
// * `root` nodes hop to every other graph's root, enabling cross-file
|
|
16
|
+
// resolution without having to model a global scope stack.
|
|
17
|
+
//
|
|
18
|
+
// Determinism is provided by sorting each node's outgoing edges on
|
|
19
|
+
// (descending precedence, ascending target id) before expansion. That gives
|
|
20
|
+
// us reproducible traversal order regardless of insertion order.
|
|
21
|
+
import { MAX_PARTIAL_PATH_DEPTH } from "./types.js";
|
|
22
|
+
function edgeSortKey(e) {
|
|
23
|
+
// Sort by descending precedence (higher first), then ascending target id
|
|
24
|
+
// to keep iteration deterministic across runs.
|
|
25
|
+
const invPrec = String(10_000 - e.precedence).padStart(6, "0");
|
|
26
|
+
return `${invPrec}|${e.target}`;
|
|
27
|
+
}
|
|
28
|
+
function outgoingEdges(graph, nodeId) {
|
|
29
|
+
const out = [];
|
|
30
|
+
for (const e of graph.edges) {
|
|
31
|
+
if (e.source === nodeId)
|
|
32
|
+
out.push(e);
|
|
33
|
+
}
|
|
34
|
+
return out.sort((a, b) => (edgeSortKey(a) < edgeSortKey(b) ? -1 : 1));
|
|
35
|
+
}
|
|
36
|
+
function makeVisitedKey(graphFile, nodeId, stack) {
|
|
37
|
+
return `${graphFile}|${nodeId}|${stack.join(">")}`;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Resolve a reference within a per-file graph. `startGraphFile` is the key
|
|
41
|
+
* into `graphs` at which the search begins.
|
|
42
|
+
*/
|
|
43
|
+
export function resolveReference(graphs, startGraphFile, referenceNodeId) {
|
|
44
|
+
const startGraph = graphs.get(startGraphFile);
|
|
45
|
+
if (startGraph === undefined)
|
|
46
|
+
return { results: [], truncated: false };
|
|
47
|
+
const startNode = startGraph.nodes.get(referenceNodeId);
|
|
48
|
+
if (startNode === undefined)
|
|
49
|
+
return { results: [], truncated: false };
|
|
50
|
+
const results = [];
|
|
51
|
+
const visited = new Set();
|
|
52
|
+
const initialStack = startNode.symbol === undefined ? [] : [startNode.symbol];
|
|
53
|
+
const queue = [];
|
|
54
|
+
queue.push({
|
|
55
|
+
nodeId: referenceNodeId,
|
|
56
|
+
graphFile: startGraphFile,
|
|
57
|
+
symbolStack: initialStack,
|
|
58
|
+
depth: 0,
|
|
59
|
+
visitedKey: makeVisitedKey(startGraphFile, referenceNodeId, initialStack),
|
|
60
|
+
});
|
|
61
|
+
visited.add(queue[0]?.visitedKey ?? "");
|
|
62
|
+
let truncated = false;
|
|
63
|
+
while (queue.length > 0) {
|
|
64
|
+
const current = queue.shift();
|
|
65
|
+
if (current === undefined)
|
|
66
|
+
continue;
|
|
67
|
+
if (current.depth > MAX_PARTIAL_PATH_DEPTH) {
|
|
68
|
+
truncated = true;
|
|
69
|
+
continue;
|
|
70
|
+
}
|
|
71
|
+
const graph = graphs.get(current.graphFile);
|
|
72
|
+
if (graph === undefined)
|
|
73
|
+
continue;
|
|
74
|
+
const node = graph.nodes.get(current.nodeId);
|
|
75
|
+
if (node === undefined)
|
|
76
|
+
continue;
|
|
77
|
+
// Successful termination: we landed on a pop node whose own symbol
|
|
78
|
+
// has already been consumed via the inbound edge traversal (stack.length
|
|
79
|
+
// now zero) AND the node advertises a definitionTarget.
|
|
80
|
+
if (node.kind === "pop" &&
|
|
81
|
+
node.definitionTarget !== undefined &&
|
|
82
|
+
current.symbolStack.length === 0) {
|
|
83
|
+
results.push({
|
|
84
|
+
targetNodeId: node.id,
|
|
85
|
+
targetKey: `${graph.file}:${node.line ?? 0}:${node.definitionTarget}`,
|
|
86
|
+
pathLength: current.depth,
|
|
87
|
+
});
|
|
88
|
+
// Don't continue from a successful terminal — any further traversal
|
|
89
|
+
// would leave the stack empty and then try to pop with nothing to
|
|
90
|
+
// pop, which is semantically invalid.
|
|
91
|
+
continue;
|
|
92
|
+
}
|
|
93
|
+
// Cross-graph hop at root nodes.
|
|
94
|
+
if (node.kind === "root") {
|
|
95
|
+
for (const [otherFile, otherGraph] of graphs) {
|
|
96
|
+
if (otherFile === current.graphFile)
|
|
97
|
+
continue;
|
|
98
|
+
const key = makeVisitedKey(otherFile, otherGraph.rootNodeId, current.symbolStack);
|
|
99
|
+
if (visited.has(key))
|
|
100
|
+
continue;
|
|
101
|
+
visited.add(key);
|
|
102
|
+
queue.push({
|
|
103
|
+
nodeId: otherGraph.rootNodeId,
|
|
104
|
+
graphFile: otherFile,
|
|
105
|
+
symbolStack: current.symbolStack,
|
|
106
|
+
depth: current.depth + 1,
|
|
107
|
+
visitedKey: key,
|
|
108
|
+
});
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
for (const edge of outgoingEdges(graph, current.nodeId)) {
|
|
112
|
+
const nextNode = graph.nodes.get(edge.target);
|
|
113
|
+
if (nextNode === undefined)
|
|
114
|
+
continue;
|
|
115
|
+
let nextStack = current.symbolStack;
|
|
116
|
+
if (nextNode.kind === "push" && nextNode.symbol !== undefined) {
|
|
117
|
+
nextStack = [...current.symbolStack, nextNode.symbol];
|
|
118
|
+
}
|
|
119
|
+
else if (nextNode.kind === "pop" && nextNode.symbol !== undefined) {
|
|
120
|
+
const top = current.symbolStack[current.symbolStack.length - 1];
|
|
121
|
+
if (top !== nextNode.symbol) {
|
|
122
|
+
// Pop mismatch — prune.
|
|
123
|
+
nextStack = null;
|
|
124
|
+
}
|
|
125
|
+
else {
|
|
126
|
+
nextStack = current.symbolStack.slice(0, -1);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
if (nextStack === null)
|
|
130
|
+
continue;
|
|
131
|
+
const key = makeVisitedKey(current.graphFile, edge.target, nextStack);
|
|
132
|
+
if (visited.has(key))
|
|
133
|
+
continue;
|
|
134
|
+
visited.add(key);
|
|
135
|
+
queue.push({
|
|
136
|
+
nodeId: edge.target,
|
|
137
|
+
graphFile: current.graphFile,
|
|
138
|
+
symbolStack: nextStack,
|
|
139
|
+
depth: current.depth + 1,
|
|
140
|
+
visitedKey: key,
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
// Sort by path length (shorter first) for deterministic output.
|
|
145
|
+
results.sort((a, b) => {
|
|
146
|
+
if (a.pathLength !== b.pathLength)
|
|
147
|
+
return a.pathLength - b.pathLength;
|
|
148
|
+
return a.targetKey < b.targetKey ? -1 : 1;
|
|
149
|
+
});
|
|
150
|
+
return { results, truncated };
|
|
151
|
+
}
|
|
152
|
+
//# sourceMappingURL=partial-path-engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"partial-path-engine.js","sourceRoot":"","sources":["../../../../src/providers/resolution/stack-graphs/partial-path-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { TsgRule } from "./types.js";
|
|
2
|
+
/** Result of parsing a tsg source file. */
|
|
3
|
+
export interface ParsedTsg {
|
|
4
|
+
readonly rules: readonly TsgRule[];
|
|
5
|
+
readonly globals: readonly string[];
|
|
6
|
+
readonly attributeShorthands: readonly string[];
|
|
7
|
+
readonly warnings: readonly string[];
|
|
8
|
+
}
|
|
9
|
+
/** Parse a .tsg source string into a set of rules plus ancillary decls. */
|
|
10
|
+
export declare function parseTsg(source: string): ParsedTsg;
|
|
11
|
+
//# sourceMappingURL=rule-parser.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rule-parser.d.ts","sourceRoot":"","sources":["../../../../src/providers/resolution/stack-graphs/rule-parser.ts"],"names":[],"mappings":"AAmBA,OAAO,KAAK,EAAsC,OAAO,EAAE,MAAM,YAAY,CAAC;AAwF9E,2CAA2C;AAC3C,MAAM,WAAW,SAAS;IACxB,QAAQ,CAAC,KAAK,EAAE,SAAS,OAAO,EAAE,CAAC;IACnC,QAAQ,CAAC,OAAO,EAAE,SAAS,MAAM,EAAE,CAAC;IACpC,QAAQ,CAAC,mBAAmB,EAAE,SAAS,MAAM,EAAE,CAAC;IAChD,QAAQ,CAAC,QAAQ,EAAE,SAAS,MAAM,EAAE,CAAC;CACtC;AAED,2EAA2E;AAC3E,wBAAgB,QAAQ,CAAC,MAAM,EAAE,MAAM,GAAG,SAAS,CAwIlD"}
|