@angular/compiler-cli 11.2.3 → 11.2.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/linker/src/file_linker/partial_linkers/partial_linker_selector.d.ts +1 -1
- package/linker/src/file_linker/partial_linkers/partial_linker_selector.js +4 -4
- package/ngcc/src/analysis/decoration_analyzer.d.ts +2 -1
- package/ngcc/src/analysis/decoration_analyzer.js +6 -4
- package/ngcc/src/analysis/ngcc_trait_compiler.d.ts +3 -2
- package/ngcc/src/analysis/ngcc_trait_compiler.js +3 -2
- package/ngcc/src/analysis/util.js +1 -3
- package/ngcc/src/command_line_options.js +10 -2
- package/ngcc/src/entry_point_finder/utils.js +85 -24
- package/ngcc/src/execution/analyze_entry_points.d.ts +1 -1
- package/ngcc/src/execution/analyze_entry_points.js +18 -9
- package/ngcc/src/execution/create_compile_function.js +5 -5
- package/ngcc/src/execution/tasks/api.d.ts +23 -2
- package/ngcc/src/execution/tasks/api.js +22 -2
- package/ngcc/src/execution/tasks/completion.js +13 -9
- package/ngcc/src/execution/tasks/utils.js +6 -3
- package/ngcc/src/main.js +3 -3
- package/ngcc/src/ngcc_options.d.ts +12 -1
- package/ngcc/src/ngcc_options.js +8 -2
- package/ngcc/src/packages/build_marker.d.ts +1 -1
- package/ngcc/src/packages/build_marker.js +1 -1
- package/ngcc/src/packages/entry_point_bundle.d.ts +4 -2
- package/ngcc/src/packages/entry_point_bundle.js +9 -6
- package/ngcc/src/packages/transformer.js +10 -5
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/component.d.ts +18 -4
- package/src/ngtsc/annotations/src/component.js +137 -23
- package/src/ngtsc/annotations/src/directive.d.ts +22 -3
- package/src/ngtsc/annotations/src/directive.js +122 -5
- package/src/ngtsc/annotations/src/injectable.d.ts +2 -1
- package/src/ngtsc/annotations/src/injectable.js +4 -1
- package/src/ngtsc/annotations/src/ng_module.d.ts +16 -5
- package/src/ngtsc/annotations/src/ng_module.js +121 -39
- package/src/ngtsc/annotations/src/pipe.d.ts +12 -1
- package/src/ngtsc/annotations/src/pipe.js +29 -3
- package/src/ngtsc/annotations/src/util.js +7 -7
- package/src/ngtsc/core/src/compiler.d.ts +0 -5
- package/src/ngtsc/core/src/compiler.js +19 -111
- package/src/ngtsc/core/src/host.d.ts +1 -0
- package/src/ngtsc/core/src/host.js +16 -1
- package/src/ngtsc/cycles/src/imports.d.ts +2 -3
- package/src/ngtsc/cycles/src/imports.js +28 -14
- package/src/ngtsc/diagnostics/src/error_code.d.ts +7 -1
- package/src/ngtsc/diagnostics/src/error_code.js +10 -4
- package/src/ngtsc/imports/index.d.ts +1 -1
- package/src/ngtsc/imports/index.js +1 -1
- package/src/ngtsc/imports/src/alias.d.ts +2 -2
- package/src/ngtsc/imports/src/alias.js +3 -3
- package/src/ngtsc/imports/src/emitter.d.ts +51 -10
- package/src/ngtsc/imports/src/emitter.js +26 -19
- package/src/ngtsc/incremental/api.d.ts +0 -14
- package/src/ngtsc/incremental/api.js +1 -1
- package/src/ngtsc/incremental/semantic_graph/index.d.ts +12 -0
- package/src/ngtsc/incremental/semantic_graph/index.js +34 -0
- package/src/ngtsc/incremental/semantic_graph/src/api.d.ts +98 -0
- package/src/ngtsc/incremental/semantic_graph/src/api.js +51 -0
- package/src/ngtsc/incremental/semantic_graph/src/graph.d.ts +105 -0
- package/src/ngtsc/incremental/semantic_graph/src/graph.js +302 -0
- package/src/ngtsc/incremental/semantic_graph/src/type_parameters.d.ts +30 -0
- package/src/ngtsc/incremental/semantic_graph/src/type_parameters.js +55 -0
- package/src/ngtsc/incremental/semantic_graph/src/util.d.ts +29 -0
- package/src/ngtsc/incremental/semantic_graph/src/util.js +111 -0
- package/src/ngtsc/incremental/src/dependency_tracking.d.ts +0 -3
- package/src/ngtsc/incremental/src/dependency_tracking.js +9 -50
- package/src/ngtsc/incremental/src/state.d.ts +2 -1
- package/src/ngtsc/incremental/src/state.js +61 -16
- package/src/ngtsc/modulewithproviders/src/scanner.js +2 -2
- package/src/ngtsc/scope/src/dependency.js +1 -2
- package/src/ngtsc/scope/src/local.d.ts +0 -13
- package/src/ngtsc/scope/src/local.js +2 -16
- package/src/ngtsc/transform/src/api.d.ts +16 -2
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.d.ts +7 -4
- package/src/ngtsc/transform/src/compilation.js +25 -8
- package/src/ngtsc/transform/src/trait.d.ts +14 -11
- package/src/ngtsc/transform/src/trait.js +7 -3
- package/src/ngtsc/typecheck/api/api.d.ts +27 -0
- package/src/ngtsc/typecheck/api/api.js +1 -1
- package/src/ngtsc/typecheck/src/context.js +25 -28
- package/src/ngtsc/typecheck/src/environment.d.ts +1 -1
- package/src/ngtsc/typecheck/src/environment.js +3 -3
- package/src/ngtsc/typecheck/src/oob.d.ts +6 -0
- package/src/ngtsc/typecheck/src/oob.js +36 -1
- package/src/ngtsc/typecheck/src/type_check_block.js +107 -23
- package/src/ngtsc/typecheck/src/type_check_file.d.ts +1 -1
- package/src/ngtsc/typecheck/src/type_check_file.js +3 -3
- package/src/perform_compile.d.ts +1 -2
- package/src/perform_compile.js +58 -47
- package/src/transformers/node_emitter.js +1 -2
- package/src/version.js +1 -1
|
@@ -39,29 +39,86 @@
|
|
|
39
39
|
* @param pathMappings Path mapping configuration, from which to extract additional base-paths.
|
|
40
40
|
*/
|
|
41
41
|
function getBasePaths(logger, sourceDirectory, pathMappings) {
|
|
42
|
+
var e_1, _a, e_2, _b, e_3, _c;
|
|
42
43
|
var fs = file_system_1.getFileSystem();
|
|
43
44
|
var basePaths = [sourceDirectory];
|
|
44
45
|
if (pathMappings) {
|
|
45
|
-
var
|
|
46
|
-
if (fs.isRoot(
|
|
47
|
-
logger.warn("The provided pathMappings baseUrl is the root path " +
|
|
46
|
+
var baseUrl = fs.resolve(pathMappings.baseUrl);
|
|
47
|
+
if (fs.isRoot(baseUrl)) {
|
|
48
|
+
logger.warn("The provided pathMappings baseUrl is the root path " + baseUrl + ".\n" +
|
|
48
49
|
"This is likely to mess up how ngcc finds entry-points and is probably not correct.\n" +
|
|
49
50
|
"Please check your path mappings configuration such as in the tsconfig.json file.");
|
|
50
51
|
}
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
52
|
+
try {
|
|
53
|
+
for (var _d = tslib_1.__values(Object.values(pathMappings.paths)), _e = _d.next(); !_e.done; _e = _d.next()) {
|
|
54
|
+
var paths = _e.value;
|
|
55
|
+
try {
|
|
56
|
+
for (var paths_1 = (e_2 = void 0, tslib_1.__values(paths)), paths_1_1 = paths_1.next(); !paths_1_1.done; paths_1_1 = paths_1.next()) {
|
|
57
|
+
var path = paths_1_1.value;
|
|
58
|
+
var foundMatch = false;
|
|
59
|
+
// We only want base paths that exist and are not files
|
|
60
|
+
var _f = extractPathPrefix(path), prefix = _f.prefix, hasWildcard = _f.hasWildcard;
|
|
61
|
+
var basePath = fs.resolve(baseUrl, prefix);
|
|
62
|
+
if (fs.exists(basePath) && fs.stat(basePath).isFile()) {
|
|
63
|
+
basePath = fs.dirname(basePath);
|
|
64
|
+
}
|
|
65
|
+
if (fs.exists(basePath)) {
|
|
66
|
+
// The `basePath` is itself a directory
|
|
67
|
+
basePaths.push(basePath);
|
|
68
|
+
foundMatch = true;
|
|
69
|
+
}
|
|
70
|
+
if (hasWildcard) {
|
|
71
|
+
// The path contains a wildcard (`*`) so also try searching for directories that start
|
|
72
|
+
// with the wildcard prefix path segment.
|
|
73
|
+
var wildcardContainer = fs.dirname(basePath);
|
|
74
|
+
var wildcardPrefix = fs.basename(basePath);
|
|
75
|
+
if (isExistingDirectory(fs, wildcardContainer)) {
|
|
76
|
+
var candidates = fs.readdir(wildcardContainer);
|
|
77
|
+
try {
|
|
78
|
+
for (var candidates_1 = (e_3 = void 0, tslib_1.__values(candidates)), candidates_1_1 = candidates_1.next(); !candidates_1_1.done; candidates_1_1 = candidates_1.next()) {
|
|
79
|
+
var candidate = candidates_1_1.value;
|
|
80
|
+
if (candidate.startsWith(wildcardPrefix)) {
|
|
81
|
+
var candidatePath = fs.resolve(wildcardContainer, candidate);
|
|
82
|
+
if (isExistingDirectory(fs, candidatePath)) {
|
|
83
|
+
foundMatch = true;
|
|
84
|
+
basePaths.push(candidatePath);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
catch (e_3_1) { e_3 = { error: e_3_1 }; }
|
|
90
|
+
finally {
|
|
91
|
+
try {
|
|
92
|
+
if (candidates_1_1 && !candidates_1_1.done && (_c = candidates_1.return)) _c.call(candidates_1);
|
|
93
|
+
}
|
|
94
|
+
finally { if (e_3) throw e_3.error; }
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
if (!foundMatch) {
|
|
99
|
+
// We neither found a direct match (i.e. `basePath` is an existing directory) nor a
|
|
100
|
+
// directory that starts with a wildcard prefix.
|
|
101
|
+
logger.debug("The basePath \"" + basePath + "\" computed from baseUrl \"" + baseUrl + "\" and path mapping \"" + path + "\" does not exist in the file-system.\n" +
|
|
102
|
+
"It will not be scanned for entry-points.");
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
107
|
+
finally {
|
|
108
|
+
try {
|
|
109
|
+
if (paths_1_1 && !paths_1_1.done && (_b = paths_1.return)) _b.call(paths_1);
|
|
110
|
+
}
|
|
111
|
+
finally { if (e_2) throw e_2.error; }
|
|
112
|
+
}
|
|
59
113
|
}
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
114
|
+
}
|
|
115
|
+
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
116
|
+
finally {
|
|
117
|
+
try {
|
|
118
|
+
if (_e && !_e.done && (_a = _d.return)) _a.call(_d);
|
|
63
119
|
}
|
|
64
|
-
|
|
120
|
+
finally { if (e_1) throw e_1.error; }
|
|
121
|
+
}
|
|
65
122
|
}
|
|
66
123
|
var dedupedBasePaths = dedupePaths(fs, basePaths);
|
|
67
124
|
// We want to ensure that the `sourceDirectory` is included when it is a node_modules folder.
|
|
@@ -73,13 +130,17 @@
|
|
|
73
130
|
return dedupedBasePaths;
|
|
74
131
|
}
|
|
75
132
|
exports.getBasePaths = getBasePaths;
|
|
133
|
+
function isExistingDirectory(fs, path) {
|
|
134
|
+
return fs.exists(path) && fs.stat(path).isDirectory();
|
|
135
|
+
}
|
|
76
136
|
/**
|
|
77
137
|
* Extract everything in the `path` up to the first `*`.
|
|
78
138
|
* @param path The path to parse.
|
|
79
|
-
* @returns The extracted prefix
|
|
139
|
+
* @returns The extracted prefix and a flag to indicate whether there was a wildcard `*`.
|
|
80
140
|
*/
|
|
81
141
|
function extractPathPrefix(path) {
|
|
82
|
-
|
|
142
|
+
var _a = tslib_1.__read(path.split('*', 2), 2), prefix = _a[0], rest = _a[1];
|
|
143
|
+
return { prefix: prefix, hasWildcard: rest !== undefined };
|
|
83
144
|
}
|
|
84
145
|
/**
|
|
85
146
|
* Run a task and track how long it takes.
|
|
@@ -105,20 +166,20 @@
|
|
|
105
166
|
* one of the base paths.)
|
|
106
167
|
*/
|
|
107
168
|
function dedupePaths(fs, paths) {
|
|
108
|
-
var
|
|
169
|
+
var e_4, _a;
|
|
109
170
|
var root = { children: new Map() };
|
|
110
171
|
try {
|
|
111
|
-
for (var
|
|
112
|
-
var path =
|
|
172
|
+
for (var paths_2 = tslib_1.__values(paths), paths_2_1 = paths_2.next(); !paths_2_1.done; paths_2_1 = paths_2.next()) {
|
|
173
|
+
var path = paths_2_1.value;
|
|
113
174
|
addPath(fs, root, path);
|
|
114
175
|
}
|
|
115
176
|
}
|
|
116
|
-
catch (
|
|
177
|
+
catch (e_4_1) { e_4 = { error: e_4_1 }; }
|
|
117
178
|
finally {
|
|
118
179
|
try {
|
|
119
|
-
if (
|
|
180
|
+
if (paths_2_1 && !paths_2_1.done && (_a = paths_2.return)) _a.call(paths_2);
|
|
120
181
|
}
|
|
121
|
-
finally { if (
|
|
182
|
+
finally { if (e_4) throw e_4.error; }
|
|
122
183
|
}
|
|
123
184
|
return flattenTree(root);
|
|
124
185
|
}
|
|
@@ -170,4 +231,4 @@
|
|
|
170
231
|
node.path = path;
|
|
171
232
|
}
|
|
172
233
|
});
|
|
173
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/entry_point_finder/utils.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 {AbsoluteFsPath, getFileSystem, PathManipulation} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {PathMappings} from '../path_mappings';\n\n/**\n * Extract all the base-paths that we need to search for entry-points.\n *\n * This always contains the standard base-path (`sourceDirectory`).\n * But it also parses the `paths` mappings object to guess additional base-paths.\n *\n * For example:\n *\n * ```\n * getBasePaths('/node_modules', {baseUrl: '/dist', paths: {'*': ['lib/*', 'lib/generated/*']}})\n * > ['/node_modules', '/dist/lib']\n * ```\n *\n * Notice that `'/dist'` is not included as there is no `'*'` path,\n * and `'/dist/lib/generated'` is not included as it is covered by `'/dist/lib'`.\n *\n * @param sourceDirectory The standard base-path (e.g. node_modules).\n * @param pathMappings Path mapping configuration, from which to extract additional base-paths.\n */\nexport function getBasePaths(\n    logger: Logger, sourceDirectory: AbsoluteFsPath,\n    pathMappings: PathMappings|undefined): AbsoluteFsPath[] {\n  const fs = getFileSystem();\n  const basePaths = [sourceDirectory];\n  if (pathMappings) {\n    const baseUrl = fs.resolve(pathMappings.baseUrl);\n    if (fs.isRoot(baseUrl)) {\n      logger.warn(\n          `The provided pathMappings baseUrl is the root path ${baseUrl}.\\n` +\n          `This is likely to mess up how ngcc finds entry-points and is probably not correct.\\n` +\n          `Please check your path mappings configuration such as in the tsconfig.json file.`);\n    }\n    Object.values(pathMappings.paths).forEach(paths => paths.forEach(path => {\n      // We only want base paths that exist and are not files\n      let basePath = fs.resolve(baseUrl, extractPathPrefix(path));\n      if (fs.exists(basePath) && fs.stat(basePath).isFile()) {\n        basePath = fs.dirname(basePath);\n      }\n      if (fs.exists(basePath)) {\n        basePaths.push(basePath);\n      } else {\n        logger.debug(\n            `The basePath \"${basePath}\" computed from baseUrl \"${baseUrl}\" and path mapping \"${\n                path}\" does not exist in the file-system.\\n` +\n            `It will not be scanned for entry-points.`);\n      }\n    }));\n  }\n\n  const dedupedBasePaths = dedupePaths(fs, basePaths);\n\n  // We want to ensure that the `sourceDirectory` is included when it is a node_modules folder.\n  // Otherwise our entry-point finding algorithm would fail to walk that folder.\n  if (fs.basename(sourceDirectory) === 'node_modules' &&\n      !dedupedBasePaths.includes(sourceDirectory)) {\n    dedupedBasePaths.unshift(sourceDirectory);\n  }\n\n  return dedupedBasePaths;\n}\n\n/**\n * Extract everything in the `path` up to the first `*`.\n * @param path The path to parse.\n * @returns The extracted prefix.\n */\nfunction extractPathPrefix(path: string) {\n  return path.split('*', 1)[0];\n}\n\n/**\n * Run a task and track how long it takes.\n *\n * @param task The task whose duration we are tracking.\n * @param log The function to call with the duration of the task.\n * @returns The result of calling `task`.\n */\nexport function trackDuration<T = void>(task: () => T extends Promise<unknown>? never : T,\n                                                              log: (duration: number) => void): T {\n  const startTime = Date.now();\n  const result = task();\n  const duration = Math.round((Date.now() - startTime) / 100) / 10;\n  log(duration);\n  return result;\n}\n\n/**\n * Remove paths that are contained by other paths.\n *\n * For example:\n * Given `['a/b/c', 'a/b/x', 'a/b', 'd/e', 'd/f']` we will end up with `['a/b', 'd/e', 'd/f]`.\n * (Note that we do not get `d` even though `d/e` and `d/f` share a base directory, since `d` is not\n * one of the base paths.)\n */\nfunction dedupePaths(fs: PathManipulation, paths: AbsoluteFsPath[]): AbsoluteFsPath[] {\n  const root: Node = {children: new Map()};\n  for (const path of paths) {\n    addPath(fs, root, path);\n  }\n  return flattenTree(root);\n}\n\n/**\n * Add a path (defined by the `segments`) to the current `node` in the tree.\n */\nfunction addPath(fs: PathManipulation, root: Node, path: AbsoluteFsPath): void {\n  let node = root;\n  if (!fs.isRoot(path)) {\n    const segments = path.split('/');\n    for (let index = 0; index < segments.length; index++) {\n      if (isLeaf(node)) {\n        // We hit a leaf so don't bother processing any more of the path\n        return;\n      }\n      // This is not the end of the path continue to process the rest of this path.\n      const next = segments[index];\n      if (!node.children.has(next)) {\n        node.children.set(next, {children: new Map()});\n      }\n      node = node.children.get(next)!;\n    }\n  }\n  // This path has finished so convert this node to a leaf\n  convertToLeaf(node, path);\n}\n\n/**\n * Flatten the tree of nodes back into an array of absolute paths.\n */\nfunction flattenTree(root: Node): AbsoluteFsPath[] {\n  const paths: AbsoluteFsPath[] = [];\n  const nodes: Node[] = [root];\n  for (let index = 0; index < nodes.length; index++) {\n    const node = nodes[index];\n    if (isLeaf(node)) {\n      // We found a leaf so store the currentPath\n      paths.push(node.path);\n    } else {\n      node.children.forEach(value => nodes.push(value));\n    }\n  }\n  return paths;\n}\n\nfunction isLeaf(node: Node): node is Leaf {\n  return node.path !== undefined;\n}\n\nfunction convertToLeaf(node: Node, path: AbsoluteFsPath) {\n  node.path = path;\n}\n\ninterface Node {\n  children: Map<string, Node>;\n  path?: AbsoluteFsPath;\n}\n\ntype Leaf = Required<Node>;\n"]}
|
|
234
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/entry_point_finder/utils.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 {AbsoluteFsPath, getFileSystem, PathManipulation, ReadonlyFileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {PathMappings} from '../path_mappings';\n\n/**\n * Extract all the base-paths that we need to search for entry-points.\n *\n * This always contains the standard base-path (`sourceDirectory`).\n * But it also parses the `paths` mappings object to guess additional base-paths.\n *\n * For example:\n *\n * ```\n * getBasePaths('/node_modules', {baseUrl: '/dist', paths: {'*': ['lib/*', 'lib/generated/*']}})\n * > ['/node_modules', '/dist/lib']\n * ```\n *\n * Notice that `'/dist'` is not included as there is no `'*'` path,\n * and `'/dist/lib/generated'` is not included as it is covered by `'/dist/lib'`.\n *\n * @param sourceDirectory The standard base-path (e.g. node_modules).\n * @param pathMappings Path mapping configuration, from which to extract additional base-paths.\n */\nexport function getBasePaths(\n    logger: Logger, sourceDirectory: AbsoluteFsPath,\n    pathMappings: PathMappings|undefined): AbsoluteFsPath[] {\n  const fs = getFileSystem();\n  const basePaths = [sourceDirectory];\n  if (pathMappings) {\n    const baseUrl = fs.resolve(pathMappings.baseUrl);\n    if (fs.isRoot(baseUrl)) {\n      logger.warn(\n          `The provided pathMappings baseUrl is the root path ${baseUrl}.\\n` +\n          `This is likely to mess up how ngcc finds entry-points and is probably not correct.\\n` +\n          `Please check your path mappings configuration such as in the tsconfig.json file.`);\n    }\n    for (const paths of Object.values(pathMappings.paths)) {\n      for (const path of paths) {\n        let foundMatch = false;\n\n        // We only want base paths that exist and are not files\n        const {prefix, hasWildcard} = extractPathPrefix(path);\n        let basePath = fs.resolve(baseUrl, prefix);\n        if (fs.exists(basePath) && fs.stat(basePath).isFile()) {\n          basePath = fs.dirname(basePath);\n        }\n\n        if (fs.exists(basePath)) {\n          // The `basePath` is itself a directory\n          basePaths.push(basePath);\n          foundMatch = true;\n        }\n\n        if (hasWildcard) {\n          // The path contains a wildcard (`*`) so also try searching for directories that start\n          // with the wildcard prefix path segment.\n          const wildcardContainer = fs.dirname(basePath);\n          const wildcardPrefix = fs.basename(basePath);\n          if (isExistingDirectory(fs, wildcardContainer)) {\n            const candidates = fs.readdir(wildcardContainer);\n            for (const candidate of candidates) {\n              if (candidate.startsWith(wildcardPrefix)) {\n                const candidatePath = fs.resolve(wildcardContainer, candidate);\n                if (isExistingDirectory(fs, candidatePath)) {\n                  foundMatch = true;\n                  basePaths.push(candidatePath);\n                }\n              }\n            }\n          }\n        }\n\n        if (!foundMatch) {\n          // We neither found a direct match (i.e. `basePath` is an existing directory) nor a\n          // directory that starts with a wildcard prefix.\n          logger.debug(\n              `The basePath \"${basePath}\" computed from baseUrl \"${baseUrl}\" and path mapping \"${\n                  path}\" does not exist in the file-system.\\n` +\n              `It will not be scanned for entry-points.`);\n        }\n      }\n    }\n  }\n\n  const dedupedBasePaths = dedupePaths(fs, basePaths);\n\n  // We want to ensure that the `sourceDirectory` is included when it is a node_modules folder.\n  // Otherwise our entry-point finding algorithm would fail to walk that folder.\n  if (fs.basename(sourceDirectory) === 'node_modules' &&\n      !dedupedBasePaths.includes(sourceDirectory)) {\n    dedupedBasePaths.unshift(sourceDirectory);\n  }\n\n  return dedupedBasePaths;\n}\n\nfunction isExistingDirectory(fs: ReadonlyFileSystem, path: AbsoluteFsPath): boolean {\n  return fs.exists(path) && fs.stat(path).isDirectory();\n}\n\n/**\n * Extract everything in the `path` up to the first `*`.\n * @param path The path to parse.\n * @returns The extracted prefix and a flag to indicate whether there was a wildcard `*`.\n */\nfunction extractPathPrefix(path: string): {prefix: string, hasWildcard: boolean} {\n  const [prefix, rest] = path.split('*', 2);\n  return {prefix, hasWildcard: rest !== undefined};\n}\n\n/**\n * Run a task and track how long it takes.\n *\n * @param task The task whose duration we are tracking.\n * @param log The function to call with the duration of the task.\n * @returns The result of calling `task`.\n */\nexport function trackDuration<T = void>(task: () => T extends Promise<unknown>? never : T,\n                                                              log: (duration: number) => void): T {\n  const startTime = Date.now();\n  const result = task();\n  const duration = Math.round((Date.now() - startTime) / 100) / 10;\n  log(duration);\n  return result;\n}\n\n/**\n * Remove paths that are contained by other paths.\n *\n * For example:\n * Given `['a/b/c', 'a/b/x', 'a/b', 'd/e', 'd/f']` we will end up with `['a/b', 'd/e', 'd/f]`.\n * (Note that we do not get `d` even though `d/e` and `d/f` share a base directory, since `d` is not\n * one of the base paths.)\n */\nfunction dedupePaths(fs: PathManipulation, paths: AbsoluteFsPath[]): AbsoluteFsPath[] {\n  const root: Node = {children: new Map()};\n  for (const path of paths) {\n    addPath(fs, root, path);\n  }\n  return flattenTree(root);\n}\n\n/**\n * Add a path (defined by the `segments`) to the current `node` in the tree.\n */\nfunction addPath(fs: PathManipulation, root: Node, path: AbsoluteFsPath): void {\n  let node = root;\n  if (!fs.isRoot(path)) {\n    const segments = path.split('/');\n    for (let index = 0; index < segments.length; index++) {\n      if (isLeaf(node)) {\n        // We hit a leaf so don't bother processing any more of the path\n        return;\n      }\n      // This is not the end of the path continue to process the rest of this path.\n      const next = segments[index];\n      if (!node.children.has(next)) {\n        node.children.set(next, {children: new Map()});\n      }\n      node = node.children.get(next)!;\n    }\n  }\n  // This path has finished so convert this node to a leaf\n  convertToLeaf(node, path);\n}\n\n/**\n * Flatten the tree of nodes back into an array of absolute paths.\n */\nfunction flattenTree(root: Node): AbsoluteFsPath[] {\n  const paths: AbsoluteFsPath[] = [];\n  const nodes: Node[] = [root];\n  for (let index = 0; index < nodes.length; index++) {\n    const node = nodes[index];\n    if (isLeaf(node)) {\n      // We found a leaf so store the currentPath\n      paths.push(node.path);\n    } else {\n      node.children.forEach(value => nodes.push(value));\n    }\n  }\n  return paths;\n}\n\nfunction isLeaf(node: Node): node is Leaf {\n  return node.path !== undefined;\n}\n\nfunction convertToLeaf(node: Node, path: AbsoluteFsPath) {\n  node.path = path;\n}\n\ninterface Node {\n  children: Map<string, Node>;\n  path?: AbsoluteFsPath;\n}\n\ntype Leaf = Required<Node>;\n"]}
|
|
@@ -7,4 +7,4 @@ import { AnalyzeEntryPointsFn } from './api';
|
|
|
7
7
|
/**
|
|
8
8
|
* Create the function for performing the analysis of the entry-points.
|
|
9
9
|
*/
|
|
10
|
-
export declare function getAnalyzeEntryPointsFn(logger: Logger, finder: EntryPointFinder, fileSystem: FileSystem, supportedPropertiesToConsider: EntryPointJsonProperty[], compileAllFormats: boolean, propertiesToConsider: string[], inParallel: boolean): AnalyzeEntryPointsFn;
|
|
10
|
+
export declare function getAnalyzeEntryPointsFn(logger: Logger, finder: EntryPointFinder, fileSystem: FileSystem, supportedPropertiesToConsider: EntryPointJsonProperty[], typingsOnly: boolean, compileAllFormats: boolean, propertiesToConsider: string[], inParallel: boolean): AnalyzeEntryPointsFn;
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
if (v !== undefined) module.exports = v;
|
|
5
5
|
}
|
|
6
6
|
else if (typeof define === "function" && define.amd) {
|
|
7
|
-
define("@angular/compiler-cli/ngcc/src/execution/analyze_entry_points", ["require", "exports", "tslib", "@angular/compiler-cli/ngcc/src/execution/tasks/queues/parallel_task_queue", "@angular/compiler-cli/ngcc/src/execution/tasks/queues/serial_task_queue", "@angular/compiler-cli/ngcc/src/execution/tasks/utils", "@angular/compiler-cli/ngcc/src/packages/build_marker", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/writing/cleaning/package_cleaner"], factory);
|
|
7
|
+
define("@angular/compiler-cli/ngcc/src/execution/analyze_entry_points", ["require", "exports", "tslib", "@angular/compiler-cli/ngcc/src/execution/tasks/queues/parallel_task_queue", "@angular/compiler-cli/ngcc/src/execution/tasks/queues/serial_task_queue", "@angular/compiler-cli/ngcc/src/execution/tasks/utils", "@angular/compiler-cli/ngcc/src/packages/build_marker", "@angular/compiler-cli/ngcc/src/packages/entry_point", "@angular/compiler-cli/ngcc/src/writing/cleaning/package_cleaner", "@angular/compiler-cli/ngcc/src/execution/tasks/api"], factory);
|
|
8
8
|
}
|
|
9
9
|
})(function (require, exports) {
|
|
10
10
|
"use strict";
|
|
@@ -17,10 +17,11 @@
|
|
|
17
17
|
var build_marker_1 = require("@angular/compiler-cli/ngcc/src/packages/build_marker");
|
|
18
18
|
var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
|
|
19
19
|
var package_cleaner_1 = require("@angular/compiler-cli/ngcc/src/writing/cleaning/package_cleaner");
|
|
20
|
+
var api_1 = require("@angular/compiler-cli/ngcc/src/execution/tasks/api");
|
|
20
21
|
/**
|
|
21
22
|
* Create the function for performing the analysis of the entry-points.
|
|
22
23
|
*/
|
|
23
|
-
function getAnalyzeEntryPointsFn(logger, finder, fileSystem, supportedPropertiesToConsider, compileAllFormats, propertiesToConsider, inParallel) {
|
|
24
|
+
function getAnalyzeEntryPointsFn(logger, finder, fileSystem, supportedPropertiesToConsider, typingsOnly, compileAllFormats, propertiesToConsider, inParallel) {
|
|
24
25
|
return function () {
|
|
25
26
|
var e_1, _a, e_2, _b;
|
|
26
27
|
logger.debug('Analyzing entry-points...');
|
|
@@ -40,9 +41,7 @@
|
|
|
40
41
|
for (var entryPoints_1 = tslib_1.__values(entryPoints), entryPoints_1_1 = entryPoints_1.next(); !entryPoints_1_1.done; entryPoints_1_1 = entryPoints_1.next()) {
|
|
41
42
|
var entryPoint = entryPoints_1_1.value;
|
|
42
43
|
var packageJson = entryPoint.packageJson;
|
|
43
|
-
var
|
|
44
|
-
var _c = getPropertiesToProcess(packageJson, supportedPropertiesToConsider, compileAllFormats), propertiesToProcess = _c.propertiesToProcess, equivalentPropertiesMap = _c.equivalentPropertiesMap;
|
|
45
|
-
var processDts = !hasProcessedTypings;
|
|
44
|
+
var _c = getPropertiesToProcess(packageJson, supportedPropertiesToConsider, compileAllFormats, typingsOnly), propertiesToProcess = _c.propertiesToProcess, equivalentPropertiesMap = _c.equivalentPropertiesMap;
|
|
46
45
|
if (propertiesToProcess.length === 0) {
|
|
47
46
|
// This entry-point is unprocessable (i.e. there is no format property that is of interest
|
|
48
47
|
// and can be processed). This will result in an error, but continue looping over
|
|
@@ -51,6 +50,15 @@
|
|
|
51
50
|
unprocessableEntryPointPaths.push(entryPoint.path);
|
|
52
51
|
continue;
|
|
53
52
|
}
|
|
53
|
+
var hasProcessedTypings = build_marker_1.hasBeenProcessed(packageJson, 'typings');
|
|
54
|
+
if (hasProcessedTypings && typingsOnly) {
|
|
55
|
+
// Typings for this entry-point have already been processed and we're in typings-only mode,
|
|
56
|
+
// so no task has to be created for this entry-point.
|
|
57
|
+
logger.debug("Skipping " + entryPoint.name + " : typings have already been processed.");
|
|
58
|
+
continue;
|
|
59
|
+
}
|
|
60
|
+
var processDts = hasProcessedTypings ? api_1.DtsProcessing.No :
|
|
61
|
+
typingsOnly ? api_1.DtsProcessing.Only : api_1.DtsProcessing.Yes;
|
|
54
62
|
try {
|
|
55
63
|
for (var propertiesToProcess_1 = (e_2 = void 0, tslib_1.__values(propertiesToProcess)), propertiesToProcess_1_1 = propertiesToProcess_1.next(); !propertiesToProcess_1_1.done; propertiesToProcess_1_1 = propertiesToProcess_1.next()) {
|
|
56
64
|
var formatProperty = propertiesToProcess_1_1.value;
|
|
@@ -62,7 +70,7 @@
|
|
|
62
70
|
var formatPropertiesToMarkAsProcessed = equivalentPropertiesMap.get(formatProperty);
|
|
63
71
|
tasks.push({ entryPoint: entryPoint, formatProperty: formatProperty, formatPropertiesToMarkAsProcessed: formatPropertiesToMarkAsProcessed, processDts: processDts });
|
|
64
72
|
// Only process typings for the first property (if not already processed).
|
|
65
|
-
processDts =
|
|
73
|
+
processDts = api_1.DtsProcessing.No;
|
|
66
74
|
}
|
|
67
75
|
}
|
|
68
76
|
catch (e_2_1) { e_2 = { error: e_2_1 }; }
|
|
@@ -109,7 +117,7 @@
|
|
|
109
117
|
* other format properties in `package.json` that need to be marked as processed as soon as the
|
|
110
118
|
* former has been processed.
|
|
111
119
|
*/
|
|
112
|
-
function getPropertiesToProcess(packageJson, propertiesToConsider, compileAllFormats) {
|
|
120
|
+
function getPropertiesToProcess(packageJson, propertiesToConsider, compileAllFormats, typingsOnly) {
|
|
113
121
|
var e_3, _a, e_4, _b, e_5, _c;
|
|
114
122
|
var formatPathsToConsider = new Set();
|
|
115
123
|
var propertiesToProcess = [];
|
|
@@ -166,7 +174,8 @@
|
|
|
166
174
|
for (var propertiesToConsider_2 = tslib_1.__values(propertiesToConsider), propertiesToConsider_2_1 = propertiesToConsider_2.next(); !propertiesToConsider_2_1.done; propertiesToConsider_2_1 = propertiesToConsider_2.next()) {
|
|
167
175
|
var prop = propertiesToConsider_2_1.value;
|
|
168
176
|
var formatPath = packageJson[prop];
|
|
169
|
-
|
|
177
|
+
// If we are only processing typings then there should be no format properties to mark
|
|
178
|
+
var equivalentProperties = typingsOnly ? [] : formatPathToProperties[formatPath];
|
|
170
179
|
equivalentPropertiesMap.set(prop, equivalentProperties);
|
|
171
180
|
}
|
|
172
181
|
}
|
|
@@ -185,4 +194,4 @@
|
|
|
185
194
|
new serial_task_queue_1.SerialTaskQueue(logger, tasks, dependencies);
|
|
186
195
|
}
|
|
187
196
|
});
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analyze_entry_points.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/analyze_entry_points.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 {DepGraph} from 'dependency-graph';\n\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {InvalidEntryPoint} from '../dependencies/dependency_resolver';\nimport {EntryPointFinder} from '../entry_point_finder/interface';\nimport {ParallelTaskQueue} from '../execution/tasks/queues/parallel_task_queue';\nimport {SerialTaskQueue} from '../execution/tasks/queues/serial_task_queue';\nimport {computeTaskDependencies} from '../execution/tasks/utils';\nimport {hasBeenProcessed} from '../packages/build_marker';\nimport {EntryPoint, EntryPointJsonProperty, EntryPointPackageJson, SUPPORTED_FORMAT_PROPERTIES} from '../packages/entry_point';\nimport {cleanOutdatedPackages} from '../writing/cleaning/package_cleaner';\n\nimport {AnalyzeEntryPointsFn} from './api';\nimport {PartiallyOrderedTasks, TaskQueue} from './tasks/api';\n\n/**\n * Create the function for performing the analysis of the entry-points.\n */\nexport function getAnalyzeEntryPointsFn(\n    logger: Logger, finder: EntryPointFinder, fileSystem: FileSystem,\n    supportedPropertiesToConsider: EntryPointJsonProperty[], compileAllFormats: boolean,\n    propertiesToConsider: string[], inParallel: boolean): AnalyzeEntryPointsFn {\n  return () => {\n    logger.debug('Analyzing entry-points...');\n    const startTime = Date.now();\n\n    let entryPointInfo = finder.findEntryPoints();\n    const cleaned = cleanOutdatedPackages(fileSystem, entryPointInfo.entryPoints);\n    if (cleaned) {\n      // If we had to clean up one or more packages then we must read in the entry-points again.\n      entryPointInfo = finder.findEntryPoints();\n    }\n\n    const {entryPoints, invalidEntryPoints, graph} = entryPointInfo;\n    logInvalidEntryPoints(logger, invalidEntryPoints);\n\n    const unprocessableEntryPointPaths: string[] = [];\n    // The tasks are partially ordered by virtue of the entry-points being partially ordered too.\n    const tasks: PartiallyOrderedTasks = [] as any;\n\n    for (const entryPoint of entryPoints) {\n      const packageJson = entryPoint.packageJson;\n      const hasProcessedTypings = hasBeenProcessed(packageJson, 'typings');\n      const {propertiesToProcess, equivalentPropertiesMap} =\n          getPropertiesToProcess(packageJson, supportedPropertiesToConsider, compileAllFormats);\n      let processDts = !hasProcessedTypings;\n\n      if (propertiesToProcess.length === 0) {\n        // This entry-point is unprocessable (i.e. there is no format property that is of interest\n        // and can be processed). This will result in an error, but continue looping over\n        // entry-points in order to collect all unprocessable ones and display a more informative\n        // error.\n        unprocessableEntryPointPaths.push(entryPoint.path);\n        continue;\n      }\n\n      for (const formatProperty of propertiesToProcess) {\n        if (hasBeenProcessed(entryPoint.packageJson, formatProperty)) {\n          // The format-path which the property maps to is already processed - nothing to do.\n          logger.debug(`Skipping ${entryPoint.name} : ${formatProperty} (already compiled).`);\n          continue;\n        }\n\n        const formatPropertiesToMarkAsProcessed = equivalentPropertiesMap.get(formatProperty)!;\n        tasks.push({entryPoint, formatProperty, formatPropertiesToMarkAsProcessed, processDts});\n\n        // Only process typings for the first property (if not already processed).\n        processDts = false;\n      }\n    }\n\n    // Check for entry-points for which we could not process any format at all.\n    if (unprocessableEntryPointPaths.length > 0) {\n      throw new Error(\n          'Unable to process any formats for the following entry-points (tried ' +\n          `${propertiesToConsider.join(', ')}): ` +\n          unprocessableEntryPointPaths.map(path => `\\n  - ${path}`).join(''));\n    }\n\n    const duration = Math.round((Date.now() - startTime) / 100) / 10;\n    logger.debug(\n        `Analyzed ${entryPoints.length} entry-points in ${duration}s. ` +\n        `(Total tasks: ${tasks.length})`);\n\n    return getTaskQueue(logger, inParallel, tasks, graph);\n  };\n}\n\nfunction logInvalidEntryPoints(logger: Logger, invalidEntryPoints: InvalidEntryPoint[]): void {\n  invalidEntryPoints.forEach(invalidEntryPoint => {\n    logger.debug(\n        `Invalid entry-point ${invalidEntryPoint.entryPoint.path}.`,\n        `It is missing required dependencies:\\n` +\n            invalidEntryPoint.missingDependencies.map(dep => ` - ${dep}`).join('\\n'));\n  });\n}\n\n/**\n * This function computes and returns the following:\n * - `propertiesToProcess`: An (ordered) list of properties that exist and need to be processed,\n *   based on the provided `propertiesToConsider`, the properties in `package.json` and their\n *   corresponding format-paths. NOTE: Only one property per format-path needs to be processed.\n * - `equivalentPropertiesMap`: A mapping from each property in `propertiesToProcess` to the list of\n *   other format properties in `package.json` that need to be marked as processed as soon as the\n *   former has been processed.\n */\nfunction getPropertiesToProcess(\n    packageJson: EntryPointPackageJson, propertiesToConsider: EntryPointJsonProperty[],\n    compileAllFormats: boolean): {\n  propertiesToProcess: EntryPointJsonProperty[];\n  equivalentPropertiesMap: Map<EntryPointJsonProperty, EntryPointJsonProperty[]>;\n} {\n  const formatPathsToConsider = new Set<string>();\n\n  const propertiesToProcess: EntryPointJsonProperty[] = [];\n  for (const prop of propertiesToConsider) {\n    const formatPath = packageJson[prop];\n\n    // Ignore properties that are not defined in `package.json`.\n    if (typeof formatPath !== 'string') continue;\n\n    // Ignore properties that map to the same format-path as a preceding property.\n    if (formatPathsToConsider.has(formatPath)) continue;\n\n    // Process this property, because it is the first one to map to this format-path.\n    formatPathsToConsider.add(formatPath);\n    propertiesToProcess.push(prop);\n\n    // If we only need one format processed, there is no need to process any more properties.\n    if (!compileAllFormats) break;\n  }\n\n  const formatPathToProperties: {[formatPath: string]: EntryPointJsonProperty[]} = {};\n  for (const prop of SUPPORTED_FORMAT_PROPERTIES) {\n    const formatPath = packageJson[prop];\n\n    // Ignore properties that are not defined in `package.json`.\n    if (typeof formatPath !== 'string') continue;\n\n    // Ignore properties that do not map to a format-path that will be considered.\n    if (!formatPathsToConsider.has(formatPath)) continue;\n\n    // Add this property to the map.\n    const list = formatPathToProperties[formatPath] || (formatPathToProperties[formatPath] = []);\n    list.push(prop);\n  }\n\n  const equivalentPropertiesMap = new Map<EntryPointJsonProperty, EntryPointJsonProperty[]>();\n  for (const prop of propertiesToConsider) {\n    const formatPath = packageJson[prop]!;\n    const equivalentProperties = formatPathToProperties[formatPath];\n    equivalentPropertiesMap.set(prop, equivalentProperties);\n  }\n\n  return {propertiesToProcess, equivalentPropertiesMap};\n}\n\nfunction getTaskQueue(\n    logger: Logger, inParallel: boolean, tasks: PartiallyOrderedTasks,\n    graph: DepGraph<EntryPoint>): TaskQueue {\n  const dependencies = computeTaskDependencies(tasks, graph);\n  return inParallel ? new ParallelTaskQueue(logger, tasks, dependencies) :\n                      new SerialTaskQueue(logger, tasks, dependencies);\n}\n"]}
|
|
197
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"analyze_entry_points.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/analyze_entry_points.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 {DepGraph} from 'dependency-graph';\n\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {InvalidEntryPoint} from '../dependencies/dependency_resolver';\nimport {EntryPointFinder} from '../entry_point_finder/interface';\nimport {ParallelTaskQueue} from '../execution/tasks/queues/parallel_task_queue';\nimport {SerialTaskQueue} from '../execution/tasks/queues/serial_task_queue';\nimport {computeTaskDependencies} from '../execution/tasks/utils';\nimport {hasBeenProcessed} from '../packages/build_marker';\nimport {EntryPoint, EntryPointJsonProperty, EntryPointPackageJson, SUPPORTED_FORMAT_PROPERTIES} from '../packages/entry_point';\nimport {cleanOutdatedPackages} from '../writing/cleaning/package_cleaner';\n\nimport {AnalyzeEntryPointsFn} from './api';\nimport {DtsProcessing, PartiallyOrderedTasks, TaskQueue} from './tasks/api';\n\n/**\n * Create the function for performing the analysis of the entry-points.\n */\nexport function getAnalyzeEntryPointsFn(\n    logger: Logger, finder: EntryPointFinder, fileSystem: FileSystem,\n    supportedPropertiesToConsider: EntryPointJsonProperty[], typingsOnly: boolean,\n    compileAllFormats: boolean, propertiesToConsider: string[],\n    inParallel: boolean): AnalyzeEntryPointsFn {\n  return () => {\n    logger.debug('Analyzing entry-points...');\n    const startTime = Date.now();\n\n    let entryPointInfo = finder.findEntryPoints();\n    const cleaned = cleanOutdatedPackages(fileSystem, entryPointInfo.entryPoints);\n    if (cleaned) {\n      // If we had to clean up one or more packages then we must read in the entry-points again.\n      entryPointInfo = finder.findEntryPoints();\n    }\n\n    const {entryPoints, invalidEntryPoints, graph} = entryPointInfo;\n    logInvalidEntryPoints(logger, invalidEntryPoints);\n\n    const unprocessableEntryPointPaths: string[] = [];\n    // The tasks are partially ordered by virtue of the entry-points being partially ordered too.\n    const tasks: PartiallyOrderedTasks = [] as any;\n\n    for (const entryPoint of entryPoints) {\n      const packageJson = entryPoint.packageJson;\n      const {propertiesToProcess, equivalentPropertiesMap} = getPropertiesToProcess(\n          packageJson, supportedPropertiesToConsider, compileAllFormats, typingsOnly);\n\n      if (propertiesToProcess.length === 0) {\n        // This entry-point is unprocessable (i.e. there is no format property that is of interest\n        // and can be processed). This will result in an error, but continue looping over\n        // entry-points in order to collect all unprocessable ones and display a more informative\n        // error.\n        unprocessableEntryPointPaths.push(entryPoint.path);\n        continue;\n      }\n\n      const hasProcessedTypings = hasBeenProcessed(packageJson, 'typings');\n      if (hasProcessedTypings && typingsOnly) {\n        // Typings for this entry-point have already been processed and we're in typings-only mode,\n        // so no task has to be created for this entry-point.\n        logger.debug(`Skipping ${entryPoint.name} : typings have already been processed.`);\n        continue;\n      }\n      let processDts = hasProcessedTypings ? DtsProcessing.No :\n                                             typingsOnly ? DtsProcessing.Only : DtsProcessing.Yes;\n\n      for (const formatProperty of propertiesToProcess) {\n        if (hasBeenProcessed(entryPoint.packageJson, formatProperty)) {\n          // The format-path which the property maps to is already processed - nothing to do.\n          logger.debug(`Skipping ${entryPoint.name} : ${formatProperty} (already compiled).`);\n          continue;\n        }\n\n        const formatPropertiesToMarkAsProcessed = equivalentPropertiesMap.get(formatProperty)!;\n        tasks.push({entryPoint, formatProperty, formatPropertiesToMarkAsProcessed, processDts});\n\n        // Only process typings for the first property (if not already processed).\n        processDts = DtsProcessing.No;\n      }\n    }\n\n    // Check for entry-points for which we could not process any format at all.\n    if (unprocessableEntryPointPaths.length > 0) {\n      throw new Error(\n          'Unable to process any formats for the following entry-points (tried ' +\n          `${propertiesToConsider.join(', ')}): ` +\n          unprocessableEntryPointPaths.map(path => `\\n  - ${path}`).join(''));\n    }\n\n    const duration = Math.round((Date.now() - startTime) / 100) / 10;\n    logger.debug(\n        `Analyzed ${entryPoints.length} entry-points in ${duration}s. ` +\n        `(Total tasks: ${tasks.length})`);\n\n    return getTaskQueue(logger, inParallel, tasks, graph);\n  };\n}\n\nfunction logInvalidEntryPoints(logger: Logger, invalidEntryPoints: InvalidEntryPoint[]): void {\n  invalidEntryPoints.forEach(invalidEntryPoint => {\n    logger.debug(\n        `Invalid entry-point ${invalidEntryPoint.entryPoint.path}.`,\n        `It is missing required dependencies:\\n` +\n            invalidEntryPoint.missingDependencies.map(dep => ` - ${dep}`).join('\\n'));\n  });\n}\n\n/**\n * This function computes and returns the following:\n * - `propertiesToProcess`: An (ordered) list of properties that exist and need to be processed,\n *   based on the provided `propertiesToConsider`, the properties in `package.json` and their\n *   corresponding format-paths. NOTE: Only one property per format-path needs to be processed.\n * - `equivalentPropertiesMap`: A mapping from each property in `propertiesToProcess` to the list of\n *   other format properties in `package.json` that need to be marked as processed as soon as the\n *   former has been processed.\n */\nfunction getPropertiesToProcess(\n    packageJson: EntryPointPackageJson, propertiesToConsider: EntryPointJsonProperty[],\n    compileAllFormats: boolean, typingsOnly: boolean): {\n  propertiesToProcess: EntryPointJsonProperty[];\n  equivalentPropertiesMap: Map<EntryPointJsonProperty, EntryPointJsonProperty[]>;\n} {\n  const formatPathsToConsider = new Set<string>();\n\n  const propertiesToProcess: EntryPointJsonProperty[] = [];\n  for (const prop of propertiesToConsider) {\n    const formatPath = packageJson[prop];\n\n    // Ignore properties that are not defined in `package.json`.\n    if (typeof formatPath !== 'string') continue;\n\n    // Ignore properties that map to the same format-path as a preceding property.\n    if (formatPathsToConsider.has(formatPath)) continue;\n\n    // Process this property, because it is the first one to map to this format-path.\n    formatPathsToConsider.add(formatPath);\n    propertiesToProcess.push(prop);\n\n    // If we only need one format processed, there is no need to process any more properties.\n    if (!compileAllFormats) break;\n  }\n\n  const formatPathToProperties: {[formatPath: string]: EntryPointJsonProperty[]} = {};\n  for (const prop of SUPPORTED_FORMAT_PROPERTIES) {\n    const formatPath = packageJson[prop];\n\n    // Ignore properties that are not defined in `package.json`.\n    if (typeof formatPath !== 'string') continue;\n\n    // Ignore properties that do not map to a format-path that will be considered.\n    if (!formatPathsToConsider.has(formatPath)) continue;\n\n    // Add this property to the map.\n    const list = formatPathToProperties[formatPath] || (formatPathToProperties[formatPath] = []);\n    list.push(prop);\n  }\n\n  const equivalentPropertiesMap = new Map<EntryPointJsonProperty, EntryPointJsonProperty[]>();\n  for (const prop of propertiesToConsider) {\n    const formatPath = packageJson[prop]!;\n    // If we are only processing typings then there should be no format properties to mark\n    const equivalentProperties = typingsOnly ? [] : formatPathToProperties[formatPath];\n    equivalentPropertiesMap.set(prop, equivalentProperties);\n  }\n\n  return {propertiesToProcess, equivalentPropertiesMap};\n}\n\nfunction getTaskQueue(\n    logger: Logger, inParallel: boolean, tasks: PartiallyOrderedTasks,\n    graph: DepGraph<EntryPoint>): TaskQueue {\n  const dependencies = computeTaskDependencies(tasks, graph);\n  return inParallel ? new ParallelTaskQueue(logger, tasks, dependencies) :\n                      new SerialTaskQueue(logger, tasks, dependencies);\n}\n"]}
|
|
@@ -41,11 +41,11 @@
|
|
|
41
41
|
// (i.e. they are defined in `entryPoint.packageJson`). Furthermore, they are also guaranteed
|
|
42
42
|
// to be among `SUPPORTED_FORMAT_PROPERTIES`.
|
|
43
43
|
// Based on the above, `formatPath` should always be defined and `getEntryPointFormat()`
|
|
44
|
-
// should always return a format here (and not `undefined`)
|
|
44
|
+
// should always return a format here (and not `undefined`) unless `formatPath` points to a
|
|
45
|
+
// missing or empty file.
|
|
45
46
|
if (!formatPath || !format) {
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
(formatProperty + " (formatPath: " + formatPath + " | format: " + format + ")"));
|
|
47
|
+
onTaskCompleted(task, 1 /* Failed */, "property `" + formatProperty + "` pointing to a missing or empty file: " + formatPath);
|
|
48
|
+
return;
|
|
49
49
|
}
|
|
50
50
|
logger.info("Compiling " + entryPoint.name + " : " + formatProperty + " as " + format);
|
|
51
51
|
var bundle = entry_point_bundle_1.makeEntryPointBundle(fileSystem, entryPoint, sharedFileCache, moduleResolutionCache, formatPath, isCore, format, processDts, pathMappings, true, enableI18nLegacyMessageIdFormat);
|
|
@@ -73,4 +73,4 @@
|
|
|
73
73
|
}
|
|
74
74
|
exports.getCreateCompileFn = getCreateCompileFn;
|
|
75
75
|
});
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create_compile_function.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/execution/create_compile_function.ts"],"names":[],"mappings":"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","sourcesContent":["\n/**\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';\n\nimport {replaceTsWithNgInErrors} from '../../../src/ngtsc/diagnostics';\nimport {FileSystem} from '../../../src/ngtsc/file_system';\nimport {Logger} from '../../../src/ngtsc/logging';\nimport {ParsedConfiguration} from '../../../src/perform_compile';\nimport {getEntryPointFormat} from '../packages/entry_point';\nimport {makeEntryPointBundle} from '../packages/entry_point_bundle';\nimport {createModuleResolutionCache, SharedFileCache} from '../packages/source_file_cache';\nimport {PathMappings} from '../path_mappings';\nimport {FileWriter} from '../writing/file_writer';\n\nimport {CreateCompileFn} from './api';\nimport {Task, TaskProcessingOutcome} from './tasks/api';\n\n/**\n * The function for creating the `compile()` function.\n */\nexport function getCreateCompileFn(\n    fileSystem: FileSystem, logger: Logger, fileWriter: FileWriter,\n    enableI18nLegacyMessageIdFormat: boolean, tsConfig: ParsedConfiguration|null,\n    pathMappings: PathMappings|undefined): CreateCompileFn {\n  return (beforeWritingFiles, onTaskCompleted) => {\n    const {Transformer} = require('../packages/transformer');\n    const transformer = new Transformer(fileSystem, logger, tsConfig);\n    const sharedFileCache = new SharedFileCache(fileSystem);\n    const moduleResolutionCache = createModuleResolutionCache(fileSystem);\n\n    return (task: Task) => {\n      const {entryPoint, formatProperty, formatPropertiesToMarkAsProcessed, processDts} = task;\n\n      const isCore = entryPoint.name === '@angular/core';  // Are we compiling the Angular core?\n      const packageJson = entryPoint.packageJson;\n      const formatPath = packageJson[formatProperty];\n      const format = getEntryPointFormat(fileSystem, entryPoint, formatProperty);\n\n      // All properties listed in `propertiesToProcess` are guaranteed to point to a format-path\n      // (i.e. they are defined in `entryPoint.packageJson`). Furthermore, they are also guaranteed\n      // to be among `SUPPORTED_FORMAT_PROPERTIES`.\n      // Based on the above, `formatPath` should always be defined and `getEntryPointFormat()`\n      // should always return a format here (and not `undefined`) unless `formatPath` points to a\n      // missing or empty file.\n      if (!formatPath || !format) {\n        onTaskCompleted(\n            task, TaskProcessingOutcome.Failed,\n            `property \\`${formatProperty}\\` pointing to a missing or empty file: ${formatPath}`);\n        return;\n      }\n\n      logger.info(`Compiling ${entryPoint.name} : ${formatProperty} as ${format}`);\n\n      const bundle = makeEntryPointBundle(\n          fileSystem, entryPoint, sharedFileCache, moduleResolutionCache, formatPath, isCore,\n          format, processDts, pathMappings, true, enableI18nLegacyMessageIdFormat);\n\n      const result = transformer.transform(bundle);\n      if (result.success) {\n        if (result.diagnostics.length > 0) {\n          logger.warn(replaceTsWithNgInErrors(\n              ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host)));\n        }\n\n        const writeBundle = () => {\n          fileWriter.writeBundle(\n              bundle, result.transformedFiles, formatPropertiesToMarkAsProcessed);\n\n          logger.debug(`  Successfully compiled ${entryPoint.name} : ${formatProperty}`);\n          onTaskCompleted(task, TaskProcessingOutcome.Processed, null);\n        };\n\n        const beforeWritingResult = beforeWritingFiles(result.transformedFiles);\n\n        return (beforeWritingResult instanceof Promise) ?\n            beforeWritingResult.then(writeBundle) as ReturnType<typeof beforeWritingFiles>:\n            writeBundle();\n      } else {\n        const errors = replaceTsWithNgInErrors(\n            ts.formatDiagnosticsWithColorAndContext(result.diagnostics, bundle.src.host));\n        onTaskCompleted(task, TaskProcessingOutcome.Failed, `compilation errors:\\n${errors}`);\n      }\n    };\n  };\n}\n"]}
|
|
@@ -29,8 +29,29 @@ export interface Task extends JsonObject {
|
|
|
29
29
|
* processed as part of the task.
|
|
30
30
|
*/
|
|
31
31
|
formatPropertiesToMarkAsProcessed: EntryPointJsonProperty[];
|
|
32
|
-
/**
|
|
33
|
-
|
|
32
|
+
/**
|
|
33
|
+
* Whether to process typings for this entry-point as part of the task.
|
|
34
|
+
*/
|
|
35
|
+
processDts: DtsProcessing;
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* The options for processing Typescript typings (.d.ts) files.
|
|
39
|
+
*/
|
|
40
|
+
export declare enum DtsProcessing {
|
|
41
|
+
/**
|
|
42
|
+
* Yes, process the typings for this entry point as part of the task.
|
|
43
|
+
*/
|
|
44
|
+
Yes = 0,
|
|
45
|
+
/**
|
|
46
|
+
* No, do not process the typings as part of this task - they must have already been processed by
|
|
47
|
+
* another task or previous ngcc process.
|
|
48
|
+
*/
|
|
49
|
+
No = 1,
|
|
50
|
+
/**
|
|
51
|
+
* Only process the typings for this entry-point; do not render any JavaScript files for the
|
|
52
|
+
* `formatProperty` of this task.
|
|
53
|
+
*/
|
|
54
|
+
Only = 2
|
|
34
55
|
}
|
|
35
56
|
/**
|
|
36
57
|
* Represents a partially ordered list of tasks.
|
|
@@ -9,7 +9,27 @@
|
|
|
9
9
|
})(function (require, exports) {
|
|
10
10
|
"use strict";
|
|
11
11
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.TaskDependencies = void 0;
|
|
12
|
+
exports.TaskDependencies = exports.DtsProcessing = void 0;
|
|
13
|
+
/**
|
|
14
|
+
* The options for processing Typescript typings (.d.ts) files.
|
|
15
|
+
*/
|
|
16
|
+
var DtsProcessing;
|
|
17
|
+
(function (DtsProcessing) {
|
|
18
|
+
/**
|
|
19
|
+
* Yes, process the typings for this entry point as part of the task.
|
|
20
|
+
*/
|
|
21
|
+
DtsProcessing[DtsProcessing["Yes"] = 0] = "Yes";
|
|
22
|
+
/**
|
|
23
|
+
* No, do not process the typings as part of this task - they must have already been processed by
|
|
24
|
+
* another task or previous ngcc process.
|
|
25
|
+
*/
|
|
26
|
+
DtsProcessing[DtsProcessing["No"] = 1] = "No";
|
|
27
|
+
/**
|
|
28
|
+
* Only process the typings for this entry-point; do not render any JavaScript files for the
|
|
29
|
+
* `formatProperty` of this task.
|
|
30
|
+
*/
|
|
31
|
+
DtsProcessing[DtsProcessing["Only"] = 2] = "Only";
|
|
32
|
+
})(DtsProcessing = exports.DtsProcessing || (exports.DtsProcessing = {}));
|
|
13
33
|
exports.TaskDependencies = Map;
|
|
14
34
|
});
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvY29tcGlsZXItY2xpL25nY2Mvc3JjL2V4ZWN1dGlvbi90YXNrcy9hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7O0lBd0NBOztPQUVHO0lBQ0gsSUFBWSxhQWVYO0lBZkQsV0FBWSxhQUFhO1FBQ3ZCOztXQUVHO1FBQ0gsK0NBQUcsQ0FBQTtRQUNIOzs7V0FHRztRQUNILDZDQUFFLENBQUE7UUFDRjs7O1dBR0c7UUFDSCxpREFBSSxDQUFBO0lBQ04sQ0FBQyxFQWZXLGFBQWEsR0FBYixxQkFBYSxLQUFiLHFCQUFhLFFBZXhCO0lBcUJZLFFBQUEsZ0JBQWdCLEdBQUcsR0FBRyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAbGljZW5zZVxuICogQ29weXJpZ2h0IEdvb2dsZSBMTEMgQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQge0VudHJ5UG9pbnQsIEVudHJ5UG9pbnRKc29uUHJvcGVydHksIEpzb25PYmplY3R9IGZyb20gJy4uLy4uL3BhY2thZ2VzL2VudHJ5X3BvaW50JztcbmltcG9ydCB7UGFydGlhbGx5T3JkZXJlZExpc3R9IGZyb20gJy4uLy4uL3V0aWxzJztcblxuLyoqXG4gKiBSZXByZXNlbnRzIGEgdW5pdCBvZiB3b3JrIHRvIGJlIHVuZGVydGFrZW4gYnkgYW4gYEV4ZWN1dG9yYC5cbiAqXG4gKiBBIHRhc2sgY29uc2lzdHMgb2YgcHJvY2Vzc2luZyBhIHNwZWNpZmljIGZvcm1hdCBwcm9wZXJ0eSBvZiBhbiBlbnRyeS1wb2ludC5cbiAqIFRoaXMgbWF5IG9yIG1heSBub3QgYWxzbyBpbmNsdWRlIHByb2Nlc3NpbmcgdGhlIHR5cGluZ3MgZm9yIHRoYXQgZW50cnktcG9pbnQsIHdoaWNoIG9ubHkgbmVlZHMgdG9cbiAqIGhhcHBlbiBvbmNlIGFjcm9zcyBhbGwgdGhlIGZvcm1hdHMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFzayBleHRlbmRzIEpzb25PYmplY3Qge1xuICAvKiogVGhlIGBFbnRyeVBvaW50YCB3aGljaCBuZWVkcyB0byBiZSBwcm9jZXNzZWQgYXMgcGFydCBvZiB0aGUgdGFzay4gKi9cbiAgZW50cnlQb2ludDogRW50cnlQb2ludDtcblxuICAvKipcbiAgICogVGhlIGBwYWNrYWdlLmpzb25gIGZvcm1hdCBwcm9wZXJ0eSB0byBwcm9jZXNzIChpLmUuIHRoZSBwcm9wZXJ0eSB3aGljaCBwb2ludHMgdG8gdGhlIGZpbGUgdGhhdFxuICAgKiBpcyB0aGUgcHJvZ3JhbSBlbnRyeS1wb2ludCkuXG4gICAqL1xuICBmb3JtYXRQcm9wZXJ0eTogRW50cnlQb2ludEpzb25Qcm9wZXJ0eTtcblxuICAvKipcbiAgICogVGhlIGxpc3Qgb2YgYWxsIGZvcm1hdCBwcm9wZXJ0aWVzIChpbmNsdWRpbmcgYHRhc2suZm9ybWF0UHJvcGVydHlgKSB0aGF0IHNob3VsZCBiZSBtYXJrZWQgYXNcbiAgICogcHJvY2Vzc2VkIG9uY2UgdGhlIHRhc2sgaGFzIGJlZW4gY29tcGxldGVkLCBiZWNhdXNlIHRoZXkgcG9pbnQgdG8gdGhlIGZvcm1hdC1wYXRoIHRoYXQgd2lsbCBiZVxuICAgKiBwcm9jZXNzZWQgYXMgcGFydCBvZiB0aGUgdGFzay5cbiAgICovXG4gIGZvcm1hdFByb3BlcnRpZXNUb01hcmtBc1Byb2Nlc3NlZDogRW50cnlQb2ludEpzb25Qcm9wZXJ0eVtdO1xuXG4gIC8qKlxuICAgKiBXaGV0aGVyIHRvIHByb2Nlc3MgdHlwaW5ncyBmb3IgdGhpcyBlbnRyeS1wb2ludCBhcyBwYXJ0IG9mIHRoZSB0YXNrLlxuICAgKi9cbiAgcHJvY2Vzc0R0czogRHRzUHJvY2Vzc2luZztcbn1cblxuLyoqXG4gKiBUaGUgb3B0aW9ucyBmb3IgcHJvY2Vzc2luZyBUeXBlc2NyaXB0IHR5cGluZ3MgKC5kLnRzKSBmaWxlcy5cbiAqL1xuZXhwb3J0IGVudW0gRHRzUHJvY2Vzc2luZyB7XG4gIC8qKlxuICAgKiBZZXMsIHByb2Nlc3MgdGhlIHR5cGluZ3MgZm9yIHRoaXMgZW50cnkgcG9pbnQgYXMgcGFydCBvZiB0aGUgdGFzay5cbiAgICovXG4gIFllcyxcbiAgLyoqXG4gICAqIE5vLCBkbyBub3QgcHJvY2VzcyB0aGUgdHlwaW5ncyBhcyBwYXJ0IG9mIHRoaXMgdGFzayAtIHRoZXkgbXVzdCBoYXZlIGFscmVhZHkgYmVlbiBwcm9jZXNzZWQgYnlcbiAgICogYW5vdGhlciB0YXNrIG9yIHByZXZpb3VzIG5nY2MgcHJvY2Vzcy5cbiAgICovXG4gIE5vLFxuICAvKipcbiAgICogT25seSBwcm9jZXNzIHRoZSB0eXBpbmdzIGZvciB0aGlzIGVudHJ5LXBvaW50OyBkbyBub3QgcmVuZGVyIGFueSBKYXZhU2NyaXB0IGZpbGVzIGZvciB0aGVcbiAgICogYGZvcm1hdFByb3BlcnR5YCBvZiB0aGlzIHRhc2suXG4gICAqL1xuICBPbmx5LFxufVxuXG4vKipcbiAqIFJlcHJlc2VudHMgYSBwYXJ0aWFsbHkgb3JkZXJlZCBsaXN0IG9mIHRhc2tzLlxuICpcbiAqIFRoZSBvcmRlcmluZy9wcmVjZWRlbmNlIG9mIHRhc2tzIGlzIGRldGVybWluZWQgYnkgdGhlIGludGVyLWRlcGVuZGVuY2llcyBiZXR3ZWVuIHRoZWlyIGFzc29jaWF0ZWRcbiAqIGVudHJ5LXBvaW50cy4gU3BlY2lmaWNhbGx5LCB0aGUgdGFza3MnIG9yZGVyL3ByZWNlZGVuY2UgaXMgc3VjaCB0aGF0IHRhc2tzIGFzc29jaWF0ZWQgdG9cbiAqIGRlcGVuZGVudCBlbnRyeS1wb2ludHMgYWx3YXlzIGNvbWUgYWZ0ZXIgdGFza3MgYXNzb2NpYXRlZCB3aXRoIHRoZWlyIGRlcGVuZGVuY2llcy5cbiAqXG4gKiBBcyByZXN1bHQgb2YgdGhpcyBvcmRlcmluZywgaXQgaXMgZ3VhcmFudGVlZCB0aGF0IC0gYnkgcHJvY2Vzc2luZyB0YXNrcyBpbiB0aGUgb3JkZXIgaW4gd2hpY2hcbiAqIHRoZXkgYXBwZWFyIGluIHRoZSBsaXN0IC0gYSB0YXNrJ3MgZGVwZW5kZW5jaWVzIHdpbGwgYWx3YXlzIGhhdmUgYmVlbiBwcm9jZXNzZWQgYmVmb3JlIHByb2Nlc3NpbmdcbiAqIHRoZSB0YXNrIGl0c2VsZi5cbiAqXG4gKiBTZWUgYERlcGVuZGVuY3lSZXNvbHZlciNzb3J0RW50cnlQb2ludHNCeURlcGVuZGVuY3koKWAuXG4gKi9cbmV4cG9ydCB0eXBlIFBhcnRpYWxseU9yZGVyZWRUYXNrcyA9IFBhcnRpYWxseU9yZGVyZWRMaXN0PFRhc2s+O1xuXG4vKipcbiAqIEEgbWFwcGluZyBmcm9tIFRhc2tzIHRvIHRoZSBUYXNrcyB0aGF0IGRlcGVuZCB1cG9uIHRoZW0gKGRlcGVuZGVudHMpLlxuICovXG5leHBvcnQgdHlwZSBUYXNrRGVwZW5kZW5jaWVzID0gTWFwPFRhc2ssIFNldDxUYXNrPj47XG5leHBvcnQgY29uc3QgVGFza0RlcGVuZGVuY2llcyA9IE1hcDtcblxuLyoqXG4gKiBBIGZ1bmN0aW9uIHRvIGNyZWF0ZSBhIFRhc2tDb21wbGV0ZWRDYWxsYmFjayBmdW5jdGlvbi5cbiAqL1xuZXhwb3J0IHR5cGUgQ3JlYXRlVGFza0NvbXBsZXRlZENhbGxiYWNrID0gKHRhc2tRdWV1ZTogVGFza1F1ZXVlKSA9PiBUYXNrQ29tcGxldGVkQ2FsbGJhY2s7XG5cbi8qKlxuICogQSBmdW5jdGlvbiB0byBiZSBjYWxsZWQgb25jZSBhIHRhc2sgaGFzIGJlZW4gcHJvY2Vzc2VkLlxuICovXG5leHBvcnQgdHlwZSBUYXNrQ29tcGxldGVkQ2FsbGJhY2sgPVxuICAgICh0YXNrOiBUYXNrLCBvdXRjb21lOiBUYXNrUHJvY2Vzc2luZ091dGNvbWUsIG1lc3NhZ2U6IHN0cmluZ3xudWxsKSA9PiB2b2lkO1xuXG4vKipcbiAqIFJlcHJlc2VudHMgdGhlIG91dGNvbWUgb2YgcHJvY2Vzc2luZyBhIGBUYXNrYC5cbiAqL1xuZXhwb3J0IGNvbnN0IGVudW0gVGFza1Byb2Nlc3NpbmdPdXRjb21lIHtcbiAgLyoqIFN1Y2Nlc3NmdWxseSBwcm9jZXNzZWQgdGhlIHRhcmdldCBmb3JtYXQgcHJvcGVydHkuICovXG4gIFByb2Nlc3NlZCxcbiAgLyoqIEZhaWxlZCB0byBwcm9jZXNzIHRoZSB0YXJnZXQgZm9ybWF0LiAqL1xuICBGYWlsZWQsXG59XG5cbi8qKlxuICogQSB3cmFwcGVyIGFyb3VuZCBhIGxpc3Qgb2YgdGFza3MgYW5kIHByb3ZpZGluZyB1dGlsaXR5IG1ldGhvZHMgZm9yIGdldHRpbmcgdGhlIG5leHQgdGFzayBvZlxuICogaW50ZXJlc3QgYW5kIGRldGVybWluaW5nIHdoZW4gYWxsIHRhc2tzIGhhdmUgYmVlbiBjb21wbGV0ZWQuXG4gKlxuICogKFRoaXMgYWxsb3dzIGRpZmZlcmVudCBpbXBsZW1lbnRhdGlvbnMgdG8gaW1wb3NlIGRpZmZlcmVudCBjb25zdHJhaW50cyBvbiB3aGVuIGEgdGFzaydzXG4gKiBwcm9jZXNzaW5nIGNhbiBzdGFydC4pXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGFza1F1ZXVlIHtcbiAgLyoqIFdoZXRoZXIgYWxsIHRhc2tzIGhhdmUgYmVlbiBjb21wbGV0ZWQuICovXG4gIGFsbFRhc2tzQ29tcGxldGVkOiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBHZXQgdGhlIG5leHQgdGFzayB3aG9zZSBwcm9jZXNzaW5nIGNhbiBzdGFydCAoaWYgYW55KS5cbiAgICpcbiAgICogVGhpcyBpbXBsaWNpdGx5IG1hcmtzIHRoZSB0YXNrIGFzIGluLXByb2dyZXNzLlxuICAgKiAoVGhpcyBpbmZvcm1hdGlvbiBpcyB1c2VkIHRvIGRldGVybWluZSB3aGV0aGVyIGFsbCB0YXNrcyBoYXZlIGJlZW4gY29tcGxldGVkLilcbiAgICpcbiAgICogQHJldHVybiBUaGUgbmV4dCB0YXNrIGF2YWlsYWJsZSBmb3IgcHJvY2Vzc2luZyBvciBgbnVsbGAsIGlmIG5vIHRhc2sgY2FuIGJlIHByb2Nlc3NlZCBhdCB0aGVcbiAgICogICAgICAgICBtb21lbnQgKGluY2x1ZGluZyBpZiB0aGVyZSBhcmUgbm8gbW9yZSB1bnByb2Nlc3NlZCB0YXNrcykuXG4gICAqL1xuICBnZXROZXh0VGFzaygpOiBUYXNrfG51bGw7XG5cbiAgLyoqXG4gICAqIE1hcmsgYSB0YXNrIGFzIGNvbXBsZXRlZC5cbiAgICpcbiAgICogVGhpcyByZW1vdmVzIHRoZSB0YXNrIGZyb20gdGhlIGludGVybmFsIGxpc3Qgb2YgaW4tcHJvZ3Jlc3MgdGFza3MuXG4gICAqIChUaGlzIGluZm9ybWF0aW9uIGlzIHVzZWQgdG8gZGV0ZXJtaW5lIHdoZXRoZXIgYWxsIHRhc2tzIGhhdmUgYmVlbiBjb21wbGV0ZWQuKVxuICAgKlxuICAgKiBAcGFyYW0gdGFzayBUaGUgdGFzayB0byBtYXJrIGFzIGNvbXBsZXRlZC5cbiAgICovXG4gIG1hcmtBc0NvbXBsZXRlZCh0YXNrOiBUYXNrKTogdm9pZDtcblxuICAvKipcbiAgICogTWFyayBhIHRhc2sgYXMgZmFpbGVkLlxuICAgKlxuICAgKiBEbyBub3QgcHJvY2VzcyB0aGUgdGFza3MgdGhhdCBkZXBlbmQgdXBvbiB0aGUgZ2l2ZW4gdGFzay5cbiAgICovXG4gIG1hcmtBc0ZhaWxlZCh0YXNrOiBUYXNrKTogdm9pZDtcblxuICAvKipcbiAgICogTWFyayBhIHRhc2sgYXMgbm90IHByb2Nlc3NlZCAoaS5lLiBhZGQgYW4gaW4tcHJvZ3Jlc3MgdGFzayBiYWNrIHRvIHRoZSBxdWV1ZSkuXG4gICAqXG4gICAqIFRoaXMgcmVtb3ZlcyB0aGUgdGFzayBmcm9tIHRoZSBpbnRlcm5hbCBsaXN0IG9mIGluLXByb2dyZXNzIHRhc2tzIGFuZCBhZGRzIGl0IGJhY2sgdG8gdGhlIGxpc3RcbiAgICogb2YgcGVuZGluZyB0YXNrcy5cbiAgICpcbiAgICogQHBhcmFtIHRhc2sgVGhlIHRhc2sgdG8gbWFyayBhcyBub3QgcHJvY2Vzc2VkLlxuICAgKi9cbiAgbWFya0FzVW5wcm9jZXNzZWQodGFzazogVGFzayk6IHZvaWQ7XG5cbiAgLyoqXG4gICAqIFJldHVybiBhIHN0cmluZyByZXByZXNlbnRhdGlvbiBvZiB0aGUgdGFzayBxdWV1ZSAoZm9yIGRlYnVnZ2luZyBwdXJwb3NlcykuXG4gICAqXG4gICAqIEByZXR1cm4gQSBzdHJpbmcgcmVwcmVzZW50YXRpb24gb2YgdGhlIHRhc2sgcXVldWUuXG4gICAqL1xuICB0b1N0cmluZygpOiBzdHJpbmc7XG59XG4iXX0=
|