@angular/compiler-cli 8.0.0 → 8.1.0-beta.0
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/index.d.ts +1 -0
- package/ngcc/index.js +1 -1
- package/ngcc/main-ngcc.js +4 -4
- package/ngcc/src/analysis/decoration_analyzer.d.ts +5 -1
- package/ngcc/src/analysis/decoration_analyzer.js +12 -12
- package/ngcc/src/analysis/module_with_providers_analyzer.js +2 -2
- package/ngcc/src/analysis/private_declarations_analyzer.d.ts +3 -2
- package/ngcc/src/analysis/private_declarations_analyzer.js +8 -7
- package/ngcc/src/dependencies/commonjs_dependency_host.d.ts +46 -0
- package/ngcc/src/dependencies/commonjs_dependency_host.js +133 -0
- package/ngcc/src/dependencies/dependency_host.d.ts +17 -0
- package/ngcc/src/dependencies/dependency_host.js +20 -0
- package/ngcc/src/{packages → dependencies}/dependency_resolver.d.ts +13 -8
- package/ngcc/src/dependencies/dependency_resolver.js +138 -0
- package/ngcc/src/dependencies/esm_dependency_host.d.ts +62 -0
- package/ngcc/src/dependencies/esm_dependency_host.js +122 -0
- package/ngcc/src/dependencies/module_resolver.d.ts +139 -0
- package/ngcc/src/dependencies/module_resolver.js +297 -0
- package/ngcc/src/dependencies/umd_dependency_host.d.ts +46 -0
- package/ngcc/src/dependencies/umd_dependency_host.js +114 -0
- package/ngcc/src/file_system/file_system.d.ts +36 -0
- package/ngcc/src/file_system/file_system.js +20 -0
- package/ngcc/src/file_system/node_js_file_system.d.ts +27 -0
- package/ngcc/src/file_system/node_js_file_system.js +44 -0
- package/ngcc/src/host/commonjs_host.d.ts +43 -0
- package/ngcc/src/host/commonjs_host.js +187 -0
- package/ngcc/src/host/esm2015_host.d.ts +8 -10
- package/ngcc/src/host/esm2015_host.js +70 -40
- package/ngcc/src/host/esm5_host.js +3 -3
- package/ngcc/src/host/umd_host.d.ts +51 -0
- package/ngcc/src/host/umd_host.js +250 -0
- package/ngcc/src/main.d.ts +7 -8
- package/ngcc/src/main.js +64 -48
- package/ngcc/src/packages/build_marker.d.ts +3 -2
- package/ngcc/src/packages/build_marker.js +5 -6
- package/ngcc/src/packages/bundle_program.d.ts +13 -4
- package/ngcc/src/packages/bundle_program.js +11 -12
- package/ngcc/src/packages/entry_point.d.ts +6 -10
- package/ngcc/src/packages/entry_point.js +28 -24
- package/ngcc/src/packages/entry_point_bundle.d.ts +3 -1
- package/ngcc/src/packages/entry_point_bundle.js +10 -21
- package/ngcc/src/packages/entry_point_finder.d.ts +33 -3
- package/ngcc/src/packages/entry_point_finder.js +80 -18
- package/ngcc/src/packages/ngcc_compiler_host.d.ts +31 -0
- package/ngcc/src/packages/ngcc_compiler_host.js +108 -0
- package/ngcc/src/packages/transformer.d.ts +7 -5
- package/ngcc/src/packages/transformer.js +36 -12
- package/ngcc/src/rendering/commonjs_rendering_formatter.d.ts +25 -0
- package/ngcc/src/rendering/commonjs_rendering_formatter.js +89 -0
- package/ngcc/src/rendering/dts_renderer.d.ts +51 -0
- package/ngcc/src/rendering/dts_renderer.js +135 -0
- package/ngcc/src/rendering/esm5_rendering_formatter.d.ts +21 -0
- package/ngcc/src/rendering/esm5_rendering_formatter.js +44 -0
- package/ngcc/src/rendering/esm_rendering_formatter.d.ts +63 -0
- package/ngcc/src/rendering/esm_rendering_formatter.js +202 -0
- package/ngcc/src/rendering/renderer.d.ts +16 -112
- package/ngcc/src/rendering/renderer.js +38 -285
- package/ngcc/src/rendering/rendering_formatter.d.ts +35 -0
- package/ngcc/src/rendering/rendering_formatter.js +14 -0
- package/ngcc/src/rendering/source_maps.d.ts +45 -0
- package/ngcc/src/rendering/source_maps.js +129 -0
- package/ngcc/src/rendering/umd_rendering_formatter.d.ts +28 -0
- package/ngcc/src/rendering/umd_rendering_formatter.js +222 -0
- package/ngcc/src/rendering/utils.d.ts +25 -0
- package/ngcc/src/rendering/utils.js +34 -0
- package/ngcc/src/utils.d.ts +12 -0
- package/ngcc/src/utils.js +10 -1
- package/ngcc/src/writing/file_writer.d.ts +2 -2
- package/ngcc/src/writing/file_writer.js +1 -1
- package/ngcc/src/writing/in_place_file_writer.d.ts +6 -10
- package/ngcc/src/writing/in_place_file_writer.js +18 -19
- package/ngcc/src/writing/new_entry_point_file_writer.d.ts +4 -4
- package/ngcc/src/writing/new_entry_point_file_writer.js +24 -25
- package/package.json +2 -2
- package/src/ngtsc/annotations/src/base_def.d.ts +5 -4
- package/src/ngtsc/annotations/src/base_def.js +12 -3
- package/src/ngtsc/annotations/src/component.d.ts +0 -1
- package/src/ngtsc/annotations/src/component.js +2 -5
- package/src/ngtsc/annotations/src/directive.d.ts +2 -1
- package/src/ngtsc/annotations/src/directive.js +5 -4
- package/src/ngtsc/annotations/src/injectable.js +1 -3
- package/src/ngtsc/annotations/src/ng_module.d.ts +2 -1
- package/src/ngtsc/annotations/src/ng_module.js +17 -10
- package/src/ngtsc/annotations/src/pipe.js +1 -1
- package/src/ngtsc/annotations/src/util.js +7 -4
- package/src/ngtsc/imports/src/emitter.d.ts +8 -6
- package/src/ngtsc/imports/src/emitter.js +10 -38
- package/src/ngtsc/imports/src/resolver.js +4 -5
- package/src/ngtsc/incremental/src/state.d.ts +15 -3
- package/src/ngtsc/incremental/src/state.js +72 -52
- package/src/ngtsc/metadata/src/api.d.ts +18 -1
- package/src/ngtsc/metadata/src/api.js +1 -1
- package/src/ngtsc/metadata/src/util.d.ts +2 -2
- package/src/ngtsc/metadata/src/util.js +28 -9
- package/src/ngtsc/partial_evaluator/index.d.ts +1 -1
- package/src/ngtsc/partial_evaluator/index.js +1 -1
- package/src/ngtsc/partial_evaluator/src/dynamic.d.ts +2 -1
- package/src/ngtsc/partial_evaluator/src/dynamic.js +1 -1
- package/src/ngtsc/partial_evaluator/src/interface.d.ts +10 -3
- package/src/ngtsc/partial_evaluator/src/interface.js +6 -7
- package/src/ngtsc/partial_evaluator/src/interpreter.d.ts +4 -3
- package/src/ngtsc/partial_evaluator/src/interpreter.js +11 -9
- package/src/ngtsc/path/src/logical.js +4 -3
- package/src/ngtsc/path/src/types.d.ts +19 -7
- package/src/ngtsc/path/src/types.js +48 -9
- package/src/ngtsc/program.js +13 -12
- package/src/ngtsc/scope/src/local.d.ts +23 -5
- package/src/ngtsc/scope/src/local.js +34 -11
- package/src/ngtsc/shims/src/factory_generator.js +4 -2
- package/src/ngtsc/transform/src/api.d.ts +0 -1
- package/src/ngtsc/transform/src/api.js +1 -1
- package/src/ngtsc/transform/src/compilation.d.ts +4 -2
- package/src/ngtsc/transform/src/compilation.js +22 -20
- package/src/ngtsc/translator/index.d.ts +1 -1
- package/src/ngtsc/translator/index.js +1 -1
- package/src/ngtsc/translator/src/translator.d.ts +21 -8
- package/src/ngtsc/translator/src/translator.js +3 -12
- package/src/ngtsc/typecheck/src/api.d.ts +2 -1
- package/src/ngtsc/typecheck/src/api.js +1 -1
- package/src/ngtsc/typecheck/src/expression.js +104 -88
- package/src/ngtsc/typecheck/src/type_check_block.js +17 -11
- package/src/ngtsc/util/src/typescript.d.ts +7 -0
- package/src/ngtsc/util/src/typescript.js +17 -1
- package/src/version.js +1 -1
- package/ngcc/src/packages/dependency_host.d.ts +0 -84
- package/ngcc/src/packages/dependency_host.js +0 -164
- package/ngcc/src/packages/dependency_resolver.js +0 -126
- package/ngcc/src/rendering/esm5_renderer.d.ts +0 -14
- package/ngcc/src/rendering/esm5_renderer.js +0 -47
- package/ngcc/src/rendering/esm_renderer.d.ts +0 -30
- package/ngcc/src/rendering/esm_renderer.js +0 -141
|
@@ -1,164 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google Inc. All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
(function (factory) {
|
|
9
|
-
if (typeof module === "object" && typeof module.exports === "object") {
|
|
10
|
-
var v = factory(require, exports);
|
|
11
|
-
if (v !== undefined) module.exports = v;
|
|
12
|
-
}
|
|
13
|
-
else if (typeof define === "function" && define.amd) {
|
|
14
|
-
define("@angular/compiler-cli/ngcc/src/packages/dependency_host", ["require", "exports", "canonical-path", "fs", "typescript", "@angular/compiler-cli/src/ngtsc/path"], factory);
|
|
15
|
-
}
|
|
16
|
-
})(function (require, exports) {
|
|
17
|
-
"use strict";
|
|
18
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
-
var path = require("canonical-path");
|
|
20
|
-
var fs = require("fs");
|
|
21
|
-
var ts = require("typescript");
|
|
22
|
-
var path_1 = require("@angular/compiler-cli/src/ngtsc/path");
|
|
23
|
-
/**
|
|
24
|
-
* Helper functions for computing dependencies.
|
|
25
|
-
*/
|
|
26
|
-
var DependencyHost = /** @class */ (function () {
|
|
27
|
-
function DependencyHost() {
|
|
28
|
-
}
|
|
29
|
-
/**
|
|
30
|
-
* Get a list of the resolved paths to all the dependencies of this entry point.
|
|
31
|
-
* @param from An absolute path to the file whose dependencies we want to get.
|
|
32
|
-
* @param dependencies A set that will have the absolute paths of resolved entry points added to
|
|
33
|
-
* it.
|
|
34
|
-
* @param missing A set that will have the dependencies that could not be found added to it.
|
|
35
|
-
* @param deepImports A set that will have the import paths that exist but cannot be mapped to
|
|
36
|
-
* entry-points, i.e. deep-imports.
|
|
37
|
-
* @param internal A set that is used to track internal dependencies to prevent getting stuck in a
|
|
38
|
-
* circular dependency loop.
|
|
39
|
-
*/
|
|
40
|
-
DependencyHost.prototype.computeDependencies = function (from, dependencies, missing, deepImports, internal) {
|
|
41
|
-
var _this = this;
|
|
42
|
-
if (dependencies === void 0) { dependencies = new Set(); }
|
|
43
|
-
if (missing === void 0) { missing = new Set(); }
|
|
44
|
-
if (deepImports === void 0) { deepImports = new Set(); }
|
|
45
|
-
if (internal === void 0) { internal = new Set(); }
|
|
46
|
-
var fromContents = fs.readFileSync(from, 'utf8');
|
|
47
|
-
if (!this.hasImportOrReexportStatements(fromContents)) {
|
|
48
|
-
return { dependencies: dependencies, missing: missing, deepImports: deepImports };
|
|
49
|
-
}
|
|
50
|
-
// Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.
|
|
51
|
-
var sf = ts.createSourceFile(from, fromContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);
|
|
52
|
-
sf.statements
|
|
53
|
-
// filter out statements that are not imports or reexports
|
|
54
|
-
.filter(this.isStringImportOrReexport)
|
|
55
|
-
// Grab the id of the module that is being imported
|
|
56
|
-
.map(function (stmt) { return stmt.moduleSpecifier.text; })
|
|
57
|
-
// Resolve this module id into an absolute path
|
|
58
|
-
.forEach(function (importPath) {
|
|
59
|
-
if (importPath.startsWith('.')) {
|
|
60
|
-
// This is an internal import so follow it
|
|
61
|
-
var internalDependency = _this.resolveInternal(from, importPath);
|
|
62
|
-
// Avoid circular dependencies
|
|
63
|
-
if (!internal.has(internalDependency)) {
|
|
64
|
-
internal.add(internalDependency);
|
|
65
|
-
_this.computeDependencies(internalDependency, dependencies, missing, deepImports, internal);
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
var resolvedEntryPoint = _this.tryResolveEntryPoint(from, importPath);
|
|
70
|
-
if (resolvedEntryPoint !== null) {
|
|
71
|
-
dependencies.add(resolvedEntryPoint);
|
|
72
|
-
}
|
|
73
|
-
else {
|
|
74
|
-
// If the import could not be resolved as entry point, it either does not exist
|
|
75
|
-
// at all or is a deep import.
|
|
76
|
-
var deeplyImportedFile = _this.tryResolve(from, importPath);
|
|
77
|
-
if (deeplyImportedFile !== null) {
|
|
78
|
-
deepImports.add(importPath);
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
missing.add(importPath);
|
|
82
|
-
}
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
return { dependencies: dependencies, missing: missing, deepImports: deepImports };
|
|
87
|
-
};
|
|
88
|
-
/**
|
|
89
|
-
* Resolve an internal module import.
|
|
90
|
-
* @param from the absolute file path from where to start trying to resolve this module
|
|
91
|
-
* @param to the module specifier of the internal dependency to resolve
|
|
92
|
-
* @returns the resolved path to the import.
|
|
93
|
-
*/
|
|
94
|
-
DependencyHost.prototype.resolveInternal = function (from, to) {
|
|
95
|
-
var fromDirectory = path.dirname(from);
|
|
96
|
-
// `fromDirectory` is absolute so we don't need to worry about telling `require.resolve`
|
|
97
|
-
// about it by adding it to a `paths` parameter - unlike `tryResolve` below.
|
|
98
|
-
return path_1.AbsoluteFsPath.from(require.resolve(path.resolve(fromDirectory, to)));
|
|
99
|
-
};
|
|
100
|
-
/**
|
|
101
|
-
* We don't want to resolve external dependencies directly because if it is a path to a
|
|
102
|
-
* sub-entry-point (e.g. @angular/animations/browser rather than @angular/animations)
|
|
103
|
-
* then `require.resolve()` may return a path to a UMD bundle, which may actually live
|
|
104
|
-
* in the folder containing the sub-entry-point
|
|
105
|
-
* (e.g. @angular/animations/bundles/animations-browser.umd.js).
|
|
106
|
-
*
|
|
107
|
-
* Instead we try to resolve it as a package, which is what we would need anyway for it to be
|
|
108
|
-
* compilable by ngcc.
|
|
109
|
-
*
|
|
110
|
-
* If `to` is actually a path to a file then this will fail, which is what we want.
|
|
111
|
-
*
|
|
112
|
-
* @param from the file path from where to start trying to resolve this module
|
|
113
|
-
* @param to the module specifier of the dependency to resolve
|
|
114
|
-
* @returns the resolved path to the entry point directory of the import or null
|
|
115
|
-
* if it cannot be resolved.
|
|
116
|
-
*/
|
|
117
|
-
DependencyHost.prototype.tryResolveEntryPoint = function (from, to) {
|
|
118
|
-
var entryPoint = this.tryResolve(from, to + "/package.json");
|
|
119
|
-
return entryPoint && path_1.AbsoluteFsPath.from(path.dirname(entryPoint));
|
|
120
|
-
};
|
|
121
|
-
/**
|
|
122
|
-
* Resolve the absolute path of a module from a particular starting point.
|
|
123
|
-
*
|
|
124
|
-
* @param from the file path from where to start trying to resolve this module
|
|
125
|
-
* @param to the module specifier of the dependency to resolve
|
|
126
|
-
* @returns an absolute path to the entry-point of the dependency or null if it could not be
|
|
127
|
-
* resolved.
|
|
128
|
-
*/
|
|
129
|
-
DependencyHost.prototype.tryResolve = function (from, to) {
|
|
130
|
-
try {
|
|
131
|
-
return path_1.AbsoluteFsPath.from(require.resolve(to, { paths: [from] }));
|
|
132
|
-
}
|
|
133
|
-
catch (e) {
|
|
134
|
-
return null;
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
|
-
/**
|
|
138
|
-
* Check whether the given statement is an import with a string literal module specifier.
|
|
139
|
-
* @param stmt the statement node to check.
|
|
140
|
-
* @returns true if the statement is an import with a string literal module specifier.
|
|
141
|
-
*/
|
|
142
|
-
DependencyHost.prototype.isStringImportOrReexport = function (stmt) {
|
|
143
|
-
return ts.isImportDeclaration(stmt) ||
|
|
144
|
-
ts.isExportDeclaration(stmt) && !!stmt.moduleSpecifier &&
|
|
145
|
-
ts.isStringLiteral(stmt.moduleSpecifier);
|
|
146
|
-
};
|
|
147
|
-
/**
|
|
148
|
-
* Check whether a source file needs to be parsed for imports.
|
|
149
|
-
* This is a performance short-circuit, which saves us from creating
|
|
150
|
-
* a TypeScript AST unnecessarily.
|
|
151
|
-
*
|
|
152
|
-
* @param source The content of the source file to check.
|
|
153
|
-
*
|
|
154
|
-
* @returns false if there are definitely no import or re-export statements
|
|
155
|
-
* in this file, true otherwise.
|
|
156
|
-
*/
|
|
157
|
-
DependencyHost.prototype.hasImportOrReexportStatements = function (source) {
|
|
158
|
-
return /(import|export)\s.+from/.test(source);
|
|
159
|
-
};
|
|
160
|
-
return DependencyHost;
|
|
161
|
-
}());
|
|
162
|
-
exports.DependencyHost = DependencyHost;
|
|
163
|
-
});
|
|
164
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_host.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/dependency_host.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as path from 'canonical-path';\nimport * as fs from 'fs';\nimport * as ts from 'typescript';\n\nimport {AbsoluteFsPath, PathSegment} from '../../../src/ngtsc/path';\n\n/**\n * Helper functions for computing dependencies.\n */\nexport class DependencyHost {\n  /**\n   * Get a list of the resolved paths to all the dependencies of this entry point.\n   * @param from An absolute path to the file whose dependencies we want to get.\n   * @param dependencies A set that will have the absolute paths of resolved entry points added to\n   * it.\n   * @param missing A set that will have the dependencies that could not be found added to it.\n   * @param deepImports A set that will have the import paths that exist but cannot be mapped to\n   * entry-points, i.e. deep-imports.\n   * @param internal A set that is used to track internal dependencies to prevent getting stuck in a\n   * circular dependency loop.\n   */\n  computeDependencies(\n      from: AbsoluteFsPath, dependencies: Set<AbsoluteFsPath> = new Set(),\n      missing: Set<PathSegment> = new Set(), deepImports: Set<PathSegment> = new Set(),\n      internal: Set<AbsoluteFsPath> = new Set()): {\n    dependencies: Set<AbsoluteFsPath>,\n    missing: Set<PathSegment>,\n    deepImports: Set<PathSegment>\n  } {\n    const fromContents = fs.readFileSync(from, 'utf8');\n    if (!this.hasImportOrReexportStatements(fromContents)) {\n      return {dependencies, missing, deepImports};\n    }\n\n    // Parse the source into a TypeScript AST and then walk it looking for imports and re-exports.\n    const sf =\n        ts.createSourceFile(from, fromContents, ts.ScriptTarget.ES2015, false, ts.ScriptKind.JS);\n    sf.statements\n        // filter out statements that are not imports or reexports\n        .filter(this.isStringImportOrReexport)\n        // Grab the id of the module that is being imported\n        .map(stmt => stmt.moduleSpecifier.text)\n        // Resolve this module id into an absolute path\n        .forEach((importPath: PathSegment) => {\n          if (importPath.startsWith('.')) {\n            // This is an internal import so follow it\n            const internalDependency = this.resolveInternal(from, importPath);\n            // Avoid circular dependencies\n            if (!internal.has(internalDependency)) {\n              internal.add(internalDependency);\n              this.computeDependencies(\n                  internalDependency, dependencies, missing, deepImports, internal);\n            }\n          } else {\n            const resolvedEntryPoint = this.tryResolveEntryPoint(from, importPath);\n            if (resolvedEntryPoint !== null) {\n              dependencies.add(resolvedEntryPoint);\n            } else {\n              // If the import could not be resolved as entry point, it either does not exist\n              // at all or is a deep import.\n              const deeplyImportedFile = this.tryResolve(from, importPath);\n              if (deeplyImportedFile !== null) {\n                deepImports.add(importPath);\n              } else {\n                missing.add(importPath);\n              }\n            }\n          }\n        });\n    return {dependencies, missing, deepImports};\n  }\n\n  /**\n   * Resolve an internal module import.\n   * @param from the absolute file path from where to start trying to resolve this module\n   * @param to the module specifier of the internal dependency to resolve\n   * @returns the resolved path to the import.\n   */\n  resolveInternal(from: AbsoluteFsPath, to: PathSegment): AbsoluteFsPath {\n    const fromDirectory = path.dirname(from);\n    // `fromDirectory` is absolute so we don't need to worry about telling `require.resolve`\n    // about it by adding it to a `paths` parameter - unlike `tryResolve` below.\n    return AbsoluteFsPath.from(require.resolve(path.resolve(fromDirectory, to)));\n  }\n\n  /**\n   * We don't want to resolve external dependencies directly because if it is a path to a\n   * sub-entry-point (e.g. @angular/animations/browser rather than @angular/animations)\n   * then `require.resolve()` may return a path to a UMD bundle, which may actually live\n   * in the folder containing the sub-entry-point\n   * (e.g. @angular/animations/bundles/animations-browser.umd.js).\n   *\n   * Instead we try to resolve it as a package, which is what we would need anyway for it to be\n   * compilable by ngcc.\n   *\n   * If `to` is actually a path to a file then this will fail, which is what we want.\n   *\n   * @param from the file path from where to start trying to resolve this module\n   * @param to the module specifier of the dependency to resolve\n   * @returns the resolved path to the entry point directory of the import or null\n   * if it cannot be resolved.\n   */\n  tryResolveEntryPoint(from: AbsoluteFsPath, to: PathSegment): AbsoluteFsPath|null {\n    const entryPoint = this.tryResolve(from, `${to}/package.json` as PathSegment);\n    return entryPoint && AbsoluteFsPath.from(path.dirname(entryPoint));\n  }\n\n  /**\n   * Resolve the absolute path of a module from a particular starting point.\n   *\n   * @param from the file path from where to start trying to resolve this module\n   * @param to the module specifier of the dependency to resolve\n   * @returns an absolute path to the entry-point of the dependency or null if it could not be\n   * resolved.\n   */\n  tryResolve(from: AbsoluteFsPath, to: PathSegment): AbsoluteFsPath|null {\n    try {\n      return AbsoluteFsPath.from(require.resolve(to, {paths: [from]}));\n    } catch (e) {\n      return null;\n    }\n  }\n\n  /**\n   * Check whether the given statement is an import with a string literal module specifier.\n   * @param stmt the statement node to check.\n   * @returns true if the statement is an import with a string literal module specifier.\n   */\n  isStringImportOrReexport(stmt: ts.Statement): stmt is ts.ImportDeclaration&\n      {moduleSpecifier: ts.StringLiteral} {\n    return ts.isImportDeclaration(stmt) ||\n        ts.isExportDeclaration(stmt) && !!stmt.moduleSpecifier &&\n        ts.isStringLiteral(stmt.moduleSpecifier);\n  }\n\n  /**\n   * Check whether a source file needs to be parsed for imports.\n   * This is a performance short-circuit, which saves us from creating\n   * a TypeScript AST unnecessarily.\n   *\n   * @param source The content of the source file to check.\n   *\n   * @returns false if there are definitely no import or re-export statements\n   * in this file, true otherwise.\n   */\n  hasImportOrReexportStatements(source: string): boolean {\n    return /(import|export)\\s.+from/.test(source);\n  }\n}\n"]}
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright Google Inc. All Rights Reserved.
|
|
4
|
-
*
|
|
5
|
-
* Use of this source code is governed by an MIT-style license that can be
|
|
6
|
-
* found in the LICENSE file at https://angular.io/license
|
|
7
|
-
*/
|
|
8
|
-
(function (factory) {
|
|
9
|
-
if (typeof module === "object" && typeof module.exports === "object") {
|
|
10
|
-
var v = factory(require, exports);
|
|
11
|
-
if (v !== undefined) module.exports = v;
|
|
12
|
-
}
|
|
13
|
-
else if (typeof define === "function" && define.amd) {
|
|
14
|
-
define("@angular/compiler-cli/ngcc/src/packages/dependency_resolver", ["require", "exports", "tslib", "canonical-path", "dependency-graph", "@angular/compiler-cli/src/ngtsc/path", "@angular/compiler-cli/ngcc/src/packages/entry_point"], factory);
|
|
15
|
-
}
|
|
16
|
-
})(function (require, exports) {
|
|
17
|
-
"use strict";
|
|
18
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
19
|
-
var tslib_1 = require("tslib");
|
|
20
|
-
var canonical_path_1 = require("canonical-path");
|
|
21
|
-
var dependency_graph_1 = require("dependency-graph");
|
|
22
|
-
var path_1 = require("@angular/compiler-cli/src/ngtsc/path");
|
|
23
|
-
var entry_point_1 = require("@angular/compiler-cli/ngcc/src/packages/entry_point");
|
|
24
|
-
/**
|
|
25
|
-
* A class that resolves dependencies between entry-points.
|
|
26
|
-
*/
|
|
27
|
-
var DependencyResolver = /** @class */ (function () {
|
|
28
|
-
function DependencyResolver(logger, host) {
|
|
29
|
-
this.logger = logger;
|
|
30
|
-
this.host = host;
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* Sort the array of entry points so that the dependant entry points always come later than
|
|
34
|
-
* their dependencies in the array.
|
|
35
|
-
* @param entryPoints An array entry points to sort.
|
|
36
|
-
* @param target If provided, only return entry-points depended on by this entry-point.
|
|
37
|
-
* @returns the result of sorting the entry points by dependency.
|
|
38
|
-
*/
|
|
39
|
-
DependencyResolver.prototype.sortEntryPointsByDependency = function (entryPoints, target) {
|
|
40
|
-
var _a = this.createDependencyInfo(entryPoints), invalidEntryPoints = _a.invalidEntryPoints, ignoredDependencies = _a.ignoredDependencies, graph = _a.graph;
|
|
41
|
-
var sortedEntryPointNodes;
|
|
42
|
-
if (target) {
|
|
43
|
-
sortedEntryPointNodes = graph.dependenciesOf(target.path);
|
|
44
|
-
sortedEntryPointNodes.push(target.path);
|
|
45
|
-
}
|
|
46
|
-
else {
|
|
47
|
-
sortedEntryPointNodes = graph.overallOrder();
|
|
48
|
-
}
|
|
49
|
-
return {
|
|
50
|
-
entryPoints: sortedEntryPointNodes.map(function (path) { return graph.getNodeData(path); }),
|
|
51
|
-
invalidEntryPoints: invalidEntryPoints,
|
|
52
|
-
ignoredDependencies: ignoredDependencies,
|
|
53
|
-
};
|
|
54
|
-
};
|
|
55
|
-
/**
|
|
56
|
-
* Computes a dependency graph of the given entry-points.
|
|
57
|
-
*
|
|
58
|
-
* The graph only holds entry-points that ngcc cares about and whose dependencies
|
|
59
|
-
* (direct and transitive) all exist.
|
|
60
|
-
*/
|
|
61
|
-
DependencyResolver.prototype.createDependencyInfo = function (entryPoints) {
|
|
62
|
-
var _this = this;
|
|
63
|
-
var invalidEntryPoints = [];
|
|
64
|
-
var ignoredDependencies = [];
|
|
65
|
-
var graph = new dependency_graph_1.DepGraph();
|
|
66
|
-
// Add the entry points to the graph as nodes
|
|
67
|
-
entryPoints.forEach(function (entryPoint) { return graph.addNode(entryPoint.path, entryPoint); });
|
|
68
|
-
// Now add the dependencies between them
|
|
69
|
-
entryPoints.forEach(function (entryPoint) {
|
|
70
|
-
var entryPointPath = getEntryPointPath(entryPoint);
|
|
71
|
-
var _a = _this.host.computeDependencies(entryPointPath), dependencies = _a.dependencies, missing = _a.missing, deepImports = _a.deepImports;
|
|
72
|
-
if (missing.size > 0) {
|
|
73
|
-
// This entry point has dependencies that are missing
|
|
74
|
-
// so remove it from the graph.
|
|
75
|
-
removeNodes(entryPoint, Array.from(missing));
|
|
76
|
-
}
|
|
77
|
-
else {
|
|
78
|
-
dependencies.forEach(function (dependencyPath) {
|
|
79
|
-
if (graph.hasNode(dependencyPath)) {
|
|
80
|
-
// The dependency path maps to an entry point that exists in the graph
|
|
81
|
-
// so add the dependency.
|
|
82
|
-
graph.addDependency(entryPoint.path, dependencyPath);
|
|
83
|
-
}
|
|
84
|
-
else if (invalidEntryPoints.some(function (i) { return i.entryPoint.path === dependencyPath; })) {
|
|
85
|
-
// The dependency path maps to an entry-point that was previously removed
|
|
86
|
-
// from the graph, so remove this entry-point as well.
|
|
87
|
-
removeNodes(entryPoint, [dependencyPath]);
|
|
88
|
-
}
|
|
89
|
-
else {
|
|
90
|
-
// The dependency path points to a package that ngcc does not care about.
|
|
91
|
-
ignoredDependencies.push({ entryPoint: entryPoint, dependencyPath: dependencyPath });
|
|
92
|
-
}
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
if (deepImports.size) {
|
|
96
|
-
var imports = Array.from(deepImports).map(function (i) { return "'" + i + "'"; }).join(', ');
|
|
97
|
-
_this.logger.warn("Entry point '" + entryPoint.name + "' contains deep imports into " + imports + ". " +
|
|
98
|
-
"This is probably not a problem, but may cause the compilation of entry points to be out of order.");
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
return { invalidEntryPoints: invalidEntryPoints, ignoredDependencies: ignoredDependencies, graph: graph };
|
|
102
|
-
function removeNodes(entryPoint, missingDependencies) {
|
|
103
|
-
var nodesToRemove = tslib_1.__spread([entryPoint.path], graph.dependantsOf(entryPoint.path));
|
|
104
|
-
nodesToRemove.forEach(function (node) {
|
|
105
|
-
invalidEntryPoints.push({ entryPoint: graph.getNodeData(node), missingDependencies: missingDependencies });
|
|
106
|
-
graph.removeNode(node);
|
|
107
|
-
});
|
|
108
|
-
}
|
|
109
|
-
};
|
|
110
|
-
return DependencyResolver;
|
|
111
|
-
}());
|
|
112
|
-
exports.DependencyResolver = DependencyResolver;
|
|
113
|
-
function getEntryPointPath(entryPoint) {
|
|
114
|
-
var properties = Object.keys(entryPoint.packageJson);
|
|
115
|
-
for (var i = 0; i < properties.length; i++) {
|
|
116
|
-
var property = properties[i];
|
|
117
|
-
var format = entry_point_1.getEntryPointFormat(property);
|
|
118
|
-
if (format === 'esm2015' || format === 'esm5') {
|
|
119
|
-
var formatPath = entryPoint.packageJson[property];
|
|
120
|
-
return path_1.AbsoluteFsPath.from(canonical_path_1.resolve(entryPoint.path, formatPath));
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
throw new Error("There is no format with import statements in '" + entryPoint.path + "' entry-point.");
|
|
124
|
-
}
|
|
125
|
-
});
|
|
126
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dependency_resolver.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/packages/dependency_resolver.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport {resolve} from 'canonical-path';\nimport {DepGraph} from 'dependency-graph';\n\nimport {AbsoluteFsPath} from '../../../src/ngtsc/path';\nimport {Logger} from '../logging/logger';\n\nimport {DependencyHost} from './dependency_host';\nimport {EntryPoint, EntryPointJsonProperty, getEntryPointFormat} from './entry_point';\n\n\n/**\n * Holds information about entry points that are removed because\n * they have dependencies that are missing (directly or transitively).\n *\n * This might not be an error, because such an entry point might not actually be used\n * in the application. If it is used then the `ngc` application compilation would\n * fail also, so we don't need ngcc to catch this.\n *\n * For example, consider an application that uses the `@angular/router` package.\n * This package includes an entry-point called `@angular/router/upgrade`, which has a dependency\n * on the `@angular/upgrade` package.\n * If the application never uses code from `@angular/router/upgrade` then there is no need for\n * `@angular/upgrade` to be installed.\n * In this case the ngcc tool should just ignore the `@angular/router/upgrade` end-point.\n */\nexport interface InvalidEntryPoint {\n  entryPoint: EntryPoint;\n  missingDependencies: string[];\n}\n\n/**\n * Holds information about dependencies of an entry-point that do not need to be processed\n * by the ngcc tool.\n *\n * For example, the `rxjs` package does not contain any Angular decorators that need to be\n * compiled and so this can be safely ignored by ngcc.\n */\nexport interface IgnoredDependency {\n  entryPoint: EntryPoint;\n  dependencyPath: string;\n}\n\n/**\n * A list of entry-points, sorted by their dependencies.\n *\n * The `entryPoints` array will be ordered so that no entry point depends upon an entry point that\n * appears later in the array.\n *\n * Some entry points or their dependencies may be have been ignored. These are captured for\n * diagnostic purposes in `invalidEntryPoints` and `ignoredDependencies` respectively.\n */\nexport interface SortedEntryPointsInfo {\n  entryPoints: EntryPoint[];\n  invalidEntryPoints: InvalidEntryPoint[];\n  ignoredDependencies: IgnoredDependency[];\n}\n\n/**\n * A class that resolves dependencies between entry-points.\n */\nexport class DependencyResolver {\n  constructor(private logger: Logger, private host: DependencyHost) {}\n  /**\n   * Sort the array of entry points so that the dependant entry points always come later than\n   * their dependencies in the array.\n   * @param entryPoints An array entry points to sort.\n   * @param target If provided, only return entry-points depended on by this entry-point.\n   * @returns the result of sorting the entry points by dependency.\n   */\n  sortEntryPointsByDependency(entryPoints: EntryPoint[], target?: EntryPoint):\n      SortedEntryPointsInfo {\n    const {invalidEntryPoints, ignoredDependencies, graph} = this.createDependencyInfo(entryPoints);\n\n    let sortedEntryPointNodes: string[];\n    if (target) {\n      sortedEntryPointNodes = graph.dependenciesOf(target.path);\n      sortedEntryPointNodes.push(target.path);\n    } else {\n      sortedEntryPointNodes = graph.overallOrder();\n    }\n\n    return {\n      entryPoints: sortedEntryPointNodes.map(path => graph.getNodeData(path)),\n      invalidEntryPoints,\n      ignoredDependencies,\n    };\n  }\n\n  /**\n   * Computes a dependency graph of the given entry-points.\n   *\n   * The graph only holds entry-points that ngcc cares about and whose dependencies\n   * (direct and transitive) all exist.\n   */\n  private createDependencyInfo(entryPoints: EntryPoint[]) {\n    const invalidEntryPoints: InvalidEntryPoint[] = [];\n    const ignoredDependencies: IgnoredDependency[] = [];\n    const graph = new DepGraph<EntryPoint>();\n\n    // Add the entry points to the graph as nodes\n    entryPoints.forEach(entryPoint => graph.addNode(entryPoint.path, entryPoint));\n\n    // Now add the dependencies between them\n    entryPoints.forEach(entryPoint => {\n      const entryPointPath = getEntryPointPath(entryPoint);\n      const {dependencies, missing, deepImports} = this.host.computeDependencies(entryPointPath);\n\n      if (missing.size > 0) {\n        // This entry point has dependencies that are missing\n        // so remove it from the graph.\n        removeNodes(entryPoint, Array.from(missing));\n      } else {\n        dependencies.forEach(dependencyPath => {\n          if (graph.hasNode(dependencyPath)) {\n            // The dependency path maps to an entry point that exists in the graph\n            // so add the dependency.\n            graph.addDependency(entryPoint.path, dependencyPath);\n          } else if (invalidEntryPoints.some(i => i.entryPoint.path === dependencyPath)) {\n            // The dependency path maps to an entry-point that was previously removed\n            // from the graph, so remove this entry-point as well.\n            removeNodes(entryPoint, [dependencyPath]);\n          } else {\n            // The dependency path points to a package that ngcc does not care about.\n            ignoredDependencies.push({entryPoint, dependencyPath});\n          }\n        });\n      }\n\n      if (deepImports.size) {\n        const imports = Array.from(deepImports).map(i => `'${i}'`).join(', ');\n        this.logger.warn(\n            `Entry point '${entryPoint.name}' contains deep imports into ${imports}. ` +\n            `This is probably not a problem, but may cause the compilation of entry points to be out of order.`);\n      }\n    });\n\n    return {invalidEntryPoints, ignoredDependencies, graph};\n\n    function removeNodes(entryPoint: EntryPoint, missingDependencies: string[]) {\n      const nodesToRemove = [entryPoint.path, ...graph.dependantsOf(entryPoint.path)];\n      nodesToRemove.forEach(node => {\n        invalidEntryPoints.push({entryPoint: graph.getNodeData(node), missingDependencies});\n        graph.removeNode(node);\n      });\n    }\n  }\n}\n\nfunction getEntryPointPath(entryPoint: EntryPoint): AbsoluteFsPath {\n  const properties = Object.keys(entryPoint.packageJson);\n  for (let i = 0; i < properties.length; i++) {\n    const property = properties[i] as EntryPointJsonProperty;\n    const format = getEntryPointFormat(property);\n\n    if (format === 'esm2015' || format === 'esm5') {\n      const formatPath = entryPoint.packageJson[property] !;\n      return AbsoluteFsPath.from(resolve(entryPoint.path, formatPath));\n    }\n  }\n  throw new Error(`There is no format with import statements in '${entryPoint.path}' entry-point.`);\n}\n"]}
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
/// <amd-module name="@angular/compiler-cli/ngcc/src/rendering/esm5_renderer" />
|
|
2
|
-
import MagicString from 'magic-string';
|
|
3
|
-
import { NgccReflectionHost } from '../host/ngcc_host';
|
|
4
|
-
import { CompiledClass } from '../analysis/decoration_analyzer';
|
|
5
|
-
import { EsmRenderer } from './esm_renderer';
|
|
6
|
-
import { EntryPointBundle } from '../packages/entry_point_bundle';
|
|
7
|
-
import { Logger } from '../logging/logger';
|
|
8
|
-
export declare class Esm5Renderer extends EsmRenderer {
|
|
9
|
-
constructor(logger: Logger, host: NgccReflectionHost, isCore: boolean, bundle: EntryPointBundle, sourcePath: string);
|
|
10
|
-
/**
|
|
11
|
-
* Add the definitions to each decorated class
|
|
12
|
-
*/
|
|
13
|
-
addDefinitions(output: MagicString, compiledClass: CompiledClass, definitions: string): void;
|
|
14
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
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/rendering/esm5_renderer", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/ngcc/src/host/esm5_host", "@angular/compiler-cli/ngcc/src/rendering/esm_renderer"], factory);
|
|
8
|
-
}
|
|
9
|
-
})(function (require, exports) {
|
|
10
|
-
"use strict";
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
var tslib_1 = require("tslib");
|
|
13
|
-
/**
|
|
14
|
-
* @license
|
|
15
|
-
* Copyright Google Inc. 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
|
-
var esm5_host_1 = require("@angular/compiler-cli/ngcc/src/host/esm5_host");
|
|
22
|
-
var esm_renderer_1 = require("@angular/compiler-cli/ngcc/src/rendering/esm_renderer");
|
|
23
|
-
var Esm5Renderer = /** @class */ (function (_super) {
|
|
24
|
-
tslib_1.__extends(Esm5Renderer, _super);
|
|
25
|
-
function Esm5Renderer(logger, host, isCore, bundle, sourcePath) {
|
|
26
|
-
return _super.call(this, logger, host, isCore, bundle, sourcePath) || this;
|
|
27
|
-
}
|
|
28
|
-
/**
|
|
29
|
-
* Add the definitions to each decorated class
|
|
30
|
-
*/
|
|
31
|
-
Esm5Renderer.prototype.addDefinitions = function (output, compiledClass, definitions) {
|
|
32
|
-
var iifeBody = esm5_host_1.getIifeBody(compiledClass.declaration);
|
|
33
|
-
if (!iifeBody) {
|
|
34
|
-
throw new Error("Compiled class declaration is not inside an IIFE: " + compiledClass.name + " in " + compiledClass.declaration.getSourceFile().fileName);
|
|
35
|
-
}
|
|
36
|
-
var returnStatement = iifeBody.statements.find(ts.isReturnStatement);
|
|
37
|
-
if (!returnStatement) {
|
|
38
|
-
throw new Error("Compiled class wrapper IIFE does not have a return statement: " + compiledClass.name + " in " + compiledClass.declaration.getSourceFile().fileName);
|
|
39
|
-
}
|
|
40
|
-
var insertionPoint = returnStatement.getFullStart();
|
|
41
|
-
output.appendLeft(insertionPoint, '\n' + definitions);
|
|
42
|
-
};
|
|
43
|
-
return Esm5Renderer;
|
|
44
|
-
}(esm_renderer_1.EsmRenderer));
|
|
45
|
-
exports.Esm5Renderer = Esm5Renderer;
|
|
46
|
-
});
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNtNV9yZW5kZXJlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL2NvbXBpbGVyLWNsaS9uZ2NjL3NyYy9yZW5kZXJpbmcvZXNtNV9yZW5kZXJlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7SUFBQTs7Ozs7O09BTUc7SUFDSCwrQkFBaUM7SUFFakMsMkVBQThDO0lBRzlDLHNGQUEyQztJQUkzQztRQUFrQyx3Q0FBVztRQUMzQyxzQkFDSSxNQUFjLEVBQUUsSUFBd0IsRUFBRSxNQUFlLEVBQUUsTUFBd0IsRUFDbkYsVUFBa0I7bUJBQ3BCLGtCQUFNLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBRSxVQUFVLENBQUM7UUFDakQsQ0FBQztRQUVEOztXQUVHO1FBQ0gscUNBQWMsR0FBZCxVQUFlLE1BQW1CLEVBQUUsYUFBNEIsRUFBRSxXQUFtQjtZQUNuRixJQUFNLFFBQVEsR0FBRyx1QkFBVyxDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQUMsQ0FBQztZQUN4RCxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUNiLE1BQU0sSUFBSSxLQUFLLENBQ1gsdURBQXFELGFBQWEsQ0FBQyxJQUFJLFlBQU8sYUFBYSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxRQUFVLENBQUMsQ0FBQzthQUN6STtZQUVELElBQU0sZUFBZSxHQUFHLFFBQVEsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO1lBQ3ZFLElBQUksQ0FBQyxlQUFlLEVBQUU7Z0JBQ3BCLE1BQU0sSUFBSSxLQUFLLENBQ1gsbUVBQWlFLGFBQWEsQ0FBQyxJQUFJLFlBQU8sYUFBYSxDQUFDLFdBQVcsQ0FBQyxhQUFhLEVBQUUsQ0FBQyxRQUFVLENBQUMsQ0FBQzthQUNySjtZQUVELElBQU0sY0FBYyxHQUFHLGVBQWUsQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUN0RCxNQUFNLENBQUMsVUFBVSxDQUFDLGNBQWMsRUFBRSxJQUFJLEdBQUcsV0FBVyxDQUFDLENBQUM7UUFDeEQsQ0FBQztRQUNILG1CQUFDO0lBQUQsQ0FBQyxBQTFCRCxDQUFrQywwQkFBVyxHQTBCNUM7SUExQlksb0NBQVkiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBsaWNlbnNlXG4gKiBDb3B5cmlnaHQgR29vZ2xlIEluYy4gQWxsIFJpZ2h0cyBSZXNlcnZlZC5cbiAqXG4gKiBVc2Ugb2YgdGhpcyBzb3VyY2UgY29kZSBpcyBnb3Zlcm5lZCBieSBhbiBNSVQtc3R5bGUgbGljZW5zZSB0aGF0IGNhbiBiZVxuICogZm91bmQgaW4gdGhlIExJQ0VOU0UgZmlsZSBhdCBodHRwczovL2FuZ3VsYXIuaW8vbGljZW5zZVxuICovXG5pbXBvcnQgKiBhcyB0cyBmcm9tICd0eXBlc2NyaXB0JztcbmltcG9ydCBNYWdpY1N0cmluZyBmcm9tICdtYWdpYy1zdHJpbmcnO1xuaW1wb3J0IHtnZXRJaWZlQm9keX0gZnJvbSAnLi4vaG9zdC9lc201X2hvc3QnO1xuaW1wb3J0IHtOZ2NjUmVmbGVjdGlvbkhvc3R9IGZyb20gJy4uL2hvc3QvbmdjY19ob3N0JztcbmltcG9ydCB7Q29tcGlsZWRDbGFzc30gZnJvbSAnLi4vYW5hbHlzaXMvZGVjb3JhdGlvbl9hbmFseXplcic7XG5pbXBvcnQge0VzbVJlbmRlcmVyfSBmcm9tICcuL2VzbV9yZW5kZXJlcic7XG5pbXBvcnQge0VudHJ5UG9pbnRCdW5kbGV9IGZyb20gJy4uL3BhY2thZ2VzL2VudHJ5X3BvaW50X2J1bmRsZSc7XG5pbXBvcnQge0xvZ2dlcn0gZnJvbSAnLi4vbG9nZ2luZy9sb2dnZXInO1xuXG5leHBvcnQgY2xhc3MgRXNtNVJlbmRlcmVyIGV4dGVuZHMgRXNtUmVuZGVyZXIge1xuICBjb25zdHJ1Y3RvcihcbiAgICAgIGxvZ2dlcjogTG9nZ2VyLCBob3N0OiBOZ2NjUmVmbGVjdGlvbkhvc3QsIGlzQ29yZTogYm9vbGVhbiwgYnVuZGxlOiBFbnRyeVBvaW50QnVuZGxlLFxuICAgICAgc291cmNlUGF0aDogc3RyaW5nKSB7XG4gICAgc3VwZXIobG9nZ2VyLCBob3N0LCBpc0NvcmUsIGJ1bmRsZSwgc291cmNlUGF0aCk7XG4gIH1cblxuICAvKipcbiAgICogQWRkIHRoZSBkZWZpbml0aW9ucyB0byBlYWNoIGRlY29yYXRlZCBjbGFzc1xuICAgKi9cbiAgYWRkRGVmaW5pdGlvbnMob3V0cHV0OiBNYWdpY1N0cmluZywgY29tcGlsZWRDbGFzczogQ29tcGlsZWRDbGFzcywgZGVmaW5pdGlvbnM6IHN0cmluZyk6IHZvaWQge1xuICAgIGNvbnN0IGlpZmVCb2R5ID0gZ2V0SWlmZUJvZHkoY29tcGlsZWRDbGFzcy5kZWNsYXJhdGlvbik7XG4gICAgaWYgKCFpaWZlQm9keSkge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgICAgIGBDb21waWxlZCBjbGFzcyBkZWNsYXJhdGlvbiBpcyBub3QgaW5zaWRlIGFuIElJRkU6ICR7Y29tcGlsZWRDbGFzcy5uYW1lfSBpbiAke2NvbXBpbGVkQ2xhc3MuZGVjbGFyYXRpb24uZ2V0U291cmNlRmlsZSgpLmZpbGVOYW1lfWApO1xuICAgIH1cblxuICAgIGNvbnN0IHJldHVyblN0YXRlbWVudCA9IGlpZmVCb2R5LnN0YXRlbWVudHMuZmluZCh0cy5pc1JldHVyblN0YXRlbWVudCk7XG4gICAgaWYgKCFyZXR1cm5TdGF0ZW1lbnQpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgICBgQ29tcGlsZWQgY2xhc3Mgd3JhcHBlciBJSUZFIGRvZXMgbm90IGhhdmUgYSByZXR1cm4gc3RhdGVtZW50OiAke2NvbXBpbGVkQ2xhc3MubmFtZX0gaW4gJHtjb21waWxlZENsYXNzLmRlY2xhcmF0aW9uLmdldFNvdXJjZUZpbGUoKS5maWxlTmFtZX1gKTtcbiAgICB9XG5cbiAgICBjb25zdCBpbnNlcnRpb25Qb2ludCA9IHJldHVyblN0YXRlbWVudC5nZXRGdWxsU3RhcnQoKTtcbiAgICBvdXRwdXQuYXBwZW5kTGVmdChpbnNlcnRpb25Qb2ludCwgJ1xcbicgKyBkZWZpbml0aW9ucyk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
/// <amd-module name="@angular/compiler-cli/ngcc/src/rendering/esm_renderer" />
|
|
2
|
-
import MagicString from 'magic-string';
|
|
3
|
-
import * as ts from 'typescript';
|
|
4
|
-
import { NgccReflectionHost, SwitchableVariableDeclaration } from '../host/ngcc_host';
|
|
5
|
-
import { CompiledClass } from '../analysis/decoration_analyzer';
|
|
6
|
-
import { RedundantDecoratorMap, Renderer } from './renderer';
|
|
7
|
-
import { EntryPointBundle } from '../packages/entry_point_bundle';
|
|
8
|
-
import { ExportInfo } from '../analysis/private_declarations_analyzer';
|
|
9
|
-
import { Logger } from '../logging/logger';
|
|
10
|
-
export declare class EsmRenderer extends Renderer {
|
|
11
|
-
constructor(logger: Logger, host: NgccReflectionHost, isCore: boolean, bundle: EntryPointBundle, sourcePath: string);
|
|
12
|
-
/**
|
|
13
|
-
* Add the imports at the top of the file
|
|
14
|
-
*/
|
|
15
|
-
addImports(output: MagicString, imports: {
|
|
16
|
-
specifier: string;
|
|
17
|
-
qualifier: string;
|
|
18
|
-
}[], sf: ts.SourceFile): void;
|
|
19
|
-
addExports(output: MagicString, entryPointBasePath: string, exports: ExportInfo[]): void;
|
|
20
|
-
addConstants(output: MagicString, constants: string, file: ts.SourceFile): void;
|
|
21
|
-
/**
|
|
22
|
-
* Add the definitions to each decorated class
|
|
23
|
-
*/
|
|
24
|
-
addDefinitions(output: MagicString, compiledClass: CompiledClass, definitions: string): void;
|
|
25
|
-
/**
|
|
26
|
-
* Remove static decorator properties from classes
|
|
27
|
-
*/
|
|
28
|
-
removeDecorators(output: MagicString, decoratorsToRemove: RedundantDecoratorMap): void;
|
|
29
|
-
rewriteSwitchableDeclarations(outputText: MagicString, sourceFile: ts.SourceFile, declarations: SwitchableVariableDeclaration[]): void;
|
|
30
|
-
}
|
|
@@ -1,141 +0,0 @@
|
|
|
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/rendering/esm_renderer", ["require", "exports", "tslib", "canonical-path", "typescript", "@angular/compiler-cli/ngcc/src/host/ngcc_host", "@angular/compiler-cli/ngcc/src/rendering/renderer", "@angular/compiler-cli/src/ngtsc/util/src/typescript"], factory);
|
|
8
|
-
}
|
|
9
|
-
})(function (require, exports) {
|
|
10
|
-
"use strict";
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
var tslib_1 = require("tslib");
|
|
13
|
-
/**
|
|
14
|
-
* @license
|
|
15
|
-
* Copyright Google Inc. 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 canonical_path_1 = require("canonical-path");
|
|
21
|
-
var ts = require("typescript");
|
|
22
|
-
var ngcc_host_1 = require("@angular/compiler-cli/ngcc/src/host/ngcc_host");
|
|
23
|
-
var renderer_1 = require("@angular/compiler-cli/ngcc/src/rendering/renderer");
|
|
24
|
-
var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
|
|
25
|
-
var EsmRenderer = /** @class */ (function (_super) {
|
|
26
|
-
tslib_1.__extends(EsmRenderer, _super);
|
|
27
|
-
function EsmRenderer(logger, host, isCore, bundle, sourcePath) {
|
|
28
|
-
return _super.call(this, logger, host, isCore, bundle, sourcePath) || this;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Add the imports at the top of the file
|
|
32
|
-
*/
|
|
33
|
-
EsmRenderer.prototype.addImports = function (output, imports, sf) {
|
|
34
|
-
var insertionPoint = findEndOfImports(sf);
|
|
35
|
-
var renderedImports = imports.map(function (i) { return "import * as " + i.qualifier + " from '" + i.specifier + "';\n"; }).join('');
|
|
36
|
-
output.appendLeft(insertionPoint, renderedImports);
|
|
37
|
-
};
|
|
38
|
-
EsmRenderer.prototype.addExports = function (output, entryPointBasePath, exports) {
|
|
39
|
-
exports.forEach(function (e) {
|
|
40
|
-
var exportFrom = '';
|
|
41
|
-
var isDtsFile = typescript_1.isDtsPath(entryPointBasePath);
|
|
42
|
-
var from = isDtsFile ? e.dtsFrom : e.from;
|
|
43
|
-
if (from) {
|
|
44
|
-
var basePath = renderer_1.stripExtension(from);
|
|
45
|
-
var relativePath = './' + canonical_path_1.relative(canonical_path_1.dirname(entryPointBasePath), basePath);
|
|
46
|
-
exportFrom = entryPointBasePath !== basePath ? " from '" + relativePath + "'" : '';
|
|
47
|
-
}
|
|
48
|
-
// aliases should only be added in dts files as these are lost when rolling up dts file.
|
|
49
|
-
var exportStatement = e.alias && isDtsFile ? e.alias + " as " + e.identifier : e.identifier;
|
|
50
|
-
var exportStr = "\nexport {" + exportStatement + "}" + exportFrom + ";";
|
|
51
|
-
output.append(exportStr);
|
|
52
|
-
});
|
|
53
|
-
};
|
|
54
|
-
EsmRenderer.prototype.addConstants = function (output, constants, file) {
|
|
55
|
-
if (constants === '') {
|
|
56
|
-
return;
|
|
57
|
-
}
|
|
58
|
-
var insertionPoint = findEndOfImports(file);
|
|
59
|
-
// Append the constants to the right of the insertion point, to ensure they get ordered after
|
|
60
|
-
// added imports (those are appended left to the insertion point).
|
|
61
|
-
output.appendRight(insertionPoint, '\n' + constants + '\n');
|
|
62
|
-
};
|
|
63
|
-
/**
|
|
64
|
-
* Add the definitions to each decorated class
|
|
65
|
-
*/
|
|
66
|
-
EsmRenderer.prototype.addDefinitions = function (output, compiledClass, definitions) {
|
|
67
|
-
var classSymbol = this.host.getClassSymbol(compiledClass.declaration);
|
|
68
|
-
if (!classSymbol) {
|
|
69
|
-
throw new Error("Compiled class does not have a valid symbol: " + compiledClass.name);
|
|
70
|
-
}
|
|
71
|
-
var insertionPoint = classSymbol.valueDeclaration.getEnd();
|
|
72
|
-
output.appendLeft(insertionPoint, '\n' + definitions);
|
|
73
|
-
};
|
|
74
|
-
/**
|
|
75
|
-
* Remove static decorator properties from classes
|
|
76
|
-
*/
|
|
77
|
-
EsmRenderer.prototype.removeDecorators = function (output, decoratorsToRemove) {
|
|
78
|
-
decoratorsToRemove.forEach(function (nodesToRemove, containerNode) {
|
|
79
|
-
if (ts.isArrayLiteralExpression(containerNode)) {
|
|
80
|
-
var items = containerNode.elements;
|
|
81
|
-
if (items.length === nodesToRemove.length) {
|
|
82
|
-
// Remove the entire statement
|
|
83
|
-
var statement = findStatement(containerNode);
|
|
84
|
-
if (statement) {
|
|
85
|
-
output.remove(statement.getFullStart(), statement.getEnd());
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
else {
|
|
89
|
-
nodesToRemove.forEach(function (node) {
|
|
90
|
-
// remove any trailing comma
|
|
91
|
-
var end = (output.slice(node.getEnd(), node.getEnd() + 1) === ',') ?
|
|
92
|
-
node.getEnd() + 1 :
|
|
93
|
-
node.getEnd();
|
|
94
|
-
output.remove(node.getFullStart(), end);
|
|
95
|
-
});
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
};
|
|
100
|
-
EsmRenderer.prototype.rewriteSwitchableDeclarations = function (outputText, sourceFile, declarations) {
|
|
101
|
-
declarations.forEach(function (declaration) {
|
|
102
|
-
var start = declaration.initializer.getStart();
|
|
103
|
-
var end = declaration.initializer.getEnd();
|
|
104
|
-
var replacement = declaration.initializer.text.replace(ngcc_host_1.PRE_R3_MARKER, ngcc_host_1.POST_R3_MARKER);
|
|
105
|
-
outputText.overwrite(start, end, replacement);
|
|
106
|
-
});
|
|
107
|
-
};
|
|
108
|
-
return EsmRenderer;
|
|
109
|
-
}(renderer_1.Renderer));
|
|
110
|
-
exports.EsmRenderer = EsmRenderer;
|
|
111
|
-
function findEndOfImports(sf) {
|
|
112
|
-
var e_1, _a;
|
|
113
|
-
try {
|
|
114
|
-
for (var _b = tslib_1.__values(sf.statements), _c = _b.next(); !_c.done; _c = _b.next()) {
|
|
115
|
-
var stmt = _c.value;
|
|
116
|
-
if (!ts.isImportDeclaration(stmt) && !ts.isImportEqualsDeclaration(stmt) &&
|
|
117
|
-
!ts.isNamespaceImport(stmt)) {
|
|
118
|
-
return stmt.getStart();
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
}
|
|
122
|
-
catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
|
123
|
-
finally {
|
|
124
|
-
try {
|
|
125
|
-
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
|
126
|
-
}
|
|
127
|
-
finally { if (e_1) throw e_1.error; }
|
|
128
|
-
}
|
|
129
|
-
return 0;
|
|
130
|
-
}
|
|
131
|
-
function findStatement(node) {
|
|
132
|
-
while (node) {
|
|
133
|
-
if (ts.isExpressionStatement(node)) {
|
|
134
|
-
return node;
|
|
135
|
-
}
|
|
136
|
-
node = node.parent;
|
|
137
|
-
}
|
|
138
|
-
return undefined;
|
|
139
|
-
}
|
|
140
|
-
});
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"esm_renderer.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/rendering/esm_renderer.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {dirname, relative} from 'canonical-path';\nimport MagicString from 'magic-string';\nimport * as ts from 'typescript';\nimport {NgccReflectionHost, POST_R3_MARKER, PRE_R3_MARKER, SwitchableVariableDeclaration} from '../host/ngcc_host';\nimport {CompiledClass} from '../analysis/decoration_analyzer';\nimport {RedundantDecoratorMap, Renderer, stripExtension} from './renderer';\nimport {EntryPointBundle} from '../packages/entry_point_bundle';\nimport {ExportInfo} from '../analysis/private_declarations_analyzer';\nimport {isDtsPath} from '../../../src/ngtsc/util/src/typescript';\nimport {Logger} from '../logging/logger';\n\nexport class EsmRenderer extends Renderer {\n  constructor(\n      logger: Logger, host: NgccReflectionHost, isCore: boolean, bundle: EntryPointBundle,\n      sourcePath: string) {\n    super(logger, host, isCore, bundle, sourcePath);\n  }\n\n  /**\n   *  Add the imports at the top of the file\n   */\n  addImports(\n      output: MagicString, imports: {specifier: string; qualifier: string;}[],\n      sf: ts.SourceFile): void {\n    const insertionPoint = findEndOfImports(sf);\n    const renderedImports =\n        imports.map(i => `import * as ${i.qualifier} from '${i.specifier}';\\n`).join('');\n    output.appendLeft(insertionPoint, renderedImports);\n  }\n\n  addExports(output: MagicString, entryPointBasePath: string, exports: ExportInfo[]): void {\n    exports.forEach(e => {\n      let exportFrom = '';\n      const isDtsFile = isDtsPath(entryPointBasePath);\n      const from = isDtsFile ? e.dtsFrom : e.from;\n\n      if (from) {\n        const basePath = stripExtension(from);\n        const relativePath = './' + relative(dirname(entryPointBasePath), basePath);\n        exportFrom = entryPointBasePath !== basePath ? ` from '${relativePath}'` : '';\n      }\n\n      // aliases should only be added in dts files as these are lost when rolling up dts file.\n      const exportStatement = e.alias && isDtsFile ? `${e.alias} as ${e.identifier}` : e.identifier;\n      const exportStr = `\\nexport {${exportStatement}}${exportFrom};`;\n      output.append(exportStr);\n    });\n  }\n\n  addConstants(output: MagicString, constants: string, file: ts.SourceFile): void {\n    if (constants === '') {\n      return;\n    }\n    const insertionPoint = findEndOfImports(file);\n\n    // Append the constants to the right of the insertion point, to ensure they get ordered after\n    // added imports (those are appended left to the insertion point).\n    output.appendRight(insertionPoint, '\\n' + constants + '\\n');\n  }\n\n  /**\n   * Add the definitions to each decorated class\n   */\n  addDefinitions(output: MagicString, compiledClass: CompiledClass, definitions: string): void {\n    const classSymbol = this.host.getClassSymbol(compiledClass.declaration);\n    if (!classSymbol) {\n      throw new Error(`Compiled class does not have a valid symbol: ${compiledClass.name}`);\n    }\n    const insertionPoint = classSymbol.valueDeclaration !.getEnd();\n    output.appendLeft(insertionPoint, '\\n' + definitions);\n  }\n\n  /**\n   * Remove static decorator properties from classes\n   */\n  removeDecorators(output: MagicString, decoratorsToRemove: RedundantDecoratorMap): void {\n    decoratorsToRemove.forEach((nodesToRemove, containerNode) => {\n      if (ts.isArrayLiteralExpression(containerNode)) {\n        const items = containerNode.elements;\n        if (items.length === nodesToRemove.length) {\n          // Remove the entire statement\n          const statement = findStatement(containerNode);\n          if (statement) {\n            output.remove(statement.getFullStart(), statement.getEnd());\n          }\n        } else {\n          nodesToRemove.forEach(node => {\n            // remove any trailing comma\n            const end = (output.slice(node.getEnd(), node.getEnd() + 1) === ',') ?\n                node.getEnd() + 1 :\n                node.getEnd();\n            output.remove(node.getFullStart(), end);\n          });\n        }\n      }\n    });\n  }\n\n  rewriteSwitchableDeclarations(\n      outputText: MagicString, sourceFile: ts.SourceFile,\n      declarations: SwitchableVariableDeclaration[]): void {\n    declarations.forEach(declaration => {\n      const start = declaration.initializer.getStart();\n      const end = declaration.initializer.getEnd();\n      const replacement = declaration.initializer.text.replace(PRE_R3_MARKER, POST_R3_MARKER);\n      outputText.overwrite(start, end, replacement);\n    });\n  }\n}\n\nfunction findEndOfImports(sf: ts.SourceFile): number {\n  for (const stmt of sf.statements) {\n    if (!ts.isImportDeclaration(stmt) && !ts.isImportEqualsDeclaration(stmt) &&\n        !ts.isNamespaceImport(stmt)) {\n      return stmt.getStart();\n    }\n  }\n\n  return 0;\n}\n\nfunction findStatement(node: ts.Node) {\n  while (node) {\n    if (ts.isExpressionStatement(node)) {\n      return node;\n    }\n    node = node.parent;\n  }\n  return undefined;\n}\n"]}
|