@angular/compiler-cli 11.1.0 → 11.1.1
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 +15 -16
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/ngcc/src/rendering/source_maps.js +18 -19
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/component.d.ts +48 -3
- package/src/ngtsc/annotations/src/component.js +197 -116
- package/src/ngtsc/core/api/src/public_options.d.ts +2 -2
- package/src/ngtsc/core/api/src/public_options.js +1 -1
- package/src/ngtsc/core/index.d.ts +1 -1
- package/src/ngtsc/core/index.js +5 -5
- package/src/ngtsc/core/src/compiler.d.ts +79 -7
- package/src/ngtsc/core/src/compiler.js +191 -49
- package/src/ngtsc/diagnostics/src/error_code.d.ts +6 -1
- package/src/ngtsc/diagnostics/src/error_code.js +9 -1
- package/src/ngtsc/incremental/src/strategy.d.ts +7 -0
- package/src/ngtsc/incremental/src/strategy.js +7 -1
- package/src/ngtsc/program.js +47 -19
- package/src/ngtsc/resource/src/loader.d.ts +4 -0
- package/src/ngtsc/resource/src/loader.js +7 -1
- package/src/ngtsc/sourcemaps/index.d.ts +3 -2
- package/src/ngtsc/sourcemaps/index.js +12 -3
- package/src/ngtsc/sourcemaps/src/content_origin.d.ts +34 -0
- package/src/ngtsc/sourcemaps/src/content_origin.js +48 -0
- package/src/ngtsc/sourcemaps/src/raw_source_map.d.ts +19 -1
- package/src/ngtsc/sourcemaps/src/raw_source_map.js +1 -8
- package/src/ngtsc/sourcemaps/src/source_file.d.ts +5 -9
- package/src/ngtsc/sourcemaps/src/source_file.js +3 -6
- package/src/ngtsc/sourcemaps/src/source_file_loader.d.ts +34 -14
- package/src/ngtsc/sourcemaps/src/source_file_loader.js +72 -19
- package/src/ngtsc/transform/src/api.d.ts +5 -0
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.d.ts +1 -0
- package/src/ngtsc/transform/src/compilation.js +40 -17
- package/src/ngtsc/tsc_plugin.js +20 -3
- package/src/ngtsc/typecheck/api/checker.d.ts +5 -0
- package/src/ngtsc/typecheck/api/checker.js +1 -1
- package/src/ngtsc/typecheck/src/checker.d.ts +1 -0
- package/src/ngtsc/typecheck/src/checker.js +17 -1
- package/src/version.js +1 -1
|
@@ -17,7 +17,7 @@ export declare const declarationFunctions: string[];
|
|
|
17
17
|
* Also, ranges are matched to include "pre-releases", therefore if the range is `>=11.1.0-next.1`
|
|
18
18
|
* then this includes `11.1.0-next.2` and also `12.0.0-next.1`.
|
|
19
19
|
*
|
|
20
|
-
* Finally, note that we always start with the current version (i.e. `11.1.
|
|
20
|
+
* Finally, note that we always start with the current version (i.e. `11.1.1`). This
|
|
21
21
|
* allows the linker to work on local builds effectively.
|
|
22
22
|
*/
|
|
23
23
|
export declare class PartialLinkerSelector<TStatement, TExpression> {
|
|
@@ -37,7 +37,7 @@
|
|
|
37
37
|
* Also, ranges are matched to include "pre-releases", therefore if the range is `>=11.1.0-next.1`
|
|
38
38
|
* then this includes `11.1.0-next.2` and also `12.0.0-next.1`.
|
|
39
39
|
*
|
|
40
|
-
* Finally, note that we always start with the current version (i.e. `11.1.
|
|
40
|
+
* Finally, note that we always start with the current version (i.e. `11.1.1`). This
|
|
41
41
|
* allows the linker to work on local builds effectively.
|
|
42
42
|
*/
|
|
43
43
|
var PartialLinkerSelector = /** @class */ (function () {
|
|
@@ -48,7 +48,7 @@
|
|
|
48
48
|
* Returns true if there are `PartialLinker` classes that can handle functions with this name.
|
|
49
49
|
*/
|
|
50
50
|
PartialLinkerSelector.prototype.supportsDeclaration = function (functionName) {
|
|
51
|
-
return this.linkers
|
|
51
|
+
return this.linkers.has(functionName);
|
|
52
52
|
};
|
|
53
53
|
/**
|
|
54
54
|
* Returns the `PartialLinker` that can handle functions with the given name and version.
|
|
@@ -56,10 +56,10 @@
|
|
|
56
56
|
*/
|
|
57
57
|
PartialLinkerSelector.prototype.getLinker = function (functionName, version) {
|
|
58
58
|
var e_1, _a;
|
|
59
|
-
|
|
60
|
-
if (versions === undefined) {
|
|
59
|
+
if (!this.linkers.has(functionName)) {
|
|
61
60
|
throw new Error("Unknown partial declaration function " + functionName + ".");
|
|
62
61
|
}
|
|
62
|
+
var versions = this.linkers.get(functionName);
|
|
63
63
|
try {
|
|
64
64
|
for (var versions_1 = tslib_1.__values(versions), versions_1_1 = versions_1.next(); !versions_1_1.done; versions_1_1 = versions_1.next()) {
|
|
65
65
|
var _b = versions_1_1.value, range = _b.range, linker = _b.linker;
|
|
@@ -79,22 +79,21 @@
|
|
|
79
79
|
'Valid version ranges are:\n' + versions.map(function (v) { return " - " + v.range; }).join('\n'));
|
|
80
80
|
};
|
|
81
81
|
PartialLinkerSelector.prototype.createLinkerMap = function (environment, sourceUrl, code) {
|
|
82
|
-
var _a;
|
|
83
82
|
var partialDirectiveLinkerVersion1 = new partial_directive_linker_1_1.PartialDirectiveLinkerVersion1(sourceUrl, code);
|
|
84
83
|
var partialComponentLinkerVersion1 = new partial_component_linker_1_1.PartialComponentLinkerVersion1(environment, get_source_file_1.createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl, code);
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
84
|
+
var linkers = new Map();
|
|
85
|
+
linkers.set(exports.ɵɵngDeclareDirective, [
|
|
86
|
+
{ range: '11.1.1', linker: partialDirectiveLinkerVersion1 },
|
|
87
|
+
{ range: '>=11.1.0-next.1', linker: partialDirectiveLinkerVersion1 },
|
|
88
|
+
]);
|
|
89
|
+
linkers.set(exports.ɵɵngDeclareComponent, [
|
|
90
|
+
{ range: '11.1.1', linker: partialComponentLinkerVersion1 },
|
|
91
|
+
{ range: '>=11.1.0-next.1', linker: partialComponentLinkerVersion1 },
|
|
92
|
+
]);
|
|
93
|
+
return linkers;
|
|
95
94
|
};
|
|
96
95
|
return PartialLinkerSelector;
|
|
97
96
|
}());
|
|
98
97
|
exports.PartialLinkerSelector = PartialLinkerSelector;
|
|
99
98
|
});
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
99
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"partial_linker_selector.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/linker/src/file_linker/partial_linkers/partial_linker_selector.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,iCAAiC;IAGjC,gGAAuD;IAGvD,sIAA4E;IAC5E,sIAA4E;IAG/D,QAAA,oBAAoB,GAAG,sBAAsB,CAAC;IAC9C,QAAA,oBAAoB,GAAG,sBAAsB,CAAC;IAC9C,QAAA,oBAAoB,GAAG,CAAC,4BAAoB,EAAE,4BAAoB,CAAC,CAAC;IAOjF;;;;;;;;;;;;;;OAcG;IACH;QAGE,+BACI,WAAuD,EAAE,SAAyB,EAClF,IAAY;YACd,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,WAAW,EAAE,SAAS,EAAE,IAAI,CAAC,CAAC;QACpE,CAAC;QAED;;WAEG;QACH,mDAAmB,GAAnB,UAAoB,YAAoB;YACtC,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;QACxC,CAAC;QAED;;;WAGG;QACH,yCAAS,GAAT,UAAU,YAAoB,EAAE,OAAe;;YAC7C,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;gBACnC,MAAM,IAAI,KAAK,CAAC,0CAAwC,YAAY,MAAG,CAAC,CAAC;aAC1E;YACD,IAAM,QAAQ,GAAG,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,YAAY,CAAE,CAAC;;gBACjD,KAA8B,IAAA,aAAA,iBAAA,QAAQ,CAAA,kCAAA,wDAAE;oBAA7B,IAAA,uBAAe,EAAd,KAAK,WAAA,EAAE,MAAM,YAAA;oBACvB,IAAI,kBAAS,CAAC,OAAO,EAAE,KAAK,EAAE,EAAC,iBAAiB,EAAE,IAAI,EAAC,CAAC,EAAE;wBACxD,OAAO,MAAM,CAAC;qBACf;iBACF;;;;;;;;;YACD,MAAM,IAAI,KAAK,CACX,6CAA2C,OAAO,aAAQ,YAAY,QAAK;gBAC3E,6BAA6B,GAAG,QAAQ,CAAC,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,QAAM,CAAC,CAAC,KAAO,EAAf,CAAe,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACrF,CAAC;QAEO,+CAAe,GAAvB,UACI,WAAuD,EAAE,SAAyB,EAClF,IAAY;YACd,IAAM,8BAA8B,GAAG,IAAI,2DAA8B,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;YAC3F,IAAM,8BAA8B,GAAG,IAAI,2DAA8B,CACrE,WAAW,EAAE,qCAAmB,CAAC,SAAS,EAAE,IAAI,EAAE,WAAW,CAAC,gBAAgB,CAAC,EAAE,SAAS,EAC1F,IAAI,CAAC,CAAC;YAEV,IAAM,OAAO,GAAG,IAAI,GAAG,EAAsC,CAAC;YAC9D,OAAO,CAAC,GAAG,CAAC,4BAAoB,EAAE;gBAChC,EAAC,KAAK,EAAE,mBAAmB,EAAE,MAAM,EAAE,8BAA8B,EAAC;gBACpE,EAAC,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,8BAA8B,EAAC;aACnE,CAAC,CAAC;YACH,OAAO,CAAC,GAAG,CAAC,4BAAoB,EAAE;gBAChC,EAAC,KAAK,EAAE,mBAAmB,EAAE,MAAM,EAAE,8BAA8B,EAAC;gBACpE,EAAC,KAAK,EAAE,iBAAiB,EAAE,MAAM,EAAE,8BAA8B,EAAC;aACnE,CAAC,CAAC;YACH,OAAO,OAAO,CAAC;QACjB,CAAC;QACH,4BAAC;IAAD,CAAC,AAtDD,IAsDC;IAtDY,sDAAqB","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 */\nimport {satisfies} from 'semver';\n\nimport {AbsoluteFsPath} from '../../../../src/ngtsc/file_system';\nimport {createGetSourceFile} from '../get_source_file';\nimport {LinkerEnvironment} from '../linker_environment';\n\nimport {PartialComponentLinkerVersion1} from './partial_component_linker_1';\nimport {PartialDirectiveLinkerVersion1} from './partial_directive_linker_1';\nimport {PartialLinker} from './partial_linker';\n\nexport const ɵɵngDeclareDirective = 'ɵɵngDeclareDirective';\nexport const ɵɵngDeclareComponent = 'ɵɵngDeclareComponent';\nexport const declarationFunctions = [ɵɵngDeclareDirective, ɵɵngDeclareComponent];\n\ninterface LinkerRange<TExpression> {\n  range: string;\n  linker: PartialLinker<TExpression>;\n}\n\n/**\n * A helper that selects the appropriate `PartialLinker` for a given declaration.\n *\n * The selection is made from a database of linker instances, chosen if their given semver range\n * satisfies the version found in the code to be linked.\n *\n * Note that the ranges are checked in order, and the first matching range will be selected, so\n * ranges should be most restrictive first.\n *\n * Also, ranges are matched to include \"pre-releases\", therefore if the range is `>=11.1.0-next.1`\n * then this includes `11.1.0-next.2` and also `12.0.0-next.1`.\n *\n * Finally, note that we always start with the current version (i.e. `0.0.0-PLACEHOLDER`). This\n * allows the linker to work on local builds effectively.\n */\nexport class PartialLinkerSelector<TStatement, TExpression> {\n  private readonly linkers: Map<string, LinkerRange<TExpression>[]>;\n\n  constructor(\n      environment: LinkerEnvironment<TStatement, TExpression>, sourceUrl: AbsoluteFsPath,\n      code: string) {\n    this.linkers = this.createLinkerMap(environment, sourceUrl, code);\n  }\n\n  /**\n   * Returns true if there are `PartialLinker` classes that can handle functions with this name.\n   */\n  supportsDeclaration(functionName: string): boolean {\n    return this.linkers.has(functionName);\n  }\n\n  /**\n   * Returns the `PartialLinker` that can handle functions with the given name and version.\n   * Throws an error if there is none.\n   */\n  getLinker(functionName: string, version: string): PartialLinker<TExpression> {\n    if (!this.linkers.has(functionName)) {\n      throw new Error(`Unknown partial declaration function ${functionName}.`);\n    }\n    const versions = this.linkers.get(functionName)!;\n    for (const {range, linker} of versions) {\n      if (satisfies(version, range, {includePrerelease: true})) {\n        return linker;\n      }\n    }\n    throw new Error(\n        `Unsupported partial declaration version ${version} for ${functionName}.\\n` +\n        'Valid version ranges are:\\n' + versions.map(v => ` - ${v.range}`).join('\\n'));\n  }\n\n  private createLinkerMap(\n      environment: LinkerEnvironment<TStatement, TExpression>, sourceUrl: AbsoluteFsPath,\n      code: string): Map<string, LinkerRange<TExpression>[]> {\n    const partialDirectiveLinkerVersion1 = new PartialDirectiveLinkerVersion1(sourceUrl, code);\n    const partialComponentLinkerVersion1 = new PartialComponentLinkerVersion1(\n        environment, createGetSourceFile(sourceUrl, code, environment.sourceFileLoader), sourceUrl,\n        code);\n\n    const linkers = new Map<string, LinkerRange<TExpression>[]>();\n    linkers.set(ɵɵngDeclareDirective, [\n      {range: '0.0.0-PLACEHOLDER', linker: partialDirectiveLinkerVersion1},\n      {range: '>=11.1.0-next.1', linker: partialDirectiveLinkerVersion1},\n    ]);\n    linkers.set(ɵɵngDeclareComponent, [\n      {range: '0.0.0-PLACEHOLDER', linker: partialComponentLinkerVersion1},\n      {range: '>=11.1.0-next.1', linker: partialComponentLinkerVersion1},\n    ]);\n    return linkers;\n  }\n}\n"]}
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
import { AbsoluteFsPath } from '../../../src/ngtsc/file_system';
|
|
10
10
|
import { PackageJsonUpdater } from '../writing/package_json_updater';
|
|
11
11
|
import { EntryPointPackageJson, PackageJsonFormatProperties } from './entry_point';
|
|
12
|
-
export declare const NGCC_VERSION = "11.1.
|
|
12
|
+
export declare const NGCC_VERSION = "11.1.1";
|
|
13
13
|
/**
|
|
14
14
|
* Returns true if there is a format in this entry-point that was compiled with an outdated version
|
|
15
15
|
* of ngcc.
|
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
exports.markAsProcessed = exports.hasBeenProcessed = exports.cleanPackageJson = exports.needsCleaning = exports.NGCC_VERSION = void 0;
|
|
13
13
|
var tslib_1 = require("tslib");
|
|
14
14
|
var new_entry_point_file_writer_1 = require("@angular/compiler-cli/ngcc/src/writing/new_entry_point_file_writer");
|
|
15
|
-
exports.NGCC_VERSION = '11.1.
|
|
15
|
+
exports.NGCC_VERSION = '11.1.1';
|
|
16
16
|
/**
|
|
17
17
|
* Returns true if there is a format in this entry-point that was compiled with an outdated version
|
|
18
18
|
* of ngcc.
|
|
@@ -25,18 +25,19 @@
|
|
|
25
25
|
* with an appropriate source-map comment pointing to the merged source-map.
|
|
26
26
|
*/
|
|
27
27
|
function renderSourceAndMap(logger, fs, sourceFile, generatedMagicString) {
|
|
28
|
-
var
|
|
29
|
-
var
|
|
28
|
+
var _a;
|
|
29
|
+
var sourceFilePath = file_system_1.absoluteFromSourceFile(sourceFile);
|
|
30
|
+
var sourceMapPath = file_system_1.absoluteFrom(sourceFilePath + ".map");
|
|
30
31
|
var generatedContent = generatedMagicString.toString();
|
|
31
|
-
var generatedMap = generatedMagicString.generateMap({ file:
|
|
32
|
+
var generatedMap = generatedMagicString.generateMap({ file: sourceFilePath, source: sourceFilePath, includeContent: true });
|
|
32
33
|
try {
|
|
33
34
|
var loader = new sourcemaps_1.SourceFileLoader(fs, logger, {});
|
|
34
|
-
var generatedFile = loader.loadSourceFile(
|
|
35
|
+
var generatedFile = loader.loadSourceFile(sourceFilePath, generatedContent, { map: generatedMap, mapPath: sourceMapPath });
|
|
35
36
|
var rawMergedMap = generatedFile.renderFlattenedSourceMap();
|
|
36
37
|
var mergedMap = convert_source_map_1.fromObject(rawMergedMap);
|
|
37
|
-
var
|
|
38
|
-
if (
|
|
39
|
-
|
|
38
|
+
var originalFile = loader.loadSourceFile(sourceFilePath, generatedMagicString.original);
|
|
39
|
+
if (originalFile.rawMap === null && !sourceFile.isDeclarationFile ||
|
|
40
|
+
((_a = originalFile.rawMap) === null || _a === void 0 ? void 0 : _a.origin) === sourcemaps_1.ContentOrigin.Inline) {
|
|
40
41
|
// We render an inline source map if one of:
|
|
41
42
|
// * there was no input source map and this is not a typings file;
|
|
42
43
|
// * the input source map exists and was inline.
|
|
@@ -45,25 +46,23 @@
|
|
|
45
46
|
// the input file because these inline source maps can be very large and it impacts on the
|
|
46
47
|
// performance of IDEs that need to read them to provide intellisense etc.
|
|
47
48
|
return [
|
|
48
|
-
{ path:
|
|
49
|
-
];
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
var sourceMapComment = convert_source_map_1.generateMapFileComment(fs.basename(generatedPath) + ".map");
|
|
53
|
-
return [
|
|
54
|
-
{ path: generatedPath, contents: generatedFile.contents + "\n" + sourceMapComment },
|
|
55
|
-
{ path: generatedMapPath, contents: mergedMap.toJSON() }
|
|
49
|
+
{ path: sourceFilePath, contents: generatedFile.contents + "\n" + mergedMap.toComment() }
|
|
56
50
|
];
|
|
57
51
|
}
|
|
52
|
+
var sourceMapComment = convert_source_map_1.generateMapFileComment(fs.basename(sourceFilePath) + ".map");
|
|
53
|
+
return [
|
|
54
|
+
{ path: sourceFilePath, contents: generatedFile.contents + "\n" + sourceMapComment },
|
|
55
|
+
{ path: sourceMapPath, contents: mergedMap.toJSON() }
|
|
56
|
+
];
|
|
58
57
|
}
|
|
59
58
|
catch (e) {
|
|
60
|
-
logger.error("Error when flattening the source-map \"" +
|
|
59
|
+
logger.error("Error when flattening the source-map \"" + sourceMapPath + "\" for \"" + sourceFilePath + "\": " + e.toString());
|
|
61
60
|
return [
|
|
62
|
-
{ path:
|
|
63
|
-
{ path:
|
|
61
|
+
{ path: sourceFilePath, contents: generatedContent },
|
|
62
|
+
{ path: sourceMapPath, contents: convert_source_map_1.fromObject(generatedMap).toJSON() },
|
|
64
63
|
];
|
|
65
64
|
}
|
|
66
65
|
}
|
|
67
66
|
exports.renderSourceAndMap = renderSourceAndMap;
|
|
68
67
|
});
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
68
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic291cmNlX21hcHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9jb21waWxlci1jbGkvbmdjYy9zcmMvcmVuZGVyaW5nL3NvdXJjZV9tYXBzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7OztJQUFBOzs7Ozs7T0FNRztJQUNILHlEQUEwRjtJQUkxRiwyRUFBd0c7SUFFeEcseUVBQTRGO0lBVTVGOzs7T0FHRztJQUNILFNBQWdCLGtCQUFrQixDQUM5QixNQUFjLEVBQUUsRUFBc0IsRUFBRSxVQUF5QixFQUNqRSxvQkFBaUM7O1FBQ25DLElBQU0sY0FBYyxHQUFHLG9DQUFzQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzFELElBQU0sYUFBYSxHQUFHLDBCQUFZLENBQUksY0FBYyxTQUFNLENBQUMsQ0FBQztRQUM1RCxJQUFNLGdCQUFnQixHQUFHLG9CQUFvQixDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3pELElBQU0sWUFBWSxHQUFpQixvQkFBb0IsQ0FBQyxXQUFXLENBQy9ELEVBQUMsSUFBSSxFQUFFLGNBQWMsRUFBRSxNQUFNLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxJQUFJLEVBQUMsQ0FBQyxDQUFDO1FBRTFFLElBQUk7WUFDRixJQUFNLE1BQU0sR0FBRyxJQUFJLDZCQUFnQixDQUFDLEVBQUUsRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7WUFDcEQsSUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FDdkMsY0FBYyxFQUFFLGdCQUFnQixFQUFFLEVBQUMsR0FBRyxFQUFFLFlBQVksRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFDLENBQUMsQ0FBQztZQUVuRixJQUFNLFlBQVksR0FBaUIsYUFBYSxDQUFDLHdCQUF3QixFQUFFLENBQUM7WUFDNUUsSUFBTSxTQUFTLEdBQUcsK0JBQVUsQ0FBQyxZQUFZLENBQUMsQ0FBQztZQUMzQyxJQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLGNBQWMsRUFBRSxvQkFBb0IsQ0FBQyxRQUFRLENBQUMsQ0FBQztZQUMxRixJQUFJLFlBQVksQ0FBQyxNQUFNLEtBQUssSUFBSSxJQUFJLENBQUMsVUFBVSxDQUFDLGlCQUFpQjtnQkFDN0QsT0FBQSxZQUFZLENBQUMsTUFBTSwwQ0FBRSxNQUFNLE1BQUssMEJBQWEsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3hELDRDQUE0QztnQkFDNUMsa0VBQWtFO2dCQUNsRSxnREFBZ0Q7Z0JBQ2hELEVBQUU7Z0JBQ0YsNkZBQTZGO2dCQUM3RiwwRkFBMEY7Z0JBQzFGLDBFQUEwRTtnQkFDMUUsT0FBTztvQkFDTCxFQUFDLElBQUksRUFBRSxjQUFjLEVBQUUsUUFBUSxFQUFLLGFBQWEsQ0FBQyxRQUFRLFVBQUssU0FBUyxDQUFDLFNBQVMsRUFBSSxFQUFDO2lCQUN4RixDQUFDO2FBQ0g7WUFFRCxJQUFNLGdCQUFnQixHQUFHLDJDQUFzQixDQUFJLEVBQUUsQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLFNBQU0sQ0FBQyxDQUFDO1lBQ3RGLE9BQU87Z0JBQ0wsRUFBQyxJQUFJLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBSyxhQUFhLENBQUMsUUFBUSxVQUFLLGdCQUFrQixFQUFDO2dCQUNsRixFQUFDLElBQUksRUFBRSxhQUFhLEVBQUUsUUFBUSxFQUFFLFNBQVMsQ0FBQyxNQUFNLEVBQUUsRUFBQzthQUNwRCxDQUFDO1NBQ0g7UUFBQyxPQUFPLENBQUMsRUFBRTtZQUNWLE1BQU0sQ0FBQyxLQUFLLENBQUMsNENBQXlDLGFBQWEsaUJBQy9ELGNBQWMsWUFBTSxDQUFDLENBQUMsUUFBUSxFQUFJLENBQUMsQ0FBQztZQUN4QyxPQUFPO2dCQUNMLEVBQUMsSUFBSSxFQUFFLGNBQWMsRUFBRSxRQUFRLEVBQUUsZ0JBQWdCLEVBQUM7Z0JBQ2xELEVBQUMsSUFBSSxFQUFFLGFBQWEsRUFBRSxRQUFRLEVBQUUsK0JBQVUsQ0FBQyxZQUFZLENBQUMsQ0FBQyxNQUFNLEVBQUUsRUFBQzthQUNuRSxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBNUNELGdEQTRDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQGxpY2Vuc2VcbiAqIENvcHlyaWdodCBHb29nbGUgTExDIEFsbCBSaWdodHMgUmVzZXJ2ZWQuXG4gKlxuICogVXNlIG9mIHRoaXMgc291cmNlIGNvZGUgaXMgZ292ZXJuZWQgYnkgYW4gTUlULXN0eWxlIGxpY2Vuc2UgdGhhdCBjYW4gYmVcbiAqIGZvdW5kIGluIHRoZSBMSUNFTlNFIGZpbGUgYXQgaHR0cHM6Ly9hbmd1bGFyLmlvL2xpY2Vuc2VcbiAqL1xuaW1wb3J0IHtmcm9tT2JqZWN0LCBnZW5lcmF0ZU1hcEZpbGVDb21tZW50LCBTb3VyY2VNYXBDb252ZXJ0ZXJ9IGZyb20gJ2NvbnZlcnQtc291cmNlLW1hcCc7XG5pbXBvcnQgTWFnaWNTdHJpbmcgZnJvbSAnbWFnaWMtc3RyaW5nJztcbmltcG9ydCAqIGFzIHRzIGZyb20gJ3R5cGVzY3JpcHQnO1xuXG5pbXBvcnQge2Fic29sdXRlRnJvbSwgYWJzb2x1dGVGcm9tU291cmNlRmlsZSwgUmVhZG9ubHlGaWxlU3lzdGVtfSBmcm9tICcuLi8uLi8uLi9zcmMvbmd0c2MvZmlsZV9zeXN0ZW0nO1xuaW1wb3J0IHtMb2dnZXJ9IGZyb20gJy4uLy4uLy4uL3NyYy9uZ3RzYy9sb2dnaW5nJztcbmltcG9ydCB7Q29udGVudE9yaWdpbiwgUmF3U291cmNlTWFwLCBTb3VyY2VGaWxlTG9hZGVyfSBmcm9tICcuLi8uLi8uLi9zcmMvbmd0c2Mvc291cmNlbWFwcyc7XG5cbmltcG9ydCB7RmlsZVRvV3JpdGV9IGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNvdXJjZU1hcEluZm8ge1xuICBzb3VyY2U6IHN0cmluZztcbiAgbWFwOiBTb3VyY2VNYXBDb252ZXJ0ZXJ8bnVsbDtcbiAgaXNJbmxpbmU6IGJvb2xlYW47XG59XG5cbi8qKlxuICogTWVyZ2UgdGhlIGlucHV0IGFuZCBvdXRwdXQgc291cmNlLW1hcHMsIHJlcGxhY2luZyB0aGUgc291cmNlLW1hcCBjb21tZW50IGluIHRoZSBvdXRwdXQgZmlsZVxuICogd2l0aCBhbiBhcHByb3ByaWF0ZSBzb3VyY2UtbWFwIGNvbW1lbnQgcG9pbnRpbmcgdG8gdGhlIG1lcmdlZCBzb3VyY2UtbWFwLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcmVuZGVyU291cmNlQW5kTWFwKFxuICAgIGxvZ2dlcjogTG9nZ2VyLCBmczogUmVhZG9ubHlGaWxlU3lzdGVtLCBzb3VyY2VGaWxlOiB0cy5Tb3VyY2VGaWxlLFxuICAgIGdlbmVyYXRlZE1hZ2ljU3RyaW5nOiBNYWdpY1N0cmluZyk6IEZpbGVUb1dyaXRlW10ge1xuICBjb25zdCBzb3VyY2VGaWxlUGF0aCA9IGFic29sdXRlRnJvbVNvdXJjZUZpbGUoc291cmNlRmlsZSk7XG4gIGNvbnN0IHNvdXJjZU1hcFBhdGggPSBhYnNvbHV0ZUZyb20oYCR7c291cmNlRmlsZVBhdGh9Lm1hcGApO1xuICBjb25zdCBnZW5lcmF0ZWRDb250ZW50ID0gZ2VuZXJhdGVkTWFnaWNTdHJpbmcudG9TdHJpbmcoKTtcbiAgY29uc3QgZ2VuZXJhdGVkTWFwOiBSYXdTb3VyY2VNYXAgPSBnZW5lcmF0ZWRNYWdpY1N0cmluZy5nZW5lcmF0ZU1hcChcbiAgICAgIHtmaWxlOiBzb3VyY2VGaWxlUGF0aCwgc291cmNlOiBzb3VyY2VGaWxlUGF0aCwgaW5jbHVkZUNvbnRlbnQ6IHRydWV9KTtcblxuICB0cnkge1xuICAgIGNvbnN0IGxvYWRlciA9IG5ldyBTb3VyY2VGaWxlTG9hZGVyKGZzLCBsb2dnZXIsIHt9KTtcbiAgICBjb25zdCBnZW5lcmF0ZWRGaWxlID0gbG9hZGVyLmxvYWRTb3VyY2VGaWxlKFxuICAgICAgICBzb3VyY2VGaWxlUGF0aCwgZ2VuZXJhdGVkQ29udGVudCwge21hcDogZ2VuZXJhdGVkTWFwLCBtYXBQYXRoOiBzb3VyY2VNYXBQYXRofSk7XG5cbiAgICBjb25zdCByYXdNZXJnZWRNYXA6IFJhd1NvdXJjZU1hcCA9IGdlbmVyYXRlZEZpbGUucmVuZGVyRmxhdHRlbmVkU291cmNlTWFwKCk7XG4gICAgY29uc3QgbWVyZ2VkTWFwID0gZnJvbU9iamVjdChyYXdNZXJnZWRNYXApO1xuICAgIGNvbnN0IG9yaWdpbmFsRmlsZSA9IGxvYWRlci5sb2FkU291cmNlRmlsZShzb3VyY2VGaWxlUGF0aCwgZ2VuZXJhdGVkTWFnaWNTdHJpbmcub3JpZ2luYWwpO1xuICAgIGlmIChvcmlnaW5hbEZpbGUucmF3TWFwID09PSBudWxsICYmICFzb3VyY2VGaWxlLmlzRGVjbGFyYXRpb25GaWxlIHx8XG4gICAgICAgIG9yaWdpbmFsRmlsZS5yYXdNYXA/Lm9yaWdpbiA9PT0gQ29udGVudE9yaWdpbi5JbmxpbmUpIHtcbiAgICAgIC8vIFdlIHJlbmRlciBhbiBpbmxpbmUgc291cmNlIG1hcCBpZiBvbmUgb2Y6XG4gICAgICAvLyAqIHRoZXJlIHdhcyBubyBpbnB1dCBzb3VyY2UgbWFwIGFuZCB0aGlzIGlzIG5vdCBhIHR5cGluZ3MgZmlsZTtcbiAgICAgIC8vICogdGhlIGlucHV0IHNvdXJjZSBtYXAgZXhpc3RzIGFuZCB3YXMgaW5saW5lLlxuICAgICAgLy9cbiAgICAgIC8vIFdlIGRvIG5vdCBnZW5lcmF0ZSBpbmxpbmUgc291cmNlIG1hcHMgZm9yIHR5cGluZ3MgZmlsZXMgdW5sZXNzIHRoZXJlIGV4cGxpY2l0bHkgd2FzIG9uZSBpblxuICAgICAgLy8gdGhlIGlucHV0IGZpbGUgYmVjYXVzZSB0aGVzZSBpbmxpbmUgc291cmNlIG1hcHMgY2FuIGJlIHZlcnkgbGFyZ2UgYW5kIGl0IGltcGFjdHMgb24gdGhlXG4gICAgICAvLyBwZXJmb3JtYW5jZSBvZiBJREVzIHRoYXQgbmVlZCB0byByZWFkIHRoZW0gdG8gcHJvdmlkZSBpbnRlbGxpc2Vuc2UgZXRjLlxuICAgICAgcmV0dXJuIFtcbiAgICAgICAge3BhdGg6IHNvdXJjZUZpbGVQYXRoLCBjb250ZW50czogYCR7Z2VuZXJhdGVkRmlsZS5jb250ZW50c31cXG4ke21lcmdlZE1hcC50b0NvbW1lbnQoKX1gfVxuICAgICAgXTtcbiAgICB9XG5cbiAgICBjb25zdCBzb3VyY2VNYXBDb21tZW50ID0gZ2VuZXJhdGVNYXBGaWxlQ29tbWVudChgJHtmcy5iYXNlbmFtZShzb3VyY2VGaWxlUGF0aCl9Lm1hcGApO1xuICAgIHJldHVybiBbXG4gICAgICB7cGF0aDogc291cmNlRmlsZVBhdGgsIGNvbnRlbnRzOiBgJHtnZW5lcmF0ZWRGaWxlLmNvbnRlbnRzfVxcbiR7c291cmNlTWFwQ29tbWVudH1gfSxcbiAgICAgIHtwYXRoOiBzb3VyY2VNYXBQYXRoLCBjb250ZW50czogbWVyZ2VkTWFwLnRvSlNPTigpfVxuICAgIF07XG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBsb2dnZXIuZXJyb3IoYEVycm9yIHdoZW4gZmxhdHRlbmluZyB0aGUgc291cmNlLW1hcCBcIiR7c291cmNlTWFwUGF0aH1cIiBmb3IgXCIke1xuICAgICAgICBzb3VyY2VGaWxlUGF0aH1cIjogJHtlLnRvU3RyaW5nKCl9YCk7XG4gICAgcmV0dXJuIFtcbiAgICAgIHtwYXRoOiBzb3VyY2VGaWxlUGF0aCwgY29udGVudHM6IGdlbmVyYXRlZENvbnRlbnR9LFxuICAgICAge3BhdGg6IHNvdXJjZU1hcFBhdGgsIGNvbnRlbnRzOiBmcm9tT2JqZWN0KGdlbmVyYXRlZE1hcCkudG9KU09OKCl9LFxuICAgIF07XG4gIH1cbn1cbiJdfQ==
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@angular/compiler-cli",
|
|
3
|
-
"version": "11.1.
|
|
3
|
+
"version": "11.1.1",
|
|
4
4
|
"description": "Angular - the compiler CLI for Node.js",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"typings": "index.d.ts",
|
|
@@ -28,7 +28,7 @@
|
|
|
28
28
|
"yargs": "^16.1.1"
|
|
29
29
|
},
|
|
30
30
|
"peerDependencies": {
|
|
31
|
-
"@angular/compiler": "11.1.
|
|
31
|
+
"@angular/compiler": "11.1.1",
|
|
32
32
|
"typescript": ">=4.0 <4.2"
|
|
33
33
|
},
|
|
34
34
|
"engines": {
|
|
@@ -6,7 +6,8 @@
|
|
|
6
6
|
* found in the LICENSE file at https://angular.io/license
|
|
7
7
|
*/
|
|
8
8
|
/// <amd-module name="@angular/compiler-cli/src/ngtsc/annotations/src/component" />
|
|
9
|
-
import { ConstantPool, ParsedTemplate, ParseSourceFile, R3ComponentMetadata, Statement, TmplAstNode } from '@angular/compiler';
|
|
9
|
+
import { ConstantPool, InterpolationConfig, ParsedTemplate, ParseSourceFile, R3ComponentMetadata, Statement, TmplAstNode } from '@angular/compiler';
|
|
10
|
+
import * as ts from 'typescript';
|
|
10
11
|
import { CycleAnalyzer } from '../../cycles';
|
|
11
12
|
import { DefaultImportRecorder, ModuleResolver, Reference, ReferenceEmitter } from '../../imports';
|
|
12
13
|
import { DependencyTracker } from '../../incremental/api';
|
|
@@ -49,6 +50,14 @@ export interface ComponentAnalysisData {
|
|
|
49
50
|
*/
|
|
50
51
|
viewProvidersRequiringFactory: Set<Reference<ClassDeclaration>> | null;
|
|
51
52
|
resources: ComponentResources;
|
|
53
|
+
/**
|
|
54
|
+
* The literal `styleUrls` extracted from the decorator, if present.
|
|
55
|
+
*/
|
|
56
|
+
styleUrls: string[] | null;
|
|
57
|
+
/**
|
|
58
|
+
* Inline stylesheets extracted from the decorator, if present.
|
|
59
|
+
*/
|
|
60
|
+
inlineStyles: string[] | null;
|
|
52
61
|
isPoisoned: boolean;
|
|
53
62
|
}
|
|
54
63
|
export declare type ComponentResolutionData = Pick<R3ComponentMetadata, ComponentMetadataResolvedFields>;
|
|
@@ -97,6 +106,7 @@ export declare class ComponentDecoratorHandler implements DecoratorHandler<Decor
|
|
|
97
106
|
index(context: IndexingContext, node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>): null | undefined;
|
|
98
107
|
typeCheck(ctx: TypeCheckContext, node: ClassDeclaration, meta: Readonly<ComponentAnalysisData>): void;
|
|
99
108
|
resolve(node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>): ResolveResult<ComponentResolutionData>;
|
|
109
|
+
updateResources(node: ClassDeclaration, analysis: ComponentAnalysisData): void;
|
|
100
110
|
compileFull(node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>, resolution: Readonly<ComponentResolutionData>, pool: ConstantPool): CompileResult[];
|
|
101
111
|
compilePartial(node: ClassDeclaration, analysis: Readonly<ComponentAnalysisData>, resolution: Readonly<ComponentResolutionData>): CompileResult[];
|
|
102
112
|
private compileComponent;
|
|
@@ -105,9 +115,9 @@ export declare class ComponentDecoratorHandler implements DecoratorHandler<Decor
|
|
|
105
115
|
private _extractStyleUrls;
|
|
106
116
|
private _extractStyleResources;
|
|
107
117
|
private _preloadAndParseTemplate;
|
|
108
|
-
private
|
|
109
|
-
private _extractInlineTemplate;
|
|
118
|
+
private extractTemplate;
|
|
110
119
|
private _parseTemplate;
|
|
120
|
+
private parseTemplateDeclaration;
|
|
111
121
|
private _expressionToImportedFile;
|
|
112
122
|
private _isCyclicImport;
|
|
113
123
|
private _recordSyntheticImport;
|
|
@@ -137,4 +147,39 @@ export interface ParsedComponentTemplate extends ParsedTemplate {
|
|
|
137
147
|
}
|
|
138
148
|
export interface ParsedTemplateWithSource extends ParsedComponentTemplate {
|
|
139
149
|
sourceMapping: TemplateSourceMapping;
|
|
150
|
+
declaration: TemplateDeclaration;
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Common fields extracted from the declaration of a template.
|
|
154
|
+
*/
|
|
155
|
+
interface CommonTemplateDeclaration {
|
|
156
|
+
preserveWhitespaces: boolean;
|
|
157
|
+
interpolationConfig: InterpolationConfig;
|
|
158
|
+
templateUrl: string;
|
|
159
|
+
resolvedTemplateUrl: string;
|
|
160
|
+
sourceMapUrl: string;
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Information extracted from the declaration of an inline template.
|
|
164
|
+
*/
|
|
165
|
+
interface InlineTemplateDeclaration extends CommonTemplateDeclaration {
|
|
166
|
+
isInline: true;
|
|
167
|
+
expression: ts.Expression;
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Information extracted from the declaration of an external template.
|
|
171
|
+
*/
|
|
172
|
+
interface ExternalTemplateDeclaration extends CommonTemplateDeclaration {
|
|
173
|
+
isInline: false;
|
|
174
|
+
templateUrlExpression: ts.Expression;
|
|
140
175
|
}
|
|
176
|
+
/**
|
|
177
|
+
* The declaration of a template extracted from a component decorator.
|
|
178
|
+
*
|
|
179
|
+
* This data is extracted and stored separately to faciliate re-interpreting the template
|
|
180
|
+
* declaration whenever the compiler is notified of a change to a template file. With this
|
|
181
|
+
* information, `ComponentDecoratorHandler` is able to re-read the template and update the component
|
|
182
|
+
* record without needing to parse the original decorator again.
|
|
183
|
+
*/
|
|
184
|
+
declare type TemplateDeclaration = InlineTemplateDeclaration | ExternalTemplateDeclaration;
|
|
185
|
+
export {};
|