@angular/compiler-cli 11.2.3 → 11.2.7
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/linker/src/file_linker/partial_linkers/partial_linker_selector.d.ts +1 -1
- package/linker/src/file_linker/partial_linkers/partial_linker_selector.js +4 -4
- package/ngcc/src/analysis/decoration_analyzer.d.ts +2 -1
- package/ngcc/src/analysis/decoration_analyzer.js +6 -4
- package/ngcc/src/analysis/ngcc_trait_compiler.d.ts +3 -2
- package/ngcc/src/analysis/ngcc_trait_compiler.js +3 -2
- package/ngcc/src/analysis/util.js +1 -3
- package/ngcc/src/command_line_options.js +10 -2
- package/ngcc/src/entry_point_finder/utils.js +85 -24
- package/ngcc/src/execution/analyze_entry_points.d.ts +1 -1
- package/ngcc/src/execution/analyze_entry_points.js +18 -9
- package/ngcc/src/execution/create_compile_function.js +5 -5
- package/ngcc/src/execution/tasks/api.d.ts +23 -2
- package/ngcc/src/execution/tasks/api.js +22 -2
- package/ngcc/src/execution/tasks/completion.js +13 -9
- package/ngcc/src/execution/tasks/utils.js +6 -3
- package/ngcc/src/main.js +3 -3
- package/ngcc/src/ngcc_options.d.ts +12 -1
- package/ngcc/src/ngcc_options.js +8 -2
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/ngcc/src/packages/entry_point_bundle.d.ts +4 -2
- package/ngcc/src/packages/entry_point_bundle.js +9 -6
- package/ngcc/src/packages/transformer.js +10 -5
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/component.d.ts +18 -4
- package/src/ngtsc/annotations/src/component.js +137 -23
- package/src/ngtsc/annotations/src/directive.d.ts +22 -3
- package/src/ngtsc/annotations/src/directive.js +122 -5
- package/src/ngtsc/annotations/src/injectable.d.ts +2 -1
- package/src/ngtsc/annotations/src/injectable.js +4 -1
- package/src/ngtsc/annotations/src/ng_module.d.ts +16 -5
- package/src/ngtsc/annotations/src/ng_module.js +121 -39
- package/src/ngtsc/annotations/src/pipe.d.ts +12 -1
- package/src/ngtsc/annotations/src/pipe.js +29 -3
- package/src/ngtsc/annotations/src/util.js +7 -7
- package/src/ngtsc/core/src/compiler.d.ts +0 -5
- package/src/ngtsc/core/src/compiler.js +19 -111
- package/src/ngtsc/core/src/host.d.ts +1 -0
- package/src/ngtsc/core/src/host.js +16 -1
- package/src/ngtsc/cycles/src/imports.d.ts +2 -3
- package/src/ngtsc/cycles/src/imports.js +28 -14
- package/src/ngtsc/diagnostics/src/error_code.d.ts +7 -1
- package/src/ngtsc/diagnostics/src/error_code.js +10 -4
- package/src/ngtsc/imports/index.d.ts +1 -1
- package/src/ngtsc/imports/index.js +1 -1
- package/src/ngtsc/imports/src/alias.d.ts +2 -2
- package/src/ngtsc/imports/src/alias.js +3 -3
- package/src/ngtsc/imports/src/emitter.d.ts +51 -10
- package/src/ngtsc/imports/src/emitter.js +26 -19
- package/src/ngtsc/incremental/api.d.ts +0 -14
- package/src/ngtsc/incremental/api.js +1 -1
- package/src/ngtsc/incremental/semantic_graph/index.d.ts +12 -0
- package/src/ngtsc/incremental/semantic_graph/index.js +34 -0
- package/src/ngtsc/incremental/semantic_graph/src/api.d.ts +98 -0
- package/src/ngtsc/incremental/semantic_graph/src/api.js +51 -0
- package/src/ngtsc/incremental/semantic_graph/src/graph.d.ts +105 -0
- package/src/ngtsc/incremental/semantic_graph/src/graph.js +302 -0
- package/src/ngtsc/incremental/semantic_graph/src/type_parameters.d.ts +30 -0
- package/src/ngtsc/incremental/semantic_graph/src/type_parameters.js +55 -0
- package/src/ngtsc/incremental/semantic_graph/src/util.d.ts +29 -0
- package/src/ngtsc/incremental/semantic_graph/src/util.js +111 -0
- package/src/ngtsc/incremental/src/dependency_tracking.d.ts +0 -3
- package/src/ngtsc/incremental/src/dependency_tracking.js +9 -50
- package/src/ngtsc/incremental/src/state.d.ts +2 -1
- package/src/ngtsc/incremental/src/state.js +61 -16
- package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
- package/src/ngtsc/scope/src/dependency.js +1 -2
- package/src/ngtsc/scope/src/local.d.ts +0 -13
- package/src/ngtsc/scope/src/local.js +2 -16
- package/src/ngtsc/transform/src/api.d.ts +16 -2
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.d.ts +7 -4
- package/src/ngtsc/transform/src/compilation.js +25 -8
- package/src/ngtsc/transform/src/trait.d.ts +14 -11
- package/src/ngtsc/transform/src/trait.js +7 -3
- package/src/ngtsc/typecheck/api/api.d.ts +27 -0
- package/src/ngtsc/typecheck/api/api.js +1 -1
- package/src/ngtsc/typecheck/src/context.js +25 -28
- package/src/ngtsc/typecheck/src/environment.d.ts +1 -1
- package/src/ngtsc/typecheck/src/environment.js +3 -3
- package/src/ngtsc/typecheck/src/oob.d.ts +6 -0
- package/src/ngtsc/typecheck/src/oob.js +36 -1
- package/src/ngtsc/typecheck/src/type_check_block.js +107 -23
- package/src/ngtsc/typecheck/src/type_check_file.d.ts +1 -1
- package/src/ngtsc/typecheck/src/type_check_file.js +3 -3
- package/src/perform_compile.d.ts +1 -2
- package/src/perform_compile.js +58 -47
- package/src/transformers/node_emitter.js +1 -2
- package/src/version.js +1 -1
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
(function (factory) {
|
|
2
|
+
if (typeof module === "object" && typeof module.exports === "object") {
|
|
3
|
+
var v = factory(require, exports);
|
|
4
|
+
if (v !== undefined) module.exports = v;
|
|
5
|
+
}
|
|
6
|
+
else if (typeof define === "function" && define.amd) {
|
|
7
|
+
define("@angular/compiler-cli/src/ngtsc/incremental/semantic_graph/src/util", ["require", "exports", "tslib"], factory);
|
|
8
|
+
}
|
|
9
|
+
})(function (require, exports) {
|
|
10
|
+
"use strict";
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.isSetEqual = exports.isArrayEqual = exports.referenceEquality = exports.isReferenceEqual = exports.isSymbolEqual = void 0;
|
|
13
|
+
var tslib_1 = require("tslib");
|
|
14
|
+
/**
|
|
15
|
+
* Determines whether the provided symbols represent the same declaration.
|
|
16
|
+
*/
|
|
17
|
+
function isSymbolEqual(a, b) {
|
|
18
|
+
if (a.decl === b.decl) {
|
|
19
|
+
// If the declaration is identical then it must represent the same symbol.
|
|
20
|
+
return true;
|
|
21
|
+
}
|
|
22
|
+
if (a.identifier === null || b.identifier === null) {
|
|
23
|
+
// Unidentifiable symbols are assumed to be different.
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
return a.path === b.path && a.identifier === b.identifier;
|
|
27
|
+
}
|
|
28
|
+
exports.isSymbolEqual = isSymbolEqual;
|
|
29
|
+
/**
|
|
30
|
+
* Determines whether the provided references to a semantic symbol are still equal, i.e. represent
|
|
31
|
+
* the same symbol and are imported by the same path.
|
|
32
|
+
*/
|
|
33
|
+
function isReferenceEqual(a, b) {
|
|
34
|
+
if (!isSymbolEqual(a.symbol, b.symbol)) {
|
|
35
|
+
// If the reference's target symbols are different, the reference itself is different.
|
|
36
|
+
return false;
|
|
37
|
+
}
|
|
38
|
+
// The reference still corresponds with the same symbol, now check that the path by which it is
|
|
39
|
+
// imported has not changed.
|
|
40
|
+
return a.importPath === b.importPath;
|
|
41
|
+
}
|
|
42
|
+
exports.isReferenceEqual = isReferenceEqual;
|
|
43
|
+
function referenceEquality(a, b) {
|
|
44
|
+
return a === b;
|
|
45
|
+
}
|
|
46
|
+
exports.referenceEquality = referenceEquality;
|
|
47
|
+
/**
|
|
48
|
+
* Determines if the provided arrays are equal to each other, using the provided equality tester
|
|
49
|
+
* that is called for all entries in the array.
|
|
50
|
+
*/
|
|
51
|
+
function isArrayEqual(a, b, equalityTester) {
|
|
52
|
+
if (equalityTester === void 0) { equalityTester = referenceEquality; }
|
|
53
|
+
if (a === null || b === null) {
|
|
54
|
+
return a === b;
|
|
55
|
+
}
|
|
56
|
+
if (a.length !== b.length) {
|
|
57
|
+
return false;
|
|
58
|
+
}
|
|
59
|
+
return !a.some(function (item, index) { return !equalityTester(item, b[index]); });
|
|
60
|
+
}
|
|
61
|
+
exports.isArrayEqual = isArrayEqual;
|
|
62
|
+
/**
|
|
63
|
+
* Determines if the provided sets are equal to each other, using the provided equality tester.
|
|
64
|
+
* Sets that only differ in ordering are considered equal.
|
|
65
|
+
*/
|
|
66
|
+
function isSetEqual(a, b, equalityTester) {
|
|
67
|
+
var e_1, _a, e_2, _b;
|
|
68
|
+
if (equalityTester === void 0) { equalityTester = referenceEquality; }
|
|
69
|
+
if (a === null || b === null) {
|
|
70
|
+
return a === b;
|
|
71
|
+
}
|
|
72
|
+
if (a.size !== b.size) {
|
|
73
|
+
return false;
|
|
74
|
+
}
|
|
75
|
+
try {
|
|
76
|
+
for (var a_1 = tslib_1.__values(a), a_1_1 = a_1.next(); !a_1_1.done; a_1_1 = a_1.next()) {
|
|
77
|
+
var itemA = a_1_1.value;
|
|
78
|
+
var found = false;
|
|
79
|
+
try {
|
|
80
|
+
for (var b_1 = (e_2 = void 0, tslib_1.__values(b)), b_1_1 = b_1.next(); !b_1_1.done; b_1_1 = b_1.next()) {
|
|
81
|
+
var itemB = b_1_1.value;
|
|
82
|
+
if (equalityTester(itemA, itemB)) {
|
|
83
|
+
found = true;
|
|
84
|
+
break;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
89
|
+
finally {
|
|
90
|
+
try {
|
|
91
|
+
if (b_1_1 && !b_1_1.done && (_b = b_1.return)) _b.call(b_1);
|
|
92
|
+
}
|
|
93
|
+
finally { if (e_2) throw e_2.error; }
|
|
94
|
+
}
|
|
95
|
+
if (!found) {
|
|
96
|
+
return false;
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
101
|
+
finally {
|
|
102
|
+
try {
|
|
103
|
+
if (a_1_1 && !a_1_1.done && (_a = a_1.return)) _a.call(a_1);
|
|
104
|
+
}
|
|
105
|
+
finally { if (e_1) throw e_1.error; }
|
|
106
|
+
}
|
|
107
|
+
return true;
|
|
108
|
+
}
|
|
109
|
+
exports.isSetEqual = isSetEqual;
|
|
110
|
+
});
|
|
111
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9zcmMvbmd0c2MvaW5jcmVtZW50YWwvc2VtYW50aWNfZ3JhcGgvc3JjL3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztJQVNBOztPQUVHO0lBQ0gsU0FBZ0IsYUFBYSxDQUFDLENBQWlCLEVBQUUsQ0FBaUI7UUFDaEUsSUFBSSxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxJQUFJLEVBQUU7WUFDckIsMEVBQTBFO1lBQzFFLE9BQU8sSUFBSSxDQUFDO1NBQ2I7UUFFRCxJQUFJLENBQUMsQ0FBQyxVQUFVLEtBQUssSUFBSSxJQUFJLENBQUMsQ0FBQyxVQUFVLEtBQUssSUFBSSxFQUFFO1lBQ2xELHNEQUFzRDtZQUN0RCxPQUFPLEtBQUssQ0FBQztTQUNkO1FBRUQsT0FBTyxDQUFDLENBQUMsSUFBSSxLQUFLLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLFVBQVUsS0FBSyxDQUFDLENBQUMsVUFBVSxDQUFDO0lBQzVELENBQUM7SUFaRCxzQ0FZQztJQUVEOzs7T0FHRztJQUNILFNBQWdCLGdCQUFnQixDQUFDLENBQW9CLEVBQUUsQ0FBb0I7UUFDekUsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN0QyxzRkFBc0Y7WUFDdEYsT0FBTyxLQUFLLENBQUM7U0FDZDtRQUVELCtGQUErRjtRQUMvRiw0QkFBNEI7UUFDNUIsT0FBTyxDQUFDLENBQUMsVUFBVSxLQUFLLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDdkMsQ0FBQztJQVRELDRDQVNDO0lBRUQsU0FBZ0IsaUJBQWlCLENBQUksQ0FBSSxFQUFFLENBQUk7UUFDN0MsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2pCLENBQUM7SUFGRCw4Q0FFQztJQUVEOzs7T0FHRztJQUNILFNBQWdCLFlBQVksQ0FDeEIsQ0FBb0IsRUFBRSxDQUFvQixFQUMxQyxjQUEyRDtRQUEzRCwrQkFBQSxFQUFBLGtDQUEyRDtRQUM3RCxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRTtZQUM1QixPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDaEI7UUFFRCxJQUFJLENBQUMsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLE1BQU0sRUFBRTtZQUN6QixPQUFPLEtBQUssQ0FBQztTQUNkO1FBRUQsT0FBTyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsVUFBQyxJQUFJLEVBQUUsS0FBSyxJQUFLLE9BQUEsQ0FBQyxjQUFjLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxFQUEvQixDQUErQixDQUFDLENBQUM7SUFDbkUsQ0FBQztJQVpELG9DQVlDO0lBRUQ7OztPQUdHO0lBQ0gsU0FBZ0IsVUFBVSxDQUN0QixDQUFzQixFQUFFLENBQXNCLEVBQzlDLGNBQTJEOztRQUEzRCwrQkFBQSxFQUFBLGtDQUEyRDtRQUM3RCxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRTtZQUM1QixPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7U0FDaEI7UUFFRCxJQUFJLENBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQyxDQUFDLElBQUksRUFBRTtZQUNyQixPQUFPLEtBQUssQ0FBQztTQUNkOztZQUVELEtBQW9CLElBQUEsTUFBQSxpQkFBQSxDQUFDLENBQUEsb0JBQUEsbUNBQUU7Z0JBQWxCLElBQU0sS0FBSyxjQUFBO2dCQUNkLElBQUksS0FBSyxHQUFHLEtBQUssQ0FBQzs7b0JBQ2xCLEtBQW9CLElBQUEscUJBQUEsaUJBQUEsQ0FBQyxDQUFBLENBQUEsb0JBQUEsbUNBQUU7d0JBQWxCLElBQU0sS0FBSyxjQUFBO3dCQUNkLElBQUksY0FBYyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsRUFBRTs0QkFDaEMsS0FBSyxHQUFHLElBQUksQ0FBQzs0QkFDYixNQUFNO3lCQUNQO3FCQUNGOzs7Ozs7Ozs7Z0JBQ0QsSUFBSSxDQUFDLEtBQUssRUFBRTtvQkFDVixPQUFPLEtBQUssQ0FBQztpQkFDZDthQUNGOzs7Ozs7Ozs7UUFFRCxPQUFPLElBQUksQ0FBQztJQUNkLENBQUM7SUF6QkQsZ0NBeUJDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge1NlbWFudGljUmVmZXJlbmNlLCBTZW1hbnRpY1N5bWJvbH0gZnJvbSAnLi9hcGknO1xuXG4vKipcbiAqIERldGVybWluZXMgd2hldGhlciB0aGUgcHJvdmlkZWQgc3ltYm9scyByZXByZXNlbnQgdGhlIHNhbWUgZGVjbGFyYXRpb24uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1N5bWJvbEVxdWFsKGE6IFNlbWFudGljU3ltYm9sLCBiOiBTZW1hbnRpY1N5bWJvbCk6IGJvb2xlYW4ge1xuICBpZiAoYS5kZWNsID09PSBiLmRlY2wpIHtcbiAgICAvLyBJZiB0aGUgZGVjbGFyYXRpb24gaXMgaWRlbnRpY2FsIHRoZW4gaXQgbXVzdCByZXByZXNlbnQgdGhlIHNhbWUgc3ltYm9sLlxuICAgIHJldHVybiB0cnVlO1xuICB9XG5cbiAgaWYgKGEuaWRlbnRpZmllciA9PT0gbnVsbCB8fCBiLmlkZW50aWZpZXIgPT09IG51bGwpIHtcbiAgICAvLyBVbmlkZW50aWZpYWJsZSBzeW1ib2xzIGFyZSBhc3N1bWVkIHRvIGJlIGRpZmZlcmVudC5cbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICByZXR1cm4gYS5wYXRoID09PSBiLnBhdGggJiYgYS5pZGVudGlmaWVyID09PSBiLmlkZW50aWZpZXI7XG59XG5cbi8qKlxuICogRGV0ZXJtaW5lcyB3aGV0aGVyIHRoZSBwcm92aWRlZCByZWZlcmVuY2VzIHRvIGEgc2VtYW50aWMgc3ltYm9sIGFyZSBzdGlsbCBlcXVhbCwgaS5lLiByZXByZXNlbnRcbiAqIHRoZSBzYW1lIHN5bWJvbCBhbmQgYXJlIGltcG9ydGVkIGJ5IHRoZSBzYW1lIHBhdGguXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBpc1JlZmVyZW5jZUVxdWFsKGE6IFNlbWFudGljUmVmZXJlbmNlLCBiOiBTZW1hbnRpY1JlZmVyZW5jZSk6IGJvb2xlYW4ge1xuICBpZiAoIWlzU3ltYm9sRXF1YWwoYS5zeW1ib2wsIGIuc3ltYm9sKSkge1xuICAgIC8vIElmIHRoZSByZWZlcmVuY2UncyB0YXJnZXQgc3ltYm9scyBhcmUgZGlmZmVyZW50LCB0aGUgcmVmZXJlbmNlIGl0c2VsZiBpcyBkaWZmZXJlbnQuXG4gICAgcmV0dXJuIGZhbHNlO1xuICB9XG5cbiAgLy8gVGhlIHJlZmVyZW5jZSBzdGlsbCBjb3JyZXNwb25kcyB3aXRoIHRoZSBzYW1lIHN5bWJvbCwgbm93IGNoZWNrIHRoYXQgdGhlIHBhdGggYnkgd2hpY2ggaXQgaXNcbiAgLy8gaW1wb3J0ZWQgaGFzIG5vdCBjaGFuZ2VkLlxuICByZXR1cm4gYS5pbXBvcnRQYXRoID09PSBiLmltcG9ydFBhdGg7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiByZWZlcmVuY2VFcXVhbGl0eTxUPihhOiBULCBiOiBUKTogYm9vbGVhbiB7XG4gIHJldHVybiBhID09PSBiO1xufVxuXG4vKipcbiAqIERldGVybWluZXMgaWYgdGhlIHByb3ZpZGVkIGFycmF5cyBhcmUgZXF1YWwgdG8gZWFjaCBvdGhlciwgdXNpbmcgdGhlIHByb3ZpZGVkIGVxdWFsaXR5IHRlc3RlclxuICogdGhhdCBpcyBjYWxsZWQgZm9yIGFsbCBlbnRyaWVzIGluIHRoZSBhcnJheS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzQXJyYXlFcXVhbDxUPihcbiAgICBhOiByZWFkb25seSBUW118bnVsbCwgYjogcmVhZG9ubHkgVFtdfG51bGwsXG4gICAgZXF1YWxpdHlUZXN0ZXI6IChhOiBULCBiOiBUKSA9PiBib29sZWFuID0gcmVmZXJlbmNlRXF1YWxpdHkpOiBib29sZWFuIHtcbiAgaWYgKGEgPT09IG51bGwgfHwgYiA9PT0gbnVsbCkge1xuICAgIHJldHVybiBhID09PSBiO1xuICB9XG5cbiAgaWYgKGEubGVuZ3RoICE9PSBiLmxlbmd0aCkge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxuXG4gIHJldHVybiAhYS5zb21lKChpdGVtLCBpbmRleCkgPT4gIWVxdWFsaXR5VGVzdGVyKGl0ZW0sIGJbaW5kZXhdKSk7XG59XG5cbi8qKlxuICogRGV0ZXJtaW5lcyBpZiB0aGUgcHJvdmlkZWQgc2V0cyBhcmUgZXF1YWwgdG8gZWFjaCBvdGhlciwgdXNpbmcgdGhlIHByb3ZpZGVkIGVxdWFsaXR5IHRlc3Rlci5cbiAqIFNldHMgdGhhdCBvbmx5IGRpZmZlciBpbiBvcmRlcmluZyBhcmUgY29uc2lkZXJlZCBlcXVhbC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzU2V0RXF1YWw8VD4oXG4gICAgYTogUmVhZG9ubHlTZXQ8VD58bnVsbCwgYjogUmVhZG9ubHlTZXQ8VD58bnVsbCxcbiAgICBlcXVhbGl0eVRlc3RlcjogKGE6IFQsIGI6IFQpID0+IGJvb2xlYW4gPSByZWZlcmVuY2VFcXVhbGl0eSk6IGJvb2xlYW4ge1xuICBpZiAoYSA9PT0gbnVsbCB8fCBiID09PSBudWxsKSB7XG4gICAgcmV0dXJuIGEgPT09IGI7XG4gIH1cblxuICBpZiAoYS5zaXplICE9PSBiLnNpemUpIHtcbiAgICByZXR1cm4gZmFsc2U7XG4gIH1cblxuICBmb3IgKGNvbnN0IGl0ZW1BIG9mIGEpIHtcbiAgICBsZXQgZm91bmQgPSBmYWxzZTtcbiAgICBmb3IgKGNvbnN0IGl0ZW1CIG9mIGIpIHtcbiAgICAgIGlmIChlcXVhbGl0eVRlc3RlcihpdGVtQSwgaXRlbUIpKSB7XG4gICAgICAgIGZvdW5kID0gdHJ1ZTtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgfVxuICAgIGlmICghZm91bmQpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gIH1cblxuICByZXR1cm4gdHJ1ZTtcbn1cbiJdfQ==
|
|
@@ -27,11 +27,8 @@ export declare class FileDependencyGraph<T extends {
|
|
|
27
27
|
private nodes;
|
|
28
28
|
addDependency(from: T, on: T): void;
|
|
29
29
|
addResourceDependency(from: T, resource: AbsoluteFsPath): void;
|
|
30
|
-
addTransitiveDependency(from: T, on: T): void;
|
|
31
|
-
addTransitiveResources(from: T, resourcesOf: T): void;
|
|
32
30
|
recordDependencyAnalysisFailure(file: T): void;
|
|
33
31
|
getResourceDependencies(from: T): AbsoluteFsPath[];
|
|
34
|
-
isStale(sf: T, changedTsPaths: Set<string>, changedResources: Set<AbsoluteFsPath>): boolean;
|
|
35
32
|
/**
|
|
36
33
|
* Update the current dependency graph from a previous one, incorporating a set of physical
|
|
37
34
|
* changes.
|
|
@@ -40,43 +40,6 @@
|
|
|
40
40
|
FileDependencyGraph.prototype.addResourceDependency = function (from, resource) {
|
|
41
41
|
this.nodeFor(from).usesResources.add(resource);
|
|
42
42
|
};
|
|
43
|
-
FileDependencyGraph.prototype.addTransitiveDependency = function (from, on) {
|
|
44
|
-
var e_1, _a;
|
|
45
|
-
var nodeFrom = this.nodeFor(from);
|
|
46
|
-
nodeFrom.dependsOn.add(on.fileName);
|
|
47
|
-
var nodeOn = this.nodeFor(on);
|
|
48
|
-
try {
|
|
49
|
-
for (var _b = tslib_1.__values(nodeOn.dependsOn), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
50
|
-
var dep = _c.value;
|
|
51
|
-
nodeFrom.dependsOn.add(dep);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
55
|
-
finally {
|
|
56
|
-
try {
|
|
57
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
58
|
-
}
|
|
59
|
-
finally { if (e_1) throw e_1.error; }
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
FileDependencyGraph.prototype.addTransitiveResources = function (from, resourcesOf) {
|
|
63
|
-
var e_2, _a;
|
|
64
|
-
var nodeFrom = this.nodeFor(from);
|
|
65
|
-
var nodeOn = this.nodeFor(resourcesOf);
|
|
66
|
-
try {
|
|
67
|
-
for (var _b = tslib_1.__values(nodeOn.usesResources), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
68
|
-
var dep = _c.value;
|
|
69
|
-
nodeFrom.usesResources.add(dep);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
73
|
-
finally {
|
|
74
|
-
try {
|
|
75
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
76
|
-
}
|
|
77
|
-
finally { if (e_2) throw e_2.error; }
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
43
|
FileDependencyGraph.prototype.recordDependencyAnalysisFailure = function (file) {
|
|
81
44
|
this.nodeFor(file).failedAnalysis = true;
|
|
82
45
|
};
|
|
@@ -84,9 +47,6 @@
|
|
|
84
47
|
var node = this.nodes.get(from);
|
|
85
48
|
return node ? tslib_1.__spread(node.usesResources) : [];
|
|
86
49
|
};
|
|
87
|
-
FileDependencyGraph.prototype.isStale = function (sf, changedTsPaths, changedResources) {
|
|
88
|
-
return isLogicallyChanged(sf, this.nodeFor(sf), changedTsPaths, EMPTY_SET, changedResources);
|
|
89
|
-
};
|
|
90
50
|
/**
|
|
91
51
|
* Update the current dependency graph from a previous one, incorporating a set of physical
|
|
92
52
|
* changes.
|
|
@@ -109,7 +69,7 @@
|
|
|
109
69
|
* P(n) = the physically changed files from build n - 1 to build n.
|
|
110
70
|
*/
|
|
111
71
|
FileDependencyGraph.prototype.updateWithPhysicalChanges = function (previous, changedTsPaths, deletedTsPaths, changedResources) {
|
|
112
|
-
var
|
|
72
|
+
var e_1, _a;
|
|
113
73
|
var logicallyChanged = new Set();
|
|
114
74
|
try {
|
|
115
75
|
for (var _b = tslib_1.__values(previous.nodes.keys()), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
@@ -127,12 +87,12 @@
|
|
|
127
87
|
}
|
|
128
88
|
}
|
|
129
89
|
}
|
|
130
|
-
catch (
|
|
90
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
131
91
|
finally {
|
|
132
92
|
try {
|
|
133
93
|
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
134
94
|
}
|
|
135
|
-
finally { if (
|
|
95
|
+
finally { if (e_1) throw e_1.error; }
|
|
136
96
|
}
|
|
137
97
|
return logicallyChanged;
|
|
138
98
|
};
|
|
@@ -154,7 +114,7 @@
|
|
|
154
114
|
* changed files and resources.
|
|
155
115
|
*/
|
|
156
116
|
function isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources) {
|
|
157
|
-
var
|
|
117
|
+
var e_2, _a, e_3, _b;
|
|
158
118
|
// A file is assumed to have logically changed if its dependencies could not be determined
|
|
159
119
|
// accurately.
|
|
160
120
|
if (node.failedAnalysis) {
|
|
@@ -173,12 +133,12 @@
|
|
|
173
133
|
}
|
|
174
134
|
}
|
|
175
135
|
}
|
|
176
|
-
catch (
|
|
136
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
177
137
|
finally {
|
|
178
138
|
try {
|
|
179
139
|
if (_d && !_d.done && (_a = _c.return)) _a.call(_c);
|
|
180
140
|
}
|
|
181
|
-
finally { if (
|
|
141
|
+
finally { if (e_2) throw e_2.error; }
|
|
182
142
|
}
|
|
183
143
|
try {
|
|
184
144
|
// A file is logically changed if one of its resources has physically changed.
|
|
@@ -189,15 +149,14 @@
|
|
|
189
149
|
}
|
|
190
150
|
}
|
|
191
151
|
}
|
|
192
|
-
catch (
|
|
152
|
+
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
|
193
153
|
finally {
|
|
194
154
|
try {
|
|
195
155
|
if (_f && !_f.done && (_b = _e.return)) _b.call(_e);
|
|
196
156
|
}
|
|
197
|
-
finally { if (
|
|
157
|
+
finally { if (e_3) throw e_3.error; }
|
|
198
158
|
}
|
|
199
159
|
return false;
|
|
200
160
|
}
|
|
201
|
-
var EMPTY_SET = new Set();
|
|
202
161
|
});
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_tracking.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/dependency_tracking.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {AbsoluteFsPath} from '../../file_system';\nimport {DependencyTracker} from '../api';\n\n/**\n * An implementation of the `DependencyTracker` dependency graph API.\n *\n * The `FileDependencyGraph`'s primary job is to determine whether a given file has \"logically\"\n * changed, given the set of physical changes (direct changes to files on disk).\n *\n * A file is logically changed if at least one of three conditions is met:\n *\n * 1. The file itself has physically changed.\n * 2. One of its dependencies has physically changed.\n * 3. One of its resource dependencies has physically changed.\n */\nexport class FileDependencyGraph<T extends {fileName: string} = ts.SourceFile> implements\n    DependencyTracker<T> {\n  private nodes = new Map<T, FileNode>();\n\n  addDependency(from: T, on: T): void {\n    this.nodeFor(from).dependsOn.add(on.fileName);\n  }\n\n  addResourceDependency(from: T, resource: AbsoluteFsPath): void {\n    this.nodeFor(from).usesResources.add(resource);\n  }\n\n  addTransitiveDependency(from: T, on: T): void {\n    const nodeFrom = this.nodeFor(from);\n    nodeFrom.dependsOn.add(on.fileName);\n\n    const nodeOn = this.nodeFor(on);\n    for (const dep of nodeOn.dependsOn) {\n      nodeFrom.dependsOn.add(dep);\n    }\n  }\n\n  addTransitiveResources(from: T, resourcesOf: T): void {\n    const nodeFrom = this.nodeFor(from);\n    const nodeOn = this.nodeFor(resourcesOf);\n    for (const dep of nodeOn.usesResources) {\n      nodeFrom.usesResources.add(dep);\n    }\n  }\n\n  recordDependencyAnalysisFailure(file: T): void {\n    this.nodeFor(file).failedAnalysis = true;\n  }\n\n  getResourceDependencies(from: T): AbsoluteFsPath[] {\n    const node = this.nodes.get(from);\n\n    return node ? [...node.usesResources] : [];\n  }\n\n  isStale(sf: T, changedTsPaths: Set<string>, changedResources: Set<AbsoluteFsPath>): boolean {\n    return isLogicallyChanged(sf, this.nodeFor(sf), changedTsPaths, EMPTY_SET, changedResources);\n  }\n\n  /**\n   * Update the current dependency graph from a previous one, incorporating a set of physical\n   * changes.\n   *\n   * This method performs two tasks:\n   *\n   * 1. For files which have not logically changed, their dependencies from `previous` are added to\n   *    `this` graph.\n   * 2. For files which have logically changed, they're added to a set of logically changed files\n   *    which is eventually returned.\n   *\n   * In essence, for build `n`, this method performs:\n   *\n   * G(n) + L(n) = G(n - 1) + P(n)\n   *\n   * where:\n   *\n   * G(n) = the dependency graph of build `n`\n   * L(n) = the logically changed files from build n - 1 to build n.\n   * P(n) = the physically changed files from build n - 1 to build n.\n   */\n  updateWithPhysicalChanges(\n      previous: FileDependencyGraph<T>, changedTsPaths: Set<string>, deletedTsPaths: Set<string>,\n      changedResources: Set<AbsoluteFsPath>): Set<string> {\n    const logicallyChanged = new Set<string>();\n\n    for (const sf of previous.nodes.keys()) {\n      const node = previous.nodeFor(sf);\n      if (isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources)) {\n        logicallyChanged.add(sf.fileName);\n      } else if (!deletedTsPaths.has(sf.fileName)) {\n        this.nodes.set(sf, {\n          dependsOn: new Set(node.dependsOn),\n          usesResources: new Set(node.usesResources),\n          failedAnalysis: false,\n        });\n      }\n    }\n\n    return logicallyChanged;\n  }\n\n  private nodeFor(sf: T): FileNode {\n    if (!this.nodes.has(sf)) {\n      this.nodes.set(sf, {\n        dependsOn: new Set<string>(),\n        usesResources: new Set<AbsoluteFsPath>(),\n        failedAnalysis: false,\n      });\n    }\n    return this.nodes.get(sf)!;\n  }\n}\n\n/**\n * Determine whether `sf` has logically changed, given its dependencies and the set of physically\n * changed files and resources.\n */\nfunction isLogicallyChanged<T extends {fileName: string}>(\n    sf: T, node: FileNode, changedTsPaths: ReadonlySet<string>, deletedTsPaths: ReadonlySet<string>,\n    changedResources: ReadonlySet<AbsoluteFsPath>): boolean {\n  // A file is assumed to have logically changed if its dependencies could not be determined\n  // accurately.\n  if (node.failedAnalysis) {\n    return true;\n  }\n\n  // A file is logically changed if it has physically changed itself (including being deleted).\n  if (changedTsPaths.has(sf.fileName) || deletedTsPaths.has(sf.fileName)) {\n    return true;\n  }\n\n  // A file is logically changed if one of its dependencies has physically changed.\n  for (const dep of node.dependsOn) {\n    if (changedTsPaths.has(dep) || deletedTsPaths.has(dep)) {\n      return true;\n    }\n  }\n\n  // A file is logically changed if one of its resources has physically changed.\n  for (const dep of node.usesResources) {\n    if (changedResources.has(dep)) {\n      return true;\n    }\n  }\n  return false;\n}\n\ninterface FileNode {\n  dependsOn: Set<string>;\n  usesResources: Set<AbsoluteFsPath>;\n  failedAnalysis: boolean;\n}\n\nconst EMPTY_SET: ReadonlySet<any> = new Set<any>();\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_tracking.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/dependency_tracking.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {AbsoluteFsPath} from '../../file_system';\nimport {DependencyTracker} from '../api';\n\n/**\n * An implementation of the `DependencyTracker` dependency graph API.\n *\n * The `FileDependencyGraph`'s primary job is to determine whether a given file has \"logically\"\n * changed, given the set of physical changes (direct changes to files on disk).\n *\n * A file is logically changed if at least one of three conditions is met:\n *\n * 1. The file itself has physically changed.\n * 2. One of its dependencies has physically changed.\n * 3. One of its resource dependencies has physically changed.\n */\nexport class FileDependencyGraph<T extends {fileName: string} = ts.SourceFile> implements\n    DependencyTracker<T> {\n  private nodes = new Map<T, FileNode>();\n\n  addDependency(from: T, on: T): void {\n    this.nodeFor(from).dependsOn.add(on.fileName);\n  }\n\n  addResourceDependency(from: T, resource: AbsoluteFsPath): void {\n    this.nodeFor(from).usesResources.add(resource);\n  }\n\n  recordDependencyAnalysisFailure(file: T): void {\n    this.nodeFor(file).failedAnalysis = true;\n  }\n\n  getResourceDependencies(from: T): AbsoluteFsPath[] {\n    const node = this.nodes.get(from);\n\n    return node ? [...node.usesResources] : [];\n  }\n\n  /**\n   * Update the current dependency graph from a previous one, incorporating a set of physical\n   * changes.\n   *\n   * This method performs two tasks:\n   *\n   * 1. For files which have not logically changed, their dependencies from `previous` are added to\n   *    `this` graph.\n   * 2. For files which have logically changed, they're added to a set of logically changed files\n   *    which is eventually returned.\n   *\n   * In essence, for build `n`, this method performs:\n   *\n   * G(n) + L(n) = G(n - 1) + P(n)\n   *\n   * where:\n   *\n   * G(n) = the dependency graph of build `n`\n   * L(n) = the logically changed files from build n - 1 to build n.\n   * P(n) = the physically changed files from build n - 1 to build n.\n   */\n  updateWithPhysicalChanges(\n      previous: FileDependencyGraph<T>, changedTsPaths: Set<string>, deletedTsPaths: Set<string>,\n      changedResources: Set<AbsoluteFsPath>): Set<string> {\n    const logicallyChanged = new Set<string>();\n\n    for (const sf of previous.nodes.keys()) {\n      const node = previous.nodeFor(sf);\n      if (isLogicallyChanged(sf, node, changedTsPaths, deletedTsPaths, changedResources)) {\n        logicallyChanged.add(sf.fileName);\n      } else if (!deletedTsPaths.has(sf.fileName)) {\n        this.nodes.set(sf, {\n          dependsOn: new Set(node.dependsOn),\n          usesResources: new Set(node.usesResources),\n          failedAnalysis: false,\n        });\n      }\n    }\n\n    return logicallyChanged;\n  }\n\n  private nodeFor(sf: T): FileNode {\n    if (!this.nodes.has(sf)) {\n      this.nodes.set(sf, {\n        dependsOn: new Set<string>(),\n        usesResources: new Set<AbsoluteFsPath>(),\n        failedAnalysis: false,\n      });\n    }\n    return this.nodes.get(sf)!;\n  }\n}\n\n/**\n * Determine whether `sf` has logically changed, given its dependencies and the set of physically\n * changed files and resources.\n */\nfunction isLogicallyChanged<T extends {fileName: string}>(\n    sf: T, node: FileNode, changedTsPaths: ReadonlySet<string>, deletedTsPaths: ReadonlySet<string>,\n    changedResources: ReadonlySet<AbsoluteFsPath>): boolean {\n  // A file is assumed to have logically changed if its dependencies could not be determined\n  // accurately.\n  if (node.failedAnalysis) {\n    return true;\n  }\n\n  // A file is logically changed if it has physically changed itself (including being deleted).\n  if (changedTsPaths.has(sf.fileName) || deletedTsPaths.has(sf.fileName)) {\n    return true;\n  }\n\n  // A file is logically changed if one of its dependencies has physically changed.\n  for (const dep of node.dependsOn) {\n    if (changedTsPaths.has(dep) || deletedTsPaths.has(dep)) {\n      return true;\n    }\n  }\n\n  // A file is logically changed if one of its resources has physically changed.\n  for (const dep of node.usesResources) {\n    if (changedResources.has(dep)) {\n      return true;\n    }\n  }\n  return false;\n}\n\ninterface FileNode {\n  dependsOn: Set<string>;\n  usesResources: Set<AbsoluteFsPath>;\n  failedAnalysis: boolean;\n}\n"]}
|
|
@@ -11,12 +11,12 @@ import { AbsoluteFsPath } from '../../file_system';
|
|
|
11
11
|
import { ClassRecord, TraitCompiler } from '../../transform';
|
|
12
12
|
import { FileTypeCheckingData } from '../../typecheck/src/checker';
|
|
13
13
|
import { IncrementalBuild } from '../api';
|
|
14
|
+
import { SemanticDepGraphUpdater } from '../semantic_graph';
|
|
14
15
|
import { FileDependencyGraph } from './dependency_tracking';
|
|
15
16
|
/**
|
|
16
17
|
* Drives an incremental build, by tracking changes and determining which files need to be emitted.
|
|
17
18
|
*/
|
|
18
19
|
export declare class IncrementalDriver implements IncrementalBuild<ClassRecord, FileTypeCheckingData> {
|
|
19
|
-
private allTsFiles;
|
|
20
20
|
readonly depGraph: FileDependencyGraph;
|
|
21
21
|
private logicalChanges;
|
|
22
22
|
/**
|
|
@@ -35,6 +35,7 @@ export declare class IncrementalDriver implements IncrementalBuild<ClassRecord,
|
|
|
35
35
|
*/
|
|
36
36
|
static reconcile(oldProgram: ts.Program, oldDriver: IncrementalDriver, newProgram: ts.Program, modifiedResourceFiles: Set<string> | null): IncrementalDriver;
|
|
37
37
|
static fresh(program: ts.Program): IncrementalDriver;
|
|
38
|
+
getSemanticDepGraphUpdater(): SemanticDepGraphUpdater;
|
|
38
39
|
recordSuccessfulAnalysis(traitCompiler: TraitCompiler): void;
|
|
39
40
|
recordSuccessfulTypeCheck(results: Map<AbsoluteFsPath, FileTypeCheckingData>): void;
|
|
40
41
|
recordSuccessfulEmit(sf: ts.SourceFile): void;
|
|
@@ -11,7 +11,7 @@
|
|
|
11
11
|
if (v !== undefined) module.exports = v;
|
|
12
12
|
}
|
|
13
13
|
else if (typeof define === "function" && define.amd) {
|
|
14
|
-
define("@angular/compiler-cli/src/ngtsc/incremental/src/state", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/incremental/src/dependency_tracking"], factory);
|
|
14
|
+
define("@angular/compiler-cli/src/ngtsc/incremental/src/state", ["require", "exports", "tslib", "@angular/compiler-cli/src/ngtsc/file_system", "@angular/compiler-cli/src/ngtsc/incremental/semantic_graph", "@angular/compiler-cli/src/ngtsc/incremental/src/dependency_tracking"], factory);
|
|
15
15
|
}
|
|
16
16
|
})(function (require, exports) {
|
|
17
17
|
"use strict";
|
|
@@ -19,13 +19,13 @@
|
|
|
19
19
|
exports.IncrementalDriver = void 0;
|
|
20
20
|
var tslib_1 = require("tslib");
|
|
21
21
|
var file_system_1 = require("@angular/compiler-cli/src/ngtsc/file_system");
|
|
22
|
+
var semantic_graph_1 = require("@angular/compiler-cli/src/ngtsc/incremental/semantic_graph");
|
|
22
23
|
var dependency_tracking_1 = require("@angular/compiler-cli/src/ngtsc/incremental/src/dependency_tracking");
|
|
23
24
|
/**
|
|
24
25
|
* Drives an incremental build, by tracking changes and determining which files need to be emitted.
|
|
25
26
|
*/
|
|
26
27
|
var IncrementalDriver = /** @class */ (function () {
|
|
27
|
-
function IncrementalDriver(state,
|
|
28
|
-
this.allTsFiles = allTsFiles;
|
|
28
|
+
function IncrementalDriver(state, depGraph, logicalChanges) {
|
|
29
29
|
this.depGraph = depGraph;
|
|
30
30
|
this.logicalChanges = logicalChanges;
|
|
31
31
|
this.state = state;
|
|
@@ -47,14 +47,20 @@
|
|
|
47
47
|
state = oldDriver.state;
|
|
48
48
|
}
|
|
49
49
|
else {
|
|
50
|
+
var priorGraph = null;
|
|
51
|
+
if (oldDriver.state.lastGood !== null) {
|
|
52
|
+
priorGraph = oldDriver.state.lastGood.semanticDepGraph;
|
|
53
|
+
}
|
|
50
54
|
// The previous build was successfully analyzed. `pendingEmit` is the only state carried
|
|
51
55
|
// forward into this build.
|
|
52
56
|
state = {
|
|
53
57
|
kind: BuildStateKind.Pending,
|
|
54
58
|
pendingEmit: oldDriver.state.pendingEmit,
|
|
59
|
+
pendingTypeCheckEmit: oldDriver.state.pendingTypeCheckEmit,
|
|
55
60
|
changedResourcePaths: new Set(),
|
|
56
61
|
changedTsPaths: new Set(),
|
|
57
62
|
lastGood: oldDriver.state.lastGood,
|
|
63
|
+
semanticDepGraphUpdater: new semantic_graph_1.SemanticDepGraphUpdater(priorGraph),
|
|
58
64
|
};
|
|
59
65
|
}
|
|
60
66
|
// Merge the freshly modified resource files with any prior ones.
|
|
@@ -119,6 +125,7 @@
|
|
|
119
125
|
for (var deletedTsPaths_1 = tslib_1.__values(deletedTsPaths), deletedTsPaths_1_1 = deletedTsPaths_1.next(); !deletedTsPaths_1_1.done; deletedTsPaths_1_1 = deletedTsPaths_1.next()) {
|
|
120
126
|
var filePath = deletedTsPaths_1_1.value;
|
|
121
127
|
state.pendingEmit.delete(filePath);
|
|
128
|
+
state.pendingTypeCheckEmit.delete(filePath);
|
|
122
129
|
// Even if the file doesn't exist in the current compilation, it still might have been changed
|
|
123
130
|
// in a previous one, so delete it from the set of changed TS files, just in case.
|
|
124
131
|
state.changedTsPaths.delete(filePath);
|
|
@@ -165,6 +172,7 @@
|
|
|
165
172
|
for (var logicalChanges_1 = tslib_1.__values(logicalChanges), logicalChanges_1_1 = logicalChanges_1.next(); !logicalChanges_1_1.done; logicalChanges_1_1 = logicalChanges_1.next()) {
|
|
166
173
|
var change = logicalChanges_1_1.value;
|
|
167
174
|
state.pendingEmit.add(change);
|
|
175
|
+
state.pendingTypeCheckEmit.add(change);
|
|
168
176
|
}
|
|
169
177
|
}
|
|
170
178
|
catch (e_5_1) { e_5 = { error: e_5_1 }; }
|
|
@@ -176,7 +184,7 @@
|
|
|
176
184
|
}
|
|
177
185
|
}
|
|
178
186
|
// `state` now reflects the initial pending state of the current compilation.
|
|
179
|
-
return new IncrementalDriver(state,
|
|
187
|
+
return new IncrementalDriver(state, depGraph, logicalChanges);
|
|
180
188
|
};
|
|
181
189
|
IncrementalDriver.fresh = function (program) {
|
|
182
190
|
// Initialize the set of files which need to be emitted to the set of all TS files in the
|
|
@@ -185,44 +193,65 @@
|
|
|
185
193
|
var state = {
|
|
186
194
|
kind: BuildStateKind.Pending,
|
|
187
195
|
pendingEmit: new Set(tsFiles.map(function (sf) { return sf.fileName; })),
|
|
196
|
+
pendingTypeCheckEmit: new Set(tsFiles.map(function (sf) { return sf.fileName; })),
|
|
188
197
|
changedResourcePaths: new Set(),
|
|
189
198
|
changedTsPaths: new Set(),
|
|
190
199
|
lastGood: null,
|
|
200
|
+
semanticDepGraphUpdater: new semantic_graph_1.SemanticDepGraphUpdater(/* priorGraph */ null),
|
|
191
201
|
};
|
|
192
|
-
return new IncrementalDriver(state, new
|
|
202
|
+
return new IncrementalDriver(state, new dependency_tracking_1.FileDependencyGraph(), /* logicalChanges */ null);
|
|
203
|
+
};
|
|
204
|
+
IncrementalDriver.prototype.getSemanticDepGraphUpdater = function () {
|
|
205
|
+
if (this.state.kind !== BuildStateKind.Pending) {
|
|
206
|
+
throw new Error('Semantic dependency updater is only available when pending analysis');
|
|
207
|
+
}
|
|
208
|
+
return this.state.semanticDepGraphUpdater;
|
|
193
209
|
};
|
|
194
210
|
IncrementalDriver.prototype.recordSuccessfulAnalysis = function (traitCompiler) {
|
|
195
|
-
var e_6, _a;
|
|
211
|
+
var e_6, _a, e_7, _b;
|
|
196
212
|
if (this.state.kind !== BuildStateKind.Pending) {
|
|
197
213
|
// Changes have already been incorporated.
|
|
198
214
|
return;
|
|
199
215
|
}
|
|
216
|
+
var _c = this.state.semanticDepGraphUpdater.finalize(), needsEmit = _c.needsEmit, needsTypeCheckEmit = _c.needsTypeCheckEmit, newGraph = _c.newGraph;
|
|
200
217
|
var pendingEmit = this.state.pendingEmit;
|
|
201
|
-
var state = this.state;
|
|
202
218
|
try {
|
|
203
|
-
for (var
|
|
204
|
-
var
|
|
205
|
-
|
|
206
|
-
// Something has changed which requires this file be re-emitted.
|
|
207
|
-
pendingEmit.add(sf.fileName);
|
|
208
|
-
}
|
|
219
|
+
for (var needsEmit_1 = tslib_1.__values(needsEmit), needsEmit_1_1 = needsEmit_1.next(); !needsEmit_1_1.done; needsEmit_1_1 = needsEmit_1.next()) {
|
|
220
|
+
var path = needsEmit_1_1.value;
|
|
221
|
+
pendingEmit.add(path);
|
|
209
222
|
}
|
|
210
223
|
}
|
|
211
224
|
catch (e_6_1) { e_6 = { error: e_6_1 }; }
|
|
212
225
|
finally {
|
|
213
226
|
try {
|
|
214
|
-
if (
|
|
227
|
+
if (needsEmit_1_1 && !needsEmit_1_1.done && (_a = needsEmit_1.return)) _a.call(needsEmit_1);
|
|
215
228
|
}
|
|
216
229
|
finally { if (e_6) throw e_6.error; }
|
|
217
230
|
}
|
|
231
|
+
var pendingTypeCheckEmit = this.state.pendingTypeCheckEmit;
|
|
232
|
+
try {
|
|
233
|
+
for (var needsTypeCheckEmit_1 = tslib_1.__values(needsTypeCheckEmit), needsTypeCheckEmit_1_1 = needsTypeCheckEmit_1.next(); !needsTypeCheckEmit_1_1.done; needsTypeCheckEmit_1_1 = needsTypeCheckEmit_1.next()) {
|
|
234
|
+
var path = needsTypeCheckEmit_1_1.value;
|
|
235
|
+
pendingTypeCheckEmit.add(path);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
catch (e_7_1) { e_7 = { error: e_7_1 }; }
|
|
239
|
+
finally {
|
|
240
|
+
try {
|
|
241
|
+
if (needsTypeCheckEmit_1_1 && !needsTypeCheckEmit_1_1.done && (_b = needsTypeCheckEmit_1.return)) _b.call(needsTypeCheckEmit_1);
|
|
242
|
+
}
|
|
243
|
+
finally { if (e_7) throw e_7.error; }
|
|
244
|
+
}
|
|
218
245
|
// Update the state to an `AnalyzedBuildState`.
|
|
219
246
|
this.state = {
|
|
220
247
|
kind: BuildStateKind.Analyzed,
|
|
221
248
|
pendingEmit: pendingEmit,
|
|
249
|
+
pendingTypeCheckEmit: pendingTypeCheckEmit,
|
|
222
250
|
// Since this compilation was successfully analyzed, update the "last good" artifacts to the
|
|
223
251
|
// ones from the current compilation.
|
|
224
252
|
lastGood: {
|
|
225
253
|
depGraph: this.depGraph,
|
|
254
|
+
semanticDepGraph: newGraph,
|
|
226
255
|
traitCompiler: traitCompiler,
|
|
227
256
|
typeCheckingResults: null,
|
|
228
257
|
},
|
|
@@ -230,10 +259,26 @@
|
|
|
230
259
|
};
|
|
231
260
|
};
|
|
232
261
|
IncrementalDriver.prototype.recordSuccessfulTypeCheck = function (results) {
|
|
262
|
+
var e_8, _a;
|
|
233
263
|
if (this.state.lastGood === null || this.state.kind !== BuildStateKind.Analyzed) {
|
|
234
264
|
return;
|
|
235
265
|
}
|
|
236
266
|
this.state.lastGood.typeCheckingResults = results;
|
|
267
|
+
try {
|
|
268
|
+
// Delete the files for which type-check code was generated from the set of pending type-check
|
|
269
|
+
// files.
|
|
270
|
+
for (var _b = tslib_1.__values(results.keys()), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
271
|
+
var fileName = _c.value;
|
|
272
|
+
this.state.pendingTypeCheckEmit.delete(fileName);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
catch (e_8_1) { e_8 = { error: e_8_1 }; }
|
|
276
|
+
finally {
|
|
277
|
+
try {
|
|
278
|
+
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
279
|
+
}
|
|
280
|
+
finally { if (e_8) throw e_8.error; }
|
|
281
|
+
}
|
|
237
282
|
};
|
|
238
283
|
IncrementalDriver.prototype.recordSuccessfulEmit = function (sf) {
|
|
239
284
|
this.state.pendingEmit.delete(sf.fileName);
|
|
@@ -260,7 +305,7 @@
|
|
|
260
305
|
this.state.priorTypeCheckingResults === null || this.logicalChanges === null) {
|
|
261
306
|
return null;
|
|
262
307
|
}
|
|
263
|
-
if (this.logicalChanges.has(sf.fileName)) {
|
|
308
|
+
if (this.logicalChanges.has(sf.fileName) || this.state.pendingTypeCheckEmit.has(sf.fileName)) {
|
|
264
309
|
return null;
|
|
265
310
|
}
|
|
266
311
|
var fileName = file_system_1.absoluteFromSourceFile(sf);
|
|
@@ -285,4 +330,4 @@
|
|
|
285
330
|
return program.getSourceFiles().filter(function (sf) { return !sf.isDeclarationFile; });
|
|
286
331
|
}
|
|
287
332
|
});
|
|
288
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, absoluteFromSourceFile, AbsoluteFsPath} from '../../file_system';\nimport {ClassRecord, TraitCompiler} from '../../transform';\nimport {FileTypeCheckingData} from '../../typecheck/src/checker';\nimport {IncrementalBuild} from '../api';\n\nimport {FileDependencyGraph} from './dependency_tracking';\n\n/**\n * Drives an incremental build, by tracking changes and determining which files need to be emitted.\n */\nexport class IncrementalDriver implements IncrementalBuild<ClassRecord, FileTypeCheckingData> {\n  /**\n   * State of the current build.\n   *\n   * This transitions as the compilation progresses.\n   */\n  private state: BuildState;\n\n  private constructor(\n      state: PendingBuildState, private allTsFiles: Set<ts.SourceFile>,\n      readonly depGraph: FileDependencyGraph, private logicalChanges: Set<string>|null) {\n    this.state = state;\n  }\n\n  /**\n   * Construct an `IncrementalDriver` with a starting state that incorporates the results of a\n   * previous build.\n   *\n   * The previous build's `BuildState` is reconciled with the new program's changes, and the results\n   * are merged into the new build's `PendingBuildState`.\n   */\n  static reconcile(\n      oldProgram: ts.Program, oldDriver: IncrementalDriver, newProgram: ts.Program,\n      modifiedResourceFiles: Set<string>|null): IncrementalDriver {\n    // Initialize the state of the current build based on the previous one.\n    let state: PendingBuildState;\n    if (oldDriver.state.kind === BuildStateKind.Pending) {\n      // The previous build never made it past the pending state. Reuse it as the starting state for\n      // this build.\n      state = oldDriver.state;\n    } else {\n      // The previous build was successfully analyzed. `pendingEmit` is the only state carried\n      // forward into this build.\n      state = {\n        kind: BuildStateKind.Pending,\n        pendingEmit: oldDriver.state.pendingEmit,\n        changedResourcePaths: new Set<AbsoluteFsPath>(),\n        changedTsPaths: new Set<string>(),\n        lastGood: oldDriver.state.lastGood,\n      };\n    }\n\n    // Merge the freshly modified resource files with any prior ones.\n    if (modifiedResourceFiles !== null) {\n      for (const resFile of modifiedResourceFiles) {\n        state.changedResourcePaths.add(absoluteFrom(resFile));\n      }\n    }\n\n    // Next, process the files in the new program, with a couple of goals:\n    // 1) Determine which TS files have changed, if any, and merge them into `changedTsFiles`.\n    // 2) Produce a list of TS files which no longer exist in the program (they've been deleted\n    //    since the previous compilation). These need to be removed from the state tracking to avoid\n    //    leaking memory.\n\n    // All files in the old program, for easy detection of changes.\n    const oldFiles = new Set<ts.SourceFile>(oldProgram.getSourceFiles());\n\n    // Assume all the old files were deleted to begin with. Only TS files are tracked.\n    const deletedTsPaths = new Set<string>(tsOnlyFiles(oldProgram).map(sf => sf.fileName));\n\n    for (const newFile of newProgram.getSourceFiles()) {\n      if (!newFile.isDeclarationFile) {\n        // This file exists in the new program, so remove it from `deletedTsPaths`.\n        deletedTsPaths.delete(newFile.fileName);\n      }\n\n      if (oldFiles.has(newFile)) {\n        // This file hasn't changed; no need to look at it further.\n        continue;\n      }\n\n      // The file has changed since the last successful build. The appropriate reaction depends on\n      // what kind of file it is.\n      if (!newFile.isDeclarationFile) {\n        // It's a .ts file, so track it as a change.\n        state.changedTsPaths.add(newFile.fileName);\n      } else {\n        // It's a .d.ts file. Currently the compiler does not do a great job of tracking\n        // dependencies on .d.ts files, so bail out of incremental builds here and do a full build.\n        // This usually only happens if something in node_modules changes.\n        return IncrementalDriver.fresh(newProgram);\n      }\n    }\n\n    // The next step is to remove any deleted files from the state.\n    for (const filePath of deletedTsPaths) {\n      state.pendingEmit.delete(filePath);\n\n      // Even if the file doesn't exist in the current compilation, it still might have been changed\n      // in a previous one, so delete it from the set of changed TS files, just in case.\n      state.changedTsPaths.delete(filePath);\n    }\n\n    // Now, changedTsPaths contains physically changed TS paths. Use the previous program's logical\n    // dependency graph to determine logically changed files.\n    const depGraph = new FileDependencyGraph();\n\n    // If a previous compilation exists, use its dependency graph to determine the set of logically\n    // changed files.\n    let logicalChanges: Set<string>|null = null;\n    if (state.lastGood !== null) {\n      // Extract the set of logically changed files. At the same time, this operation populates the\n      // current (fresh) dependency graph with information about those files which have not\n      // logically changed.\n      logicalChanges = depGraph.updateWithPhysicalChanges(\n          state.lastGood.depGraph, state.changedTsPaths, deletedTsPaths,\n          state.changedResourcePaths);\n      for (const fileName of state.changedTsPaths) {\n        logicalChanges.add(fileName);\n      }\n\n      // Any logically changed files need to be re-emitted. Most of the time this would happen\n      // regardless because the new dependency graph would _also_ identify the file as stale.\n      // However there are edge cases such as removing a component from an NgModule without adding\n      // it to another one, where the previous graph identifies the file as logically changed, but\n      // the new graph (which does not have that edge) fails to identify that the file should be\n      // re-emitted.\n      for (const change of logicalChanges) {\n        state.pendingEmit.add(change);\n      }\n    }\n\n    // `state` now reflects the initial pending state of the current compilation.\n\n    return new IncrementalDriver(\n        state, new Set<ts.SourceFile>(tsOnlyFiles(newProgram)), depGraph, logicalChanges);\n  }\n\n  static fresh(program: ts.Program): IncrementalDriver {\n    // Initialize the set of files which need to be emitted to the set of all TS files in the\n    // program.\n    const tsFiles = tsOnlyFiles(program);\n\n    const state: PendingBuildState = {\n      kind: BuildStateKind.Pending,\n      pendingEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      changedResourcePaths: new Set<AbsoluteFsPath>(),\n      changedTsPaths: new Set<string>(),\n      lastGood: null,\n    };\n\n    return new IncrementalDriver(\n        state, new Set(tsFiles), new FileDependencyGraph(), /* logicalChanges */ null);\n  }\n\n  recordSuccessfulAnalysis(traitCompiler: TraitCompiler): void {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      // Changes have already been incorporated.\n      return;\n    }\n\n    const pendingEmit = this.state.pendingEmit;\n\n    const state: PendingBuildState = this.state;\n\n    for (const sf of this.allTsFiles) {\n      if (this.depGraph.isStale(sf, state.changedTsPaths, state.changedResourcePaths)) {\n        // Something has changed which requires this file be re-emitted.\n        pendingEmit.add(sf.fileName);\n      }\n    }\n\n    // Update the state to an `AnalyzedBuildState`.\n    this.state = {\n      kind: BuildStateKind.Analyzed,\n      pendingEmit,\n\n      // Since this compilation was successfully analyzed, update the \"last good\" artifacts to the\n      // ones from the current compilation.\n      lastGood: {\n        depGraph: this.depGraph,\n        traitCompiler: traitCompiler,\n        typeCheckingResults: null,\n      },\n\n      priorTypeCheckingResults:\n          this.state.lastGood !== null ? this.state.lastGood.typeCheckingResults : null,\n    };\n  }\n\n  recordSuccessfulTypeCheck(results: Map<AbsoluteFsPath, FileTypeCheckingData>): void {\n    if (this.state.lastGood === null || this.state.kind !== BuildStateKind.Analyzed) {\n      return;\n    }\n    this.state.lastGood.typeCheckingResults = results;\n  }\n\n  recordSuccessfulEmit(sf: ts.SourceFile): void {\n    this.state.pendingEmit.delete(sf.fileName);\n  }\n\n  safeToSkipEmit(sf: ts.SourceFile): boolean {\n    return !this.state.pendingEmit.has(sf.fileName);\n  }\n\n  priorWorkFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (this.state.lastGood === null || this.logicalChanges === null) {\n      // There is no previous good build, so no prior work exists.\n      return null;\n    } else if (this.logicalChanges.has(sf.fileName)) {\n      // Prior work might exist, but would be stale as the file in question has logically changed.\n      return null;\n    } else {\n      // Prior work might exist, and if it does then it's usable!\n      return this.state.lastGood.traitCompiler.recordsFor(sf);\n    }\n  }\n\n  priorTypeCheckingResultsFor(sf: ts.SourceFile): FileTypeCheckingData|null {\n    if (this.state.kind !== BuildStateKind.Analyzed ||\n        this.state.priorTypeCheckingResults === null || this.logicalChanges === null) {\n      return null;\n    }\n\n    if (this.logicalChanges.has(sf.fileName)) {\n      return null;\n    }\n\n    const fileName = absoluteFromSourceFile(sf);\n    if (!this.state.priorTypeCheckingResults.has(fileName)) {\n      return null;\n    }\n    const data = this.state.priorTypeCheckingResults.get(fileName)!;\n    if (data.hasInlines) {\n      return null;\n    }\n\n    return data;\n  }\n}\n\ntype BuildState = PendingBuildState|AnalyzedBuildState;\n\nenum BuildStateKind {\n  Pending,\n  Analyzed,\n}\n\ninterface BaseBuildState {\n  kind: BuildStateKind;\n\n  /**\n   * The heart of incremental builds. This `Set` tracks the set of files which need to be emitted\n   * during the current compilation.\n   *\n   * This starts out as the set of files which are still pending from the previous program (or the\n   * full set of .ts files on a fresh build).\n   *\n   * After analysis, it's updated to include any files which might have changed and need a re-emit\n   * as a result of incremental changes.\n   *\n   * If an emit happens, any written files are removed from the `Set`, as they're no longer\n   * pending.\n   *\n   * Thus, after compilation `pendingEmit` should be empty (on a successful build) or contain the\n   * files which still need to be emitted but have not yet been (due to errors).\n   *\n   * `pendingEmit` is tracked as as `Set<string>` instead of a `Set<ts.SourceFile>`, because the\n   * contents of the file are not important here, only whether or not the current version of it\n   * needs to be emitted. The `string`s here are TS file paths.\n   *\n   * See the README.md for more information on this algorithm.\n   */\n  pendingEmit: Set<string>;\n\n\n  /**\n   * Specific aspects of the last compilation which successfully completed analysis, if any.\n   */\n  lastGood: {\n    /**\n     * The dependency graph from the last successfully analyzed build.\n     *\n     * This is used to determine the logical impact of physical file changes.\n     */\n    depGraph: FileDependencyGraph;\n\n    /**\n     * The `TraitCompiler` from the last successfully analyzed build.\n     *\n     * This is used to extract \"prior work\" which might be reusable in this compilation.\n     */\n    traitCompiler: TraitCompiler;\n\n    /**\n     * Type checking results which will be passed onto the next build.\n     */\n    typeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>| null;\n  }|null;\n}\n\n/**\n * State of a build before the Angular analysis phase completes.\n */\ninterface PendingBuildState extends BaseBuildState {\n  kind: BuildStateKind.Pending;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * Before the compiler's analysis phase completes, `pendingEmit` only contains files that were\n   * still pending after the previous build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Set of TypeScript file paths which have changed since the last successfully analyzed build.\n   */\n  changedTsPaths: Set<string>;\n\n  /**\n   * Set of resource file paths which have changed since the last successfully analyzed build.\n   */\n  changedResourcePaths: Set<AbsoluteFsPath>;\n}\n\ninterface AnalyzedBuildState extends BaseBuildState {\n  kind: BuildStateKind.Analyzed;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * After analysis completes (that is, the state transitions to `AnalyzedBuildState`), the\n   * `pendingEmit` set takes into account any on-disk changes made since the last successfully\n   * analyzed build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Type checking results from the previous compilation, which can be reused in this one.\n   */\n  priorTypeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>|null;\n}\n\nfunction tsOnlyFiles(program: ts.Program): ReadonlyArray<ts.SourceFile> {\n  return program.getSourceFiles().filter(sf => !sf.isDeclarationFile);\n}\n"]}
|
|
333
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"state.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/incremental/src/state.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\n\nimport {absoluteFrom, absoluteFromSourceFile, AbsoluteFsPath} from '../../file_system';\nimport {ClassDeclaration} from '../../reflection';\nimport {ClassRecord, TraitCompiler} from '../../transform';\nimport {FileTypeCheckingData} from '../../typecheck/src/checker';\nimport {IncrementalBuild} from '../api';\nimport {SemanticDepGraph, SemanticDepGraphUpdater} from '../semantic_graph';\n\nimport {FileDependencyGraph} from './dependency_tracking';\n\n/**\n * Drives an incremental build, by tracking changes and determining which files need to be emitted.\n */\nexport class IncrementalDriver implements IncrementalBuild<ClassRecord, FileTypeCheckingData> {\n  /**\n   * State of the current build.\n   *\n   * This transitions as the compilation progresses.\n   */\n  private state: BuildState;\n\n  private constructor(\n      state: PendingBuildState, readonly depGraph: FileDependencyGraph,\n      private logicalChanges: Set<string>|null) {\n    this.state = state;\n  }\n\n  /**\n   * Construct an `IncrementalDriver` with a starting state that incorporates the results of a\n   * previous build.\n   *\n   * The previous build's `BuildState` is reconciled with the new program's changes, and the results\n   * are merged into the new build's `PendingBuildState`.\n   */\n  static reconcile(\n      oldProgram: ts.Program, oldDriver: IncrementalDriver, newProgram: ts.Program,\n      modifiedResourceFiles: Set<string>|null): IncrementalDriver {\n    // Initialize the state of the current build based on the previous one.\n    let state: PendingBuildState;\n    if (oldDriver.state.kind === BuildStateKind.Pending) {\n      // The previous build never made it past the pending state. Reuse it as the starting state for\n      // this build.\n      state = oldDriver.state;\n    } else {\n      let priorGraph: SemanticDepGraph|null = null;\n      if (oldDriver.state.lastGood !== null) {\n        priorGraph = oldDriver.state.lastGood.semanticDepGraph;\n      }\n\n      // The previous build was successfully analyzed. `pendingEmit` is the only state carried\n      // forward into this build.\n      state = {\n        kind: BuildStateKind.Pending,\n        pendingEmit: oldDriver.state.pendingEmit,\n        pendingTypeCheckEmit: oldDriver.state.pendingTypeCheckEmit,\n        changedResourcePaths: new Set<AbsoluteFsPath>(),\n        changedTsPaths: new Set<string>(),\n        lastGood: oldDriver.state.lastGood,\n        semanticDepGraphUpdater: new SemanticDepGraphUpdater(priorGraph),\n      };\n    }\n\n    // Merge the freshly modified resource files with any prior ones.\n    if (modifiedResourceFiles !== null) {\n      for (const resFile of modifiedResourceFiles) {\n        state.changedResourcePaths.add(absoluteFrom(resFile));\n      }\n    }\n\n    // Next, process the files in the new program, with a couple of goals:\n    // 1) Determine which TS files have changed, if any, and merge them into `changedTsFiles`.\n    // 2) Produce a list of TS files which no longer exist in the program (they've been deleted\n    //    since the previous compilation). These need to be removed from the state tracking to avoid\n    //    leaking memory.\n\n    // All files in the old program, for easy detection of changes.\n    const oldFiles = new Set<ts.SourceFile>(oldProgram.getSourceFiles());\n\n    // Assume all the old files were deleted to begin with. Only TS files are tracked.\n    const deletedTsPaths = new Set<string>(tsOnlyFiles(oldProgram).map(sf => sf.fileName));\n\n    for (const newFile of newProgram.getSourceFiles()) {\n      if (!newFile.isDeclarationFile) {\n        // This file exists in the new program, so remove it from `deletedTsPaths`.\n        deletedTsPaths.delete(newFile.fileName);\n      }\n\n      if (oldFiles.has(newFile)) {\n        // This file hasn't changed; no need to look at it further.\n        continue;\n      }\n\n      // The file has changed since the last successful build. The appropriate reaction depends on\n      // what kind of file it is.\n      if (!newFile.isDeclarationFile) {\n        // It's a .ts file, so track it as a change.\n        state.changedTsPaths.add(newFile.fileName);\n      } else {\n        // It's a .d.ts file. Currently the compiler does not do a great job of tracking\n        // dependencies on .d.ts files, so bail out of incremental builds here and do a full build.\n        // This usually only happens if something in node_modules changes.\n        return IncrementalDriver.fresh(newProgram);\n      }\n    }\n\n    // The next step is to remove any deleted files from the state.\n    for (const filePath of deletedTsPaths) {\n      state.pendingEmit.delete(filePath);\n      state.pendingTypeCheckEmit.delete(filePath);\n\n      // Even if the file doesn't exist in the current compilation, it still might have been changed\n      // in a previous one, so delete it from the set of changed TS files, just in case.\n      state.changedTsPaths.delete(filePath);\n    }\n\n    // Now, changedTsPaths contains physically changed TS paths. Use the previous program's logical\n    // dependency graph to determine logically changed files.\n    const depGraph = new FileDependencyGraph();\n\n    // If a previous compilation exists, use its dependency graph to determine the set of logically\n    // changed files.\n    let logicalChanges: Set<string>|null = null;\n    if (state.lastGood !== null) {\n      // Extract the set of logically changed files. At the same time, this operation populates the\n      // current (fresh) dependency graph with information about those files which have not\n      // logically changed.\n      logicalChanges = depGraph.updateWithPhysicalChanges(\n          state.lastGood.depGraph, state.changedTsPaths, deletedTsPaths,\n          state.changedResourcePaths);\n      for (const fileName of state.changedTsPaths) {\n        logicalChanges.add(fileName);\n      }\n\n      // Any logically changed files need to be re-emitted. Most of the time this would happen\n      // regardless because the new dependency graph would _also_ identify the file as stale.\n      // However there are edge cases such as removing a component from an NgModule without adding\n      // it to another one, where the previous graph identifies the file as logically changed, but\n      // the new graph (which does not have that edge) fails to identify that the file should be\n      // re-emitted.\n      for (const change of logicalChanges) {\n        state.pendingEmit.add(change);\n        state.pendingTypeCheckEmit.add(change);\n      }\n    }\n\n    // `state` now reflects the initial pending state of the current compilation.\n\n    return new IncrementalDriver(state, depGraph, logicalChanges);\n  }\n\n  static fresh(program: ts.Program): IncrementalDriver {\n    // Initialize the set of files which need to be emitted to the set of all TS files in the\n    // program.\n    const tsFiles = tsOnlyFiles(program);\n\n    const state: PendingBuildState = {\n      kind: BuildStateKind.Pending,\n      pendingEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      pendingTypeCheckEmit: new Set<string>(tsFiles.map(sf => sf.fileName)),\n      changedResourcePaths: new Set<AbsoluteFsPath>(),\n      changedTsPaths: new Set<string>(),\n      lastGood: null,\n      semanticDepGraphUpdater: new SemanticDepGraphUpdater(/* priorGraph */ null),\n    };\n\n    return new IncrementalDriver(state, new FileDependencyGraph(), /* logicalChanges */ null);\n  }\n\n  getSemanticDepGraphUpdater(): SemanticDepGraphUpdater {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      throw new Error('Semantic dependency updater is only available when pending analysis');\n    }\n    return this.state.semanticDepGraphUpdater;\n  }\n\n  recordSuccessfulAnalysis(traitCompiler: TraitCompiler): void {\n    if (this.state.kind !== BuildStateKind.Pending) {\n      // Changes have already been incorporated.\n      return;\n    }\n\n    const {needsEmit, needsTypeCheckEmit, newGraph} = this.state.semanticDepGraphUpdater.finalize();\n\n    const pendingEmit = this.state.pendingEmit;\n    for (const path of needsEmit) {\n      pendingEmit.add(path);\n    }\n\n    const pendingTypeCheckEmit = this.state.pendingTypeCheckEmit;\n    for (const path of needsTypeCheckEmit) {\n      pendingTypeCheckEmit.add(path);\n    }\n\n    // Update the state to an `AnalyzedBuildState`.\n    this.state = {\n      kind: BuildStateKind.Analyzed,\n      pendingEmit,\n      pendingTypeCheckEmit,\n\n      // Since this compilation was successfully analyzed, update the \"last good\" artifacts to the\n      // ones from the current compilation.\n      lastGood: {\n        depGraph: this.depGraph,\n        semanticDepGraph: newGraph,\n        traitCompiler: traitCompiler,\n        typeCheckingResults: null,\n      },\n\n      priorTypeCheckingResults:\n          this.state.lastGood !== null ? this.state.lastGood.typeCheckingResults : null,\n    };\n  }\n\n  recordSuccessfulTypeCheck(results: Map<AbsoluteFsPath, FileTypeCheckingData>): void {\n    if (this.state.lastGood === null || this.state.kind !== BuildStateKind.Analyzed) {\n      return;\n    }\n    this.state.lastGood.typeCheckingResults = results;\n\n    // Delete the files for which type-check code was generated from the set of pending type-check\n    // files.\n    for (const fileName of results.keys()) {\n      this.state.pendingTypeCheckEmit.delete(fileName);\n    }\n  }\n\n  recordSuccessfulEmit(sf: ts.SourceFile): void {\n    this.state.pendingEmit.delete(sf.fileName);\n  }\n\n  safeToSkipEmit(sf: ts.SourceFile): boolean {\n    return !this.state.pendingEmit.has(sf.fileName);\n  }\n\n  priorWorkFor(sf: ts.SourceFile): ClassRecord[]|null {\n    if (this.state.lastGood === null || this.logicalChanges === null) {\n      // There is no previous good build, so no prior work exists.\n      return null;\n    } else if (this.logicalChanges.has(sf.fileName)) {\n      // Prior work might exist, but would be stale as the file in question has logically changed.\n      return null;\n    } else {\n      // Prior work might exist, and if it does then it's usable!\n      return this.state.lastGood.traitCompiler.recordsFor(sf);\n    }\n  }\n\n  priorTypeCheckingResultsFor(sf: ts.SourceFile): FileTypeCheckingData|null {\n    if (this.state.kind !== BuildStateKind.Analyzed ||\n        this.state.priorTypeCheckingResults === null || this.logicalChanges === null) {\n      return null;\n    }\n\n    if (this.logicalChanges.has(sf.fileName) || this.state.pendingTypeCheckEmit.has(sf.fileName)) {\n      return null;\n    }\n\n    const fileName = absoluteFromSourceFile(sf);\n    if (!this.state.priorTypeCheckingResults.has(fileName)) {\n      return null;\n    }\n    const data = this.state.priorTypeCheckingResults.get(fileName)!;\n    if (data.hasInlines) {\n      return null;\n    }\n\n    return data;\n  }\n}\n\ntype BuildState = PendingBuildState|AnalyzedBuildState;\n\nenum BuildStateKind {\n  Pending,\n  Analyzed,\n}\n\ninterface BaseBuildState {\n  kind: BuildStateKind;\n\n  /**\n   * The heart of incremental builds. This `Set` tracks the set of files which need to be emitted\n   * during the current compilation.\n   *\n   * This starts out as the set of files which are still pending from the previous program (or the\n   * full set of .ts files on a fresh build).\n   *\n   * After analysis, it's updated to include any files which might have changed and need a re-emit\n   * as a result of incremental changes.\n   *\n   * If an emit happens, any written files are removed from the `Set`, as they're no longer\n   * pending.\n   *\n   * Thus, after compilation `pendingEmit` should be empty (on a successful build) or contain the\n   * files which still need to be emitted but have not yet been (due to errors).\n   *\n   * `pendingEmit` is tracked as as `Set<string>` instead of a `Set<ts.SourceFile>`, because the\n   * contents of the file are not important here, only whether or not the current version of it\n   * needs to be emitted. The `string`s here are TS file paths.\n   *\n   * See the README.md for more information on this algorithm.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Similar to `pendingEmit`, but then for representing the set of files for which the type-check\n   * file should be regenerated. It behaves identically with respect to errored compilations as\n   * `pendingEmit`.\n   */\n  pendingTypeCheckEmit: Set<string>;\n\n\n  /**\n   * Specific aspects of the last compilation which successfully completed analysis, if any.\n   */\n  lastGood: {\n    /**\n     * The dependency graph from the last successfully analyzed build.\n     *\n     * This is used to determine the logical impact of physical file changes.\n     */\n    depGraph: FileDependencyGraph;\n\n    /**\n     * The semantic dependency graph from the last successfully analyzed build.\n     *\n     * This is used to perform in-depth comparison of Angular decorated classes, to determine\n     * which files have to be re-emitted and/or re-type-checked.\n     */\n    semanticDepGraph: SemanticDepGraph;\n\n    /**\n     * The `TraitCompiler` from the last successfully analyzed build.\n     *\n     * This is used to extract \"prior work\" which might be reusable in this compilation.\n     */\n    traitCompiler: TraitCompiler;\n\n    /**\n     * Type checking results which will be passed onto the next build.\n     */\n    typeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>| null;\n  }|null;\n}\n\n/**\n * State of a build before the Angular analysis phase completes.\n */\ninterface PendingBuildState extends BaseBuildState {\n  kind: BuildStateKind.Pending;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * Before the compiler's analysis phase completes, `pendingEmit` only contains files that were\n   * still pending after the previous build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Set of TypeScript file paths which have changed since the last successfully analyzed build.\n   */\n  changedTsPaths: Set<string>;\n\n  /**\n   * Set of resource file paths which have changed since the last successfully analyzed build.\n   */\n  changedResourcePaths: Set<AbsoluteFsPath>;\n\n  /**\n   * In a pending state, the semantic dependency graph is available to the compilation to register\n   * the incremental symbols into.\n   */\n  semanticDepGraphUpdater: SemanticDepGraphUpdater;\n}\n\ninterface AnalyzedBuildState extends BaseBuildState {\n  kind: BuildStateKind.Analyzed;\n\n  /**\n   * Set of files which are known to need an emit.\n   *\n   * After analysis completes (that is, the state transitions to `AnalyzedBuildState`), the\n   * `pendingEmit` set takes into account any on-disk changes made since the last successfully\n   * analyzed build.\n   */\n  pendingEmit: Set<string>;\n\n  /**\n   * Type checking results from the previous compilation, which can be reused in this one.\n   */\n  priorTypeCheckingResults: Map<AbsoluteFsPath, FileTypeCheckingData>|null;\n}\n\nfunction tsOnlyFiles(program: ts.Program): ReadonlyArray<ts.SourceFile> {\n  return program.getSourceFiles().filter(sf => !sf.isDeclarationFile);\n}\n"]}
|