@jterrats/smart-deployment 1.0.4 → 1.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/README.md +3 -2
- package/lib/ai/wave-validation-prompt.d.ts +2 -0
- package/lib/ai/wave-validation-prompt.js +56 -0
- package/lib/ai/wave-validation-prompt.js.map +1 -0
- package/lib/ai/wave-validation-report.d.ts +2 -0
- package/lib/ai/wave-validation-report.js +96 -0
- package/lib/ai/wave-validation-report.js.map +1 -0
- package/lib/ai/wave-validation-response-parser.d.ts +8 -0
- package/lib/ai/wave-validation-response-parser.js +112 -0
- package/lib/ai/wave-validation-response-parser.js.map +1 -0
- package/lib/ai/wave-validation-result-synthesis.d.ts +6 -0
- package/lib/ai/wave-validation-result-synthesis.js +49 -0
- package/lib/ai/wave-validation-result-synthesis.js.map +1 -0
- package/lib/ai/wave-validation-service.d.ts +1 -55
- package/lib/ai/wave-validation-service.js +11 -359
- package/lib/ai/wave-validation-service.js.map +1 -1
- package/lib/ai/wave-validation-transport.d.ts +7 -0
- package/lib/ai/wave-validation-transport.js +10 -0
- package/lib/ai/wave-validation-transport.js.map +1 -0
- package/lib/analysis/analysis-reporter.d.ts +29 -0
- package/lib/analysis/analysis-reporter.js +84 -1
- package/lib/analysis/analysis-reporter.js.map +1 -1
- package/lib/analysis/analyze-context-service.d.ts +1 -1
- package/lib/analysis/analyze-context-service.js +2 -0
- package/lib/analysis/analyze-context-service.js.map +1 -1
- package/lib/analysis/project-analysis-service.d.ts +2 -0
- package/lib/analysis/project-analysis-service.js +2 -0
- package/lib/analysis/project-analysis-service.js.map +1 -1
- package/lib/commands/start.d.ts +1 -0
- package/lib/commands/start.js +14 -1
- package/lib/commands/start.js.map +1 -1
- package/lib/commands/status.d.ts +2 -0
- package/lib/commands/status.js +1 -0
- package/lib/commands/status.js.map +1 -1
- package/lib/commands/validate.d.ts +3 -3
- package/lib/commands/validate.js +4 -4
- package/lib/commands/validate.js.map +1 -1
- package/lib/constants/api-version.d.ts +2 -2
- package/lib/constants/api-version.js +2 -2
- package/lib/constants/deployment-order.js +11 -8
- package/lib/constants/deployment-order.js.map +1 -1
- package/lib/dependencies/circular-dependency-detector.d.ts +1 -31
- package/lib/dependencies/circular-dependency-detector.js +7 -156
- package/lib/dependencies/circular-dependency-detector.js.map +1 -1
- package/lib/dependencies/cycle-break-suggestions.d.ts +3 -0
- package/lib/dependencies/cycle-break-suggestions.js +63 -0
- package/lib/dependencies/cycle-break-suggestions.js.map +1 -0
- package/lib/dependencies/cycle-discovery.d.ts +16 -0
- package/lib/dependencies/cycle-discovery.js +70 -0
- package/lib/dependencies/cycle-discovery.js.map +1 -0
- package/lib/dependencies/dependency-graph-builder.d.ts +0 -65
- package/lib/dependencies/dependency-graph-builder.js +19 -233
- package/lib/dependencies/dependency-graph-builder.js.map +1 -1
- package/lib/dependencies/dependency-graph-intake.d.ts +17 -0
- package/lib/dependencies/dependency-graph-intake.js +20 -0
- package/lib/dependencies/dependency-graph-intake.js.map +1 -0
- package/lib/dependencies/dependency-graph-stats.d.ts +4 -0
- package/lib/dependencies/dependency-graph-stats.js +82 -0
- package/lib/dependencies/dependency-graph-stats.js.map +1 -0
- package/lib/dependencies/dependency-graph-validation.d.ts +16 -0
- package/lib/dependencies/dependency-graph-validation.js +78 -0
- package/lib/dependencies/dependency-graph-validation.js.map +1 -0
- package/lib/dependencies/dependency-impact-analyzer.d.ts +1 -22
- package/lib/dependencies/dependency-impact-analyzer.js +12 -110
- package/lib/dependencies/dependency-impact-analyzer.js.map +1 -1
- package/lib/dependencies/dependency-impact-scoring.d.ts +5 -0
- package/lib/dependencies/dependency-impact-scoring.js +24 -0
- package/lib/dependencies/dependency-impact-scoring.js.map +1 -0
- package/lib/dependencies/dependency-impact-traversal.d.ts +18 -0
- package/lib/dependencies/dependency-impact-traversal.js +74 -0
- package/lib/dependencies/dependency-impact-traversal.js.map +1 -0
- package/lib/dependencies/dependency-resolution-classifier.d.ts +19 -0
- package/lib/dependencies/dependency-resolution-classifier.js +67 -0
- package/lib/dependencies/dependency-resolution-classifier.js.map +1 -0
- package/lib/dependencies/dependency-resolver.d.ts +1 -48
- package/lib/dependencies/dependency-resolver.js +12 -181
- package/lib/dependencies/dependency-resolver.js.map +1 -1
- package/lib/dependencies/dynamic-query-dependency-references.d.ts +3 -0
- package/lib/dependencies/dynamic-query-dependency-references.js +41 -0
- package/lib/dependencies/dynamic-query-dependency-references.js.map +1 -0
- package/lib/dependencies/topological-dependency-sorter.d.ts +10 -0
- package/lib/dependencies/topological-dependency-sorter.js +84 -0
- package/lib/dependencies/topological-dependency-sorter.js.map +1 -0
- package/lib/deployment/cycle-remediation-runner.d.ts +1 -0
- package/lib/deployment/cycle-remediation-runner.js +5 -1
- package/lib/deployment/cycle-remediation-runner.js.map +1 -1
- package/lib/deployment/deployment-runner.d.ts +3 -1
- package/lib/deployment/deployment-runner.js +6 -1
- package/lib/deployment/deployment-runner.js.map +1 -1
- package/lib/deployment/deployment-status-service.d.ts +2 -0
- package/lib/deployment/deployment-status-service.js +2 -0
- package/lib/deployment/deployment-status-service.js.map +1 -1
- package/lib/deployment/deployment-validation-service.js +1 -1
- package/lib/deployment/deployment-validation-service.js.map +1 -1
- package/lib/deployment/dynamic-query-target-validator.d.ts +24 -0
- package/lib/deployment/dynamic-query-target-validator.js +65 -0
- package/lib/deployment/dynamic-query-target-validator.js.map +1 -0
- package/lib/deployment/sf-cli-integration.d.ts +1 -0
- package/lib/deployment/sf-cli-integration.js +1 -1
- package/lib/deployment/sf-cli-integration.js.map +1 -1
- package/lib/deployment/sf-cli-metadata-lookup.d.ts +4 -0
- package/lib/deployment/sf-cli-metadata-lookup.js +26 -0
- package/lib/deployment/sf-cli-metadata-lookup.js.map +1 -0
- package/lib/deployment/start-execution-service.d.ts +5 -0
- package/lib/deployment/start-execution-service.js +26 -6
- package/lib/deployment/start-execution-service.js.map +1 -1
- package/lib/deployment/wave-graph-state.d.ts +6 -0
- package/lib/deployment/wave-graph-state.js +89 -0
- package/lib/deployment/wave-graph-state.js.map +1 -0
- package/lib/deployment/wave-manifest-service.d.ts +1 -0
- package/lib/deployment/wave-manifest-service.js +1 -1
- package/lib/deployment/wave-manifest-service.js.map +1 -1
- package/lib/errors/deployment-error.js +1 -1
- package/lib/errors/deployment-error.js.map +1 -1
- package/lib/parsers/apex-class-dependencies.d.ts +4 -0
- package/lib/parsers/apex-class-dependencies.js +122 -0
- package/lib/parsers/apex-class-dependencies.js.map +1 -0
- package/lib/parsers/apex-class-lexical.d.ts +3 -0
- package/lib/parsers/apex-class-lexical.js +101 -0
- package/lib/parsers/apex-class-lexical.js.map +1 -0
- package/lib/parsers/apex-class-names.d.ts +18 -0
- package/lib/parsers/apex-class-names.js +93 -0
- package/lib/parsers/apex-class-names.js.map +1 -0
- package/lib/parsers/apex-class-parser-model.d.ts +59 -0
- package/lib/parsers/apex-class-parser-model.js +2 -0
- package/lib/parsers/apex-class-parser-model.js.map +1 -0
- package/lib/parsers/apex-class-parser.d.ts +3 -29
- package/lib/parsers/apex-class-parser.js +10 -395
- package/lib/parsers/apex-class-parser.js.map +1 -1
- package/lib/parsers/apex-class-symbols.d.ts +2 -0
- package/lib/parsers/apex-class-symbols.js +61 -0
- package/lib/parsers/apex-class-symbols.js.map +1 -0
- package/lib/parsers/apex-dynamic-query-analysis.d.ts +2 -0
- package/lib/parsers/apex-dynamic-query-analysis.js +150 -0
- package/lib/parsers/apex-dynamic-query-analysis.js.map +1 -0
- package/lib/parsers/custom-metadata-dynamic-query-analysis.d.ts +2 -0
- package/lib/parsers/custom-metadata-dynamic-query-analysis.js +50 -0
- package/lib/parsers/custom-metadata-dynamic-query-analysis.js.map +1 -0
- package/lib/parsers/custom-metadata-parser.d.ts +2 -0
- package/lib/parsers/custom-metadata-parser.js +3 -0
- package/lib/parsers/custom-metadata-parser.js.map +1 -1
- package/lib/parsers/custom-object-dependency-builder.d.ts +3 -0
- package/lib/parsers/custom-object-dependency-builder.js +103 -0
- package/lib/parsers/custom-object-dependency-builder.js.map +1 -0
- package/lib/parsers/custom-object-parser.js +1 -208
- package/lib/parsers/custom-object-parser.js.map +1 -1
- package/lib/parsers/custom-object-reference-helpers.d.ts +4 -0
- package/lib/parsers/custom-object-reference-helpers.js +92 -0
- package/lib/parsers/custom-object-reference-helpers.js.map +1 -0
- package/lib/parsers/dynamic-query-reference.d.ts +16 -0
- package/lib/parsers/dynamic-query-reference.js +65 -0
- package/lib/parsers/dynamic-query-reference.js.map +1 -0
- package/lib/parsers/layout-action-analysis.d.ts +6 -0
- package/lib/parsers/layout-action-analysis.js +36 -0
- package/lib/parsers/layout-action-analysis.js.map +1 -0
- package/lib/parsers/layout-parser.js +4 -272
- package/lib/parsers/layout-parser.js.map +1 -1
- package/lib/parsers/layout-reference-analysis.d.ts +9 -0
- package/lib/parsers/layout-reference-analysis.js +70 -0
- package/lib/parsers/layout-reference-analysis.js.map +1 -0
- package/lib/parsers/layout-result-assembly.d.ts +5 -0
- package/lib/parsers/layout-result-assembly.js +35 -0
- package/lib/parsers/layout-result-assembly.js.map +1 -0
- package/lib/parsers/layout-section-analysis.d.ts +7 -0
- package/lib/parsers/layout-section-analysis.js +9 -0
- package/lib/parsers/layout-section-analysis.js.map +1 -0
- package/lib/parsers/lwc-code-analysis.d.ts +10 -0
- package/lib/parsers/lwc-code-analysis.js +161 -0
- package/lib/parsers/lwc-code-analysis.js.map +1 -0
- package/lib/parsers/lwc-metadata-analysis.d.ts +6 -0
- package/lib/parsers/lwc-metadata-analysis.js +112 -0
- package/lib/parsers/lwc-metadata-analysis.js.map +1 -0
- package/lib/parsers/lwc-parser.d.ts +3 -27
- package/lib/parsers/lwc-parser.js +6 -377
- package/lib/parsers/lwc-parser.js.map +1 -1
- package/lib/parsers/lwc-result-assembly.d.ts +4 -0
- package/lib/parsers/lwc-result-assembly.js +47 -0
- package/lib/parsers/lwc-result-assembly.js.map +1 -0
- package/lib/presentation/status-command-presenter.d.ts +1 -0
- package/lib/presentation/status-command-presenter.js +20 -0
- package/lib/presentation/status-command-presenter.js.map +1 -1
- package/lib/scanner/forceignore-parser.d.ts +1 -0
- package/lib/scanner/forceignore-parser.js +14 -3
- package/lib/scanner/forceignore-parser.js.map +1 -1
- package/lib/scanner/structure-validator.js +1 -1
- package/lib/services/metadata-scanner-service.d.ts +2 -0
- package/lib/services/metadata-scanner-service.js +9 -2
- package/lib/services/metadata-scanner-service.js.map +1 -1
- package/lib/services/scanners/additional-metadata-scanner.d.ts +2 -0
- package/lib/services/scanners/additional-metadata-scanner.js +183 -0
- package/lib/services/scanners/additional-metadata-scanner.js.map +1 -0
- package/lib/services/scanners/automation-ai-metadata-scanner.d.ts +1 -0
- package/lib/services/scanners/automation-ai-metadata-scanner.js +11 -0
- package/lib/services/scanners/automation-ai-metadata-scanner.js.map +1 -1
- package/lib/services/scanners/code-metadata-scanner.js +14 -1
- package/lib/services/scanners/code-metadata-scanner.js.map +1 -1
- package/lib/services/scanners/data-metadata-scanner.js +24 -8
- package/lib/services/scanners/data-metadata-scanner.js.map +1 -1
- package/lib/types/metadata.d.ts +1 -1
- package/lib/utils/cache-entry-serializer.d.ts +7 -0
- package/lib/utils/cache-entry-serializer.js +15 -0
- package/lib/utils/cache-entry-serializer.js.map +1 -0
- package/lib/utils/cache-expiry-policy.d.ts +7 -0
- package/lib/utils/cache-expiry-policy.js +34 -0
- package/lib/utils/cache-expiry-policy.js.map +1 -0
- package/lib/utils/cache-key-derivation.d.ts +11 -0
- package/lib/utils/cache-key-derivation.js +28 -0
- package/lib/utils/cache-key-derivation.js.map +1 -0
- package/lib/utils/cache-lock-lifecycle.d.ts +15 -0
- package/lib/utils/cache-lock-lifecycle.js +84 -0
- package/lib/utils/cache-lock-lifecycle.js.map +1 -0
- package/lib/utils/cache-logger.d.ts +8 -0
- package/lib/utils/cache-logger.js +19 -0
- package/lib/utils/cache-logger.js.map +1 -0
- package/lib/utils/cache-manager.d.ts +1 -2
- package/lib/utils/cache-manager.js +7 -253
- package/lib/utils/cache-manager.js.map +1 -1
- package/lib/utils/cache-storage.d.ts +20 -0
- package/lib/utils/cache-storage.js +83 -0
- package/lib/utils/cache-storage.js.map +1 -0
- package/lib/validators/xml-metadata-validator.js +1 -1
- package/lib/waves/priority-wave-generator.js +8 -2
- package/lib/waves/priority-wave-generator.js.map +1 -1
- package/lib/waves/test-optimizer-discovery.d.ts +12 -0
- package/lib/waves/test-optimizer-discovery.js +46 -0
- package/lib/waves/test-optimizer-discovery.js.map +1 -0
- package/lib/waves/test-optimizer-matching.d.ts +6 -0
- package/lib/waves/test-optimizer-matching.js +43 -0
- package/lib/waves/test-optimizer-matching.js.map +1 -0
- package/lib/waves/test-optimizer-model.d.ts +92 -0
- package/lib/waves/test-optimizer-model.js +2 -0
- package/lib/waves/test-optimizer-model.js.map +1 -0
- package/lib/waves/test-optimizer-scoring.d.ts +11 -0
- package/lib/waves/test-optimizer-scoring.js +53 -0
- package/lib/waves/test-optimizer-scoring.js.map +1 -0
- package/lib/waves/test-optimizer.d.ts +2 -102
- package/lib/waves/test-optimizer.js +9 -154
- package/lib/waves/test-optimizer.js.map +1 -1
- package/lib/waves/wave-builder.d.ts +0 -11
- package/lib/waves/wave-builder.js +19 -193
- package/lib/waves/wave-builder.js.map +1 -1
- package/lib/waves/wave-graph.d.ts +25 -0
- package/lib/waves/wave-graph.js +138 -0
- package/lib/waves/wave-graph.js.map +1 -0
- package/lib/waves/wave-metadata.d.ts +4 -0
- package/lib/waves/wave-metadata.js +36 -0
- package/lib/waves/wave-metadata.js.map +1 -0
- package/lib/waves/wave-priority-policy.d.ts +5 -0
- package/lib/waves/wave-priority-policy.js +83 -0
- package/lib/waves/wave-priority-policy.js.map +1 -0
- package/lib/waves/wave-topology.d.ts +28 -0
- package/lib/waves/wave-topology.js +65 -0
- package/lib/waves/wave-topology.js.map +1 -0
- package/messages/start.json +5 -5
- package/messages/validate.json +1 -1
- package/npm-shrinkwrap.json +357 -229
- package/oclif.lock +157 -99
- package/oclif.manifest.json +7 -7
- package/package.json +25 -9
|
@@ -1,43 +1,16 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Dependency Graph Builder
|
|
3
|
-
* Builds a dependency graph from parsed metadata components
|
|
4
|
-
*
|
|
5
|
-
* @ac US-028-AC-1: Add nodes for each component
|
|
6
|
-
* @ac US-028-AC-2: Add edges for each dependency
|
|
7
|
-
* @ac US-028-AC-3: Handle bidirectional dependencies
|
|
8
|
-
* @ac US-028-AC-4: Track dependency types (hard, soft)
|
|
9
|
-
* @ac US-028-AC-5: Support incremental graph building
|
|
10
|
-
* @ac US-028-AC-6: Validate graph structure
|
|
11
|
-
*
|
|
12
|
-
* @issue #28
|
|
13
|
-
*/
|
|
14
1
|
import { getLogger } from '../utils/logger.js';
|
|
15
|
-
import {
|
|
2
|
+
import { getDependencySourceForKind } from './dependency-semantics.js';
|
|
3
|
+
import { createComponentIntake, } from './dependency-graph-intake.js';
|
|
4
|
+
import { countGraphEdges, generateDependencyGraphStats } from './dependency-graph-stats.js';
|
|
5
|
+
import { collectBuildAnnotations, collectValidationSummary, } from './dependency-graph-validation.js';
|
|
16
6
|
const logger = getLogger('DependencyGraphBuilder');
|
|
17
|
-
/**
|
|
18
|
-
* Dependency Graph Builder
|
|
19
|
-
*
|
|
20
|
-
* Performance optimized for 10,000+ nodes:
|
|
21
|
-
* - Uses Map/Set for O(1) lookups
|
|
22
|
-
* - Lazy validation
|
|
23
|
-
* - Incremental building support
|
|
24
|
-
*
|
|
25
|
-
* @example
|
|
26
|
-
* const builder = new DependencyGraphBuilder();
|
|
27
|
-
* builder.addComponent(apexClassComponent);
|
|
28
|
-
* builder.addComponent(triggerComponent);
|
|
29
|
-
* const result = builder.build();
|
|
30
|
-
* console.log(result.stats.totalComponents); // 2
|
|
31
|
-
*/
|
|
32
7
|
export class DependencyGraphBuilder {
|
|
33
|
-
// Private properties
|
|
34
8
|
components = new Map();
|
|
35
9
|
graph = new Map();
|
|
36
10
|
reverseGraph = new Map();
|
|
37
11
|
edges = new Map(); // "from->to" => edge
|
|
38
12
|
options;
|
|
39
13
|
cachedBuildResult;
|
|
40
|
-
// Constructor
|
|
41
14
|
constructor(options = {}) {
|
|
42
15
|
this.options = {
|
|
43
16
|
trackDependencyTypes: options.trackDependencyTypes ?? true,
|
|
@@ -48,7 +21,6 @@ export class DependencyGraphBuilder {
|
|
|
48
21
|
options: this.options,
|
|
49
22
|
});
|
|
50
23
|
}
|
|
51
|
-
// Public getters
|
|
52
24
|
/**
|
|
53
25
|
* Get current size of the graph
|
|
54
26
|
*/
|
|
@@ -61,14 +33,6 @@ export class DependencyGraphBuilder {
|
|
|
61
33
|
get isEmpty() {
|
|
62
34
|
return this.components.size === 0;
|
|
63
35
|
}
|
|
64
|
-
// Private static methods
|
|
65
|
-
/**
|
|
66
|
-
* Create a node ID from type and name
|
|
67
|
-
*/
|
|
68
|
-
static createNodeId(type, name) {
|
|
69
|
-
return `${type}:${name}`;
|
|
70
|
-
}
|
|
71
|
-
// Public methods
|
|
72
36
|
/**
|
|
73
37
|
* Add a metadata component to the graph
|
|
74
38
|
*
|
|
@@ -171,7 +135,7 @@ export class DependencyGraphBuilder {
|
|
|
171
135
|
return this.cachedBuildResult;
|
|
172
136
|
}
|
|
173
137
|
const startTime = Date.now();
|
|
174
|
-
const totalEdges = this.
|
|
138
|
+
const totalEdges = countGraphEdges(this.graph);
|
|
175
139
|
logger.info('Building dependency analysis result', {
|
|
176
140
|
components: this.components.size,
|
|
177
141
|
edges: totalEdges,
|
|
@@ -180,7 +144,7 @@ export class DependencyGraphBuilder {
|
|
|
180
144
|
this.validate();
|
|
181
145
|
}
|
|
182
146
|
const annotations = this.createBuildAnnotations();
|
|
183
|
-
const stats = this.
|
|
147
|
+
const stats = generateDependencyGraphStats(this.components, this.graph, this.reverseGraph);
|
|
184
148
|
const duration = Date.now() - startTime;
|
|
185
149
|
logger.info('Dependency graph built successfully', {
|
|
186
150
|
totalComponents: stats.totalComponents,
|
|
@@ -221,22 +185,15 @@ export class DependencyGraphBuilder {
|
|
|
221
185
|
* Collect non-statistical build annotations from the graph.
|
|
222
186
|
*/
|
|
223
187
|
createBuildAnnotations() {
|
|
224
|
-
return
|
|
225
|
-
circularDependencies: this.detectCircularDependencies(),
|
|
226
|
-
isolatedComponents: this.findIsolatedComponents(),
|
|
227
|
-
};
|
|
188
|
+
return collectBuildAnnotations(this.components, this.graph, this.reverseGraph);
|
|
228
189
|
}
|
|
229
|
-
// Private methods
|
|
230
190
|
/**
|
|
231
191
|
* Stage 1: normalize node identity and typed dependency details for intake.
|
|
232
192
|
*/
|
|
233
193
|
normalizeComponentIntake(component) {
|
|
234
|
-
const
|
|
235
|
-
|
|
236
|
-
return
|
|
237
|
-
nodeId,
|
|
238
|
-
dependencyDetails,
|
|
239
|
-
};
|
|
194
|
+
const intake = createComponentIntake(component);
|
|
195
|
+
this.intakeComponentNode(intake.nodeId, component);
|
|
196
|
+
return intake;
|
|
240
197
|
}
|
|
241
198
|
/**
|
|
242
199
|
* Stage 2 orchestration: ingest expanded dependency details for a component.
|
|
@@ -269,23 +226,10 @@ export class DependencyGraphBuilder {
|
|
|
269
226
|
/**
|
|
270
227
|
* Stage 1a: intake and register the component node.
|
|
271
228
|
*/
|
|
272
|
-
intakeComponentNode(component) {
|
|
273
|
-
const nodeId = DependencyGraphBuilder.createNodeId(component.type, component.name);
|
|
229
|
+
intakeComponentNode(nodeId, component) {
|
|
274
230
|
this.warnIfGraphIsLarge();
|
|
275
231
|
this.components.set(nodeId, component);
|
|
276
232
|
this.initializeNodeEntries(nodeId);
|
|
277
|
-
return nodeId;
|
|
278
|
-
}
|
|
279
|
-
/**
|
|
280
|
-
* Stage 2: expand legacy dependency sets into typed dependency details.
|
|
281
|
-
*/
|
|
282
|
-
expandTypedDependencies(component) {
|
|
283
|
-
return expandComponentDependencyReferences(component, DEFAULT_GRAPH_DEPENDENCY_KIND).map((dependency) => ({
|
|
284
|
-
nodeId: dependency.nodeId,
|
|
285
|
-
kind: dependency.kind,
|
|
286
|
-
reason: dependency.reason,
|
|
287
|
-
confidence: dependency.confidence,
|
|
288
|
-
}));
|
|
289
233
|
}
|
|
290
234
|
/**
|
|
291
235
|
* Stage 3: assemble graph edges from expanded dependency details.
|
|
@@ -308,139 +252,14 @@ export class DependencyGraphBuilder {
|
|
|
308
252
|
* @ac US-028-AC-6: Validate graph structure
|
|
309
253
|
*/
|
|
310
254
|
validate() {
|
|
311
|
-
this.
|
|
312
|
-
|
|
255
|
+
const summary = collectValidationSummary(this.components, this.graph);
|
|
256
|
+
this.reportDanglingReferences(summary.danglingReferences);
|
|
313
257
|
if (summary.selfLoopErrors.length > 0) {
|
|
314
258
|
logger.error('Graph validation failed', { errors: summary.selfLoopErrors });
|
|
315
259
|
throw new Error(`Graph validation failed:\n${summary.selfLoopErrors.join('\n')}`);
|
|
316
260
|
}
|
|
317
261
|
logger.debug('Graph validation passed');
|
|
318
262
|
}
|
|
319
|
-
/**
|
|
320
|
-
* Detect circular dependencies using DFS
|
|
321
|
-
*/
|
|
322
|
-
detectCircularDependencies() {
|
|
323
|
-
const cycles = [];
|
|
324
|
-
const visited = new Set();
|
|
325
|
-
const recursionStack = new Set();
|
|
326
|
-
const currentPath = [];
|
|
327
|
-
const dfs = (nodeId) => {
|
|
328
|
-
visited.add(nodeId);
|
|
329
|
-
recursionStack.add(nodeId);
|
|
330
|
-
currentPath.push(nodeId);
|
|
331
|
-
const deps = this.graph.get(nodeId) ?? new Set();
|
|
332
|
-
for (const depId of deps) {
|
|
333
|
-
if (!visited.has(depId)) {
|
|
334
|
-
dfs(depId);
|
|
335
|
-
}
|
|
336
|
-
else if (recursionStack.has(depId)) {
|
|
337
|
-
// Found a cycle
|
|
338
|
-
const cycleStart = currentPath.indexOf(depId);
|
|
339
|
-
const cycle = currentPath.slice(cycleStart);
|
|
340
|
-
cycles.push({
|
|
341
|
-
cycle,
|
|
342
|
-
severity: 'warning',
|
|
343
|
-
message: `Circular dependency detected: ${cycle.join(' → ')} → ${depId}`,
|
|
344
|
-
});
|
|
345
|
-
}
|
|
346
|
-
}
|
|
347
|
-
recursionStack.delete(nodeId);
|
|
348
|
-
currentPath.pop();
|
|
349
|
-
};
|
|
350
|
-
for (const nodeId of this.graph.keys()) {
|
|
351
|
-
if (!visited.has(nodeId)) {
|
|
352
|
-
dfs(nodeId);
|
|
353
|
-
}
|
|
354
|
-
}
|
|
355
|
-
return cycles;
|
|
356
|
-
}
|
|
357
|
-
/**
|
|
358
|
-
* Find components with no dependencies or dependents
|
|
359
|
-
*/
|
|
360
|
-
findIsolatedComponents() {
|
|
361
|
-
const isolated = [];
|
|
362
|
-
for (const nodeId of this.components.keys()) {
|
|
363
|
-
const deps = this.graph.get(nodeId)?.size ?? 0;
|
|
364
|
-
const dependents = this.reverseGraph.get(nodeId)?.size ?? 0;
|
|
365
|
-
if (deps === 0 && dependents === 0) {
|
|
366
|
-
isolated.push(nodeId);
|
|
367
|
-
}
|
|
368
|
-
}
|
|
369
|
-
return isolated;
|
|
370
|
-
}
|
|
371
|
-
/**
|
|
372
|
-
* Generate graph statistics
|
|
373
|
-
*/
|
|
374
|
-
generateStats() {
|
|
375
|
-
const metrics = this.collectGraphMetrics();
|
|
376
|
-
return {
|
|
377
|
-
totalComponents: metrics.totalComponents,
|
|
378
|
-
totalDependencies: metrics.totalDependencies,
|
|
379
|
-
componentsByType: metrics.componentsByType,
|
|
380
|
-
maxDepth: metrics.maxDepth,
|
|
381
|
-
mostDepended: this.findMaxCountEntry(metrics.counts.dependentCounts),
|
|
382
|
-
mostDependencies: this.findMaxCountEntry(metrics.counts.dependencyCounts),
|
|
383
|
-
};
|
|
384
|
-
}
|
|
385
|
-
collectGraphMetrics() {
|
|
386
|
-
return {
|
|
387
|
-
totalComponents: this.components.size,
|
|
388
|
-
totalDependencies: this.countEdges(),
|
|
389
|
-
maxDepth: this.calculateMaxDepth(),
|
|
390
|
-
componentsByType: this.collectComponentsByType(),
|
|
391
|
-
counts: this.collectGraphCounts(),
|
|
392
|
-
};
|
|
393
|
-
}
|
|
394
|
-
collectComponentsByType() {
|
|
395
|
-
const componentsByType = {};
|
|
396
|
-
for (const component of this.components.values()) {
|
|
397
|
-
componentsByType[component.type] = (componentsByType[component.type] ?? 0) + 1;
|
|
398
|
-
}
|
|
399
|
-
return componentsByType;
|
|
400
|
-
}
|
|
401
|
-
/**
|
|
402
|
-
* Calculate maximum dependency depth (simplified BFS)
|
|
403
|
-
*/
|
|
404
|
-
calculateMaxDepth() {
|
|
405
|
-
let maxDepth = 0;
|
|
406
|
-
for (const startNode of this.components.keys()) {
|
|
407
|
-
const depth = this.bfsDepth(startNode);
|
|
408
|
-
maxDepth = Math.max(maxDepth, depth);
|
|
409
|
-
}
|
|
410
|
-
return maxDepth;
|
|
411
|
-
}
|
|
412
|
-
/**
|
|
413
|
-
* BFS to calculate depth from a starting node
|
|
414
|
-
*/
|
|
415
|
-
bfsDepth(startNode) {
|
|
416
|
-
const visited = new Set();
|
|
417
|
-
const queue = [{ node: startNode, depth: 0 }];
|
|
418
|
-
let maxDepth = 0;
|
|
419
|
-
while (queue.length > 0) {
|
|
420
|
-
const { node, depth } = queue.shift();
|
|
421
|
-
if (visited.has(node))
|
|
422
|
-
continue;
|
|
423
|
-
visited.add(node);
|
|
424
|
-
maxDepth = Math.max(maxDepth, depth);
|
|
425
|
-
const deps = this.graph.get(node) ?? new Set();
|
|
426
|
-
for (const depId of deps) {
|
|
427
|
-
if (!visited.has(depId)) {
|
|
428
|
-
queue.push({ node: depId, depth: depth + 1 });
|
|
429
|
-
}
|
|
430
|
-
}
|
|
431
|
-
}
|
|
432
|
-
return maxDepth;
|
|
433
|
-
}
|
|
434
|
-
/**
|
|
435
|
-
* Count total edges in the graph
|
|
436
|
-
*/
|
|
437
|
-
countEdges() {
|
|
438
|
-
let count = 0;
|
|
439
|
-
for (const deps of this.graph.values()) {
|
|
440
|
-
count += deps.size;
|
|
441
|
-
}
|
|
442
|
-
return count;
|
|
443
|
-
}
|
|
444
263
|
warnIfGraphIsLarge() {
|
|
445
264
|
if (this.components.size >= this.options.maxNodes) {
|
|
446
265
|
logger.warn('Graph size exceeds recommended maximum', {
|
|
@@ -471,46 +290,13 @@ export class DependencyGraphBuilder {
|
|
|
471
290
|
this.reverseGraph.set(nodeId, new Set());
|
|
472
291
|
}
|
|
473
292
|
}
|
|
474
|
-
reportDanglingReferences() {
|
|
475
|
-
for (const
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
to: depId,
|
|
481
|
-
});
|
|
482
|
-
}
|
|
483
|
-
}
|
|
484
|
-
}
|
|
485
|
-
}
|
|
486
|
-
validateGraphStructure() {
|
|
487
|
-
const selfLoopErrors = [];
|
|
488
|
-
for (const [nodeId, deps] of this.graph.entries()) {
|
|
489
|
-
if (deps.has(nodeId)) {
|
|
490
|
-
selfLoopErrors.push(`Self-loop detected: ${nodeId}`);
|
|
491
|
-
}
|
|
492
|
-
}
|
|
493
|
-
return { selfLoopErrors };
|
|
494
|
-
}
|
|
495
|
-
collectGraphCounts() {
|
|
496
|
-
const dependencyCounts = new Map();
|
|
497
|
-
const dependentCounts = new Map();
|
|
498
|
-
for (const [nodeId, deps] of this.graph.entries()) {
|
|
499
|
-
dependencyCounts.set(nodeId, deps.size);
|
|
500
|
-
}
|
|
501
|
-
for (const [nodeId, dependents] of this.reverseGraph.entries()) {
|
|
502
|
-
dependentCounts.set(nodeId, dependents.size);
|
|
503
|
-
}
|
|
504
|
-
return { dependencyCounts, dependentCounts };
|
|
505
|
-
}
|
|
506
|
-
findMaxCountEntry(counts) {
|
|
507
|
-
let maxEntry = { nodeId: '', count: 0 };
|
|
508
|
-
for (const [nodeId, count] of counts.entries()) {
|
|
509
|
-
if (count > maxEntry.count) {
|
|
510
|
-
maxEntry = { nodeId, count };
|
|
511
|
-
}
|
|
293
|
+
reportDanglingReferences(danglingReferences) {
|
|
294
|
+
for (const reference of danglingReferences) {
|
|
295
|
+
logger.warn('Dangling reference detected', {
|
|
296
|
+
from: reference.from,
|
|
297
|
+
to: reference.to,
|
|
298
|
+
});
|
|
512
299
|
}
|
|
513
|
-
return maxEntry;
|
|
514
300
|
}
|
|
515
301
|
}
|
|
516
302
|
//# sourceMappingURL=dependency-graph-builder.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dependency-graph-builder.js","sourceRoot":"","sources":["../../src/dependencies/dependency-graph-builder.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"dependency-graph-builder.js","sourceRoot":"","sources":["../../src/dependencies/dependency-graph-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type { NodeId } from '../types/dependency.js';
|
|
2
|
+
import type { MetadataComponent, MetadataDependencyReference, MetadataType } from '../types/metadata.js';
|
|
3
|
+
import type { DependencyType } from './dependency-graph-builder.js';
|
|
4
|
+
export type ExpandedDependencyDetail = {
|
|
5
|
+
nodeId: NodeId;
|
|
6
|
+
kind: DependencyType;
|
|
7
|
+
source?: MetadataDependencyReference['source'];
|
|
8
|
+
reason?: string;
|
|
9
|
+
confidence?: number;
|
|
10
|
+
};
|
|
11
|
+
export type ComponentIntake = {
|
|
12
|
+
nodeId: NodeId;
|
|
13
|
+
dependencyDetails: ExpandedDependencyDetail[];
|
|
14
|
+
};
|
|
15
|
+
export declare function createComponentNodeId(type: MetadataType, name: string): NodeId;
|
|
16
|
+
export declare function createComponentIntake(component: MetadataComponent): ComponentIntake;
|
|
17
|
+
export declare function expandGraphDependencyDetails(component: MetadataComponent): ExpandedDependencyDetail[];
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { DEFAULT_GRAPH_DEPENDENCY_KIND, expandComponentDependencyReferences } from './dependency-semantics.js';
|
|
2
|
+
export function createComponentNodeId(type, name) {
|
|
3
|
+
return `${type}:${name}`;
|
|
4
|
+
}
|
|
5
|
+
export function createComponentIntake(component) {
|
|
6
|
+
return {
|
|
7
|
+
nodeId: createComponentNodeId(component.type, component.name),
|
|
8
|
+
dependencyDetails: expandGraphDependencyDetails(component),
|
|
9
|
+
};
|
|
10
|
+
}
|
|
11
|
+
export function expandGraphDependencyDetails(component) {
|
|
12
|
+
return expandComponentDependencyReferences(component, DEFAULT_GRAPH_DEPENDENCY_KIND).map((dependency) => ({
|
|
13
|
+
nodeId: dependency.nodeId,
|
|
14
|
+
kind: dependency.kind,
|
|
15
|
+
source: dependency.source,
|
|
16
|
+
reason: dependency.reason,
|
|
17
|
+
confidence: dependency.confidence,
|
|
18
|
+
}));
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=dependency-graph-intake.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependency-graph-intake.js","sourceRoot":"","sources":["../../src/dependencies/dependency-graph-intake.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,6BAA6B,EAAE,mCAAmC,EAAE,MAAM,2BAA2B,CAAC;AAgB/G,MAAM,UAAU,qBAAqB,CAAC,IAAkB,EAAE,IAAY;IACpE,OAAO,GAAG,IAAI,IAAI,IAAI,EAAE,CAAC;AAC3B,CAAC;AAED,MAAM,UAAU,qBAAqB,CAAC,SAA4B;IAChE,OAAO;QACL,MAAM,EAAE,qBAAqB,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC;QAC7D,iBAAiB,EAAE,4BAA4B,CAAC,SAAS,CAAC;KAC3D,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,4BAA4B,CAAC,SAA4B;IACvE,OAAO,mCAAmC,CAAC,SAAS,EAAE,6BAA6B,CAAC,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;QACxG,MAAM,EAAE,UAAU,CAAC,MAAM;QACzB,IAAI,EAAE,UAAU,CAAC,IAAI;QACrB,MAAM,EAAE,UAAU,CAAC,MAAM;QACzB,MAAM,EAAE,UAAU,CAAC,MAAM;QACzB,UAAU,EAAE,UAAU,CAAC,UAAU;KAClC,CAAC,CAAC,CAAC;AACN,CAAC"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import type { NodeId, DependencyGraph, DependencyStats, ReverseGraph } from '../types/dependency.js';
|
|
2
|
+
import type { MetadataComponent } from '../types/metadata.js';
|
|
3
|
+
export declare function generateDependencyGraphStats(components: ReadonlyMap<NodeId, MetadataComponent>, graph: DependencyGraph, reverseGraph: ReverseGraph): DependencyStats;
|
|
4
|
+
export declare function countGraphEdges(graph: DependencyGraph): number;
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
export function generateDependencyGraphStats(components, graph, reverseGraph) {
|
|
2
|
+
const metrics = collectGraphMetrics(components, graph, reverseGraph);
|
|
3
|
+
return {
|
|
4
|
+
totalComponents: metrics.totalComponents,
|
|
5
|
+
totalDependencies: metrics.totalDependencies,
|
|
6
|
+
componentsByType: metrics.componentsByType,
|
|
7
|
+
maxDepth: metrics.maxDepth,
|
|
8
|
+
mostDepended: findMaxCountEntry(metrics.counts.dependentCounts),
|
|
9
|
+
mostDependencies: findMaxCountEntry(metrics.counts.dependencyCounts),
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export function countGraphEdges(graph) {
|
|
13
|
+
let count = 0;
|
|
14
|
+
for (const deps of graph.values()) {
|
|
15
|
+
count += deps.size;
|
|
16
|
+
}
|
|
17
|
+
return count;
|
|
18
|
+
}
|
|
19
|
+
function collectGraphMetrics(components, graph, reverseGraph) {
|
|
20
|
+
return {
|
|
21
|
+
totalComponents: components.size,
|
|
22
|
+
totalDependencies: countGraphEdges(graph),
|
|
23
|
+
maxDepth: calculateMaxDepth(components, graph),
|
|
24
|
+
componentsByType: collectComponentsByType(components),
|
|
25
|
+
counts: collectGraphCounts(graph, reverseGraph),
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
function collectComponentsByType(components) {
|
|
29
|
+
const componentsByType = {};
|
|
30
|
+
for (const component of components.values()) {
|
|
31
|
+
componentsByType[component.type] = (componentsByType[component.type] ?? 0) + 1;
|
|
32
|
+
}
|
|
33
|
+
return componentsByType;
|
|
34
|
+
}
|
|
35
|
+
function calculateMaxDepth(components, graph) {
|
|
36
|
+
let maxDepth = 0;
|
|
37
|
+
for (const startNode of components.keys()) {
|
|
38
|
+
const depth = bfsDepth(startNode, graph);
|
|
39
|
+
maxDepth = Math.max(maxDepth, depth);
|
|
40
|
+
}
|
|
41
|
+
return maxDepth;
|
|
42
|
+
}
|
|
43
|
+
function bfsDepth(startNode, graph) {
|
|
44
|
+
const visited = new Set();
|
|
45
|
+
const queue = [{ node: startNode, depth: 0 }];
|
|
46
|
+
let maxDepth = 0;
|
|
47
|
+
while (queue.length > 0) {
|
|
48
|
+
const { node, depth } = queue.shift();
|
|
49
|
+
if (visited.has(node))
|
|
50
|
+
continue;
|
|
51
|
+
visited.add(node);
|
|
52
|
+
maxDepth = Math.max(maxDepth, depth);
|
|
53
|
+
const deps = graph.get(node) ?? new Set();
|
|
54
|
+
for (const depId of deps) {
|
|
55
|
+
if (!visited.has(depId)) {
|
|
56
|
+
queue.push({ node: depId, depth: depth + 1 });
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return maxDepth;
|
|
61
|
+
}
|
|
62
|
+
function collectGraphCounts(graph, reverseGraph) {
|
|
63
|
+
const dependencyCounts = new Map();
|
|
64
|
+
const dependentCounts = new Map();
|
|
65
|
+
for (const [nodeId, deps] of graph.entries()) {
|
|
66
|
+
dependencyCounts.set(nodeId, deps.size);
|
|
67
|
+
}
|
|
68
|
+
for (const [nodeId, dependents] of reverseGraph.entries()) {
|
|
69
|
+
dependentCounts.set(nodeId, dependents.size);
|
|
70
|
+
}
|
|
71
|
+
return { dependencyCounts, dependentCounts };
|
|
72
|
+
}
|
|
73
|
+
function findMaxCountEntry(counts) {
|
|
74
|
+
let maxEntry = { nodeId: '', count: 0 };
|
|
75
|
+
for (const [nodeId, count] of counts.entries()) {
|
|
76
|
+
if (count > maxEntry.count) {
|
|
77
|
+
maxEntry = { nodeId, count };
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
return maxEntry;
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=dependency-graph-stats.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependency-graph-stats.js","sourceRoot":"","sources":["../../src/dependencies/dependency-graph-stats.ts"],"names":[],"mappings":"AAgBA,MAAM,UAAU,4BAA4B,CAC1C,UAAkD,EAClD,KAAsB,EACtB,YAA0B;IAE1B,MAAM,OAAO,GAAG,mBAAmB,CAAC,UAAU,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC;IAErE,OAAO;QACL,eAAe,EAAE,OAAO,CAAC,eAAe;QACxC,iBAAiB,EAAE,OAAO,CAAC,iBAAiB;QAC5C,gBAAgB,EAAE,OAAO,CAAC,gBAAgB;QAC1C,QAAQ,EAAE,OAAO,CAAC,QAAQ;QAC1B,YAAY,EAAE,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC;QAC/D,gBAAgB,EAAE,iBAAiB,CAAC,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAC;KACrE,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,KAAsB;IACpD,IAAI,KAAK,GAAG,CAAC,CAAC;IAEd,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC;QAClC,KAAK,IAAI,IAAI,CAAC,IAAI,CAAC;IACrB,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,mBAAmB,CAC1B,UAAkD,EAClD,KAAsB,EACtB,YAA0B;IAE1B,OAAO;QACL,eAAe,EAAE,UAAU,CAAC,IAAI;QAChC,iBAAiB,EAAE,eAAe,CAAC,KAAK,CAAC;QACzC,QAAQ,EAAE,iBAAiB,CAAC,UAAU,EAAE,KAAK,CAAC;QAC9C,gBAAgB,EAAE,uBAAuB,CAAC,UAAU,CAAC;QACrD,MAAM,EAAE,kBAAkB,CAAC,KAAK,EAAE,YAAY,CAAC;KAChD,CAAC;AACJ,CAAC;AAED,SAAS,uBAAuB,CAAC,UAAkD;IACjF,MAAM,gBAAgB,GAA2B,EAAE,CAAC;IAEpD,KAAK,MAAM,SAAS,IAAI,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC;QAC5C,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,gBAAgB,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;IACjF,CAAC;IAED,OAAO,gBAAgB,CAAC;AAC1B,CAAC;AAED,SAAS,iBAAiB,CAAC,UAAkD,EAAE,KAAsB;IACnG,IAAI,QAAQ,GAAG,CAAC,CAAC;IAEjB,KAAK,MAAM,SAAS,IAAI,UAAU,CAAC,IAAI,EAAE,EAAE,CAAC;QAC1C,MAAM,KAAK,GAAG,QAAQ,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACzC,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IACvC,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,QAAQ,CAAC,SAAiB,EAAE,KAAsB;IACzD,MAAM,OAAO,GAAG,IAAI,GAAG,EAAU,CAAC;IAClC,MAAM,KAAK,GAA2C,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;IACtF,IAAI,QAAQ,GAAG,CAAC,CAAC;IAEjB,OAAO,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxB,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,KAAK,CAAC,KAAK,EAAG,CAAC;QAEvC,IAAI,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC;YAAE,SAAS;QAChC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAElB,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAErC,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,IAAI,GAAG,EAAE,CAAC;QAC1C,KAAK,MAAM,KAAK,IAAI,IAAI,EAAE,CAAC;YACzB,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxB,KAAK,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,KAAK,GAAG,CAAC,EAAE,CAAC,CAAC;YAChD,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,kBAAkB,CAAC,KAAsB,EAAE,YAA0B;IAC5E,MAAM,gBAAgB,GAAG,IAAI,GAAG,EAAkB,CAAC;IACnD,MAAM,eAAe,GAAG,IAAI,GAAG,EAAkB,CAAC;IAElD,KAAK,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,KAAK,CAAC,OAAO,EAAE,EAAE,CAAC;QAC7C,gBAAgB,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1C,CAAC;IAED,KAAK,MAAM,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,YAAY,CAAC,OAAO,EAAE,EAAE,CAAC;QAC1D,eAAe,CAAC,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;IAC/C,CAAC;IAED,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,CAAC;AAC/C,CAAC;AAED,SAAS,iBAAiB,CAAC,MAAmC;IAC5D,IAAI,QAAQ,GAAsC,EAAE,MAAM,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC;IAE3E,KAAK,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,EAAE,EAAE,CAAC;QAC/C,IAAI,KAAK,GAAG,QAAQ,CAAC,KAAK,EAAE,CAAC;YAC3B,QAAQ,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC;QAC/B,CAAC;IACH,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type { NodeId, CircularDependency, DependencyGraph, ReverseGraph } from '../types/dependency.js';
|
|
2
|
+
import type { MetadataComponent } from '../types/metadata.js';
|
|
3
|
+
export type DanglingDependencyReference = {
|
|
4
|
+
from: NodeId;
|
|
5
|
+
to: NodeId;
|
|
6
|
+
};
|
|
7
|
+
export type ValidationSummary = {
|
|
8
|
+
selfLoopErrors: string[];
|
|
9
|
+
danglingReferences: DanglingDependencyReference[];
|
|
10
|
+
};
|
|
11
|
+
export type BuildAnnotations = {
|
|
12
|
+
circularDependencies: CircularDependency[];
|
|
13
|
+
isolatedComponents: NodeId[];
|
|
14
|
+
};
|
|
15
|
+
export declare function collectValidationSummary(components: ReadonlyMap<NodeId, MetadataComponent>, graph: DependencyGraph): ValidationSummary;
|
|
16
|
+
export declare function collectBuildAnnotations(components: ReadonlyMap<NodeId, MetadataComponent>, graph: DependencyGraph, reverseGraph: ReverseGraph): BuildAnnotations;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
export function collectValidationSummary(components, graph) {
|
|
2
|
+
return {
|
|
3
|
+
selfLoopErrors: collectSelfLoopErrors(graph),
|
|
4
|
+
danglingReferences: collectDanglingReferences(components, graph),
|
|
5
|
+
};
|
|
6
|
+
}
|
|
7
|
+
export function collectBuildAnnotations(components, graph, reverseGraph) {
|
|
8
|
+
return {
|
|
9
|
+
circularDependencies: detectCircularDependencies(graph),
|
|
10
|
+
isolatedComponents: findIsolatedComponents(components, graph, reverseGraph),
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
function collectSelfLoopErrors(graph) {
|
|
14
|
+
const selfLoopErrors = [];
|
|
15
|
+
for (const [nodeId, deps] of graph.entries()) {
|
|
16
|
+
if (deps.has(nodeId)) {
|
|
17
|
+
selfLoopErrors.push(`Self-loop detected: ${nodeId}`);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
return selfLoopErrors;
|
|
21
|
+
}
|
|
22
|
+
function collectDanglingReferences(components, graph) {
|
|
23
|
+
const danglingReferences = [];
|
|
24
|
+
for (const [nodeId, deps] of graph.entries()) {
|
|
25
|
+
for (const depId of deps) {
|
|
26
|
+
if (!components.has(depId) && !graph.has(depId)) {
|
|
27
|
+
danglingReferences.push({ from: nodeId, to: depId });
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
return danglingReferences;
|
|
32
|
+
}
|
|
33
|
+
function detectCircularDependencies(graph) {
|
|
34
|
+
const cycles = [];
|
|
35
|
+
const visited = new Set();
|
|
36
|
+
const recursionStack = new Set();
|
|
37
|
+
const currentPath = [];
|
|
38
|
+
const dfs = (nodeId) => {
|
|
39
|
+
visited.add(nodeId);
|
|
40
|
+
recursionStack.add(nodeId);
|
|
41
|
+
currentPath.push(nodeId);
|
|
42
|
+
const deps = graph.get(nodeId) ?? new Set();
|
|
43
|
+
for (const depId of deps) {
|
|
44
|
+
if (!visited.has(depId)) {
|
|
45
|
+
dfs(depId);
|
|
46
|
+
}
|
|
47
|
+
else if (recursionStack.has(depId)) {
|
|
48
|
+
const cycleStart = currentPath.indexOf(depId);
|
|
49
|
+
const cycle = currentPath.slice(cycleStart);
|
|
50
|
+
cycles.push({
|
|
51
|
+
cycle,
|
|
52
|
+
severity: 'warning',
|
|
53
|
+
message: `Circular dependency detected: ${cycle.join(' → ')} → ${depId}`,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
recursionStack.delete(nodeId);
|
|
58
|
+
currentPath.pop();
|
|
59
|
+
};
|
|
60
|
+
for (const nodeId of graph.keys()) {
|
|
61
|
+
if (!visited.has(nodeId)) {
|
|
62
|
+
dfs(nodeId);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return cycles;
|
|
66
|
+
}
|
|
67
|
+
function findIsolatedComponents(components, graph, reverseGraph) {
|
|
68
|
+
const isolated = [];
|
|
69
|
+
for (const nodeId of components.keys()) {
|
|
70
|
+
const deps = graph.get(nodeId)?.size ?? 0;
|
|
71
|
+
const dependents = reverseGraph.get(nodeId)?.size ?? 0;
|
|
72
|
+
if (deps === 0 && dependents === 0) {
|
|
73
|
+
isolated.push(nodeId);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return isolated;
|
|
77
|
+
}
|
|
78
|
+
//# sourceMappingURL=dependency-graph-validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dependency-graph-validation.js","sourceRoot":"","sources":["../../src/dependencies/dependency-graph-validation.ts"],"names":[],"mappings":"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"}
|