context-probe 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 +183 -0
- package/README.ja.md +323 -0
- package/README.md +323 -0
- package/dist/src/analyzers/architecture-contract-declarations-dart.d.ts +2 -0
- package/dist/src/analyzers/architecture-contract-declarations-dart.js +129 -0
- package/dist/src/analyzers/architecture-contract-declarations-ecma-core.d.ts +2 -0
- package/dist/src/analyzers/architecture-contract-declarations-ecma-core.js +89 -0
- package/dist/src/analyzers/architecture-contract-declarations-ecma-shared.d.ts +10 -0
- package/dist/src/analyzers/architecture-contract-declarations-ecma-shared.js +56 -0
- package/dist/src/analyzers/architecture-contract-declarations-ecma.d.ts +1 -0
- package/dist/src/analyzers/architecture-contract-declarations-ecma.js +1 -0
- package/dist/src/analyzers/architecture-contract-declarations-shared.d.ts +8 -0
- package/dist/src/analyzers/architecture-contract-declarations-shared.js +21 -0
- package/dist/src/analyzers/architecture-contract-declarations.d.ts +2 -0
- package/dist/src/analyzers/architecture-contract-declarations.js +2 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-analysis.d.ts +8 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-analysis.js +70 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-core.d.ts +8 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-core.js +4 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-entry.d.ts +19 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-entry.js +89 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-scope.d.ts +8 -0
- package/dist/src/analyzers/architecture-contract-score-baseline-scope.js +18 -0
- package/dist/src/analyzers/architecture-contract-score-baseline.d.ts +1 -0
- package/dist/src/analyzers/architecture-contract-score-baseline.js +1 -0
- package/dist/src/analyzers/architecture-contract-score-current.d.ts +3 -0
- package/dist/src/analyzers/architecture-contract-score-current.js +39 -0
- package/dist/src/analyzers/architecture-contract-score-shared.d.ts +18 -0
- package/dist/src/analyzers/architecture-contract-score-shared.js +9 -0
- package/dist/src/analyzers/architecture-contract-scoring.d.ts +15 -0
- package/dist/src/analyzers/architecture-contract-scoring.js +70 -0
- package/dist/src/analyzers/architecture-contract-stats-core.d.ts +9 -0
- package/dist/src/analyzers/architecture-contract-stats-core.js +20 -0
- package/dist/src/analyzers/architecture-contract-stats-file.d.ts +23 -0
- package/dist/src/analyzers/architecture-contract-stats-file.js +77 -0
- package/dist/src/analyzers/architecture-contract-stats.d.ts +2 -0
- package/dist/src/analyzers/architecture-contract-stats.js +1 -0
- package/dist/src/analyzers/architecture-contract-types.d.ts +24 -0
- package/dist/src/analyzers/architecture-contract-types.js +1 -0
- package/dist/src/analyzers/architecture-contracts.d.ts +2 -0
- package/dist/src/analyzers/architecture-contracts.js +1 -0
- package/dist/src/analyzers/architecture-cti-ingest.d.ts +19 -0
- package/dist/src/analyzers/architecture-cti-ingest.js +64 -0
- package/dist/src/analyzers/architecture-delivery-normalization-core.d.ts +6 -0
- package/dist/src/analyzers/architecture-delivery-normalization-core.js +83 -0
- package/dist/src/analyzers/architecture-delivery-normalization-shared.d.ts +16 -0
- package/dist/src/analyzers/architecture-delivery-normalization-shared.js +1 -0
- package/dist/src/analyzers/architecture-delivery-normalization-spec.d.ts +13 -0
- package/dist/src/analyzers/architecture-delivery-normalization-spec.js +52 -0
- package/dist/src/analyzers/architecture-delivery-normalization.d.ts +6 -0
- package/dist/src/analyzers/architecture-delivery-normalization.js +4 -0
- package/dist/src/analyzers/architecture-evolution-efficiency.d.ts +8 -0
- package/dist/src/analyzers/architecture-evolution-efficiency.js +76 -0
- package/dist/src/analyzers/architecture-evolution-locality.d.ts +7 -0
- package/dist/src/analyzers/architecture-evolution-locality.js +129 -0
- package/dist/src/analyzers/architecture-evolution-shared.d.ts +33 -0
- package/dist/src/analyzers/architecture-evolution-shared.js +29 -0
- package/dist/src/analyzers/architecture-evolution.d.ts +3 -0
- package/dist/src/analyzers/architecture-evolution.js +2 -0
- package/dist/src/analyzers/architecture-observation-ingest-delivery.d.ts +9 -0
- package/dist/src/analyzers/architecture-observation-ingest-delivery.js +62 -0
- package/dist/src/analyzers/architecture-observation-ingest-shared.d.ts +13 -0
- package/dist/src/analyzers/architecture-observation-ingest-shared.js +12 -0
- package/dist/src/analyzers/architecture-observation-ingest-telemetry.d.ts +10 -0
- package/dist/src/analyzers/architecture-observation-ingest-telemetry.js +71 -0
- package/dist/src/analyzers/architecture-observation-ingest.d.ts +5 -0
- package/dist/src/analyzers/architecture-observation-ingest.js +2 -0
- package/dist/src/analyzers/architecture-observation-normalization-shared.d.ts +10 -0
- package/dist/src/analyzers/architecture-observation-normalization-shared.js +19 -0
- package/dist/src/analyzers/architecture-operations-common-ops.d.ts +16 -0
- package/dist/src/analyzers/architecture-operations-common-ops.js +76 -0
- package/dist/src/analyzers/architecture-operations.d.ts +27 -0
- package/dist/src/analyzers/architecture-operations.js +56 -0
- package/dist/src/analyzers/architecture-pattern-runtime-fallback.d.ts +8 -0
- package/dist/src/analyzers/architecture-pattern-runtime-fallback.js +79 -0
- package/dist/src/analyzers/architecture-pattern-runtime-family.d.ts +7 -0
- package/dist/src/analyzers/architecture-pattern-runtime-family.js +56 -0
- package/dist/src/analyzers/architecture-pattern-runtime-normalization-blocks.d.ts +12 -0
- package/dist/src/analyzers/architecture-pattern-runtime-normalization-blocks.js +41 -0
- package/dist/src/analyzers/architecture-pattern-runtime-normalization-math.d.ts +10 -0
- package/dist/src/analyzers/architecture-pattern-runtime-normalization-math.js +19 -0
- package/dist/src/analyzers/architecture-pattern-runtime-normalization.d.ts +21 -0
- package/dist/src/analyzers/architecture-pattern-runtime-normalization.js +103 -0
- package/dist/src/analyzers/architecture-pattern-runtime-resolution-shared.d.ts +16 -0
- package/dist/src/analyzers/architecture-pattern-runtime-resolution-shared.js +65 -0
- package/dist/src/analyzers/architecture-pattern-runtime-resolution.d.ts +15 -0
- package/dist/src/analyzers/architecture-pattern-runtime-resolution.js +99 -0
- package/dist/src/analyzers/architecture-pattern-runtime-shared.d.ts +2 -0
- package/dist/src/analyzers/architecture-pattern-runtime-shared.js +1 -0
- package/dist/src/analyzers/architecture-pattern-runtime-types.d.ts +29 -0
- package/dist/src/analyzers/architecture-pattern-runtime-types.js +1 -0
- package/dist/src/analyzers/architecture-pattern-runtime.d.ts +7 -0
- package/dist/src/analyzers/architecture-pattern-runtime.js +20 -0
- package/dist/src/analyzers/architecture-purity-signals.d.ts +6 -0
- package/dist/src/analyzers/architecture-purity-signals.js +21 -0
- package/dist/src/analyzers/architecture-purity.d.ts +2 -0
- package/dist/src/analyzers/architecture-purity.js +1 -0
- package/dist/src/analyzers/architecture-scenarios.d.ts +22 -0
- package/dist/src/analyzers/architecture-scenarios.js +95 -0
- package/dist/src/analyzers/architecture-source-loader-command.d.ts +8 -0
- package/dist/src/analyzers/architecture-source-loader-command.js +73 -0
- package/dist/src/analyzers/architecture-source-loader-core.d.ts +22 -0
- package/dist/src/analyzers/architecture-source-loader-core.js +41 -0
- package/dist/src/analyzers/architecture-source-loader-file.d.ts +8 -0
- package/dist/src/analyzers/architecture-source-loader-file.js +28 -0
- package/dist/src/analyzers/architecture-source-loader-shared.d.ts +24 -0
- package/dist/src/analyzers/architecture-source-loader-shared.js +4 -0
- package/dist/src/analyzers/architecture-source-loader.d.ts +2 -0
- package/dist/src/analyzers/architecture-source-loader.js +1 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-band.d.ts +10 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-band.js +78 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-core.d.ts +6 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-core.js +30 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-shared.d.ts +16 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-shared.js +1 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-spec.d.ts +10 -0
- package/dist/src/analyzers/architecture-telemetry-normalization-spec.js +20 -0
- package/dist/src/analyzers/architecture-telemetry-normalization.d.ts +6 -0
- package/dist/src/analyzers/architecture-telemetry-normalization.js +4 -0
- package/dist/src/analyzers/architecture-topology-core.d.ts +7 -0
- package/dist/src/analyzers/architecture-topology-core.js +4 -0
- package/dist/src/analyzers/architecture-topology-shared.d.ts +2 -0
- package/dist/src/analyzers/architecture-topology-shared.js +9 -0
- package/dist/src/analyzers/architecture-topology-signals.d.ts +21 -0
- package/dist/src/analyzers/architecture-topology-signals.js +98 -0
- package/dist/src/analyzers/architecture-topology.d.ts +2 -0
- package/dist/src/analyzers/architecture-topology.js +1 -0
- package/dist/src/analyzers/architecture.d.ts +16 -0
- package/dist/src/analyzers/architecture.js +44 -0
- package/dist/src/analyzers/code-contracts.d.ts +4 -0
- package/dist/src/analyzers/code-contracts.js +74 -0
- package/dist/src/analyzers/code-dart.d.ts +3 -0
- package/dist/src/analyzers/code-dart.js +57 -0
- package/dist/src/analyzers/code-ecma.d.ts +2 -0
- package/dist/src/analyzers/code-ecma.js +53 -0
- package/dist/src/analyzers/code-shared.d.ts +19 -0
- package/dist/src/analyzers/code-shared.js +64 -0
- package/dist/src/analyzers/code.d.ts +3 -0
- package/dist/src/analyzers/code.js +34 -0
- package/dist/src/analyzers/contract-files.d.ts +13 -0
- package/dist/src/analyzers/contract-files.js +80 -0
- package/dist/src/analyzers/cti-complexity-components.d.ts +12 -0
- package/dist/src/analyzers/cti-complexity-components.js +83 -0
- package/dist/src/analyzers/cti-complexity-recorder.d.ts +31 -0
- package/dist/src/analyzers/cti-complexity-recorder.js +58 -0
- package/dist/src/analyzers/cti-complexity.d.ts +7 -0
- package/dist/src/analyzers/cti-complexity.js +15 -0
- package/dist/src/analyzers/cti-helpers.d.ts +7 -0
- package/dist/src/analyzers/cti-helpers.js +40 -0
- package/dist/src/analyzers/cti.d.ts +2 -0
- package/dist/src/analyzers/cti.js +1 -0
- package/dist/src/cli.d.ts +2 -0
- package/dist/src/cli.js +95 -0
- package/dist/src/command-architecture-inputs-loaders-config.d.ts +24 -0
- package/dist/src/command-architecture-inputs-loaders-config.js +17 -0
- package/dist/src/command-architecture-inputs-loaders-data.d.ts +22 -0
- package/dist/src/command-architecture-inputs-loaders-data.js +105 -0
- package/dist/src/command-architecture-inputs-loaders.d.ts +42 -0
- package/dist/src/command-architecture-inputs-loaders.js +12 -0
- package/dist/src/command-architecture-inputs-provenance.d.ts +2 -0
- package/dist/src/command-architecture-inputs-provenance.js +29 -0
- package/dist/src/command-architecture-inputs-resolved.d.ts +44 -0
- package/dist/src/command-architecture-inputs-resolved.js +72 -0
- package/dist/src/command-architecture-inputs-sources.d.ts +2 -0
- package/dist/src/command-architecture-inputs-sources.js +1 -0
- package/dist/src/command-architecture-inputs.d.ts +4 -0
- package/dist/src/command-architecture-inputs.js +63 -0
- package/dist/src/command-architecture.d.ts +2 -0
- package/dist/src/command-architecture.js +35 -0
- package/dist/src/command-domain.d.ts +2 -0
- package/dist/src/command-domain.js +124 -0
- package/dist/src/command-extraction-helpers.d.ts +13 -0
- package/dist/src/command-extraction-helpers.js +33 -0
- package/dist/src/command-helpers.d.ts +4 -0
- package/dist/src/command-helpers.js +3 -0
- package/dist/src/command-history.d.ts +2 -0
- package/dist/src/command-history.js +61 -0
- package/dist/src/command-input-loaders-architecture-compat-delivery-complexity.d.ts +3 -0
- package/dist/src/command-input-loaders-architecture-compat-delivery-complexity.js +132 -0
- package/dist/src/command-input-loaders-architecture-compat-pattern-runtime.d.ts +2 -0
- package/dist/src/command-input-loaders-architecture-compat-pattern-runtime.js +54 -0
- package/dist/src/command-input-loaders-architecture-compat-scenario.d.ts +3 -0
- package/dist/src/command-input-loaders-architecture-compat-scenario.js +94 -0
- package/dist/src/command-input-loaders-architecture-compat-shared.d.ts +17 -0
- package/dist/src/command-input-loaders-architecture-compat-shared.js +109 -0
- package/dist/src/command-input-loaders-architecture-compat-telemetry.d.ts +3 -0
- package/dist/src/command-input-loaders-architecture-compat-telemetry.js +137 -0
- package/dist/src/command-input-loaders-architecture-compat-topology-boundary.d.ts +3 -0
- package/dist/src/command-input-loaders-architecture-compat-topology-boundary.js +178 -0
- package/dist/src/command-input-loaders-architecture-compat.d.ts +4 -0
- package/dist/src/command-input-loaders-architecture-compat.js +4 -0
- package/dist/src/command-input-loaders-architecture-config.d.ts +34 -0
- package/dist/src/command-input-loaders-architecture-config.js +25 -0
- package/dist/src/command-input-loaders-architecture-data.d.ts +17 -0
- package/dist/src/command-input-loaders-architecture-data.js +47 -0
- package/dist/src/command-input-loaders-architecture.d.ts +2 -0
- package/dist/src/command-input-loaders-architecture.js +2 -0
- package/dist/src/command-input-loaders-core.d.ts +20 -0
- package/dist/src/command-input-loaders-core.js +58 -0
- package/dist/src/command-input-loaders.d.ts +2 -0
- package/dist/src/command-input-loaders.js +2 -0
- package/dist/src/command-path-helpers.d.ts +6 -0
- package/dist/src/command-path-helpers.js +15 -0
- package/dist/src/command-score-driven.d.ts +19 -0
- package/dist/src/command-score-driven.js +96 -0
- package/dist/src/command-score.d.ts +3 -0
- package/dist/src/command-score.js +78 -0
- package/dist/src/command-shadow-rollout-batch.d.ts +5 -0
- package/dist/src/command-shadow-rollout-batch.js +85 -0
- package/dist/src/command-shadow-rollout-gate.d.ts +5 -0
- package/dist/src/command-shadow-rollout-gate.js +33 -0
- package/dist/src/command-shadow-rollout-observe.d.ts +5 -0
- package/dist/src/command-shadow-rollout-observe.js +43 -0
- package/dist/src/command-shadow-rollout-shared.d.ts +4 -0
- package/dist/src/command-shadow-rollout-shared.js +23 -0
- package/dist/src/command-shadow-rollout.d.ts +2 -0
- package/dist/src/command-shadow-rollout.js +16 -0
- package/dist/src/command-types.d.ts +4 -0
- package/dist/src/command-types.js +1 -0
- package/dist/src/commands.d.ts +6 -0
- package/dist/src/commands.js +66 -0
- package/dist/src/core/aggregate-fitness-core.d.ts +24 -0
- package/dist/src/core/aggregate-fitness-core.js +40 -0
- package/dist/src/core/aggregate-fitness-evidence.d.ts +2 -0
- package/dist/src/core/aggregate-fitness-evidence.js +24 -0
- package/dist/src/core/aggregate-fitness-mapping.d.ts +17 -0
- package/dist/src/core/aggregate-fitness-mapping.js +57 -0
- package/dist/src/core/aggregate-fitness-scoring.d.ts +24 -0
- package/dist/src/core/aggregate-fitness-scoring.js +71 -0
- package/dist/src/core/aggregate-fitness-shared.d.ts +21 -0
- package/dist/src/core/aggregate-fitness-shared.js +127 -0
- package/dist/src/core/aggregate-fitness.d.ts +2 -0
- package/dist/src/core/aggregate-fitness.js +1 -0
- package/dist/src/core/architecture-purity-core.d.ts +3 -0
- package/dist/src/core/architecture-purity-core.js +94 -0
- package/dist/src/core/architecture-purity-types.d.ts +18 -0
- package/dist/src/core/architecture-purity-types.js +1 -0
- package/dist/src/core/architecture-scenario-quality.d.ts +5 -0
- package/dist/src/core/architecture-scenario-quality.js +52 -0
- package/dist/src/core/architecture-scoring-evidence-architecture.d.ts +10 -0
- package/dist/src/core/architecture-scoring-evidence-architecture.js +50 -0
- package/dist/src/core/architecture-scoring-evidence-findings.d.ts +2 -0
- package/dist/src/core/architecture-scoring-evidence-findings.js +2 -0
- package/dist/src/core/architecture-scoring-evidence-inputs-ingest.d.ts +5 -0
- package/dist/src/core/architecture-scoring-evidence-inputs-ingest.js +68 -0
- package/dist/src/core/architecture-scoring-evidence-inputs-shared.d.ts +20 -0
- package/dist/src/core/architecture-scoring-evidence-inputs-shared.js +24 -0
- package/dist/src/core/architecture-scoring-evidence-inputs-source.d.ts +7 -0
- package/dist/src/core/architecture-scoring-evidence-inputs-source.js +16 -0
- package/dist/src/core/architecture-scoring-evidence-inputs.d.ts +2 -0
- package/dist/src/core/architecture-scoring-evidence-inputs.js +2 -0
- package/dist/src/core/architecture-scoring-evidence-observability.d.ts +12 -0
- package/dist/src/core/architecture-scoring-evidence-observability.js +75 -0
- package/dist/src/core/architecture-scoring-evidence.d.ts +30 -0
- package/dist/src/core/architecture-scoring-evidence.js +76 -0
- package/dist/src/core/architecture-scoring-evolution-inputs.d.ts +10 -0
- package/dist/src/core/architecture-scoring-evolution-inputs.js +56 -0
- package/dist/src/core/architecture-scoring-inputs-complexity.d.ts +7 -0
- package/dist/src/core/architecture-scoring-inputs-complexity.js +24 -0
- package/dist/src/core/architecture-scoring-inputs-observability.d.ts +11 -0
- package/dist/src/core/architecture-scoring-inputs-observability.js +84 -0
- package/dist/src/core/architecture-scoring-inputs-static.d.ts +13 -0
- package/dist/src/core/architecture-scoring-inputs-static.js +48 -0
- package/dist/src/core/architecture-scoring-inputs.d.ts +9 -0
- package/dist/src/core/architecture-scoring-inputs.js +16 -0
- package/dist/src/core/architecture-scoring-metric-shared.d.ts +11 -0
- package/dist/src/core/architecture-scoring-metric-shared.js +3 -0
- package/dist/src/core/architecture-scoring-metrics-composite.d.ts +3 -0
- package/dist/src/core/architecture-scoring-metrics-composite.js +56 -0
- package/dist/src/core/architecture-scoring-metrics-core.d.ts +3 -0
- package/dist/src/core/architecture-scoring-metrics-core.js +81 -0
- package/dist/src/core/architecture-scoring-metrics-evolution.d.ts +3 -0
- package/dist/src/core/architecture-scoring-metrics-evolution.js +74 -0
- package/dist/src/core/architecture-scoring-metrics-runtime.d.ts +3 -0
- package/dist/src/core/architecture-scoring-metrics-runtime.js +68 -0
- package/dist/src/core/architecture-scoring-metrics.d.ts +4 -0
- package/dist/src/core/architecture-scoring-metrics.js +14 -0
- package/dist/src/core/architecture-scoring-types.d.ts +94 -0
- package/dist/src/core/architecture-scoring-types.js +1 -0
- package/dist/src/core/architecture-scoring.d.ts +9 -0
- package/dist/src/core/architecture-scoring.js +82 -0
- package/dist/src/core/artifacts.d.ts +3 -0
- package/dist/src/core/artifacts.js +58 -0
- package/dist/src/core/boundary-fitness-attraction.d.ts +4 -0
- package/dist/src/core/boundary-fitness-attraction.js +11 -0
- package/dist/src/core/boundary-fitness-contexts.d.ts +7 -0
- package/dist/src/core/boundary-fitness-contexts.js +80 -0
- package/dist/src/core/boundary-fitness-core.d.ts +28 -0
- package/dist/src/core/boundary-fitness-core.js +132 -0
- package/dist/src/core/boundary-fitness-evidence.d.ts +17 -0
- package/dist/src/core/boundary-fitness-evidence.js +27 -0
- package/dist/src/core/boundary-fitness-separation.d.ts +13 -0
- package/dist/src/core/boundary-fitness-separation.js +14 -0
- package/dist/src/core/boundary-fitness-shared.d.ts +3 -0
- package/dist/src/core/boundary-fitness-shared.js +17 -0
- package/dist/src/core/boundary-fitness-signals.d.ts +21 -0
- package/dist/src/core/boundary-fitness-signals.js +104 -0
- package/dist/src/core/boundary-fitness.d.ts +3 -0
- package/dist/src/core/boundary-fitness.js +2 -0
- package/dist/src/core/command-analytics.d.ts +32 -0
- package/dist/src/core/command-analytics.js +80 -0
- package/dist/src/core/contracts/analysis.d.ts +105 -0
- package/dist/src/core/contracts/analysis.js +1 -0
- package/dist/src/core/contracts/architecture-complexity.d.ts +20 -0
- package/dist/src/core/contracts/architecture-complexity.js +1 -0
- package/dist/src/core/contracts/architecture-constraints.d.ts +62 -0
- package/dist/src/core/contracts/architecture-constraints.js +1 -0
- package/dist/src/core/contracts/architecture-contract-baseline.d.ts +33 -0
- package/dist/src/core/contracts/architecture-contract-baseline.js +1 -0
- package/dist/src/core/contracts/architecture-delivery.d.ts +42 -0
- package/dist/src/core/contracts/architecture-delivery.js +1 -0
- package/dist/src/core/contracts/architecture-normalization.d.ts +6 -0
- package/dist/src/core/contracts/architecture-normalization.js +1 -0
- package/dist/src/core/contracts/architecture-pattern-runtime.d.ts +69 -0
- package/dist/src/core/contracts/architecture-pattern-runtime.js +1 -0
- package/dist/src/core/contracts/architecture-scenarios.d.ts +62 -0
- package/dist/src/core/contracts/architecture-scenarios.js +1 -0
- package/dist/src/core/contracts/architecture-telemetry.d.ts +47 -0
- package/dist/src/core/contracts/architecture-telemetry.js +1 -0
- package/dist/src/core/contracts/architecture-topology.d.ts +35 -0
- package/dist/src/core/contracts/architecture-topology.js +1 -0
- package/dist/src/core/contracts/architecture.d.ts +9 -0
- package/dist/src/core/contracts/architecture.js +9 -0
- package/dist/src/core/contracts/common.d.ts +87 -0
- package/dist/src/core/contracts/common.js +1 -0
- package/dist/src/core/contracts/domain-design-score.d.ts +14 -0
- package/dist/src/core/contracts/domain-design-score.js +1 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-batch.d.ts +58 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-batch.js +1 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-gate.d.ts +46 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-gate.js +1 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-observation.d.ts +17 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-observation.js +1 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-registry.d.ts +15 -0
- package/dist/src/core/contracts/domain-design-shadow-rollout-registry.js +1 -0
- package/dist/src/core/contracts/domain-design.d.ts +5 -0
- package/dist/src/core/contracts/domain-design.js +5 -0
- package/dist/src/core/contracts/domain-model.d.ts +35 -0
- package/dist/src/core/contracts/domain-model.js +1 -0
- package/dist/src/core/contracts/governance-extraction.d.ts +65 -0
- package/dist/src/core/contracts/governance-extraction.js +1 -0
- package/dist/src/core/contracts/governance-policy.d.ts +23 -0
- package/dist/src/core/contracts/governance-policy.js +1 -0
- package/dist/src/core/contracts/governance-review.d.ts +31 -0
- package/dist/src/core/contracts/governance-review.js +1 -0
- package/dist/src/core/contracts/governance-runtime.d.ts +12 -0
- package/dist/src/core/contracts/governance-runtime.js +1 -0
- package/dist/src/core/contracts/governance-scoring.d.ts +41 -0
- package/dist/src/core/contracts/governance-scoring.js +1 -0
- package/dist/src/core/contracts/governance.d.ts +5 -0
- package/dist/src/core/contracts/governance.js +5 -0
- package/dist/src/core/contracts.d.ts +6 -0
- package/dist/src/core/contracts.js +6 -0
- package/dist/src/core/document-extractor-glossary.d.ts +3 -0
- package/dist/src/core/document-extractor-glossary.js +90 -0
- package/dist/src/core/document-extractor-identity.d.ts +18 -0
- package/dist/src/core/document-extractor-identity.js +37 -0
- package/dist/src/core/document-extractor-shared.d.ts +3 -0
- package/dist/src/core/document-extractor-shared.js +2 -0
- package/dist/src/core/document-extractor-statements-classification-cli.d.ts +3 -0
- package/dist/src/core/document-extractor-statements-classification-cli.js +50 -0
- package/dist/src/core/document-extractor-statements-classification-core.d.ts +17 -0
- package/dist/src/core/document-extractor-statements-classification-core.js +91 -0
- package/dist/src/core/document-extractor-statements-classification-heuristic.d.ts +3 -0
- package/dist/src/core/document-extractor-statements-classification-heuristic.js +32 -0
- package/dist/src/core/document-extractor-statements-classification.d.ts +2 -0
- package/dist/src/core/document-extractor-statements-classification.js +2 -0
- package/dist/src/core/document-extractor-statements-segments.d.ts +3 -0
- package/dist/src/core/document-extractor-statements-segments.js +38 -0
- package/dist/src/core/document-extractor-statements.d.ts +1 -0
- package/dist/src/core/document-extractor-statements.js +1 -0
- package/dist/src/core/document-extractor-text-normalization.d.ts +5 -0
- package/dist/src/core/document-extractor-text-normalization.js +29 -0
- package/dist/src/core/document-extractor-text-review.d.ts +3 -0
- package/dist/src/core/document-extractor-text-review.js +15 -0
- package/dist/src/core/document-extractor-text-signals.d.ts +11 -0
- package/dist/src/core/document-extractor-text-signals.js +115 -0
- package/dist/src/core/document-extractor-text.d.ts +3 -0
- package/dist/src/core/document-extractor-text.js +3 -0
- package/dist/src/core/document-extractor-types.d.ts +30 -0
- package/dist/src/core/document-extractor-types.js +1 -0
- package/dist/src/core/document-extractors-review.d.ts +4 -0
- package/dist/src/core/document-extractors-review.js +10 -0
- package/dist/src/core/document-extractors-runner.d.ts +15 -0
- package/dist/src/core/document-extractors-runner.js +31 -0
- package/dist/src/core/document-extractors.d.ts +24 -0
- package/dist/src/core/document-extractors.js +130 -0
- package/dist/src/core/domain-design-matching.d.ts +2 -0
- package/dist/src/core/domain-design-matching.js +85 -0
- package/dist/src/core/domain-design-scoring-context.d.ts +25 -0
- package/dist/src/core/domain-design-scoring-context.js +66 -0
- package/dist/src/core/domain-design-scoring-core-docs.d.ts +5 -0
- package/dist/src/core/domain-design-scoring-core-docs.js +8 -0
- package/dist/src/core/domain-design-scoring-core.d.ts +24 -0
- package/dist/src/core/domain-design-scoring-core.js +137 -0
- package/dist/src/core/domain-design-scoring-docs-afs.d.ts +2 -0
- package/dist/src/core/domain-design-scoring-docs-afs.js +40 -0
- package/dist/src/core/domain-design-scoring-docs-bfs.d.ts +2 -0
- package/dist/src/core/domain-design-scoring-docs-bfs.js +46 -0
- package/dist/src/core/domain-design-scoring-docs-core.d.ts +12 -0
- package/dist/src/core/domain-design-scoring-docs-core.js +47 -0
- package/dist/src/core/domain-design-scoring-docs-drf.d.ts +2 -0
- package/dist/src/core/domain-design-scoring-docs-drf.js +55 -0
- package/dist/src/core/domain-design-scoring-docs-shared.d.ts +25 -0
- package/dist/src/core/domain-design-scoring-docs-shared.js +1 -0
- package/dist/src/core/domain-design-scoring-docs-uli.d.ts +2 -0
- package/dist/src/core/domain-design-scoring-docs-uli.js +39 -0
- package/dist/src/core/domain-design-scoring-docs.d.ts +1 -0
- package/dist/src/core/domain-design-scoring-docs.js +1 -0
- package/dist/src/core/domain-design-scoring-locality.d.ts +27 -0
- package/dist/src/core/domain-design-scoring-locality.js +87 -0
- package/dist/src/core/domain-design-scoring-mccs.d.ts +18 -0
- package/dist/src/core/domain-design-scoring-mccs.js +29 -0
- package/dist/src/core/domain-design-scoring-pilot.d.ts +13 -0
- package/dist/src/core/domain-design-scoring-pilot.js +57 -0
- package/dist/src/core/domain-design-scoring-response-shared.d.ts +20 -0
- package/dist/src/core/domain-design-scoring-response-shared.js +30 -0
- package/dist/src/core/domain-design-scoring-response.d.ts +18 -0
- package/dist/src/core/domain-design-scoring-response.js +27 -0
- package/dist/src/core/domain-design-scoring-support-drf.d.ts +17 -0
- package/dist/src/core/domain-design-scoring-support-drf.js +118 -0
- package/dist/src/core/domain-design-scoring-support-persistence.d.ts +6 -0
- package/dist/src/core/domain-design-scoring-support-persistence.js +8 -0
- package/dist/src/core/domain-design-scoring-support-uli.d.ts +12 -0
- package/dist/src/core/domain-design-scoring-support-uli.js +31 -0
- package/dist/src/core/domain-design-scoring-support.d.ts +3 -0
- package/dist/src/core/domain-design-scoring-support.js +3 -0
- package/dist/src/core/domain-design-scoring.d.ts +1 -0
- package/dist/src/core/domain-design-scoring.js +1 -0
- package/dist/src/core/formula-parser-tokenize.d.ts +14 -0
- package/dist/src/core/formula-parser-tokenize.js +58 -0
- package/dist/src/core/formula-parser.d.ts +1 -0
- package/dist/src/core/formula-parser.js +91 -0
- package/dist/src/core/formula.d.ts +1 -0
- package/dist/src/core/formula.js +1 -0
- package/dist/src/core/history-locality.d.ts +5 -0
- package/dist/src/core/history-locality.js +48 -0
- package/dist/src/core/history-normalization.d.ts +13 -0
- package/dist/src/core/history-normalization.js +105 -0
- package/dist/src/core/history-persistence-analysis.d.ts +6 -0
- package/dist/src/core/history-persistence-analysis.js +26 -0
- package/dist/src/core/history-persistence-clusters.d.ts +6 -0
- package/dist/src/core/history-persistence-clusters.js +9 -0
- package/dist/src/core/history-persistence-comparison.d.ts +6 -0
- package/dist/src/core/history-persistence-comparison.js +66 -0
- package/dist/src/core/history-persistence-components.d.ts +8 -0
- package/dist/src/core/history-persistence-components.js +99 -0
- package/dist/src/core/history-persistence-stability.d.ts +8 -0
- package/dist/src/core/history-persistence-stability.js +79 -0
- package/dist/src/core/history-persistence.d.ts +2 -0
- package/dist/src/core/history-persistence.js +2 -0
- package/dist/src/core/history-shared.d.ts +27 -0
- package/dist/src/core/history-shared.js +145 -0
- package/dist/src/core/history.d.ts +3 -0
- package/dist/src/core/history.js +3 -0
- package/dist/src/core/io.d.ts +9 -0
- package/dist/src/core/io.js +86 -0
- package/dist/src/core/measurement-metadata.d.ts +13 -0
- package/dist/src/core/measurement-metadata.js +142 -0
- package/dist/src/core/model.d.ts +3 -0
- package/dist/src/core/model.js +33 -0
- package/dist/src/core/policy-defaults-architecture.d.ts +2 -0
- package/dist/src/core/policy-defaults-architecture.js +75 -0
- package/dist/src/core/policy-defaults-domain.d.ts +2 -0
- package/dist/src/core/policy-defaults-domain.js +51 -0
- package/dist/src/core/policy-defaults-profiles.d.ts +2 -0
- package/dist/src/core/policy-defaults-profiles.js +24 -0
- package/dist/src/core/policy-defaults.d.ts +2 -0
- package/dist/src/core/policy-defaults.js +4 -0
- package/dist/src/core/policy-formulas.d.ts +5 -0
- package/dist/src/core/policy-formulas.js +5 -0
- package/dist/src/core/policy.d.ts +4 -0
- package/dist/src/core/policy.js +20 -0
- package/dist/src/core/progress.d.ts +8 -0
- package/dist/src/core/progress.js +40 -0
- package/dist/src/core/providers-normalization.d.ts +7 -0
- package/dist/src/core/providers-normalization.js +27 -0
- package/dist/src/core/providers-prompt.d.ts +4 -0
- package/dist/src/core/providers-prompt.js +63 -0
- package/dist/src/core/providers-runner.d.ts +3 -0
- package/dist/src/core/providers-runner.js +32 -0
- package/dist/src/core/providers-types.d.ts +10 -0
- package/dist/src/core/providers-types.js +1 -0
- package/dist/src/core/providers.d.ts +4 -0
- package/dist/src/core/providers.js +30 -0
- package/dist/src/core/report-actionability.d.ts +4 -0
- package/dist/src/core/report-actionability.js +57 -0
- package/dist/src/core/report-architecture.d.ts +2 -0
- package/dist/src/core/report-architecture.js +80 -0
- package/dist/src/core/report-domain.d.ts +2 -0
- package/dist/src/core/report-domain.js +50 -0
- package/dist/src/core/report-gate.d.ts +3 -0
- package/dist/src/core/report-gate.js +54 -0
- package/dist/src/core/report-shared-format.d.ts +2 -0
- package/dist/src/core/report-shared-format.js +6 -0
- package/dist/src/core/report-shared-guidance.d.ts +2 -0
- package/dist/src/core/report-shared-guidance.js +98 -0
- package/dist/src/core/report-shared-predicates.d.ts +17 -0
- package/dist/src/core/report-shared-predicates.js +9 -0
- package/dist/src/core/report-shared.d.ts +4 -0
- package/dist/src/core/report-shared.js +3 -0
- package/dist/src/core/report.d.ts +3 -0
- package/dist/src/core/report.js +10 -0
- package/dist/src/core/response.d.ts +8 -0
- package/dist/src/core/response.js +67 -0
- package/dist/src/core/review-items.d.ts +2 -0
- package/dist/src/core/review-items.js +116 -0
- package/dist/src/core/review-resolutions.d.ts +3 -0
- package/dist/src/core/review-resolutions.js +43 -0
- package/dist/src/core/review.d.ts +2 -0
- package/dist/src/core/review.js +2 -0
- package/dist/src/core/scaffold-aggregation.d.ts +13 -0
- package/dist/src/core/scaffold-aggregation.js +18 -0
- package/dist/src/core/scaffold-architecture-balances.d.ts +3 -0
- package/dist/src/core/scaffold-architecture-balances.js +25 -0
- package/dist/src/core/scaffold-architecture-drafts-builders.d.ts +19 -0
- package/dist/src/core/scaffold-architecture-drafts-builders.js +114 -0
- package/dist/src/core/scaffold-architecture-drafts-profiles.d.ts +11 -0
- package/dist/src/core/scaffold-architecture-drafts-profiles.js +183 -0
- package/dist/src/core/scaffold-architecture-drafts.d.ts +12 -0
- package/dist/src/core/scaffold-architecture-drafts.js +4 -0
- package/dist/src/core/scaffold-architecture-layer-candidates.d.ts +3 -0
- package/dist/src/core/scaffold-architecture-layer-candidates.js +32 -0
- package/dist/src/core/scaffold-architecture-layers.d.ts +3 -0
- package/dist/src/core/scaffold-architecture-layers.js +15 -0
- package/dist/src/core/scaffold-architecture-orchestration.d.ts +5 -0
- package/dist/src/core/scaffold-architecture-orchestration.js +36 -0
- package/dist/src/core/scaffold-architecture-ordering.d.ts +4 -0
- package/dist/src/core/scaffold-architecture-ordering.js +55 -0
- package/dist/src/core/scaffold-architecture.d.ts +1 -0
- package/dist/src/core/scaffold-architecture.js +1 -0
- package/dist/src/core/scaffold-domain-aggregates-candidates.d.ts +4 -0
- package/dist/src/core/scaffold-domain-aggregates-candidates.js +8 -0
- package/dist/src/core/scaffold-domain-aggregates-core.d.ts +1 -0
- package/dist/src/core/scaffold-domain-aggregates-core.js +1 -0
- package/dist/src/core/scaffold-domain-aggregates-dedupe.d.ts +2 -0
- package/dist/src/core/scaffold-domain-aggregates-dedupe.js +18 -0
- package/dist/src/core/scaffold-domain-aggregates-explicit.d.ts +4 -0
- package/dist/src/core/scaffold-domain-aggregates-explicit.js +43 -0
- package/dist/src/core/scaffold-domain-aggregates-inferred.d.ts +4 -0
- package/dist/src/core/scaffold-domain-aggregates-inferred.js +117 -0
- package/dist/src/core/scaffold-domain-aggregates-shared.d.ts +23 -0
- package/dist/src/core/scaffold-domain-aggregates-shared.js +91 -0
- package/dist/src/core/scaffold-domain-aggregates.d.ts +1 -0
- package/dist/src/core/scaffold-domain-aggregates.js +1 -0
- package/dist/src/core/scaffold-domain-context-candidates.d.ts +5 -0
- package/dist/src/core/scaffold-domain-context-candidates.js +65 -0
- package/dist/src/core/scaffold-domain-context-naming.d.ts +8 -0
- package/dist/src/core/scaffold-domain-context-naming.js +117 -0
- package/dist/src/core/scaffold-domain-contexts.d.ts +11 -0
- package/dist/src/core/scaffold-domain-contexts.js +75 -0
- package/dist/src/core/scaffold-domain-docs.d.ts +17 -0
- package/dist/src/core/scaffold-domain-docs.js +18 -0
- package/dist/src/core/scaffold-domain.d.ts +7 -0
- package/dist/src/core/scaffold-domain.js +62 -0
- package/dist/src/core/scaffold-naming.d.ts +4 -0
- package/dist/src/core/scaffold-naming.js +32 -0
- package/dist/src/core/scaffold-options.d.ts +2 -0
- package/dist/src/core/scaffold-options.js +10 -0
- package/dist/src/core/scaffold-shared.d.ts +5 -0
- package/dist/src/core/scaffold-shared.js +4 -0
- package/dist/src/core/scaffold-source-group-classification.d.ts +3 -0
- package/dist/src/core/scaffold-source-group-classification.js +91 -0
- package/dist/src/core/scaffold-source-group-constants.d.ts +3 -0
- package/dist/src/core/scaffold-source-group-constants.js +52 -0
- package/dist/src/core/scaffold-source-group-merge.d.ts +5 -0
- package/dist/src/core/scaffold-source-group-merge.js +56 -0
- package/dist/src/core/scaffold-source-group-naming.d.ts +4 -0
- package/dist/src/core/scaffold-source-group-naming.js +66 -0
- package/dist/src/core/scaffold-source-groups.d.ts +5 -0
- package/dist/src/core/scaffold-source-groups.js +123 -0
- package/dist/src/core/scaffold-types.d.ts +30 -0
- package/dist/src/core/scaffold-types.js +1 -0
- package/dist/src/core/scaffold.d.ts +2 -0
- package/dist/src/core/scaffold.js +2 -0
- package/dist/src/core/scoring-shared.d.ts +12 -0
- package/dist/src/core/scoring-shared.js +39 -0
- package/dist/src/core/scoring.d.ts +2 -0
- package/dist/src/core/scoring.js +2 -0
- package/dist/src/core/shadow-rollout-gate-reasons.d.ts +8 -0
- package/dist/src/core/shadow-rollout-gate-reasons.js +22 -0
- package/dist/src/core/shadow-rollout-gate-summary.d.ts +2 -0
- package/dist/src/core/shadow-rollout-gate-summary.js +36 -0
- package/dist/src/core/shadow-rollout-gate.d.ts +2 -0
- package/dist/src/core/shadow-rollout-gate.js +50 -0
- package/dist/src/core/shadow-rollout-registry.d.ts +5 -0
- package/dist/src/core/shadow-rollout-registry.js +31 -0
- package/dist/src/core/shadow-rollout-summary.d.ts +4 -0
- package/dist/src/core/shadow-rollout-summary.js +39 -0
- package/dist/src/core/shadow-rollout.d.ts +3 -0
- package/dist/src/core/shadow-rollout.js +3 -0
- package/dist/src/core/shared-utils.d.ts +4 -0
- package/dist/src/core/shared-utils.js +15 -0
- package/dist/src/core/trace.d.ts +14 -0
- package/dist/src/core/trace.js +118 -0
- package/dist/src/index.d.ts +7 -0
- package/dist/src/index.js +7 -0
- package/dist/src/packs/index.d.ts +2 -0
- package/dist/src/packs/index.js +36 -0
- package/package.json +68 -0
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { classifyReviewItemKind, sortReviewItems } from "./measurement-metadata.js";
|
|
2
|
+
function isGlossaryTerm(entity) {
|
|
3
|
+
return "termId" in entity;
|
|
4
|
+
}
|
|
5
|
+
function getEntityId(entity) {
|
|
6
|
+
if ("termId" in entity) {
|
|
7
|
+
return entity.termId;
|
|
8
|
+
}
|
|
9
|
+
if ("ruleId" in entity) {
|
|
10
|
+
return entity.ruleId;
|
|
11
|
+
}
|
|
12
|
+
return entity.invariantId;
|
|
13
|
+
}
|
|
14
|
+
function getEntitySummary(entity) {
|
|
15
|
+
if (isGlossaryTerm(entity)) {
|
|
16
|
+
return entity.canonicalTerm;
|
|
17
|
+
}
|
|
18
|
+
return entity.statement;
|
|
19
|
+
}
|
|
20
|
+
function getReviewItemsFromEntities(entities, evidenceRefs) {
|
|
21
|
+
const reviewItems = [];
|
|
22
|
+
entities.forEach((entity, index) => {
|
|
23
|
+
const targetEntityId = getEntityId(entity);
|
|
24
|
+
const summary = getEntitySummary(entity);
|
|
25
|
+
if (entity.confidence < 0.75) {
|
|
26
|
+
reviewItems.push({
|
|
27
|
+
reviewItemId: `RV-LOW-${index + 1}`,
|
|
28
|
+
reason: "low_confidence",
|
|
29
|
+
kind: "low_confidence",
|
|
30
|
+
summary: `${summary} has low confidence`,
|
|
31
|
+
confidence: entity.confidence,
|
|
32
|
+
evidenceRefs,
|
|
33
|
+
targetEntityId,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
entity.unknowns.forEach((unknown, unknownIndex) => {
|
|
37
|
+
reviewItems.push({
|
|
38
|
+
reviewItemId: `RV-UNK-${index + 1}-${unknownIndex + 1}`,
|
|
39
|
+
reason: "unknown",
|
|
40
|
+
kind: classifyReviewItemKind(unknown, "unknown"),
|
|
41
|
+
summary: unknown,
|
|
42
|
+
confidence: entity.confidence,
|
|
43
|
+
evidenceRefs,
|
|
44
|
+
targetEntityId,
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
if (isGlossaryTerm(entity) && entity.collision) {
|
|
48
|
+
reviewItems.push({
|
|
49
|
+
reviewItemId: `RV-COLL-${index + 1}`,
|
|
50
|
+
reason: "collision",
|
|
51
|
+
kind: "collision",
|
|
52
|
+
summary: `${entity.canonicalTerm} may have a collision`,
|
|
53
|
+
confidence: entity.confidence,
|
|
54
|
+
evidenceRefs,
|
|
55
|
+
targetEntityId,
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
return reviewItems;
|
|
60
|
+
}
|
|
61
|
+
export function listReviewItems(response) {
|
|
62
|
+
const reviewItems = [];
|
|
63
|
+
const evidenceRefs = response.evidence.map((entry) => entry.evidenceId);
|
|
64
|
+
response.unknowns.forEach((unknown, index) => {
|
|
65
|
+
reviewItems.push({
|
|
66
|
+
reviewItemId: `RV-RSP-${index + 1}`,
|
|
67
|
+
reason: "unknown",
|
|
68
|
+
kind: classifyReviewItemKind(unknown, "unknown"),
|
|
69
|
+
summary: unknown,
|
|
70
|
+
confidence: response.confidence,
|
|
71
|
+
evidenceRefs,
|
|
72
|
+
});
|
|
73
|
+
});
|
|
74
|
+
if (typeof response.result !== "object" || response.result === null) {
|
|
75
|
+
return reviewItems;
|
|
76
|
+
}
|
|
77
|
+
const result = response.result;
|
|
78
|
+
if (Array.isArray(result.terms)) {
|
|
79
|
+
reviewItems.push(...getReviewItemsFromEntities(result.terms, evidenceRefs));
|
|
80
|
+
}
|
|
81
|
+
if (Array.isArray(result.rules)) {
|
|
82
|
+
reviewItems.push(...getReviewItemsFromEntities(result.rules, evidenceRefs));
|
|
83
|
+
}
|
|
84
|
+
if (Array.isArray(result.invariants)) {
|
|
85
|
+
reviewItems.push(...getReviewItemsFromEntities(result.invariants, evidenceRefs));
|
|
86
|
+
}
|
|
87
|
+
if (Array.isArray(result.metrics)) {
|
|
88
|
+
for (const [index, metric] of result.metrics.entries()) {
|
|
89
|
+
if (metric.confidence < 0.75) {
|
|
90
|
+
reviewItems.push({
|
|
91
|
+
reviewItemId: `RV-METRIC-${index + 1}`,
|
|
92
|
+
reason: "low_confidence",
|
|
93
|
+
kind: "low_confidence",
|
|
94
|
+
summary: `${metric.metricId} has low confidence`,
|
|
95
|
+
confidence: metric.confidence,
|
|
96
|
+
evidenceRefs,
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
if (Array.isArray(result.localityWatchlist)) {
|
|
102
|
+
for (const [index, item] of result.localityWatchlist.entries()) {
|
|
103
|
+
reviewItems.push({
|
|
104
|
+
reviewItemId: `RV-HOTSPOT-${index + 1}`,
|
|
105
|
+
reason: "history_hotspot",
|
|
106
|
+
kind: "history_hotspot",
|
|
107
|
+
summary: `Recurring cross-boundary hotspot ${item.boundaries.join(" <-> ")} appears in ${item.count} commits${item.sampleCommitHashes && item.sampleCommitHashes.length > 0
|
|
108
|
+
? ` (${item.sampleCommitHashes.join(", ")})`
|
|
109
|
+
: ""}.`,
|
|
110
|
+
confidence: response.confidence,
|
|
111
|
+
evidenceRefs,
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
return sortReviewItems(reviewItems);
|
|
116
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { ReviewItem, ReviewResolution, ReviewResolutionLog } from "./contracts.js";
|
|
2
|
+
export declare function resolveReviewItems(reviewItems: ReviewItem[], resolutions: ReviewResolution[]): ReviewResolutionLog;
|
|
3
|
+
export declare function applyReviewOverrides<T extends object>(items: T[], log: ReviewResolutionLog | undefined, idKey: keyof T): T[];
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
export function resolveReviewItems(reviewItems, resolutions) {
|
|
2
|
+
const resolvedItems = reviewItems.map((reviewItem) => ({
|
|
3
|
+
...reviewItem,
|
|
4
|
+
resolution: resolutions.find((resolution) => resolution.reviewItemId === reviewItem.reviewItemId) ?? null,
|
|
5
|
+
}));
|
|
6
|
+
const overrides = resolvedItems.flatMap((reviewItem) => {
|
|
7
|
+
const patch = reviewItem.resolution?.decision?.patch;
|
|
8
|
+
if (!reviewItem.targetEntityId || !patch || Object.keys(patch).length === 0) {
|
|
9
|
+
return [];
|
|
10
|
+
}
|
|
11
|
+
return [
|
|
12
|
+
{
|
|
13
|
+
targetEntityId: reviewItem.targetEntityId,
|
|
14
|
+
patch,
|
|
15
|
+
reason: reviewItem.reason,
|
|
16
|
+
},
|
|
17
|
+
];
|
|
18
|
+
});
|
|
19
|
+
return {
|
|
20
|
+
reviewItems: resolvedItems,
|
|
21
|
+
overrides,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
export function applyReviewOverrides(items, log, idKey) {
|
|
25
|
+
if (!log) {
|
|
26
|
+
return items;
|
|
27
|
+
}
|
|
28
|
+
const overrideMap = new Map(log.overrides.map((override) => [override.targetEntityId, override.patch]));
|
|
29
|
+
return items.map((item) => {
|
|
30
|
+
const id = item[idKey];
|
|
31
|
+
if (typeof id !== "string") {
|
|
32
|
+
return item;
|
|
33
|
+
}
|
|
34
|
+
const patch = overrideMap.get(id);
|
|
35
|
+
if (!patch) {
|
|
36
|
+
return item;
|
|
37
|
+
}
|
|
38
|
+
return {
|
|
39
|
+
...item,
|
|
40
|
+
...patch,
|
|
41
|
+
};
|
|
42
|
+
});
|
|
43
|
+
}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type { ArchitectureLayerCandidate, DomainContextCandidate, Evidence } from "./contracts.js";
|
|
2
|
+
export declare function mergeEvidence(candidates: Array<{
|
|
3
|
+
evidence: Evidence[];
|
|
4
|
+
}>): Evidence[];
|
|
5
|
+
export declare function mergeUnknowns(candidates: Array<{
|
|
6
|
+
unknowns: string[];
|
|
7
|
+
}>, extras?: string[]): string[];
|
|
8
|
+
export declare function averageConfidence(contextCandidates: Array<{
|
|
9
|
+
candidate: DomainContextCandidate;
|
|
10
|
+
}>, aggregateCandidates: Array<{
|
|
11
|
+
confidence: number;
|
|
12
|
+
}>, extraSignals: number[]): number;
|
|
13
|
+
export declare function averageLayerConfidence(layers: ArchitectureLayerCandidate[]): number;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { unique } from "./scaffold-naming.js";
|
|
2
|
+
export function mergeEvidence(candidates) {
|
|
3
|
+
return candidates.flatMap((candidate) => candidate.evidence).slice(0, 12);
|
|
4
|
+
}
|
|
5
|
+
export function mergeUnknowns(candidates, extras = []) {
|
|
6
|
+
return unique([...extras, ...candidates.flatMap((candidate) => candidate.unknowns)]);
|
|
7
|
+
}
|
|
8
|
+
export function averageConfidence(contextCandidates, aggregateCandidates, extraSignals) {
|
|
9
|
+
const signals = [
|
|
10
|
+
...contextCandidates.map((entry) => entry.candidate.confidence),
|
|
11
|
+
...aggregateCandidates.map((candidate) => candidate.confidence),
|
|
12
|
+
...extraSignals,
|
|
13
|
+
];
|
|
14
|
+
return signals.reduce((sum, signal) => sum + signal, 0) / Math.max(1, signals.length);
|
|
15
|
+
}
|
|
16
|
+
export function averageLayerConfidence(layers) {
|
|
17
|
+
return layers.reduce((sum, layer) => sum + layer.confidence, 0) / Math.max(1, layers.length);
|
|
18
|
+
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
export function buildArchitectureLayerBalances(codebase, groups) {
|
|
2
|
+
const fileToGroup = new Map();
|
|
3
|
+
for (const group of groups) {
|
|
4
|
+
for (const filePath of group.files) {
|
|
5
|
+
fileToGroup.set(filePath, group.key);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
const balances = new Map();
|
|
9
|
+
for (const group of groups) {
|
|
10
|
+
balances.set(group.key, 0);
|
|
11
|
+
}
|
|
12
|
+
for (const dependency of codebase.dependencies) {
|
|
13
|
+
if (dependency.targetKind !== "file") {
|
|
14
|
+
continue;
|
|
15
|
+
}
|
|
16
|
+
const sourceGroup = fileToGroup.get(dependency.source);
|
|
17
|
+
const targetGroup = fileToGroup.get(dependency.target);
|
|
18
|
+
if (!sourceGroup || !targetGroup || sourceGroup === targetGroup) {
|
|
19
|
+
continue;
|
|
20
|
+
}
|
|
21
|
+
balances.set(sourceGroup, (balances.get(sourceGroup) ?? 0) + 1);
|
|
22
|
+
balances.set(targetGroup, (balances.get(targetGroup) ?? 0) - 1);
|
|
23
|
+
}
|
|
24
|
+
return balances;
|
|
25
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { ArchitectureBoundaryMap, ArchitectureConstraints, ArchitectureScenarioCatalog, ArchitectureScenarioObservationTemplate, ArchitectureTopologyModel, CodebaseAnalysis } from "./contracts.js";
|
|
2
|
+
export declare function buildArchitectureScaffoldDrafts(codebase: CodebaseAnalysis, constraints: ArchitectureConstraints): {
|
|
3
|
+
scenarioObservationsTemplate: {
|
|
4
|
+
value: ArchitectureScenarioObservationTemplate;
|
|
5
|
+
yaml: string;
|
|
6
|
+
};
|
|
7
|
+
scenarioCatalog: {
|
|
8
|
+
value: ArchitectureScenarioCatalog;
|
|
9
|
+
yaml: string;
|
|
10
|
+
};
|
|
11
|
+
topologyModel: {
|
|
12
|
+
value: ArchitectureTopologyModel;
|
|
13
|
+
yaml: string;
|
|
14
|
+
};
|
|
15
|
+
boundaryMap: {
|
|
16
|
+
value: ArchitectureBoundaryMap;
|
|
17
|
+
yaml: string;
|
|
18
|
+
};
|
|
19
|
+
};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import YAML from "yaml";
|
|
2
|
+
import { matchGlobs } from "./io.js";
|
|
3
|
+
import { buildScenarioProfile, inferTopologyNodeKind, normalizeNodeId, } from "./scaffold-architecture-drafts-profiles.js";
|
|
4
|
+
function buildScenarioCatalog(constraints) {
|
|
5
|
+
return {
|
|
6
|
+
version: constraints.version,
|
|
7
|
+
scenarios: constraints.layers.map((layer, index) => {
|
|
8
|
+
const profile = buildScenarioProfile(layer);
|
|
9
|
+
return {
|
|
10
|
+
scenarioId: `SC-${String(index + 1).padStart(3, "0")}`,
|
|
11
|
+
name: profile.name,
|
|
12
|
+
qualityAttribute: profile.qualityAttribute,
|
|
13
|
+
stimulus: profile.stimulus,
|
|
14
|
+
environment: "Docs-first repository with scaffolded architecture constraints.",
|
|
15
|
+
response: profile.response,
|
|
16
|
+
responseMeasure: {
|
|
17
|
+
metric: profile.metric,
|
|
18
|
+
unit: "ratio",
|
|
19
|
+
},
|
|
20
|
+
direction: "higher_is_better",
|
|
21
|
+
priority: index + 1,
|
|
22
|
+
target: 0.8,
|
|
23
|
+
worstAcceptable: 0.5,
|
|
24
|
+
};
|
|
25
|
+
}),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
function buildScenarioObservationsTemplate(catalog) {
|
|
29
|
+
return {
|
|
30
|
+
version: catalog.version,
|
|
31
|
+
scenarios: catalog.scenarios.map((scenario) => ({
|
|
32
|
+
scenarioId: scenario.scenarioId,
|
|
33
|
+
...(scenario.name ? { name: scenario.name } : {}),
|
|
34
|
+
...(scenario.qualityAttribute ? { qualityAttribute: scenario.qualityAttribute } : {}),
|
|
35
|
+
priority: scenario.priority,
|
|
36
|
+
measurementStatus: "needs_measurement",
|
|
37
|
+
note: `Populate an observed value for ${scenario.qualityAttribute ?? scenario.name ?? scenario.scenarioId} from benchmark or incident review before scoring.`,
|
|
38
|
+
})),
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
function classifyLayer(path, constraints) {
|
|
42
|
+
return constraints.layers.find((layer) => matchGlobs(path, layer.globs));
|
|
43
|
+
}
|
|
44
|
+
function buildTopologyModel(codebase, constraints) {
|
|
45
|
+
const nodes = constraints.layers.map((layer) => ({
|
|
46
|
+
nodeId: normalizeNodeId(layer.name),
|
|
47
|
+
kind: inferTopologyNodeKind(layer),
|
|
48
|
+
isolationBoundary: layer.name,
|
|
49
|
+
}));
|
|
50
|
+
const edges = new Map();
|
|
51
|
+
for (const dependency of codebase.dependencies) {
|
|
52
|
+
if (dependency.targetKind !== "file") {
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
const sourceLayer = classifyLayer(dependency.source, constraints);
|
|
56
|
+
const targetLayer = classifyLayer(dependency.target, constraints);
|
|
57
|
+
if (!sourceLayer || !targetLayer || sourceLayer.name === targetLayer.name) {
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
const edgeKey = `${sourceLayer.name} -> ${targetLayer.name}`;
|
|
61
|
+
if (!edges.has(edgeKey)) {
|
|
62
|
+
edges.set(edgeKey, {
|
|
63
|
+
source: normalizeNodeId(sourceLayer.name),
|
|
64
|
+
target: normalizeNodeId(targetLayer.name),
|
|
65
|
+
kind: "sync_call",
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
const fallbackEdges = edges.size > 0
|
|
70
|
+
? Array.from(edges.values())
|
|
71
|
+
: nodes.slice(1).map((node, index) => ({
|
|
72
|
+
source: nodes[index]?.nodeId ?? node.nodeId,
|
|
73
|
+
target: node.nodeId,
|
|
74
|
+
kind: "sync_call",
|
|
75
|
+
}));
|
|
76
|
+
return {
|
|
77
|
+
version: constraints.version,
|
|
78
|
+
nodes,
|
|
79
|
+
edges: fallbackEdges,
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
function buildBoundaryMap(constraints) {
|
|
83
|
+
return {
|
|
84
|
+
version: constraints.version,
|
|
85
|
+
boundaries: constraints.layers.map((layer) => ({
|
|
86
|
+
name: layer.name,
|
|
87
|
+
pathGlobs: layer.globs,
|
|
88
|
+
})),
|
|
89
|
+
};
|
|
90
|
+
}
|
|
91
|
+
export function buildArchitectureScaffoldDrafts(codebase, constraints) {
|
|
92
|
+
const scenarioCatalog = buildScenarioCatalog(constraints);
|
|
93
|
+
const scenarioObservationsTemplate = buildScenarioObservationsTemplate(scenarioCatalog);
|
|
94
|
+
const topologyModel = buildTopologyModel(codebase, constraints);
|
|
95
|
+
const boundaryMap = buildBoundaryMap(constraints);
|
|
96
|
+
return {
|
|
97
|
+
scenarioObservationsTemplate: {
|
|
98
|
+
value: scenarioObservationsTemplate,
|
|
99
|
+
yaml: YAML.stringify(scenarioObservationsTemplate),
|
|
100
|
+
},
|
|
101
|
+
scenarioCatalog: {
|
|
102
|
+
value: scenarioCatalog,
|
|
103
|
+
yaml: YAML.stringify(scenarioCatalog),
|
|
104
|
+
},
|
|
105
|
+
topologyModel: {
|
|
106
|
+
value: topologyModel,
|
|
107
|
+
yaml: YAML.stringify(topologyModel),
|
|
108
|
+
},
|
|
109
|
+
boundaryMap: {
|
|
110
|
+
value: boundaryMap,
|
|
111
|
+
yaml: YAML.stringify(boundaryMap),
|
|
112
|
+
},
|
|
113
|
+
};
|
|
114
|
+
}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { LayerDefinition } from "./contracts.js";
|
|
2
|
+
export interface ScenarioDraftProfile {
|
|
3
|
+
name: string;
|
|
4
|
+
qualityAttribute: string;
|
|
5
|
+
metric: string;
|
|
6
|
+
stimulus: string;
|
|
7
|
+
response: string;
|
|
8
|
+
}
|
|
9
|
+
export declare function normalizeNodeId(name: string): string;
|
|
10
|
+
export declare function buildScenarioProfile(layer: LayerDefinition): ScenarioDraftProfile;
|
|
11
|
+
export declare function inferTopologyNodeKind(layer: LayerDefinition): "service" | "datastore" | "queue" | "cache" | "gateway" | "worker" | "unknown";
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
export function normalizeNodeId(name) {
|
|
2
|
+
return name
|
|
3
|
+
.trim()
|
|
4
|
+
.replace(/([a-z0-9])([A-Z])/g, "$1_$2")
|
|
5
|
+
.replace(/[^a-zA-Z0-9]+/g, "_")
|
|
6
|
+
.replace(/_+/g, "_")
|
|
7
|
+
.replace(/^_+|_+$/g, "")
|
|
8
|
+
.toLowerCase();
|
|
9
|
+
}
|
|
10
|
+
function humanizeLayerName(name) {
|
|
11
|
+
const stripped = name.replace(/\d+$/u, "");
|
|
12
|
+
const words = stripped
|
|
13
|
+
.trim()
|
|
14
|
+
.replace(/([a-z0-9])([A-Z])/g, "$1 $2")
|
|
15
|
+
.replace(/[^a-zA-Z0-9]+/g, " ")
|
|
16
|
+
.split(/\s+/u)
|
|
17
|
+
.filter((segment) => segment.length > 0);
|
|
18
|
+
if (words.length === 0) {
|
|
19
|
+
return name;
|
|
20
|
+
}
|
|
21
|
+
const lowercaseWords = new Set(["and", "or", "of", "the", "to", "for", "in", "on", "with"]);
|
|
22
|
+
return words
|
|
23
|
+
.map((word, index) => {
|
|
24
|
+
const normalized = word.toLowerCase();
|
|
25
|
+
if (index > 0 && lowercaseWords.has(normalized)) {
|
|
26
|
+
return normalized;
|
|
27
|
+
}
|
|
28
|
+
if (/^[A-Z0-9]{2,}$/u.test(word)) {
|
|
29
|
+
return word;
|
|
30
|
+
}
|
|
31
|
+
return `${word.charAt(0).toUpperCase()}${word.slice(1).toLowerCase()}`;
|
|
32
|
+
})
|
|
33
|
+
.join(" ");
|
|
34
|
+
}
|
|
35
|
+
function includesAny(normalizedName, markers) {
|
|
36
|
+
return markers.some((marker) => normalizedName.includes(marker));
|
|
37
|
+
}
|
|
38
|
+
export function buildScenarioProfile(layer) {
|
|
39
|
+
const normalized = normalizeNodeId(layer.name);
|
|
40
|
+
const displayName = humanizeLayerName(layer.name);
|
|
41
|
+
const stimulus = `A change request primarily affects the ${displayName} layer.`;
|
|
42
|
+
if (includesAny(normalized, ["domain", "core", "kernel", "model", "foundation"])) {
|
|
43
|
+
return {
|
|
44
|
+
name: "Domain cohesion",
|
|
45
|
+
qualityAttribute: "Domain cohesion",
|
|
46
|
+
metric: "cohesion",
|
|
47
|
+
stimulus,
|
|
48
|
+
response: `The change preserves ${displayName} cohesion and avoids unnecessary cross-layer spread.`,
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
if (includesAny(normalized, ["contract", "contracts", "schema", "schemas", "dto", "dtos", "api"])) {
|
|
52
|
+
return {
|
|
53
|
+
name: "Contract stability",
|
|
54
|
+
qualityAttribute: "Contract stability",
|
|
55
|
+
metric: "stability",
|
|
56
|
+
stimulus,
|
|
57
|
+
response: `The change preserves ${displayName} contract boundaries and avoids interface churn.`,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
if (includesAny(normalized, ["ingest", "extract", "import", "load", "parser", "parse", "sync", "crawl"])) {
|
|
61
|
+
return {
|
|
62
|
+
name: "Ingestion coverage",
|
|
63
|
+
qualityAttribute: "Ingestion coverage",
|
|
64
|
+
metric: "coverage",
|
|
65
|
+
stimulus,
|
|
66
|
+
response: `The change keeps ${displayName} ingestion work localized and avoids spreading parsing concerns.`,
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
if (includesAny(normalized, ["runtime", "infra", "infrastructure", "platform", "persistence"])) {
|
|
70
|
+
return {
|
|
71
|
+
name: "Runtime containment",
|
|
72
|
+
qualityAttribute: "Runtime containment",
|
|
73
|
+
metric: "containment",
|
|
74
|
+
stimulus,
|
|
75
|
+
response: `The change stays contained within ${displayName} and avoids pulling runtime concerns inward.`,
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
if (includesAny(normalized, ["workspace", "project", "bootstrap", "config", "env", "setup"])) {
|
|
79
|
+
return {
|
|
80
|
+
name: "Workspace bootstrap readiness",
|
|
81
|
+
qualityAttribute: "Workspace bootstrap readiness",
|
|
82
|
+
metric: "readiness",
|
|
83
|
+
stimulus,
|
|
84
|
+
response: `The change preserves ${displayName} readiness and keeps setup concerns isolated.`,
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
if (includesAny(normalized, ["evaluation", "quality", "benchmark", "review", "telemetry", "metric", "score", "eval"])) {
|
|
88
|
+
return {
|
|
89
|
+
name: "Evaluation fidelity",
|
|
90
|
+
qualityAttribute: "Evaluation fidelity",
|
|
91
|
+
metric: "fidelity",
|
|
92
|
+
stimulus,
|
|
93
|
+
response: `The change preserves ${displayName} fidelity and keeps measurement logic explicit.`,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
if (includesAny(normalized, ["test", "tests", "verify", "validation"])) {
|
|
97
|
+
return {
|
|
98
|
+
name: "Validation coverage",
|
|
99
|
+
qualityAttribute: "Validation coverage",
|
|
100
|
+
metric: "coverage",
|
|
101
|
+
stimulus,
|
|
102
|
+
response: `The change preserves ${displayName} coverage and keeps validation concerns isolated.`,
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
if (includesAny(normalized, ["shared", "common", "util", "utils", "types"])) {
|
|
106
|
+
return {
|
|
107
|
+
name: "Shared surface stability",
|
|
108
|
+
qualityAttribute: "Shared surface stability",
|
|
109
|
+
metric: "stability",
|
|
110
|
+
stimulus,
|
|
111
|
+
response: `The change preserves ${displayName} surface stability and avoids leaking shared abstractions.`,
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
if (includesAny(normalized, ["data", "store", "storage", "db", "database", "cache", "queue"])) {
|
|
115
|
+
return {
|
|
116
|
+
name: "Data locality",
|
|
117
|
+
qualityAttribute: "Data locality",
|
|
118
|
+
metric: "locality",
|
|
119
|
+
stimulus,
|
|
120
|
+
response: `The change keeps ${displayName} data work localized and avoids data-path spillover.`,
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
if (includesAny(normalized, ["tool", "tools", "tooling", "script", "scripts"])) {
|
|
124
|
+
return {
|
|
125
|
+
name: "Tooling fit",
|
|
126
|
+
qualityAttribute: "Tooling fit",
|
|
127
|
+
metric: "fit",
|
|
128
|
+
stimulus,
|
|
129
|
+
response: `The change keeps ${displayName} tooling aligned with operational needs.`,
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
if (includesAny(normalized, ["application", "app", "usecase", "usecases", "service", "services", "orchestration"])) {
|
|
133
|
+
return {
|
|
134
|
+
name: "Application flow locality",
|
|
135
|
+
qualityAttribute: "Application flow locality",
|
|
136
|
+
metric: "locality",
|
|
137
|
+
stimulus,
|
|
138
|
+
response: `The change keeps ${displayName} flow localized and avoids unnecessary cross-layer spread.`,
|
|
139
|
+
};
|
|
140
|
+
}
|
|
141
|
+
if (includesAny(normalized, [
|
|
142
|
+
"adapter",
|
|
143
|
+
"adapters",
|
|
144
|
+
"delivery",
|
|
145
|
+
"presentation",
|
|
146
|
+
"interface",
|
|
147
|
+
"interfaces",
|
|
148
|
+
"ui",
|
|
149
|
+
"server",
|
|
150
|
+
"mcp",
|
|
151
|
+
])) {
|
|
152
|
+
return {
|
|
153
|
+
name: "Boundary adaptation",
|
|
154
|
+
qualityAttribute: "Boundary adaptation",
|
|
155
|
+
metric: "adaptation",
|
|
156
|
+
stimulus,
|
|
157
|
+
response: `The change keeps ${displayName} boundary work explicit and avoids hidden coupling.`,
|
|
158
|
+
};
|
|
159
|
+
}
|
|
160
|
+
return {
|
|
161
|
+
name: `${displayName} locality`,
|
|
162
|
+
qualityAttribute: "Architecture locality",
|
|
163
|
+
metric: "locality",
|
|
164
|
+
stimulus,
|
|
165
|
+
response: `The change remains localized to the ${displayName} layer and avoids unnecessary cross-layer spread.`,
|
|
166
|
+
};
|
|
167
|
+
}
|
|
168
|
+
export function inferTopologyNodeKind(layer) {
|
|
169
|
+
const normalized = normalizeNodeId(layer.name);
|
|
170
|
+
if (/(data|store|storage|db|database|persistence|cache|queue)/u.test(normalized)) {
|
|
171
|
+
return "datastore";
|
|
172
|
+
}
|
|
173
|
+
if (/(worker|job|script|test|eval|quality)/u.test(normalized)) {
|
|
174
|
+
return "worker";
|
|
175
|
+
}
|
|
176
|
+
if (/(api|ui|presentation|delivery|adapter|adapters|extract|extractors|server|mcp)/u.test(normalized)) {
|
|
177
|
+
return "gateway";
|
|
178
|
+
}
|
|
179
|
+
if (/(contract|domain|core|kernel|foundation|model|usecase|usecases|service|services|application|runtime|project|workspace|bootstrap|infra|infrastructure|platform)/u.test(normalized)) {
|
|
180
|
+
return "service";
|
|
181
|
+
}
|
|
182
|
+
return "unknown";
|
|
183
|
+
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { ArchitectureBoundaryMap, ArchitectureConstraints, ArchitectureScenarioCatalog, ArchitectureScenarioObservationTemplate, ArchitectureTopologyModel, CodebaseAnalysis } from "./contracts.js";
|
|
2
|
+
export interface ArchitectureScaffoldDraft<T> {
|
|
3
|
+
value: T;
|
|
4
|
+
yaml: string;
|
|
5
|
+
}
|
|
6
|
+
export interface ArchitectureScaffoldDrafts {
|
|
7
|
+
scenarioObservationsTemplate: ArchitectureScaffoldDraft<ArchitectureScenarioObservationTemplate>;
|
|
8
|
+
scenarioCatalog: ArchitectureScaffoldDraft<ArchitectureScenarioCatalog>;
|
|
9
|
+
topologyModel: ArchitectureScaffoldDraft<ArchitectureTopologyModel>;
|
|
10
|
+
boundaryMap: ArchitectureScaffoldDraft<ArchitectureBoundaryMap>;
|
|
11
|
+
}
|
|
12
|
+
export declare function buildArchitectureScaffoldDrafts(codebase: CodebaseAnalysis, constraints: ArchitectureConstraints): ArchitectureScaffoldDrafts;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { buildArchitectureScaffoldDrafts as buildArchitectureScaffoldDraftsImpl } from "./scaffold-architecture-drafts-builders.js";
|
|
2
|
+
export function buildArchitectureScaffoldDrafts(codebase, constraints) {
|
|
3
|
+
return buildArchitectureScaffoldDraftsImpl(codebase, constraints);
|
|
4
|
+
}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { clampConfidence, toEvidence } from "./response.js";
|
|
2
|
+
import { inferGroupDisplayName, LAYER_PRIORITY_HINTS, normalizeName } from "./scaffold-shared.js";
|
|
3
|
+
export function buildLayerCandidate(group, balance) {
|
|
4
|
+
const name = inferGroupDisplayName(group);
|
|
5
|
+
const globs = group.pathGlobs;
|
|
6
|
+
const hintKey = normalizeName(group.segment ?? name).replace(/\s+/gu, "_");
|
|
7
|
+
const confidence = clampConfidence(0.58 + (LAYER_PRIORITY_HINTS.has(hintKey) ? 0.18 : 0) + (group.files.length >= 2 ? 0.08 : 0));
|
|
8
|
+
const groupScope = group.heuristicSplit && (group.origins?.length ?? 0) > 1
|
|
9
|
+
? `${group.origins?.length ?? 0} source buckets`
|
|
10
|
+
: group.basePath || ".";
|
|
11
|
+
return {
|
|
12
|
+
definition: {
|
|
13
|
+
name,
|
|
14
|
+
rank: 0,
|
|
15
|
+
globs,
|
|
16
|
+
},
|
|
17
|
+
confidence,
|
|
18
|
+
evidence: [
|
|
19
|
+
toEvidence(`${name} was inferred from ${group.files.length} source file(s) under ${groupScope}.`, {
|
|
20
|
+
group: group.basePath || ".",
|
|
21
|
+
...(group.origins && group.origins.length > 0 ? { origins: group.origins } : {}),
|
|
22
|
+
outgoingMinusIncomingDependencies: balance,
|
|
23
|
+
globs,
|
|
24
|
+
}, undefined, confidence),
|
|
25
|
+
],
|
|
26
|
+
unknowns: group.heuristicSplit
|
|
27
|
+
? ["This layer was split from a broad infrastructure bucket by heuristic and should be reviewed."]
|
|
28
|
+
: group.segment
|
|
29
|
+
? []
|
|
30
|
+
: ["Root-level source files were grouped into a single layer by heuristic."],
|
|
31
|
+
};
|
|
32
|
+
}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import type { ArchitectureConstraints, ArchitectureLayerCandidate } from "./contracts.js";
|
|
2
|
+
import type { SourceGroup } from "./scaffold-shared.js";
|
|
3
|
+
export declare function buildArchitectureScaffoldLayers(orderedGroups: SourceGroup[], constraints: ArchitectureConstraints, balances: Map<string, number>): ArchitectureLayerCandidate[];
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { buildLayerCandidate } from "./scaffold-architecture-layer-candidates.js";
|
|
2
|
+
export function buildArchitectureScaffoldLayers(orderedGroups, constraints, balances) {
|
|
3
|
+
return orderedGroups.map((group, index) => {
|
|
4
|
+
const candidate = buildLayerCandidate(group, balances.get(group.key) ?? 0);
|
|
5
|
+
return {
|
|
6
|
+
...candidate,
|
|
7
|
+
definition: {
|
|
8
|
+
...candidate.definition,
|
|
9
|
+
name: constraints.layers[index]?.name ?? candidate.definition.name,
|
|
10
|
+
rank: index,
|
|
11
|
+
globs: constraints.layers[index]?.globs ?? candidate.definition.globs,
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
});
|
|
15
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import type { ArchitectureConstraintsScaffoldResult } from "./contracts.js";
|
|
2
|
+
import { type ScaffoldComputation } from "./scaffold-shared.js";
|
|
3
|
+
export declare function scaffoldArchitectureConstraints(options: {
|
|
4
|
+
repoRoot: string;
|
|
5
|
+
}): Promise<ScaffoldComputation<ArchitectureConstraintsScaffoldResult>>;
|