@angular/compiler-cli 11.2.5 → 11.2.9
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/index.d.ts +1 -0
- package/index.js +5 -3
- 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.js +10 -8
- package/ngcc/src/execution/analyze_entry_points.js +10 -4
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/package.json +3 -3
- package/src/ngtsc/annotations/src/component.d.ts +4 -7
- package/src/ngtsc/annotations/src/component.js +107 -77
- package/src/ngtsc/annotations/src/directive.d.ts +3 -1
- package/src/ngtsc/annotations/src/directive.js +6 -3
- package/src/ngtsc/annotations/src/injectable.d.ts +3 -1
- package/src/ngtsc/annotations/src/injectable.js +6 -3
- package/src/ngtsc/annotations/src/ng_module.d.ts +3 -1
- package/src/ngtsc/annotations/src/ng_module.js +6 -3
- package/src/ngtsc/annotations/src/pipe.d.ts +3 -1
- package/src/ngtsc/annotations/src/pipe.js +6 -3
- package/src/ngtsc/core/api/src/options.d.ts +2 -3
- package/src/ngtsc/core/api/src/options.js +1 -1
- package/src/ngtsc/core/src/compiler.d.ts +19 -8
- package/src/ngtsc/core/src/compiler.js +222 -165
- package/src/ngtsc/cycles/src/imports.d.ts +3 -1
- package/src/ngtsc/cycles/src/imports.js +35 -30
- package/src/ngtsc/diagnostics/src/error_code.d.ts +7 -1
- package/src/ngtsc/diagnostics/src/error_code.js +10 -4
- package/src/ngtsc/incremental/src/state.d.ts +2 -1
- package/src/ngtsc/incremental/src/state.js +134 -129
- package/src/ngtsc/perf/index.d.ts +2 -2
- package/src/ngtsc/perf/index.js +8 -5
- package/src/ngtsc/perf/src/api.d.ts +300 -5
- package/src/ngtsc/perf/src/api.js +268 -1
- package/src/ngtsc/perf/src/noop.d.ts +7 -0
- package/src/ngtsc/perf/src/noop.js +25 -10
- package/src/ngtsc/perf/src/recorder.d.ts +58 -0
- package/src/ngtsc/perf/src/recorder.js +143 -0
- package/src/ngtsc/program.d.ts +0 -2
- package/src/ngtsc/program.js +138 -122
- package/src/ngtsc/transform/src/compilation.js +6 -4
- package/src/ngtsc/transform/src/transform.d.ts +2 -1
- package/src/ngtsc/transform/src/transform.js +5 -4
- package/src/ngtsc/tsc_plugin.js +14 -4
- package/src/ngtsc/typecheck/api/api.d.ts +27 -0
- package/src/ngtsc/typecheck/api/api.js +1 -1
- package/src/ngtsc/typecheck/src/checker.d.ts +3 -1
- package/src/ngtsc/typecheck/src/checker.js +132 -110
- package/src/ngtsc/typecheck/src/context.d.ts +3 -1
- package/src/ngtsc/typecheck/src/context.js +31 -30
- package/src/ngtsc/typecheck/src/environment.d.ts +1 -1
- package/src/ngtsc/typecheck/src/environment.js +1 -1
- 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.js +16 -10
- package/src/version.js +1 -1
- package/src/ngtsc/perf/src/tracking.d.ts +0 -33
- package/src/ngtsc/perf/src/tracking.js +0 -103
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
/// <amd-module name="@angular/compiler-cli/src/ngtsc/perf/src/recorder" />
|
|
9
|
+
import { PerfCheckpoint, PerfEvent, PerfPhase, PerfRecorder } from './api';
|
|
10
|
+
/**
|
|
11
|
+
* Serializable performance data for the compilation, using string names.
|
|
12
|
+
*/
|
|
13
|
+
export interface PerfResults {
|
|
14
|
+
events: Record<string, number>;
|
|
15
|
+
phases: Record<string, number>;
|
|
16
|
+
memory: Record<string, number>;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* A `PerfRecorder` that actively tracks performance statistics.
|
|
20
|
+
*/
|
|
21
|
+
export declare class ActivePerfRecorder implements PerfRecorder {
|
|
22
|
+
private zeroTime;
|
|
23
|
+
private counters;
|
|
24
|
+
private phaseTime;
|
|
25
|
+
private bytes;
|
|
26
|
+
private currentPhase;
|
|
27
|
+
private currentPhaseEntered;
|
|
28
|
+
/**
|
|
29
|
+
* Creates an `ActivePerfRecoder` with its zero point set to the current time.
|
|
30
|
+
*/
|
|
31
|
+
static zeroedToNow(): ActivePerfRecorder;
|
|
32
|
+
private constructor();
|
|
33
|
+
reset(): void;
|
|
34
|
+
memory(after: PerfCheckpoint): void;
|
|
35
|
+
phase(phase: PerfPhase): PerfPhase;
|
|
36
|
+
inPhase<T>(phase: PerfPhase, fn: () => T): T;
|
|
37
|
+
eventCount(counter: PerfEvent, incrementBy?: number): void;
|
|
38
|
+
/**
|
|
39
|
+
* Return the current performance metrics as a serializable object.
|
|
40
|
+
*/
|
|
41
|
+
finalize(): PerfResults;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* A `PerfRecorder` that delegates to a target `PerfRecorder` which can be updated later.
|
|
45
|
+
*
|
|
46
|
+
* `DelegatingPerfRecorder` is useful when a compiler class that needs a `PerfRecorder` can outlive
|
|
47
|
+
* the current compilation. This is true for most compiler classes as resource-only changes reuse
|
|
48
|
+
* the same `NgCompiler` for a new compilation.
|
|
49
|
+
*/
|
|
50
|
+
export declare class DelegatingPerfRecorder implements PerfRecorder {
|
|
51
|
+
target: PerfRecorder;
|
|
52
|
+
constructor(target: PerfRecorder);
|
|
53
|
+
eventCount(counter: PerfEvent, incrementBy?: number): void;
|
|
54
|
+
phase(phase: PerfPhase): PerfPhase;
|
|
55
|
+
inPhase<T>(phase: PerfPhase, fn: () => T): T;
|
|
56
|
+
memory(after: PerfCheckpoint): void;
|
|
57
|
+
reset(): void;
|
|
58
|
+
}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright Google LLC All Rights Reserved.
|
|
4
|
+
*
|
|
5
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
+
* found in the LICENSE file at https://angular.io/license
|
|
7
|
+
*/
|
|
8
|
+
/// <reference types="node" />
|
|
9
|
+
(function (factory) {
|
|
10
|
+
if (typeof module === "object" && typeof module.exports === "object") {
|
|
11
|
+
var v = factory(require, exports);
|
|
12
|
+
if (v !== undefined) module.exports = v;
|
|
13
|
+
}
|
|
14
|
+
else if (typeof define === "function" && define.amd) {
|
|
15
|
+
define("@angular/compiler-cli/src/ngtsc/perf/src/recorder", ["require", "exports", "@angular/compiler-cli/src/ngtsc/perf/src/api", "@angular/compiler-cli/src/ngtsc/perf/src/clock"], factory);
|
|
16
|
+
}
|
|
17
|
+
})(function (require, exports) {
|
|
18
|
+
"use strict";
|
|
19
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
exports.DelegatingPerfRecorder = exports.ActivePerfRecorder = void 0;
|
|
21
|
+
var api_1 = require("@angular/compiler-cli/src/ngtsc/perf/src/api");
|
|
22
|
+
var clock_1 = require("@angular/compiler-cli/src/ngtsc/perf/src/clock");
|
|
23
|
+
/**
|
|
24
|
+
* A `PerfRecorder` that actively tracks performance statistics.
|
|
25
|
+
*/
|
|
26
|
+
var ActivePerfRecorder = /** @class */ (function () {
|
|
27
|
+
function ActivePerfRecorder(zeroTime) {
|
|
28
|
+
this.zeroTime = zeroTime;
|
|
29
|
+
this.currentPhase = api_1.PerfPhase.Unaccounted;
|
|
30
|
+
this.currentPhaseEntered = this.zeroTime;
|
|
31
|
+
this.counters = Array(api_1.PerfEvent.LAST).fill(0);
|
|
32
|
+
this.phaseTime = Array(api_1.PerfPhase.LAST).fill(0);
|
|
33
|
+
this.bytes = Array(api_1.PerfCheckpoint.LAST).fill(0);
|
|
34
|
+
// Take an initial memory snapshot before any other compilation work begins.
|
|
35
|
+
this.memory(api_1.PerfCheckpoint.Initial);
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Creates an `ActivePerfRecoder` with its zero point set to the current time.
|
|
39
|
+
*/
|
|
40
|
+
ActivePerfRecorder.zeroedToNow = function () {
|
|
41
|
+
return new ActivePerfRecorder(clock_1.mark());
|
|
42
|
+
};
|
|
43
|
+
ActivePerfRecorder.prototype.reset = function () {
|
|
44
|
+
this.counters = Array(api_1.PerfEvent.LAST).fill(0);
|
|
45
|
+
this.phaseTime = Array(api_1.PerfPhase.LAST).fill(0);
|
|
46
|
+
this.bytes = Array(api_1.PerfCheckpoint.LAST).fill(0);
|
|
47
|
+
this.zeroTime = clock_1.mark();
|
|
48
|
+
this.currentPhase = api_1.PerfPhase.Unaccounted;
|
|
49
|
+
this.currentPhaseEntered = this.zeroTime;
|
|
50
|
+
};
|
|
51
|
+
ActivePerfRecorder.prototype.memory = function (after) {
|
|
52
|
+
this.bytes[after] = process.memoryUsage().heapUsed;
|
|
53
|
+
};
|
|
54
|
+
ActivePerfRecorder.prototype.phase = function (phase) {
|
|
55
|
+
var previous = this.currentPhase;
|
|
56
|
+
this.phaseTime[this.currentPhase] += clock_1.timeSinceInMicros(this.currentPhaseEntered);
|
|
57
|
+
this.currentPhase = phase;
|
|
58
|
+
this.currentPhaseEntered = clock_1.mark();
|
|
59
|
+
return previous;
|
|
60
|
+
};
|
|
61
|
+
ActivePerfRecorder.prototype.inPhase = function (phase, fn) {
|
|
62
|
+
var previousPhase = this.phase(phase);
|
|
63
|
+
try {
|
|
64
|
+
return fn();
|
|
65
|
+
}
|
|
66
|
+
finally {
|
|
67
|
+
this.phase(previousPhase);
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
ActivePerfRecorder.prototype.eventCount = function (counter, incrementBy) {
|
|
71
|
+
if (incrementBy === void 0) { incrementBy = 1; }
|
|
72
|
+
this.counters[counter] += incrementBy;
|
|
73
|
+
};
|
|
74
|
+
/**
|
|
75
|
+
* Return the current performance metrics as a serializable object.
|
|
76
|
+
*/
|
|
77
|
+
ActivePerfRecorder.prototype.finalize = function () {
|
|
78
|
+
// Track the last segment of time spent in `this.currentPhase` in the time array.
|
|
79
|
+
this.phase(api_1.PerfPhase.Unaccounted);
|
|
80
|
+
var results = {
|
|
81
|
+
events: {},
|
|
82
|
+
phases: {},
|
|
83
|
+
memory: {},
|
|
84
|
+
};
|
|
85
|
+
for (var i = 0; i < this.phaseTime.length; i++) {
|
|
86
|
+
if (this.phaseTime[i] > 0) {
|
|
87
|
+
results.phases[api_1.PerfPhase[i]] = this.phaseTime[i];
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
for (var i = 0; i < this.phaseTime.length; i++) {
|
|
91
|
+
if (this.counters[i] > 0) {
|
|
92
|
+
results.events[api_1.PerfEvent[i]] = this.counters[i];
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
for (var i = 0; i < this.bytes.length; i++) {
|
|
96
|
+
if (this.bytes[i] > 0) {
|
|
97
|
+
results.memory[api_1.PerfCheckpoint[i]] = this.bytes[i];
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
return results;
|
|
101
|
+
};
|
|
102
|
+
return ActivePerfRecorder;
|
|
103
|
+
}());
|
|
104
|
+
exports.ActivePerfRecorder = ActivePerfRecorder;
|
|
105
|
+
/**
|
|
106
|
+
* A `PerfRecorder` that delegates to a target `PerfRecorder` which can be updated later.
|
|
107
|
+
*
|
|
108
|
+
* `DelegatingPerfRecorder` is useful when a compiler class that needs a `PerfRecorder` can outlive
|
|
109
|
+
* the current compilation. This is true for most compiler classes as resource-only changes reuse
|
|
110
|
+
* the same `NgCompiler` for a new compilation.
|
|
111
|
+
*/
|
|
112
|
+
var DelegatingPerfRecorder = /** @class */ (function () {
|
|
113
|
+
function DelegatingPerfRecorder(target) {
|
|
114
|
+
this.target = target;
|
|
115
|
+
}
|
|
116
|
+
DelegatingPerfRecorder.prototype.eventCount = function (counter, incrementBy) {
|
|
117
|
+
this.target.eventCount(counter, incrementBy);
|
|
118
|
+
};
|
|
119
|
+
DelegatingPerfRecorder.prototype.phase = function (phase) {
|
|
120
|
+
return this.target.phase(phase);
|
|
121
|
+
};
|
|
122
|
+
DelegatingPerfRecorder.prototype.inPhase = function (phase, fn) {
|
|
123
|
+
// Note: this doesn't delegate to `this.target.inPhase` but instead is implemented manually here
|
|
124
|
+
// to avoid adding an additional frame of noise to the stack when debugging.
|
|
125
|
+
var previousPhase = this.target.phase(phase);
|
|
126
|
+
try {
|
|
127
|
+
return fn();
|
|
128
|
+
}
|
|
129
|
+
finally {
|
|
130
|
+
this.target.phase(previousPhase);
|
|
131
|
+
}
|
|
132
|
+
};
|
|
133
|
+
DelegatingPerfRecorder.prototype.memory = function (after) {
|
|
134
|
+
this.target.memory(after);
|
|
135
|
+
};
|
|
136
|
+
DelegatingPerfRecorder.prototype.reset = function () {
|
|
137
|
+
this.target.reset();
|
|
138
|
+
};
|
|
139
|
+
return DelegatingPerfRecorder;
|
|
140
|
+
}());
|
|
141
|
+
exports.DelegatingPerfRecorder = DelegatingPerfRecorder;
|
|
142
|
+
});
|
|
143
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"recorder.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/src/ngtsc/perf/src/recorder.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/// <reference types=\"node\" />\n\nimport {PerfCheckpoint, PerfEvent, PerfPhase, PerfRecorder} from './api';\nimport {HrTime, mark, timeSinceInMicros} from './clock';\n\n/**\n * Serializable performance data for the compilation, using string names.\n */\nexport interface PerfResults {\n  events: Record<string, number>;\n  phases: Record<string, number>;\n  memory: Record<string, number>;\n}\n\n/**\n * A `PerfRecorder` that actively tracks performance statistics.\n */\nexport class ActivePerfRecorder implements PerfRecorder {\n  private counters: number[];\n  private phaseTime: number[];\n  private bytes: number[];\n\n  private currentPhase = PerfPhase.Unaccounted;\n  private currentPhaseEntered = this.zeroTime;\n\n  /**\n   * Creates an `ActivePerfRecoder` with its zero point set to the current time.\n   */\n  static zeroedToNow(): ActivePerfRecorder {\n    return new ActivePerfRecorder(mark());\n  }\n\n  private constructor(private zeroTime: HrTime) {\n    this.counters = Array(PerfEvent.LAST).fill(0);\n    this.phaseTime = Array(PerfPhase.LAST).fill(0);\n    this.bytes = Array(PerfCheckpoint.LAST).fill(0);\n\n    // Take an initial memory snapshot before any other compilation work begins.\n    this.memory(PerfCheckpoint.Initial);\n  }\n\n  reset(): void {\n    this.counters = Array(PerfEvent.LAST).fill(0);\n    this.phaseTime = Array(PerfPhase.LAST).fill(0);\n    this.bytes = Array(PerfCheckpoint.LAST).fill(0);\n    this.zeroTime = mark();\n    this.currentPhase = PerfPhase.Unaccounted;\n    this.currentPhaseEntered = this.zeroTime;\n  }\n\n  memory(after: PerfCheckpoint): void {\n    this.bytes[after] = process.memoryUsage().heapUsed;\n  }\n\n  phase(phase: PerfPhase): PerfPhase {\n    const previous = this.currentPhase;\n    this.phaseTime[this.currentPhase] += timeSinceInMicros(this.currentPhaseEntered);\n    this.currentPhase = phase;\n    this.currentPhaseEntered = mark();\n    return previous;\n  }\n\n  inPhase<T>(phase: PerfPhase, fn: () => T): T {\n    const previousPhase = this.phase(phase);\n    try {\n      return fn();\n    } finally {\n      this.phase(previousPhase);\n    }\n  }\n\n  eventCount(counter: PerfEvent, incrementBy: number = 1): void {\n    this.counters[counter] += incrementBy;\n  }\n\n  /**\n   * Return the current performance metrics as a serializable object.\n   */\n  finalize(): PerfResults {\n    // Track the last segment of time spent in `this.currentPhase` in the time array.\n    this.phase(PerfPhase.Unaccounted);\n\n    const results: PerfResults = {\n      events: {},\n      phases: {},\n      memory: {},\n    };\n\n    for (let i = 0; i < this.phaseTime.length; i++) {\n      if (this.phaseTime[i] > 0) {\n        results.phases[PerfPhase[i]] = this.phaseTime[i];\n      }\n    }\n\n    for (let i = 0; i < this.phaseTime.length; i++) {\n      if (this.counters[i] > 0) {\n        results.events[PerfEvent[i]] = this.counters[i];\n      }\n    }\n\n    for (let i = 0; i < this.bytes.length; i++) {\n      if (this.bytes[i] > 0) {\n        results.memory[PerfCheckpoint[i]] = this.bytes[i];\n      }\n    }\n\n    return results;\n  }\n}\n\n/**\n * A `PerfRecorder` that delegates to a target `PerfRecorder` which can be updated later.\n *\n * `DelegatingPerfRecorder` is useful when a compiler class that needs a `PerfRecorder` can outlive\n * the current compilation. This is true for most compiler classes as resource-only changes reuse\n * the same `NgCompiler` for a new compilation.\n */\nexport class DelegatingPerfRecorder implements PerfRecorder {\n  constructor(public target: PerfRecorder) {}\n\n  eventCount(counter: PerfEvent, incrementBy?: number): void {\n    this.target.eventCount(counter, incrementBy);\n  }\n\n  phase(phase: PerfPhase): PerfPhase {\n    return this.target.phase(phase);\n  }\n\n  inPhase<T>(phase: PerfPhase, fn: () => T): T {\n    // Note: this doesn't delegate to `this.target.inPhase` but instead is implemented manually here\n    // to avoid adding an additional frame of noise to the stack when debugging.\n    const previousPhase = this.target.phase(phase);\n    try {\n      return fn();\n    } finally {\n      this.target.phase(previousPhase);\n    }\n  }\n\n  memory(after: PerfCheckpoint): void {\n    this.target.memory(after);\n  }\n\n  reset(): void {\n    this.target.reset();\n  }\n}\n"]}
|
package/src/ngtsc/program.d.ts
CHANGED
|
@@ -41,8 +41,6 @@ export declare class NgtscProgram implements api.Program {
|
|
|
41
41
|
private reuseTsProgram;
|
|
42
42
|
private closureCompilerEnabled;
|
|
43
43
|
private host;
|
|
44
|
-
private perfRecorder;
|
|
45
|
-
private perfTracker;
|
|
46
44
|
private incrementalStrategy;
|
|
47
45
|
constructor(rootNames: ReadonlyArray<string>, options: NgCompilerOptions, delegateHost: api.CompilerHost, oldProgram?: NgtscProgram);
|
|
48
46
|
getTsProgram(): ts.Program;
|