@angular/compiler-cli 10.1.0-rc.0 → 10.1.3
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/ngcc/src/execution/create_compile_function.js +6 -3
- package/ngcc/src/host/esm2015_host.d.ts +18 -0
- package/ngcc/src/host/esm2015_host.js +53 -31
- package/ngcc/src/main.js +9 -12
- package/ngcc/src/ngcc_options.d.ts +8 -7
- package/ngcc/src/ngcc_options.js +27 -3
- 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 +12 -1
- package/ngcc/src/packages/entry_point_bundle.js +9 -6
- package/ngcc/src/packages/ngcc_compiler_host.d.ts +16 -1
- package/ngcc/src/packages/ngcc_compiler_host.js +35 -5
- package/ngcc/src/packages/source_file_cache.d.ts +97 -0
- package/ngcc/src/packages/source_file_cache.js +207 -0
- package/ngcc/src/rendering/renderer.js +9 -10
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/component.d.ts +4 -1
- package/src/ngtsc/annotations/src/component.js +94 -122
- package/src/ngtsc/annotations/src/directive.d.ts +5 -1
- package/src/ngtsc/annotations/src/directive.js +21 -11
- package/src/ngtsc/annotations/src/typecheck_scopes.d.ts +56 -0
- package/src/ngtsc/annotations/src/typecheck_scopes.js +109 -0
- package/src/ngtsc/annotations/src/util.js +4 -2
- package/src/ngtsc/core/src/compiler.js +4 -3
- package/src/ngtsc/diagnostics/src/error_code.d.ts +4 -0
- package/src/ngtsc/diagnostics/src/error_code.js +5 -1
- package/src/ngtsc/file_system/src/invalid_file_system.d.ts +2 -2
- package/src/ngtsc/file_system/src/invalid_file_system.js +1 -1
- package/src/ngtsc/file_system/src/node_js_file_system.d.ts +2 -2
- package/src/ngtsc/file_system/src/node_js_file_system.js +1 -1
- package/src/ngtsc/file_system/src/types.d.ts +2 -2
- package/src/ngtsc/file_system/src/types.js +1 -1
- package/src/ngtsc/file_system/testing/src/mock_file_system.d.ts +3 -3
- package/src/ngtsc/file_system/testing/src/mock_file_system.js +2 -2
- package/src/ngtsc/indexer/src/template.js +10 -24
- package/src/ngtsc/metadata/index.d.ts +2 -0
- package/src/ngtsc/metadata/index.js +7 -3
- package/src/ngtsc/metadata/src/api.d.ts +13 -4
- package/src/ngtsc/metadata/src/api.js +1 -1
- package/src/ngtsc/metadata/src/dts.js +7 -4
- package/src/ngtsc/metadata/src/inheritance.d.ts +1 -1
- package/src/ngtsc/metadata/src/inheritance.js +10 -6
- package/src/ngtsc/metadata/src/property_mapping.d.ts +117 -0
- package/src/ngtsc/metadata/src/property_mapping.js +244 -0
- package/src/ngtsc/metadata/src/util.d.ts +2 -3
- package/src/ngtsc/metadata/src/util.js +9 -9
- package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
- package/src/ngtsc/reflection/src/host.d.ts +1 -1
- package/src/ngtsc/reflection/src/host.js +1 -1
- package/src/ngtsc/reflection/src/type_to_value.js +6 -2
- package/src/ngtsc/scope/src/local.d.ts +1 -0
- package/src/ngtsc/scope/src/local.js +2 -1
- package/src/ngtsc/translator/index.d.ts +1 -1
- package/src/ngtsc/translator/index.js +3 -2
- package/src/ngtsc/translator/src/translator.d.ts +8 -1
- package/src/ngtsc/translator/src/translator.js +185 -111
- package/src/ngtsc/typecheck/api/api.d.ts +3 -1
- package/src/ngtsc/typecheck/api/api.js +1 -1
- package/src/ngtsc/typecheck/diagnostics/index.d.ts +10 -0
- package/src/ngtsc/typecheck/diagnostics/index.js +23 -0
- package/src/ngtsc/typecheck/diagnostics/src/diagnostic.d.ts +33 -0
- package/src/ngtsc/typecheck/diagnostics/src/diagnostic.js +114 -0
- package/src/ngtsc/typecheck/diagnostics/src/id.d.ts +11 -0
- package/src/ngtsc/typecheck/diagnostics/src/id.js +37 -0
- package/src/ngtsc/typecheck/index.d.ts +0 -1
- package/src/ngtsc/typecheck/index.js +3 -5
- package/src/ngtsc/typecheck/src/checker.js +1 -1
- package/src/ngtsc/typecheck/src/context.d.ts +1 -1
- package/src/ngtsc/typecheck/src/context.js +3 -3
- package/src/ngtsc/typecheck/src/diagnostics.d.ts +1 -22
- package/src/ngtsc/typecheck/src/diagnostics.js +5 -96
- package/src/ngtsc/typecheck/src/dom.d.ts +2 -1
- package/src/ngtsc/typecheck/src/dom.js +3 -3
- package/src/ngtsc/typecheck/src/environment.js +4 -4
- package/src/ngtsc/typecheck/src/oob.d.ts +2 -1
- package/src/ngtsc/typecheck/src/oob.js +3 -3
- package/src/ngtsc/typecheck/src/source.js +5 -18
- package/src/ngtsc/typecheck/src/type_check_block.js +49 -95
- package/src/transformers/node_emitter.d.ts +2 -8
- package/src/transformers/node_emitter.js +54 -68
- package/src/transformers/node_emitter_transform.js +8 -8
- package/src/transformers/util.d.ts +6 -0
- package/src/transformers/util.js +11 -2
- package/src/version.js +1 -1
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
/// <amd-module name="@angular/compiler-cli/ngcc/src/packages/source_file_cache" />
|
|
2
|
+
/**
|
|
3
|
+
* @license
|
|
4
|
+
* Copyright Google LLC All Rights Reserved.
|
|
5
|
+
*
|
|
6
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
7
|
+
* found in the LICENSE file at https://angular.io/license
|
|
8
|
+
*/
|
|
9
|
+
import * as ts from 'typescript';
|
|
10
|
+
import { AbsoluteFsPath, FileSystem } from '../../../src/ngtsc/file_system';
|
|
11
|
+
/**
|
|
12
|
+
* A cache that holds on to source files that can be shared for processing all entry-points in a
|
|
13
|
+
* single invocation of ngcc. In particular, the following files are shared across all entry-points
|
|
14
|
+
* through this cache:
|
|
15
|
+
*
|
|
16
|
+
* 1. Default library files such as `lib.dom.d.ts` and `lib.es5.d.ts`. These files don't change
|
|
17
|
+
* and some are very large, so parsing is expensive. Therefore, the parsed `ts.SourceFile`s for
|
|
18
|
+
* the default library files are cached.
|
|
19
|
+
* 2. The typings of @angular scoped packages. The typing files for @angular packages are typically
|
|
20
|
+
* used in the entry-points that ngcc processes, so benefit from a single source file cache.
|
|
21
|
+
* Especially `@angular/core/core.d.ts` is large and expensive to parse repeatedly. In contrast
|
|
22
|
+
* to default library files, we have to account for these files to be invalidated during a single
|
|
23
|
+
* invocation of ngcc, as ngcc will overwrite the .d.ts files during its processing.
|
|
24
|
+
*
|
|
25
|
+
* The lifecycle of this cache corresponds with a single invocation of ngcc. Separate invocations,
|
|
26
|
+
* e.g. the CLI's synchronous module resolution fallback will therefore all have their own cache.
|
|
27
|
+
* This allows for the source file cache to be garbage collected once ngcc processing has completed.
|
|
28
|
+
*/
|
|
29
|
+
export declare class SharedFileCache {
|
|
30
|
+
private fs;
|
|
31
|
+
private sfCache;
|
|
32
|
+
constructor(fs: FileSystem);
|
|
33
|
+
/**
|
|
34
|
+
* Loads a `ts.SourceFile` if the provided `fileName` is deemed appropriate to be cached. To
|
|
35
|
+
* optimize for memory usage, only files that are generally used in all entry-points are cached.
|
|
36
|
+
* If `fileName` is not considered to benefit from caching or the requested file does not exist,
|
|
37
|
+
* then `undefined` is returned.
|
|
38
|
+
*/
|
|
39
|
+
getCachedSourceFile(fileName: string): ts.SourceFile | undefined;
|
|
40
|
+
/**
|
|
41
|
+
* Attempts to load the source file from the cache, or parses the file into a `ts.SourceFile` if
|
|
42
|
+
* it's not yet cached. This method assumes that the file will not be modified for the duration
|
|
43
|
+
* that this cache is valid for. If that assumption does not hold, the `getVolatileCachedFile`
|
|
44
|
+
* method is to be used instead.
|
|
45
|
+
*/
|
|
46
|
+
private getStableCachedFile;
|
|
47
|
+
/**
|
|
48
|
+
* In contrast to `getStableCachedFile`, this method always verifies that the cached source file
|
|
49
|
+
* is the same as what's stored on disk. This is done for files that are expected to change during
|
|
50
|
+
* ngcc's processing, such as @angular scoped packages for which the .d.ts files are overwritten
|
|
51
|
+
* by ngcc. If the contents on disk have changed compared to a previously cached source file, the
|
|
52
|
+
* content from disk is re-parsed and the cache entry is replaced.
|
|
53
|
+
*/
|
|
54
|
+
private getVolatileCachedFile;
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Determines whether the provided path corresponds with a default library file inside of the
|
|
58
|
+
* typescript package.
|
|
59
|
+
*
|
|
60
|
+
* @param absPath The path for which to determine if it corresponds with a default library file.
|
|
61
|
+
* @param fs The filesystem to use for inspecting the path.
|
|
62
|
+
*/
|
|
63
|
+
export declare function isDefaultLibrary(absPath: AbsoluteFsPath, fs: FileSystem): boolean;
|
|
64
|
+
/**
|
|
65
|
+
* Determines whether the provided path corresponds with a .d.ts file inside of an @angular
|
|
66
|
+
* scoped package. This logic only accounts for the .d.ts files in the root, which is sufficient
|
|
67
|
+
* to find the large, flattened entry-point files that benefit from caching.
|
|
68
|
+
*
|
|
69
|
+
* @param absPath The path for which to determine if it corresponds with an @angular .d.ts file.
|
|
70
|
+
* @param fs The filesystem to use for inspecting the path.
|
|
71
|
+
*/
|
|
72
|
+
export declare function isAngularDts(absPath: AbsoluteFsPath, fs: FileSystem): boolean;
|
|
73
|
+
/**
|
|
74
|
+
* A cache for processing a single entry-point. This exists to share `ts.SourceFile`s between the
|
|
75
|
+
* source and typing programs that are created for a single program.
|
|
76
|
+
*/
|
|
77
|
+
export declare class EntryPointFileCache {
|
|
78
|
+
private fs;
|
|
79
|
+
private sharedFileCache;
|
|
80
|
+
private readonly sfCache;
|
|
81
|
+
constructor(fs: FileSystem, sharedFileCache: SharedFileCache);
|
|
82
|
+
/**
|
|
83
|
+
* Returns and caches a parsed `ts.SourceFile` for the provided `fileName`. If the `fileName` is
|
|
84
|
+
* cached in the shared file cache, that result is used. Otherwise, the source file is cached
|
|
85
|
+
* internally. This method returns `undefined` if the requested file does not exist.
|
|
86
|
+
*
|
|
87
|
+
* @param fileName The path of the file to retrieve a source file for.
|
|
88
|
+
* @param languageVersion The language version to use for parsing the file.
|
|
89
|
+
*/
|
|
90
|
+
getCachedSourceFile(fileName: string, languageVersion: ts.ScriptTarget): ts.SourceFile | undefined;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Creates a `ts.ModuleResolutionCache` that uses the provided filesystem for path operations.
|
|
94
|
+
*
|
|
95
|
+
* @param fs The filesystem to use for path operations.
|
|
96
|
+
*/
|
|
97
|
+
export declare function createModuleResolutionCache(fs: FileSystem): ts.ModuleResolutionCache;
|
|
@@ -0,0 +1,207 @@
|
|
|
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/ngcc/src/packages/source_file_cache", ["require", "exports", "typescript"], factory);
|
|
8
|
+
}
|
|
9
|
+
})(function (require, exports) {
|
|
10
|
+
"use strict";
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.createModuleResolutionCache = exports.EntryPointFileCache = exports.isAngularDts = exports.isDefaultLibrary = exports.SharedFileCache = void 0;
|
|
13
|
+
/**
|
|
14
|
+
* @license
|
|
15
|
+
* Copyright Google LLC All Rights Reserved.
|
|
16
|
+
*
|
|
17
|
+
* Use of this source code is governed by an MIT-style license that can be
|
|
18
|
+
* found in the LICENSE file at https://angular.io/license
|
|
19
|
+
*/
|
|
20
|
+
var ts = require("typescript");
|
|
21
|
+
/**
|
|
22
|
+
* A cache that holds on to source files that can be shared for processing all entry-points in a
|
|
23
|
+
* single invocation of ngcc. In particular, the following files are shared across all entry-points
|
|
24
|
+
* through this cache:
|
|
25
|
+
*
|
|
26
|
+
* 1. Default library files such as `lib.dom.d.ts` and `lib.es5.d.ts`. These files don't change
|
|
27
|
+
* and some are very large, so parsing is expensive. Therefore, the parsed `ts.SourceFile`s for
|
|
28
|
+
* the default library files are cached.
|
|
29
|
+
* 2. The typings of @angular scoped packages. The typing files for @angular packages are typically
|
|
30
|
+
* used in the entry-points that ngcc processes, so benefit from a single source file cache.
|
|
31
|
+
* Especially `@angular/core/core.d.ts` is large and expensive to parse repeatedly. In contrast
|
|
32
|
+
* to default library files, we have to account for these files to be invalidated during a single
|
|
33
|
+
* invocation of ngcc, as ngcc will overwrite the .d.ts files during its processing.
|
|
34
|
+
*
|
|
35
|
+
* The lifecycle of this cache corresponds with a single invocation of ngcc. Separate invocations,
|
|
36
|
+
* e.g. the CLI's synchronous module resolution fallback will therefore all have their own cache.
|
|
37
|
+
* This allows for the source file cache to be garbage collected once ngcc processing has completed.
|
|
38
|
+
*/
|
|
39
|
+
var SharedFileCache = /** @class */ (function () {
|
|
40
|
+
function SharedFileCache(fs) {
|
|
41
|
+
this.fs = fs;
|
|
42
|
+
this.sfCache = new Map();
|
|
43
|
+
}
|
|
44
|
+
/**
|
|
45
|
+
* Loads a `ts.SourceFile` if the provided `fileName` is deemed appropriate to be cached. To
|
|
46
|
+
* optimize for memory usage, only files that are generally used in all entry-points are cached.
|
|
47
|
+
* If `fileName` is not considered to benefit from caching or the requested file does not exist,
|
|
48
|
+
* then `undefined` is returned.
|
|
49
|
+
*/
|
|
50
|
+
SharedFileCache.prototype.getCachedSourceFile = function (fileName) {
|
|
51
|
+
var absPath = this.fs.resolve(fileName);
|
|
52
|
+
if (isDefaultLibrary(absPath, this.fs)) {
|
|
53
|
+
return this.getStableCachedFile(absPath);
|
|
54
|
+
}
|
|
55
|
+
else if (isAngularDts(absPath, this.fs)) {
|
|
56
|
+
return this.getVolatileCachedFile(absPath);
|
|
57
|
+
}
|
|
58
|
+
else {
|
|
59
|
+
return undefined;
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
/**
|
|
63
|
+
* Attempts to load the source file from the cache, or parses the file into a `ts.SourceFile` if
|
|
64
|
+
* it's not yet cached. This method assumes that the file will not be modified for the duration
|
|
65
|
+
* that this cache is valid for. If that assumption does not hold, the `getVolatileCachedFile`
|
|
66
|
+
* method is to be used instead.
|
|
67
|
+
*/
|
|
68
|
+
SharedFileCache.prototype.getStableCachedFile = function (absPath) {
|
|
69
|
+
if (!this.sfCache.has(absPath)) {
|
|
70
|
+
var content = readFile(absPath, this.fs);
|
|
71
|
+
if (content === undefined) {
|
|
72
|
+
return undefined;
|
|
73
|
+
}
|
|
74
|
+
var sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);
|
|
75
|
+
this.sfCache.set(absPath, sf);
|
|
76
|
+
}
|
|
77
|
+
return this.sfCache.get(absPath);
|
|
78
|
+
};
|
|
79
|
+
/**
|
|
80
|
+
* In contrast to `getStableCachedFile`, this method always verifies that the cached source file
|
|
81
|
+
* is the same as what's stored on disk. This is done for files that are expected to change during
|
|
82
|
+
* ngcc's processing, such as @angular scoped packages for which the .d.ts files are overwritten
|
|
83
|
+
* by ngcc. If the contents on disk have changed compared to a previously cached source file, the
|
|
84
|
+
* content from disk is re-parsed and the cache entry is replaced.
|
|
85
|
+
*/
|
|
86
|
+
SharedFileCache.prototype.getVolatileCachedFile = function (absPath) {
|
|
87
|
+
var content = readFile(absPath, this.fs);
|
|
88
|
+
if (content === undefined) {
|
|
89
|
+
return undefined;
|
|
90
|
+
}
|
|
91
|
+
if (!this.sfCache.has(absPath) || this.sfCache.get(absPath).text !== content) {
|
|
92
|
+
var sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);
|
|
93
|
+
this.sfCache.set(absPath, sf);
|
|
94
|
+
}
|
|
95
|
+
return this.sfCache.get(absPath);
|
|
96
|
+
};
|
|
97
|
+
return SharedFileCache;
|
|
98
|
+
}());
|
|
99
|
+
exports.SharedFileCache = SharedFileCache;
|
|
100
|
+
var DEFAULT_LIB_PATTERN = ['node_modules', 'typescript', 'lib', /^lib\..+\.d\.ts$/];
|
|
101
|
+
/**
|
|
102
|
+
* Determines whether the provided path corresponds with a default library file inside of the
|
|
103
|
+
* typescript package.
|
|
104
|
+
*
|
|
105
|
+
* @param absPath The path for which to determine if it corresponds with a default library file.
|
|
106
|
+
* @param fs The filesystem to use for inspecting the path.
|
|
107
|
+
*/
|
|
108
|
+
function isDefaultLibrary(absPath, fs) {
|
|
109
|
+
return isFile(absPath, DEFAULT_LIB_PATTERN, fs);
|
|
110
|
+
}
|
|
111
|
+
exports.isDefaultLibrary = isDefaultLibrary;
|
|
112
|
+
var ANGULAR_DTS_PATTERN = ['node_modules', '@angular', /./, /\.d\.ts$/];
|
|
113
|
+
/**
|
|
114
|
+
* Determines whether the provided path corresponds with a .d.ts file inside of an @angular
|
|
115
|
+
* scoped package. This logic only accounts for the .d.ts files in the root, which is sufficient
|
|
116
|
+
* to find the large, flattened entry-point files that benefit from caching.
|
|
117
|
+
*
|
|
118
|
+
* @param absPath The path for which to determine if it corresponds with an @angular .d.ts file.
|
|
119
|
+
* @param fs The filesystem to use for inspecting the path.
|
|
120
|
+
*/
|
|
121
|
+
function isAngularDts(absPath, fs) {
|
|
122
|
+
return isFile(absPath, ANGULAR_DTS_PATTERN, fs);
|
|
123
|
+
}
|
|
124
|
+
exports.isAngularDts = isAngularDts;
|
|
125
|
+
/**
|
|
126
|
+
* Helper function to determine whether a file corresponds with a given pattern of segments.
|
|
127
|
+
*
|
|
128
|
+
* @param path The path for which to determine if it corresponds with the provided segments.
|
|
129
|
+
* @param segments Array of segments; the `path` must have ending segments that match the
|
|
130
|
+
* patterns in this array.
|
|
131
|
+
* @param fs The filesystem to use for inspecting the path.
|
|
132
|
+
*/
|
|
133
|
+
function isFile(path, segments, fs) {
|
|
134
|
+
for (var i = segments.length - 1; i >= 0; i--) {
|
|
135
|
+
var pattern = segments[i];
|
|
136
|
+
var segment = fs.basename(path);
|
|
137
|
+
if (typeof pattern === 'string') {
|
|
138
|
+
if (pattern !== segment) {
|
|
139
|
+
return false;
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
else {
|
|
143
|
+
if (!pattern.test(segment)) {
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
path = fs.dirname(path);
|
|
148
|
+
}
|
|
149
|
+
return true;
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* A cache for processing a single entry-point. This exists to share `ts.SourceFile`s between the
|
|
153
|
+
* source and typing programs that are created for a single program.
|
|
154
|
+
*/
|
|
155
|
+
var EntryPointFileCache = /** @class */ (function () {
|
|
156
|
+
function EntryPointFileCache(fs, sharedFileCache) {
|
|
157
|
+
this.fs = fs;
|
|
158
|
+
this.sharedFileCache = sharedFileCache;
|
|
159
|
+
this.sfCache = new Map();
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Returns and caches a parsed `ts.SourceFile` for the provided `fileName`. If the `fileName` is
|
|
163
|
+
* cached in the shared file cache, that result is used. Otherwise, the source file is cached
|
|
164
|
+
* internally. This method returns `undefined` if the requested file does not exist.
|
|
165
|
+
*
|
|
166
|
+
* @param fileName The path of the file to retrieve a source file for.
|
|
167
|
+
* @param languageVersion The language version to use for parsing the file.
|
|
168
|
+
*/
|
|
169
|
+
EntryPointFileCache.prototype.getCachedSourceFile = function (fileName, languageVersion) {
|
|
170
|
+
var staticSf = this.sharedFileCache.getCachedSourceFile(fileName);
|
|
171
|
+
if (staticSf !== undefined) {
|
|
172
|
+
return staticSf;
|
|
173
|
+
}
|
|
174
|
+
var absPath = this.fs.resolve(fileName);
|
|
175
|
+
if (this.sfCache.has(absPath)) {
|
|
176
|
+
return this.sfCache.get(absPath);
|
|
177
|
+
}
|
|
178
|
+
var content = readFile(absPath, this.fs);
|
|
179
|
+
if (content === undefined) {
|
|
180
|
+
return undefined;
|
|
181
|
+
}
|
|
182
|
+
var sf = ts.createSourceFile(fileName, content, languageVersion);
|
|
183
|
+
this.sfCache.set(absPath, sf);
|
|
184
|
+
return sf;
|
|
185
|
+
};
|
|
186
|
+
return EntryPointFileCache;
|
|
187
|
+
}());
|
|
188
|
+
exports.EntryPointFileCache = EntryPointFileCache;
|
|
189
|
+
function readFile(absPath, fs) {
|
|
190
|
+
if (!fs.exists(absPath) || !fs.stat(absPath).isFile()) {
|
|
191
|
+
return undefined;
|
|
192
|
+
}
|
|
193
|
+
return fs.readFile(absPath);
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Creates a `ts.ModuleResolutionCache` that uses the provided filesystem for path operations.
|
|
197
|
+
*
|
|
198
|
+
* @param fs The filesystem to use for path operations.
|
|
199
|
+
*/
|
|
200
|
+
function createModuleResolutionCache(fs) {
|
|
201
|
+
return ts.createModuleResolutionCache(fs.pwd(), function (fileName) {
|
|
202
|
+
return fs.isCaseSensitive() ? fileName : fileName.toLowerCase();
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
exports.createModuleResolutionCache = createModuleResolutionCache;
|
|
206
|
+
});
|
|
207
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"source_file_cache.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/source_file_cache.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 */\nimport * as ts from 'typescript';\nimport {AbsoluteFsPath, FileSystem} from '../../../src/ngtsc/file_system';\n\n/**\n * A cache that holds on to source files that can be shared for processing all entry-points in a\n * single invocation of ngcc. In particular, the following files are shared across all entry-points\n * through this cache:\n *\n * 1. Default library files such as `lib.dom.d.ts` and `lib.es5.d.ts`. These files don't change\n *    and some are very large, so parsing is expensive. Therefore, the parsed `ts.SourceFile`s for\n *    the default library files are cached.\n * 2. The typings of @angular scoped packages. The typing files for @angular packages are typically\n *    used in the entry-points that ngcc processes, so benefit from a single source file cache.\n *    Especially `@angular/core/core.d.ts` is large and expensive to parse repeatedly. In contrast\n *    to default library files, we have to account for these files to be invalidated during a single\n *    invocation of ngcc, as ngcc will overwrite the .d.ts files during its processing.\n *\n * The lifecycle of this cache corresponds with a single invocation of ngcc. Separate invocations,\n * e.g. the CLI's synchronous module resolution fallback will therefore all have their own cache.\n * This allows for the source file cache to be garbage collected once ngcc processing has completed.\n */\nexport class SharedFileCache {\n  private sfCache = new Map<AbsoluteFsPath, ts.SourceFile>();\n\n  constructor(private fs: FileSystem) {}\n\n  /**\n   * Loads a `ts.SourceFile` if the provided `fileName` is deemed appropriate to be cached. To\n   * optimize for memory usage, only files that are generally used in all entry-points are cached.\n   * If `fileName` is not considered to benefit from caching or the requested file does not exist,\n   * then `undefined` is returned.\n   */\n  getCachedSourceFile(fileName: string): ts.SourceFile|undefined {\n    const absPath = this.fs.resolve(fileName);\n    if (isDefaultLibrary(absPath, this.fs)) {\n      return this.getStableCachedFile(absPath);\n    } else if (isAngularDts(absPath, this.fs)) {\n      return this.getVolatileCachedFile(absPath);\n    } else {\n      return undefined;\n    }\n  }\n\n  /**\n   * Attempts to load the source file from the cache, or parses the file into a `ts.SourceFile` if\n   * it's not yet cached. This method assumes that the file will not be modified for the duration\n   * that this cache is valid for. If that assumption does not hold, the `getVolatileCachedFile`\n   * method is to be used instead.\n   */\n  private getStableCachedFile(absPath: AbsoluteFsPath): ts.SourceFile|undefined {\n    if (!this.sfCache.has(absPath)) {\n      const content = readFile(absPath, this.fs);\n      if (content === undefined) {\n        return undefined;\n      }\n      const sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);\n      this.sfCache.set(absPath, sf);\n    }\n    return this.sfCache.get(absPath)!;\n  }\n\n  /**\n   * In contrast to `getStableCachedFile`, this method always verifies that the cached source file\n   * is the same as what's stored on disk. This is done for files that are expected to change during\n   * ngcc's processing, such as @angular scoped packages for which the .d.ts files are overwritten\n   * by ngcc. If the contents on disk have changed compared to a previously cached source file, the\n   * content from disk is re-parsed and the cache entry is replaced.\n   */\n  private getVolatileCachedFile(absPath: AbsoluteFsPath): ts.SourceFile|undefined {\n    const content = readFile(absPath, this.fs);\n    if (content === undefined) {\n      return undefined;\n    }\n    if (!this.sfCache.has(absPath) || this.sfCache.get(absPath)!.text !== content) {\n      const sf = ts.createSourceFile(absPath, content, ts.ScriptTarget.ES2015);\n      this.sfCache.set(absPath, sf);\n    }\n    return this.sfCache.get(absPath)!;\n  }\n}\n\nconst DEFAULT_LIB_PATTERN = ['node_modules', 'typescript', 'lib', /^lib\\..+\\.d\\.ts$/];\n\n/**\n * Determines whether the provided path corresponds with a default library file inside of the\n * typescript package.\n *\n * @param absPath The path for which to determine if it corresponds with a default library file.\n * @param fs The filesystem to use for inspecting the path.\n */\nexport function isDefaultLibrary(absPath: AbsoluteFsPath, fs: FileSystem): boolean {\n  return isFile(absPath, DEFAULT_LIB_PATTERN, fs);\n}\n\nconst ANGULAR_DTS_PATTERN = ['node_modules', '@angular', /./, /\\.d\\.ts$/];\n\n/**\n * Determines whether the provided path corresponds with a .d.ts file inside of an @angular\n * scoped package. This logic only accounts for the .d.ts files in the root, which is sufficient\n * to find the large, flattened entry-point files that benefit from caching.\n *\n * @param absPath The path for which to determine if it corresponds with an @angular .d.ts file.\n * @param fs The filesystem to use for inspecting the path.\n */\nexport function isAngularDts(absPath: AbsoluteFsPath, fs: FileSystem): boolean {\n  return isFile(absPath, ANGULAR_DTS_PATTERN, fs);\n}\n\n/**\n * Helper function to determine whether a file corresponds with a given pattern of segments.\n *\n * @param path The path for which to determine if it corresponds with the provided segments.\n * @param segments Array of segments; the `path` must have ending segments that match the\n * patterns in this array.\n * @param fs The filesystem to use for inspecting the path.\n */\nfunction isFile(\n    path: AbsoluteFsPath, segments: ReadonlyArray<string|RegExp>, fs: FileSystem): boolean {\n  for (let i = segments.length - 1; i >= 0; i--) {\n    const pattern = segments[i];\n    const segment = fs.basename(path);\n    if (typeof pattern === 'string') {\n      if (pattern !== segment) {\n        return false;\n      }\n    } else {\n      if (!pattern.test(segment)) {\n        return false;\n      }\n    }\n    path = fs.dirname(path);\n  }\n  return true;\n}\n\n/**\n * A cache for processing a single entry-point. This exists to share `ts.SourceFile`s between the\n * source and typing programs that are created for a single program.\n */\nexport class EntryPointFileCache {\n  private readonly sfCache = new Map<AbsoluteFsPath, ts.SourceFile>();\n\n  constructor(private fs: FileSystem, private sharedFileCache: SharedFileCache) {}\n\n  /**\n   * Returns and caches a parsed `ts.SourceFile` for the provided `fileName`. If the `fileName` is\n   * cached in the shared file cache, that result is used. Otherwise, the source file is cached\n   * internally. This method returns `undefined` if the requested file does not exist.\n   *\n   * @param fileName The path of the file to retrieve a source file for.\n   * @param languageVersion The language version to use for parsing the file.\n   */\n  getCachedSourceFile(fileName: string, languageVersion: ts.ScriptTarget): ts.SourceFile|undefined {\n    const staticSf = this.sharedFileCache.getCachedSourceFile(fileName);\n    if (staticSf !== undefined) {\n      return staticSf;\n    }\n\n    const absPath = this.fs.resolve(fileName);\n    if (this.sfCache.has(absPath)) {\n      return this.sfCache.get(absPath);\n    }\n\n    const content = readFile(absPath, this.fs);\n    if (content === undefined) {\n      return undefined;\n    }\n    const sf = ts.createSourceFile(fileName, content, languageVersion);\n    this.sfCache.set(absPath, sf);\n    return sf;\n  }\n}\n\nfunction readFile(absPath: AbsoluteFsPath, fs: FileSystem): string|undefined {\n  if (!fs.exists(absPath) || !fs.stat(absPath).isFile()) {\n    return undefined;\n  }\n  return fs.readFile(absPath);\n}\n\n/**\n * Creates a `ts.ModuleResolutionCache` that uses the provided filesystem for path operations.\n *\n * @param fs The filesystem to use for path operations.\n */\nexport function createModuleResolutionCache(fs: FileSystem): ts.ModuleResolutionCache {\n  return ts.createModuleResolutionCache(fs.pwd(), fileName => {\n    return fs.isCaseSensitive() ? fileName : fileName.toLowerCase();\n  });\n}\n"]}
|
|
@@ -138,10 +138,9 @@
|
|
|
138
138
|
*/
|
|
139
139
|
Renderer.prototype.renderDefinitions = function (sourceFile, compiledClass, imports, annotateForClosureCompiler) {
|
|
140
140
|
var name = this.host.getInternalNameOfClass(compiledClass.declaration);
|
|
141
|
-
var
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
return this.renderStatements(sourceFile, Array.prototype.concat.apply([], statements), imports);
|
|
141
|
+
var leadingComment = annotateForClosureCompiler ? compiler_1.jsDocComment([{ tagName: 'nocollapse' }]) : undefined;
|
|
142
|
+
var statements = compiledClass.compilation.map(function (c) { return createAssignmentStatement(name, c.name, c.initializer, leadingComment); });
|
|
143
|
+
return this.renderStatements(sourceFile, statements, imports);
|
|
145
144
|
};
|
|
146
145
|
/**
|
|
147
146
|
* Render the adjacent statements as source code for the given class.
|
|
@@ -192,14 +191,14 @@
|
|
|
192
191
|
* compiled decorator to be applied to the class.
|
|
193
192
|
* @param analyzedClass The info about the class whose statement we want to create.
|
|
194
193
|
*/
|
|
195
|
-
function
|
|
194
|
+
function createAssignmentStatement(receiverName, propName, initializer, leadingComment) {
|
|
196
195
|
var receiver = new compiler_1.WrappedNodeExpr(receiverName);
|
|
197
|
-
var
|
|
198
|
-
|
|
196
|
+
var statement = new compiler_1.WritePropExpr(receiver, propName, initializer, /* type */ undefined, /* sourceSpan */ undefined)
|
|
197
|
+
.toStmt();
|
|
199
198
|
if (leadingComment !== undefined) {
|
|
200
|
-
|
|
199
|
+
statement.addLeadingComment(leadingComment);
|
|
201
200
|
}
|
|
202
|
-
return
|
|
201
|
+
return statement;
|
|
203
202
|
}
|
|
204
203
|
});
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/rendering/renderer.ts"],"names":[],"mappings":";;;;;;;;;;;;;IAAA;;;;;;OAMG;IACH,8CAAmH;IACnH,6CAAuC;IAKvC,yEAA4D;IAK5D,sEAA2C;IAI3C,oGAAgF;IAChF,oFAAiD;IACjD,wEAAuE;IAEvE;;;;;OAKG;IACH;QACE,kBACY,IAAwB,EAAU,YAAgC,EAClE,EAAc,EAAU,MAAc,EAAU,MAAwB,EACxE,QAAyC;YAAzC,yBAAA,EAAA,eAAyC;YAFzC,SAAI,GAAJ,IAAI,CAAoB;YAAU,iBAAY,GAAZ,YAAY,CAAoB;YAClE,OAAE,GAAF,EAAE,CAAY;YAAU,WAAM,GAAN,MAAM,CAAQ;YAAU,WAAM,GAAN,MAAM,CAAkB;YACxE,aAAQ,GAAR,QAAQ,CAAiC;QAAG,CAAC;QAEzD,gCAAa,GAAb,UACI,kBAAsC,EAAE,oBAA0C,EAClF,2BAAwD;YAF5D,iBAiBC;YAdC,IAAM,aAAa,GAAkB,EAAE,CAAC;YAExC,8BAA8B;YAC9B,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC,OAAO,CAAC,UAAA,UAAU;gBACzD,IAAI,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,IAAI,oBAAoB,CAAC,GAAG,CAAC,UAAU,CAAC;oBAC1E,UAAU,KAAK,KAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE;oBACvC,IAAM,YAAY,GAAG,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBACxD,IAAM,oBAAoB,GAAG,oBAAoB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;oBAClE,aAAa,CAAC,IAAI,OAAlB,aAAa,mBAAS,KAAI,CAAC,UAAU,CACjC,UAAU,EAAE,YAAY,EAAE,oBAAoB,EAAE,2BAA2B,CAAC,GAAE;iBACnF;YACH,CAAC,CAAC,CAAC;YAEH,OAAO,aAAa,CAAC;QACvB,CAAC;QAED;;;;WAIG;QACH,6BAAU,GAAV,UACI,UAAyB,EAAE,YAAoC,EAC/D,oBAAoD,EACpD,2BAAwD;YAH5D,iBA+DC;YA3DC,IAAM,YAAY,GAAG,UAAU,KAAK,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC;YACzD,IAAM,UAAU,GAAG,IAAI,sBAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEpD,IAAI,oBAAoB,EAAE;gBACxB,IAAI,CAAC,YAAY,CAAC,6BAA6B,CAC3C,UAAU,EAAE,oBAAoB,CAAC,UAAU,EAAE,oBAAoB,CAAC,YAAY,CAAC,CAAC;aACrF;YAED,IAAM,aAAa,GAAG,IAAI,0BAAa,CACnC,yBAAiB,CACb,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,EAC9E,yBAAa,CAAC,CAAC;YAEnB,IAAI,YAAY,EAAE;gBAChB,yFAAyF;gBACzF,uBAAuB;gBACvB,IAAM,kBAAkB,GAAG,IAAI,CAAC,yBAAyB,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;gBACxF,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAAC,UAAU,EAAE,kBAAkB,CAAC,CAAC;gBAEnE,YAAY,CAAC,eAAe,CAAC,OAAO,CAAC,UAAA,KAAK;;oBACxC,IAAM,kBAAkB,GAAG,KAAI,CAAC,iBAAiB,CAC7C,YAAY,CAAC,UAAU,EAAE,KAAK,EAAE,aAAa,EAC7C,CAAC,QAAC,KAAI,CAAC,QAAQ,0CAAE,OAAO,CAAC,0BAA0B,CAAA,CAAC,CAAC;oBACzD,KAAI,CAAC,YAAY,CAAC,cAAc,CAAC,UAAU,EAAE,KAAK,EAAE,kBAAkB,CAAC,CAAC;oBAExE,IAAM,kBAAkB,GACpB,KAAI,CAAC,wBAAwB,CAAC,YAAY,CAAC,UAAU,EAAE,KAAK,EAAE,aAAa,CAAC,CAAC;oBACjF,KAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,UAAU,EAAE,KAAK,EAAE,kBAAkB,CAAC,CAAC;gBACjF,CAAC,CAAC,CAAC;gBAEH,IAAI,CAAC,YAAY,IAAI,YAAY,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;oBACtD,IAAI,CAAC,YAAY,CAAC,gBAAgB,CAC9B,UAAU,EAAE,YAAY,CAAC,SAAS,EAAE,aAAa,EAAE,YAAY,CAAC,UAAU,CAAC,CAAC;iBACjF;gBAED,IAAI,CAAC,YAAY,CAAC,YAAY,CAC1B,UAAU,EACV,kBAAkB,CACd,IAAI,CAAC,YAAY,EAAE,YAAY,CAAC,UAAU,EAAE,YAAY,CAAC,YAAY,EAAE,aAAa,CAAC,EACzF,YAAY,CAAC,UAAU,CAAC,CAAC;aAC9B;YAED,sCAAsC;YACtC,IAAI,YAAY,EAAE;gBAChB,IAAM,kBAAkB,GAAG,sBAAc,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAChE,IAAI,CAAC,YAAY,CAAC,UAAU,CACxB,UAAU,EAAE,kBAAkB,EAAE,2BAA2B,EAAE,aAAa,EAAE,UAAU,CAAC,CAAC;aAC7F;YAED,IAAI,YAAY,IAAI,YAAY,EAAE;gBAChC,IAAI,CAAC,YAAY,CAAC,UAAU,CACxB,UAAU,EAAE,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,UAAU,CAAC,CAAC;aAC/E;YAED,IAAI,YAAY,IAAI,oBAAoB,IAAI,YAAY,EAAE;gBACxD,OAAO,gCAAkB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE,EAAE,UAAU,EAAE,UAAU,CAAC,CAAC;aACzE;iBAAM;gBACL,OAAO,EAAE,CAAC;aACX;QACH,CAAC;QAED;;;;;;WAMG;QACK,4CAAyB,GAAjC,UAAkC,OAAwB;YACxD,IAAM,kBAAkB,GAAG,IAAI,2CAAqB,EAAE,CAAC;YACvD,OAAO,CAAC,OAAO,CAAC,UAAA,KAAK;gBACnB,IAAI,KAAK,CAAC,UAAU,KAAK,IAAI,EAAE;oBAC7B,OAAO;iBACR;gBAED,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,UAAA,GAAG;oBAC1B,IAAI,GAAG,CAAC,IAAI,KAAK,IAAI,EAAE;wBACrB,OAAO;qBACR;oBACD,IAAM,cAAc,GAAG,GAAG,CAAC,IAAI,CAAC,MAAO,CAAC;oBACxC,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE;wBAC3C,kBAAkB,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;qBACpD;yBAAM;wBACL,kBAAkB,CAAC,GAAG,CAAC,cAAc,CAAE,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;qBACxD;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;YACH,OAAO,kBAAkB,CAAC;QAC5B,CAAC;QAED;;;;;;;WAOG;QACK,oCAAiB,GAAzB,UACI,UAAyB,EAAE,aAA4B,EAAE,OAAsB,EAC/E,0BAAmC;YACrC,IAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,sBAAsB,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;YACzE,IAAM,UAAU,GAAkB,aAAa,CAAC,WAAW,CAAC,GAAG,CAAC,UAAA,CAAC;gBAC/D,OAAO,0BAA0B,CAC7B,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,WAAW,EAAE,0BAA0B,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;YAC9F,CAAC,CAAC,CAAC;YACH,OAAO,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,UAAU,CAAC,EAAE,OAAO,CAAC,CAAC;QAClG,CAAC;QAED;;;;;;;WAOG;QACK,2CAAwB,GAAhC,UACI,UAAyB,EAAE,aAA4B,EAAE,OAAsB;;YACjF,IAAM,UAAU,GAAgB,EAAE,CAAC;;gBACnC,KAAgB,IAAA,KAAA,iBAAA,aAAa,CAAC,WAAW,CAAA,gBAAA,4BAAE;oBAAtC,IAAM,CAAC,WAAA;oBACV,UAAU,CAAC,IAAI,OAAf,UAAU,mBAAS,CAAC,CAAC,UAAU,GAAE;iBAClC;;;;;;;;;YACD,OAAO,IAAI,CAAC,gBAAgB,CAAC,UAAU,EAAE,UAAU,EAAE,OAAO,CAAC,CAAC;QAChE,CAAC;QAEO,mCAAgB,GAAxB,UACI,UAAyB,EAAE,UAAuB,EAAE,OAAsB;YAD9E,iBAKC;YAHC,IAAM,cAAc,GAAG,UAAC,IAAe;gBACnC,OAAA,KAAI,CAAC,YAAY,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC;YAA3D,CAA2D,CAAC;YAChE,OAAO,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACnD,CAAC;QACH,eAAC;IAAD,CAAC,AAtKD,IAsKC;IAtKY,4BAAQ;IAwKrB;;OAEG;IACH,SAAgB,kBAAkB,CAC9B,SAA6B,EAAE,UAAyB,EAAE,YAA0B,EACpF,OAAsB;QACxB,IAAM,cAAc,GAAG,UAAC,IAAe,IAAK,OAAA,SAAS,CAAC,cAAc,CAAC,IAAI,EAAE,UAAU,EAAE,OAAO,CAAC,EAAnD,CAAmD,CAAC;QAChG,OAAO,YAAY,CAAC,UAAU,CAAC,GAAG,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChE,CAAC;IALD,gDAKC;IAED;;;;OAIG;IACH,SAAS,0BAA0B,CAC/B,YAAgC,EAAE,QAAgB,EAAE,WAAuB,EAC3E,cAAuB;QACzB,IAAM,QAAQ,GAAG,IAAI,0BAAe,CAAC,YAAY,CAAC,CAAC;QACnD,IAAM,UAAU,GACZ,CAAC,IAAI,wBAAa,CACb,QAAQ,EAAE,QAAQ,EAAE,WAAW,EAAE,UAAU,CAAC,SAAS,EAAE,gBAAgB,CAAC,SAAS,CAAC;iBACjF,MAAM,EAAE,CAAC,CAAC;QACpB,IAAI,cAAc,KAAK,SAAS,EAAE;YAChC,UAAU,CAAC,OAAO,CAAC,IAAI,sBAAW,CAAC,cAAc,EAAE,IAAI,CAAC,CAAC,CAAC;SAC3D;QACD,OAAO,UAAU,CAAC;IACpB,CAAC","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 {CommentStmt, ConstantPool, Expression, Statement, WrappedNodeExpr, WritePropExpr} from '@angular/compiler';\nimport MagicString from 'magic-string';\nimport * as ts from 'typescript';\n\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {ImportManager} from '../../../src/ngtsc/translator';\nimport {ParsedConfiguration} from '../../../src/perform_compile';\nimport {PrivateDeclarationsAnalyses} from '../analysis/private_declarations_analyzer';\nimport {SwitchMarkerAnalyses, SwitchMarkerAnalysis} from '../analysis/switch_marker_analyzer';\nimport {CompiledClass, CompiledFile, DecorationAnalyses} from '../analysis/types';\nimport {IMPORT_PREFIX} from '../constants';\nimport {NgccReflectionHost} from '../host/ngcc_host';\nimport {EntryPointBundle} from '../packages/entry_point_bundle';\n\nimport {RedundantDecoratorMap, RenderingFormatter} from './rendering_formatter';\nimport {renderSourceAndMap} from './source_maps';\nimport {FileToWrite, getImportRewriter, stripExtension} from './utils';\n\n/**\n * A base-class for rendering an `AnalyzedFile`.\n *\n * Package formats have output files that must be rendered differently. Concrete sub-classes must\n * implement the `addImports`, `addDefinitions` and `removeDecorators` abstract methods.\n */\nexport class Renderer {\n  constructor(\n      private host: NgccReflectionHost, private srcFormatter: RenderingFormatter,\n      private fs: FileSystem, private logger: Logger, private bundle: EntryPointBundle,\n      private tsConfig: ParsedConfiguration|null = null) {}\n\n  renderProgram(\n      decorationAnalyses: DecorationAnalyses, switchMarkerAnalyses: SwitchMarkerAnalyses,\n      privateDeclarationsAnalyses: PrivateDeclarationsAnalyses): FileToWrite[] {\n    const renderedFiles: FileToWrite[] = [];\n\n    // Transform the source files.\n    this.bundle.src.program.getSourceFiles().forEach(sourceFile => {\n      if (decorationAnalyses.has(sourceFile) || switchMarkerAnalyses.has(sourceFile) ||\n          sourceFile === this.bundle.src.file) {\n        const compiledFile = decorationAnalyses.get(sourceFile);\n        const switchMarkerAnalysis = switchMarkerAnalyses.get(sourceFile);\n        renderedFiles.push(...this.renderFile(\n            sourceFile, compiledFile, switchMarkerAnalysis, privateDeclarationsAnalyses));\n      }\n    });\n\n    return renderedFiles;\n  }\n\n  /**\n   * Render the source code and source-map for an Analyzed file.\n   * @param compiledFile The analyzed file to render.\n   * @param targetPath The absolute path where the rendered file will be written.\n   */\n  renderFile(\n      sourceFile: ts.SourceFile, compiledFile: CompiledFile|undefined,\n      switchMarkerAnalysis: SwitchMarkerAnalysis|undefined,\n      privateDeclarationsAnalyses: PrivateDeclarationsAnalyses): FileToWrite[] {\n    const isEntryPoint = sourceFile === this.bundle.src.file;\n    const outputText = new MagicString(sourceFile.text);\n\n    if (switchMarkerAnalysis) {\n      this.srcFormatter.rewriteSwitchableDeclarations(\n          outputText, switchMarkerAnalysis.sourceFile, switchMarkerAnalysis.declarations);\n    }\n\n    const importManager = new ImportManager(\n        getImportRewriter(\n            this.bundle.src.r3SymbolsFile, this.bundle.isCore, this.bundle.isFlatCore),\n        IMPORT_PREFIX);\n\n    if (compiledFile) {\n      // TODO: remove constructor param metadata and property decorators (we need info from the\n      // handlers to do this)\n      const decoratorsToRemove = this.computeDecoratorsToRemove(compiledFile.compiledClasses);\n      this.srcFormatter.removeDecorators(outputText, decoratorsToRemove);\n\n      compiledFile.compiledClasses.forEach(clazz => {\n        const renderedDefinition = this.renderDefinitions(\n            compiledFile.sourceFile, clazz, importManager,\n            !!this.tsConfig?.options.annotateForClosureCompiler);\n        this.srcFormatter.addDefinitions(outputText, clazz, renderedDefinition);\n\n        const renderedStatements =\n            this.renderAdjacentStatements(compiledFile.sourceFile, clazz, importManager);\n        this.srcFormatter.addAdjacentStatements(outputText, clazz, renderedStatements);\n      });\n\n      if (!isEntryPoint && compiledFile.reexports.length > 0) {\n        this.srcFormatter.addDirectExports(\n            outputText, compiledFile.reexports, importManager, compiledFile.sourceFile);\n      }\n\n      this.srcFormatter.addConstants(\n          outputText,\n          renderConstantPool(\n              this.srcFormatter, compiledFile.sourceFile, compiledFile.constantPool, importManager),\n          compiledFile.sourceFile);\n    }\n\n    // Add exports to the entry-point file\n    if (isEntryPoint) {\n      const entryPointBasePath = stripExtension(this.bundle.src.path);\n      this.srcFormatter.addExports(\n          outputText, entryPointBasePath, privateDeclarationsAnalyses, importManager, sourceFile);\n    }\n\n    if (isEntryPoint || compiledFile) {\n      this.srcFormatter.addImports(\n          outputText, importManager.getAllImports(sourceFile.fileName), sourceFile);\n    }\n\n    if (compiledFile || switchMarkerAnalysis || isEntryPoint) {\n      return renderSourceAndMap(this.logger, this.fs, sourceFile, outputText);\n    } else {\n      return [];\n    }\n  }\n\n  /**\n   * From the given list of classes, computes a map of decorators that should be removed.\n   * The decorators to remove are keyed by their container node, such that we can tell if\n   * we should remove the entire decorator property.\n   * @param classes The list of classes that may have decorators to remove.\n   * @returns A map of decorators to remove, keyed by their container node.\n   */\n  private computeDecoratorsToRemove(classes: CompiledClass[]): RedundantDecoratorMap {\n    const decoratorsToRemove = new RedundantDecoratorMap();\n    classes.forEach(clazz => {\n      if (clazz.decorators === null) {\n        return;\n      }\n\n      clazz.decorators.forEach(dec => {\n        if (dec.node === null) {\n          return;\n        }\n        const decoratorArray = dec.node.parent!;\n        if (!decoratorsToRemove.has(decoratorArray)) {\n          decoratorsToRemove.set(decoratorArray, [dec.node]);\n        } else {\n          decoratorsToRemove.get(decoratorArray)!.push(dec.node);\n        }\n      });\n    });\n    return decoratorsToRemove;\n  }\n\n  /**\n   * Render the definitions as source code for the given class.\n   * @param sourceFile The file containing the class to process.\n   * @param clazz The class whose definitions are to be rendered.\n   * @param compilation The results of analyzing the class - this is used to generate the rendered\n   * definitions.\n   * @param imports An object that tracks the imports that are needed by the rendered definitions.\n   */\n  private renderDefinitions(\n      sourceFile: ts.SourceFile, compiledClass: CompiledClass, imports: ImportManager,\n      annotateForClosureCompiler: boolean): string {\n    const name = this.host.getInternalNameOfClass(compiledClass.declaration);\n    const statements: Statement[][] = compiledClass.compilation.map(c => {\n      return createAssignmentStatements(\n          name, c.name, c.initializer, annotateForClosureCompiler ? '* @nocollapse ' : undefined);\n    });\n    return this.renderStatements(sourceFile, Array.prototype.concat.apply([], statements), imports);\n  }\n\n  /**\n   * Render the adjacent statements as source code for the given class.\n   * @param sourceFile The file containing the class to process.\n   * @param clazz The class whose statements are to be rendered.\n   * @param compilation The results of analyzing the class - this is used to generate the rendered\n   * definitions.\n   * @param imports An object that tracks the imports that are needed by the rendered definitions.\n   */\n  private renderAdjacentStatements(\n      sourceFile: ts.SourceFile, compiledClass: CompiledClass, imports: ImportManager): string {\n    const statements: Statement[] = [];\n    for (const c of compiledClass.compilation) {\n      statements.push(...c.statements);\n    }\n    return this.renderStatements(sourceFile, statements, imports);\n  }\n\n  private renderStatements(\n      sourceFile: ts.SourceFile, statements: Statement[], imports: ImportManager): string {\n    const printStatement = (stmt: Statement) =>\n        this.srcFormatter.printStatement(stmt, sourceFile, imports);\n    return statements.map(printStatement).join('\\n');\n  }\n}\n\n/**\n * Render the constant pool as source code for the given class.\n */\nexport function renderConstantPool(\n    formatter: RenderingFormatter, sourceFile: ts.SourceFile, constantPool: ConstantPool,\n    imports: ImportManager): string {\n  const printStatement = (stmt: Statement) => formatter.printStatement(stmt, sourceFile, imports);\n  return constantPool.statements.map(printStatement).join('\\n');\n}\n\n/**\n * Create an Angular AST statement node that contains the assignment of the\n * compiled decorator to be applied to the class.\n * @param analyzedClass The info about the class whose statement we want to create.\n */\nfunction createAssignmentStatements(\n    receiverName: ts.DeclarationName, propName: string, initializer: Expression,\n    leadingComment?: string): Statement[] {\n  const receiver = new WrappedNodeExpr(receiverName);\n  const statements =\n      [new WritePropExpr(\n           receiver, propName, initializer, /* type */ undefined, /* sourceSpan */ undefined)\n           .toStmt()];\n  if (leadingComment !== undefined) {\n    statements.unshift(new CommentStmt(leadingComment, true));\n  }\n  return statements;\n}\n"]}
|
|
204
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"renderer.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/rendering/renderer.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 */\nimport {ConstantPool, Expression, jsDocComment, LeadingComment, Statement, WrappedNodeExpr, WritePropExpr} from '@angular/compiler';\nimport MagicString from 'magic-string';\nimport * as ts from 'typescript';\n\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {ImportManager} from '../../../src/ngtsc/translator';\nimport {ParsedConfiguration} from '../../../src/perform_compile';\nimport {PrivateDeclarationsAnalyses} from '../analysis/private_declarations_analyzer';\nimport {SwitchMarkerAnalyses, SwitchMarkerAnalysis} from '../analysis/switch_marker_analyzer';\nimport {CompiledClass, CompiledFile, DecorationAnalyses} from '../analysis/types';\nimport {IMPORT_PREFIX} from '../constants';\nimport {NgccReflectionHost} from '../host/ngcc_host';\nimport {EntryPointBundle} from '../packages/entry_point_bundle';\n\nimport {RedundantDecoratorMap, RenderingFormatter} from './rendering_formatter';\nimport {renderSourceAndMap} from './source_maps';\nimport {FileToWrite, getImportRewriter, stripExtension} from './utils';\n\n/**\n * A base-class for rendering an `AnalyzedFile`.\n *\n * Package formats have output files that must be rendered differently. Concrete sub-classes must\n * implement the `addImports`, `addDefinitions` and `removeDecorators` abstract methods.\n */\nexport class Renderer {\n  constructor(\n      private host: NgccReflectionHost, private srcFormatter: RenderingFormatter,\n      private fs: FileSystem, private logger: Logger, private bundle: EntryPointBundle,\n      private tsConfig: ParsedConfiguration|null = null) {}\n\n  renderProgram(\n      decorationAnalyses: DecorationAnalyses, switchMarkerAnalyses: SwitchMarkerAnalyses,\n      privateDeclarationsAnalyses: PrivateDeclarationsAnalyses): FileToWrite[] {\n    const renderedFiles: FileToWrite[] = [];\n\n    // Transform the source files.\n    this.bundle.src.program.getSourceFiles().forEach(sourceFile => {\n      if (decorationAnalyses.has(sourceFile) || switchMarkerAnalyses.has(sourceFile) ||\n          sourceFile === this.bundle.src.file) {\n        const compiledFile = decorationAnalyses.get(sourceFile);\n        const switchMarkerAnalysis = switchMarkerAnalyses.get(sourceFile);\n        renderedFiles.push(...this.renderFile(\n            sourceFile, compiledFile, switchMarkerAnalysis, privateDeclarationsAnalyses));\n      }\n    });\n\n    return renderedFiles;\n  }\n\n  /**\n   * Render the source code and source-map for an Analyzed file.\n   * @param compiledFile The analyzed file to render.\n   * @param targetPath The absolute path where the rendered file will be written.\n   */\n  renderFile(\n      sourceFile: ts.SourceFile, compiledFile: CompiledFile|undefined,\n      switchMarkerAnalysis: SwitchMarkerAnalysis|undefined,\n      privateDeclarationsAnalyses: PrivateDeclarationsAnalyses): FileToWrite[] {\n    const isEntryPoint = sourceFile === this.bundle.src.file;\n    const outputText = new MagicString(sourceFile.text);\n\n    if (switchMarkerAnalysis) {\n      this.srcFormatter.rewriteSwitchableDeclarations(\n          outputText, switchMarkerAnalysis.sourceFile, switchMarkerAnalysis.declarations);\n    }\n\n    const importManager = new ImportManager(\n        getImportRewriter(\n            this.bundle.src.r3SymbolsFile, this.bundle.isCore, this.bundle.isFlatCore),\n        IMPORT_PREFIX);\n\n    if (compiledFile) {\n      // TODO: remove constructor param metadata and property decorators (we need info from the\n      // handlers to do this)\n      const decoratorsToRemove = this.computeDecoratorsToRemove(compiledFile.compiledClasses);\n      this.srcFormatter.removeDecorators(outputText, decoratorsToRemove);\n\n      compiledFile.compiledClasses.forEach(clazz => {\n        const renderedDefinition = this.renderDefinitions(\n            compiledFile.sourceFile, clazz, importManager,\n            !!this.tsConfig?.options.annotateForClosureCompiler);\n        this.srcFormatter.addDefinitions(outputText, clazz, renderedDefinition);\n\n        const renderedStatements =\n            this.renderAdjacentStatements(compiledFile.sourceFile, clazz, importManager);\n        this.srcFormatter.addAdjacentStatements(outputText, clazz, renderedStatements);\n      });\n\n      if (!isEntryPoint && compiledFile.reexports.length > 0) {\n        this.srcFormatter.addDirectExports(\n            outputText, compiledFile.reexports, importManager, compiledFile.sourceFile);\n      }\n\n      this.srcFormatter.addConstants(\n          outputText,\n          renderConstantPool(\n              this.srcFormatter, compiledFile.sourceFile, compiledFile.constantPool, importManager),\n          compiledFile.sourceFile);\n    }\n\n    // Add exports to the entry-point file\n    if (isEntryPoint) {\n      const entryPointBasePath = stripExtension(this.bundle.src.path);\n      this.srcFormatter.addExports(\n          outputText, entryPointBasePath, privateDeclarationsAnalyses, importManager, sourceFile);\n    }\n\n    if (isEntryPoint || compiledFile) {\n      this.srcFormatter.addImports(\n          outputText, importManager.getAllImports(sourceFile.fileName), sourceFile);\n    }\n\n    if (compiledFile || switchMarkerAnalysis || isEntryPoint) {\n      return renderSourceAndMap(this.logger, this.fs, sourceFile, outputText);\n    } else {\n      return [];\n    }\n  }\n\n  /**\n   * From the given list of classes, computes a map of decorators that should be removed.\n   * The decorators to remove are keyed by their container node, such that we can tell if\n   * we should remove the entire decorator property.\n   * @param classes The list of classes that may have decorators to remove.\n   * @returns A map of decorators to remove, keyed by their container node.\n   */\n  private computeDecoratorsToRemove(classes: CompiledClass[]): RedundantDecoratorMap {\n    const decoratorsToRemove = new RedundantDecoratorMap();\n    classes.forEach(clazz => {\n      if (clazz.decorators === null) {\n        return;\n      }\n\n      clazz.decorators.forEach(dec => {\n        if (dec.node === null) {\n          return;\n        }\n        const decoratorArray = dec.node.parent!;\n        if (!decoratorsToRemove.has(decoratorArray)) {\n          decoratorsToRemove.set(decoratorArray, [dec.node]);\n        } else {\n          decoratorsToRemove.get(decoratorArray)!.push(dec.node);\n        }\n      });\n    });\n    return decoratorsToRemove;\n  }\n\n  /**\n   * Render the definitions as source code for the given class.\n   * @param sourceFile The file containing the class to process.\n   * @param clazz The class whose definitions are to be rendered.\n   * @param compilation The results of analyzing the class - this is used to generate the rendered\n   * definitions.\n   * @param imports An object that tracks the imports that are needed by the rendered definitions.\n   */\n  private renderDefinitions(\n      sourceFile: ts.SourceFile, compiledClass: CompiledClass, imports: ImportManager,\n      annotateForClosureCompiler: boolean): string {\n    const name = this.host.getInternalNameOfClass(compiledClass.declaration);\n    const leadingComment =\n        annotateForClosureCompiler ? jsDocComment([{tagName: 'nocollapse'}]) : undefined;\n    const statements: Statement[] = compiledClass.compilation.map(\n        c => createAssignmentStatement(name, c.name, c.initializer, leadingComment));\n    return this.renderStatements(sourceFile, statements, imports);\n  }\n\n  /**\n   * Render the adjacent statements as source code for the given class.\n   * @param sourceFile The file containing the class to process.\n   * @param clazz The class whose statements are to be rendered.\n   * @param compilation The results of analyzing the class - this is used to generate the rendered\n   * definitions.\n   * @param imports An object that tracks the imports that are needed by the rendered definitions.\n   */\n  private renderAdjacentStatements(\n      sourceFile: ts.SourceFile, compiledClass: CompiledClass, imports: ImportManager): string {\n    const statements: Statement[] = [];\n    for (const c of compiledClass.compilation) {\n      statements.push(...c.statements);\n    }\n    return this.renderStatements(sourceFile, statements, imports);\n  }\n\n  private renderStatements(\n      sourceFile: ts.SourceFile, statements: Statement[], imports: ImportManager): string {\n    const printStatement = (stmt: Statement) =>\n        this.srcFormatter.printStatement(stmt, sourceFile, imports);\n    return statements.map(printStatement).join('\\n');\n  }\n}\n\n/**\n * Render the constant pool as source code for the given class.\n */\nexport function renderConstantPool(\n    formatter: RenderingFormatter, sourceFile: ts.SourceFile, constantPool: ConstantPool,\n    imports: ImportManager): string {\n  const printStatement = (stmt: Statement) => formatter.printStatement(stmt, sourceFile, imports);\n  return constantPool.statements.map(printStatement).join('\\n');\n}\n\n/**\n * Create an Angular AST statement node that contains the assignment of the\n * compiled decorator to be applied to the class.\n * @param analyzedClass The info about the class whose statement we want to create.\n */\nfunction createAssignmentStatement(\n    receiverName: ts.DeclarationName, propName: string, initializer: Expression,\n    leadingComment?: LeadingComment): Statement {\n  const receiver = new WrappedNodeExpr(receiverName);\n  const statement =\n      new WritePropExpr(\n          receiver, propName, initializer, /* type */ undefined, /* sourceSpan */ undefined)\n          .toStmt();\n  if (leadingComment !== undefined) {\n    statement.addLeadingComment(leadingComment);\n  }\n  return statement;\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@angular/compiler-cli",
|
|
3
|
-
"version": "10.1.
|
|
3
|
+
"version": "10.1.3",
|
|
4
4
|
"description": "Angular - the compiler CLI for Node.js",
|
|
5
5
|
"main": "index.js",
|
|
6
6
|
"typings": "index.d.ts",
|
|
@@ -26,7 +26,7 @@
|
|
|
26
26
|
"yargs": "15.3.0"
|
|
27
27
|
},
|
|
28
28
|
"peerDependencies": {
|
|
29
|
-
"@angular/compiler": "10.1.
|
|
29
|
+
"@angular/compiler": "10.1.3",
|
|
30
30
|
"typescript": ">=3.9 <4.1"
|
|
31
31
|
},
|
|
32
32
|
"engines": {
|
|
@@ -11,7 +11,7 @@ import { CycleAnalyzer } from '../../cycles';
|
|
|
11
11
|
import { DefaultImportRecorder, ModuleResolver, Reference, ReferenceEmitter } from '../../imports';
|
|
12
12
|
import { DependencyTracker } from '../../incremental/api';
|
|
13
13
|
import { IndexingContext } from '../../indexer';
|
|
14
|
-
import { DirectiveTypeCheckMeta, InjectableClassRegistry, MetadataReader, MetadataRegistry } from '../../metadata';
|
|
14
|
+
import { ClassPropertyMapping, DirectiveTypeCheckMeta, InjectableClassRegistry, MetadataReader, MetadataRegistry } from '../../metadata';
|
|
15
15
|
import { PartialEvaluator } from '../../partial_evaluator';
|
|
16
16
|
import { ClassDeclaration, Decorator, ReflectionHost } from '../../reflection';
|
|
17
17
|
import { ComponentScopeReader, LocalModuleScopeRegistry } from '../../scope';
|
|
@@ -36,6 +36,8 @@ export interface ComponentAnalysisData {
|
|
|
36
36
|
typeCheckMeta: DirectiveTypeCheckMeta;
|
|
37
37
|
template: ParsedTemplateWithSource;
|
|
38
38
|
metadataStmt: Statement | null;
|
|
39
|
+
inputs: ClassPropertyMapping;
|
|
40
|
+
outputs: ClassPropertyMapping;
|
|
39
41
|
/**
|
|
40
42
|
* Providers extracted from the `providers` field of the component annotation which will require
|
|
41
43
|
* an Angular factory definition at runtime.
|
|
@@ -75,6 +77,7 @@ export declare class ComponentDecoratorHandler implements DecoratorHandler<Decor
|
|
|
75
77
|
constructor(reflector: ReflectionHost, evaluator: PartialEvaluator, metaRegistry: MetadataRegistry, metaReader: MetadataReader, scopeReader: ComponentScopeReader, scopeRegistry: LocalModuleScopeRegistry, isCore: boolean, resourceLoader: ResourceLoader, rootDirs: ReadonlyArray<string>, defaultPreserveWhitespaces: boolean, i18nUseExternalIds: boolean, enableI18nLegacyMessageIdFormat: boolean, i18nNormalizeLineEndingsInICUs: boolean | undefined, moduleResolver: ModuleResolver, cycleAnalyzer: CycleAnalyzer, refEmitter: ReferenceEmitter, defaultImportRecorder: DefaultImportRecorder, depTracker: DependencyTracker | null, injectableRegistry: InjectableClassRegistry, annotateForClosureCompiler: boolean);
|
|
76
78
|
private literalCache;
|
|
77
79
|
private elementSchemaRegistry;
|
|
80
|
+
private typeCheckScopes;
|
|
78
81
|
/**
|
|
79
82
|
* During the asynchronous preanalyze phase, it's necessary to parse the template to extract
|
|
80
83
|
* any potential <link> tags which might need to be loaded. This cache ensures that work is not
|