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/umd_rendering_formatter", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/ngcc/src/rendering/esm5_rendering_formatter", "@angular/compiler-cli/ngcc/src/rendering/utils"], factory);
|
---|
8 | }
|
---|
9 | })(function (require, exports) {
|
---|
10 | "use strict";
|
---|
11 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
12 | exports.UmdRenderingFormatter = void 0;
|
---|
13 | var tslib_1 = require("tslib");
|
---|
14 | var ts = require("typescript");
|
---|
15 | var esm5_rendering_formatter_1 = require("@angular/compiler-cli/ngcc/src/rendering/esm5_rendering_formatter");
|
---|
16 | var utils_1 = require("@angular/compiler-cli/ngcc/src/rendering/utils");
|
---|
17 | /**
|
---|
18 | * A RenderingFormatter that works with UMD files, instead of `import` and `export` statements
|
---|
19 | * the module is an IIFE with a factory function call with dependencies, which are defined in a
|
---|
20 | * wrapper function for AMD, CommonJS and global module formats.
|
---|
21 | */
|
---|
22 | var UmdRenderingFormatter = /** @class */ (function (_super) {
|
---|
23 | tslib_1.__extends(UmdRenderingFormatter, _super);
|
---|
24 | function UmdRenderingFormatter(fs, umdHost, isCore) {
|
---|
25 | var _this = _super.call(this, fs, umdHost, isCore) || this;
|
---|
26 | _this.umdHost = umdHost;
|
---|
27 | return _this;
|
---|
28 | }
|
---|
29 | /**
|
---|
30 | * Add the imports to the UMD module IIFE.
|
---|
31 | *
|
---|
32 | * Note that imports at "prepended" to the start of the parameter list of the factory function,
|
---|
33 | * and so also to the arguments passed to it when it is called.
|
---|
34 | * This is because there are scenarios where the factory function does not accept as many
|
---|
35 | * parameters as are passed as argument in the call. For example:
|
---|
36 | *
|
---|
37 | * ```
|
---|
38 | * (function (global, factory) {
|
---|
39 | * typeof exports === 'object' && typeof module !== 'undefined' ?
|
---|
40 | * factory(exports,require('x'),require('z')) :
|
---|
41 | * typeof define === 'function' && define.amd ?
|
---|
42 | * define(['exports', 'x', 'z'], factory) :
|
---|
43 | * (global = global || self, factory(global.myBundle = {}, global.x));
|
---|
44 | * }(this, (function (exports, x) { ... }
|
---|
45 | * ```
|
---|
46 | *
|
---|
47 | * (See that the `z` import is not being used by the factory function.)
|
---|
48 | */
|
---|
49 | UmdRenderingFormatter.prototype.addImports = function (output, imports, file) {
|
---|
50 | if (imports.length === 0) {
|
---|
51 | return;
|
---|
52 | }
|
---|
53 | // Assume there is only one UMD module in the file
|
---|
54 | var umdModule = this.umdHost.getUmdModule(file);
|
---|
55 | if (!umdModule) {
|
---|
56 | return;
|
---|
57 | }
|
---|
58 | var wrapperFunction = umdModule.wrapperFn;
|
---|
59 | // We need to add new `require()` calls for each import in the CommonJS initializer
|
---|
60 | renderCommonJsDependencies(output, wrapperFunction, imports);
|
---|
61 | renderAmdDependencies(output, wrapperFunction, imports);
|
---|
62 | renderGlobalDependencies(output, wrapperFunction, imports);
|
---|
63 | renderFactoryParameters(output, wrapperFunction, imports);
|
---|
64 | };
|
---|
65 | /**
|
---|
66 | * Add the exports to the bottom of the UMD module factory function.
|
---|
67 | */
|
---|
68 | UmdRenderingFormatter.prototype.addExports = function (output, entryPointBasePath, exports, importManager, file) {
|
---|
69 | var _this = this;
|
---|
70 | var umdModule = this.umdHost.getUmdModule(file);
|
---|
71 | if (!umdModule) {
|
---|
72 | return;
|
---|
73 | }
|
---|
74 | var factoryFunction = umdModule.factoryFn;
|
---|
75 | var lastStatement = factoryFunction.body.statements[factoryFunction.body.statements.length - 1];
|
---|
76 | var insertionPoint = lastStatement ? lastStatement.getEnd() : factoryFunction.body.getEnd() - 1;
|
---|
77 | exports.forEach(function (e) {
|
---|
78 | var basePath = utils_1.stripExtension(e.from);
|
---|
79 | var relativePath = './' + _this.fs.relative(_this.fs.dirname(entryPointBasePath), basePath);
|
---|
80 | var namedImport = entryPointBasePath !== basePath ?
|
---|
81 | importManager.generateNamedImport(relativePath, e.identifier) :
|
---|
82 | { symbol: e.identifier, moduleImport: null };
|
---|
83 | var importNamespace = namedImport.moduleImport ? namedImport.moduleImport.text + "." : '';
|
---|
84 | var exportStr = "\nexports." + e.identifier + " = " + importNamespace + namedImport.symbol + ";";
|
---|
85 | output.appendRight(insertionPoint, exportStr);
|
---|
86 | });
|
---|
87 | };
|
---|
88 | UmdRenderingFormatter.prototype.addDirectExports = function (output, exports, importManager, file) {
|
---|
89 | var e_1, _a;
|
---|
90 | var umdModule = this.umdHost.getUmdModule(file);
|
---|
91 | if (!umdModule) {
|
---|
92 | return;
|
---|
93 | }
|
---|
94 | var factoryFunction = umdModule.factoryFn;
|
---|
95 | var lastStatement = factoryFunction.body.statements[factoryFunction.body.statements.length - 1];
|
---|
96 | var insertionPoint = lastStatement ? lastStatement.getEnd() : factoryFunction.body.getEnd() - 1;
|
---|
97 | try {
|
---|
98 | for (var exports_1 = tslib_1.__values(exports), exports_1_1 = exports_1.next(); !exports_1_1.done; exports_1_1 = exports_1.next()) {
|
---|
99 | var e = exports_1_1.value;
|
---|
100 | var namedImport = importManager.generateNamedImport(e.fromModule, e.symbolName);
|
---|
101 | var importNamespace = namedImport.moduleImport ? namedImport.moduleImport.text + "." : '';
|
---|
102 | var exportStr = "\nexports." + e.asAlias + " = " + importNamespace + namedImport.symbol + ";";
|
---|
103 | output.appendRight(insertionPoint, exportStr);
|
---|
104 | }
|
---|
105 | }
|
---|
106 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
107 | finally {
|
---|
108 | try {
|
---|
109 | if (exports_1_1 && !exports_1_1.done && (_a = exports_1.return)) _a.call(exports_1);
|
---|
110 | }
|
---|
111 | finally { if (e_1) throw e_1.error; }
|
---|
112 | }
|
---|
113 | };
|
---|
114 | /**
|
---|
115 | * Add the constants to the top of the UMD factory function.
|
---|
116 | */
|
---|
117 | UmdRenderingFormatter.prototype.addConstants = function (output, constants, file) {
|
---|
118 | if (constants === '') {
|
---|
119 | return;
|
---|
120 | }
|
---|
121 | var umdModule = this.umdHost.getUmdModule(file);
|
---|
122 | if (!umdModule) {
|
---|
123 | return;
|
---|
124 | }
|
---|
125 | var factoryFunction = umdModule.factoryFn;
|
---|
126 | var firstStatement = factoryFunction.body.statements[0];
|
---|
127 | var insertionPoint = firstStatement ? firstStatement.getStart() : factoryFunction.body.getStart() + 1;
|
---|
128 | output.appendLeft(insertionPoint, '\n' + constants + '\n');
|
---|
129 | };
|
---|
130 | return UmdRenderingFormatter;
|
---|
131 | }(esm5_rendering_formatter_1.Esm5RenderingFormatter));
|
---|
132 | exports.UmdRenderingFormatter = UmdRenderingFormatter;
|
---|
133 | /**
|
---|
134 | * Add dependencies to the CommonJS part of the UMD wrapper function.
|
---|
135 | */
|
---|
136 | function renderCommonJsDependencies(output, wrapperFunction, imports) {
|
---|
137 | var conditional = find(wrapperFunction.body.statements[0], isCommonJSConditional);
|
---|
138 | if (!conditional) {
|
---|
139 | return;
|
---|
140 | }
|
---|
141 | var factoryCall = conditional.whenTrue;
|
---|
142 | var injectionPoint = factoryCall.arguments.length > 0 ?
|
---|
143 | // Add extra dependencies before the first argument
|
---|
144 | factoryCall.arguments[0].getFullStart() :
|
---|
145 | // Backup one char to account for the closing parenthesis on the call
|
---|
146 | factoryCall.getEnd() - 1;
|
---|
147 | var importString = imports.map(function (i) { return "require('" + i.specifier + "')"; }).join(',');
|
---|
148 | output.appendLeft(injectionPoint, importString + (factoryCall.arguments.length > 0 ? ',' : ''));
|
---|
149 | }
|
---|
150 | /**
|
---|
151 | * Add dependencies to the AMD part of the UMD wrapper function.
|
---|
152 | */
|
---|
153 | function renderAmdDependencies(output, wrapperFunction, imports) {
|
---|
154 | var conditional = find(wrapperFunction.body.statements[0], isAmdConditional);
|
---|
155 | if (!conditional) {
|
---|
156 | return;
|
---|
157 | }
|
---|
158 | var amdDefineCall = conditional.whenTrue;
|
---|
159 | var importString = imports.map(function (i) { return "'" + i.specifier + "'"; }).join(',');
|
---|
160 | // The dependency array (if it exists) is the second to last argument
|
---|
161 | // `define(id?, dependencies?, factory);`
|
---|
162 | var factoryIndex = amdDefineCall.arguments.length - 1;
|
---|
163 | var dependencyArray = amdDefineCall.arguments[factoryIndex - 1];
|
---|
164 | if (dependencyArray === undefined || !ts.isArrayLiteralExpression(dependencyArray)) {
|
---|
165 | // No array provided: `define(factory)` or `define(id, factory)`.
|
---|
166 | // Insert a new array in front the `factory` call.
|
---|
167 | var injectionPoint = amdDefineCall.arguments[factoryIndex].getFullStart();
|
---|
168 | output.appendLeft(injectionPoint, "[" + importString + "],");
|
---|
169 | }
|
---|
170 | else {
|
---|
171 | // Already an array
|
---|
172 | var injectionPoint = dependencyArray.elements.length > 0 ?
|
---|
173 | // Add imports before the first item.
|
---|
174 | dependencyArray.elements[0].getFullStart() :
|
---|
175 | // Backup one char to account for the closing square bracket on the array
|
---|
176 | dependencyArray.getEnd() - 1;
|
---|
177 | output.appendLeft(injectionPoint, importString + (dependencyArray.elements.length > 0 ? ',' : ''));
|
---|
178 | }
|
---|
179 | }
|
---|
180 | /**
|
---|
181 | * Add dependencies to the global part of the UMD wrapper function.
|
---|
182 | */
|
---|
183 | function renderGlobalDependencies(output, wrapperFunction, imports) {
|
---|
184 | var globalFactoryCall = find(wrapperFunction.body.statements[0], isGlobalFactoryCall);
|
---|
185 | if (!globalFactoryCall) {
|
---|
186 | return;
|
---|
187 | }
|
---|
188 | var injectionPoint = globalFactoryCall.arguments.length > 0 ?
|
---|
189 | // Add extra dependencies before the first argument
|
---|
190 | globalFactoryCall.arguments[0].getFullStart() :
|
---|
191 | // Backup one char to account for the closing parenthesis on the call
|
---|
192 | globalFactoryCall.getEnd() - 1;
|
---|
193 | var importString = imports.map(function (i) { return "global." + getGlobalIdentifier(i); }).join(',');
|
---|
194 | output.appendLeft(injectionPoint, importString + (globalFactoryCall.arguments.length > 0 ? ',' : ''));
|
---|
195 | }
|
---|
196 | /**
|
---|
197 | * Add dependency parameters to the UMD factory function.
|
---|
198 | */
|
---|
199 | function renderFactoryParameters(output, wrapperFunction, imports) {
|
---|
200 | var wrapperCall = wrapperFunction.parent;
|
---|
201 | var secondArgument = wrapperCall.arguments[1];
|
---|
202 | if (!secondArgument) {
|
---|
203 | return;
|
---|
204 | }
|
---|
205 | // Be resilient to the factory being inside parentheses
|
---|
206 | var factoryFunction = ts.isParenthesizedExpression(secondArgument) ? secondArgument.expression : secondArgument;
|
---|
207 | if (!ts.isFunctionExpression(factoryFunction)) {
|
---|
208 | return;
|
---|
209 | }
|
---|
210 | var parameters = factoryFunction.parameters;
|
---|
211 | var parameterString = imports.map(function (i) { return i.qualifier.text; }).join(',');
|
---|
212 | if (parameters.length > 0) {
|
---|
213 | var injectionPoint = parameters[0].getFullStart();
|
---|
214 | output.appendLeft(injectionPoint, parameterString + ',');
|
---|
215 | }
|
---|
216 | else {
|
---|
217 | // If there are no parameters then the factory function will look like:
|
---|
218 | // function () { ... }
|
---|
219 | // The AST does not give us a way to find the insertion point - between the two parentheses.
|
---|
220 | // So we must use a regular expression on the text of the function.
|
---|
221 | var injectionPoint = factoryFunction.getStart() + factoryFunction.getText().indexOf('()') + 1;
|
---|
222 | output.appendLeft(injectionPoint, parameterString);
|
---|
223 | }
|
---|
224 | }
|
---|
225 | /**
|
---|
226 | * Is this node the CommonJS conditional expression in the UMD wrapper?
|
---|
227 | */
|
---|
228 | function isCommonJSConditional(value) {
|
---|
229 | if (!ts.isConditionalExpression(value)) {
|
---|
230 | return false;
|
---|
231 | }
|
---|
232 | if (!ts.isBinaryExpression(value.condition) ||
|
---|
233 | value.condition.operatorToken.kind !== ts.SyntaxKind.AmpersandAmpersandToken) {
|
---|
234 | return false;
|
---|
235 | }
|
---|
236 | if (!oneOfBinaryConditions(value.condition, function (exp) { return isTypeOf(exp, 'exports', 'module'); })) {
|
---|
237 | return false;
|
---|
238 | }
|
---|
239 | if (!ts.isCallExpression(value.whenTrue) || !ts.isIdentifier(value.whenTrue.expression)) {
|
---|
240 | return false;
|
---|
241 | }
|
---|
242 | return value.whenTrue.expression.text === 'factory';
|
---|
243 | }
|
---|
244 | /**
|
---|
245 | * Is this node the AMD conditional expression in the UMD wrapper?
|
---|
246 | */
|
---|
247 | function isAmdConditional(value) {
|
---|
248 | if (!ts.isConditionalExpression(value)) {
|
---|
249 | return false;
|
---|
250 | }
|
---|
251 | if (!ts.isBinaryExpression(value.condition) ||
|
---|
252 | value.condition.operatorToken.kind !== ts.SyntaxKind.AmpersandAmpersandToken) {
|
---|
253 | return false;
|
---|
254 | }
|
---|
255 | if (!oneOfBinaryConditions(value.condition, function (exp) { return isTypeOf(exp, 'define'); })) {
|
---|
256 | return false;
|
---|
257 | }
|
---|
258 | if (!ts.isCallExpression(value.whenTrue) || !ts.isIdentifier(value.whenTrue.expression)) {
|
---|
259 | return false;
|
---|
260 | }
|
---|
261 | return value.whenTrue.expression.text === 'define';
|
---|
262 | }
|
---|
263 | /**
|
---|
264 | * Is this node the call to setup the global dependencies in the UMD wrapper?
|
---|
265 | */
|
---|
266 | function isGlobalFactoryCall(value) {
|
---|
267 | if (ts.isCallExpression(value) && !!value.parent) {
|
---|
268 | // Be resilient to the value being part of a comma list
|
---|
269 | value = isCommaExpression(value.parent) ? value.parent : value;
|
---|
270 | // Be resilient to the value being inside parentheses
|
---|
271 | value = ts.isParenthesizedExpression(value.parent) ? value.parent : value;
|
---|
272 | return !!value.parent && ts.isConditionalExpression(value.parent) &&
|
---|
273 | value.parent.whenFalse === value;
|
---|
274 | }
|
---|
275 | else {
|
---|
276 | return false;
|
---|
277 | }
|
---|
278 | }
|
---|
279 | function isCommaExpression(value) {
|
---|
280 | return ts.isBinaryExpression(value) && value.operatorToken.kind === ts.SyntaxKind.CommaToken;
|
---|
281 | }
|
---|
282 | /**
|
---|
283 | * Compute a global identifier for the given import (`i`).
|
---|
284 | *
|
---|
285 | * The identifier used to access a package when using the "global" form of a UMD bundle usually
|
---|
286 | * follows a special format where snake-case is conveted to camelCase and path separators are
|
---|
287 | * converted to dots. In addition there are special cases such as `@angular` is mapped to `ng`.
|
---|
288 | *
|
---|
289 | * For example
|
---|
290 | *
|
---|
291 | * * `@ns/package/entry-point` => `ns.package.entryPoint`
|
---|
292 | * * `@angular/common/testing` => `ng.common.testing`
|
---|
293 | * * `@angular/platform-browser-dynamic` => `ng.platformBrowserDynamic`
|
---|
294 | *
|
---|
295 | * It is possible for packages to specify completely different identifiers for attaching the package
|
---|
296 | * to the global, and so there is no guaranteed way to compute this.
|
---|
297 | * Currently, this approach appears to work for the known scenarios; also it is not known how common
|
---|
298 | * it is to use globals for importing packages.
|
---|
299 | *
|
---|
300 | * If it turns out that there are packages that are being used via globals, where this approach
|
---|
301 | * fails, we should consider implementing a configuration based solution, similar to what would go
|
---|
302 | * in a rollup configuration for mapping import paths to global indentifiers.
|
---|
303 | */
|
---|
304 | function getGlobalIdentifier(i) {
|
---|
305 | return i.specifier.replace(/^@angular\//, 'ng.')
|
---|
306 | .replace(/^@/, '')
|
---|
307 | .replace(/\//g, '.')
|
---|
308 | .replace(/[-_]+(.?)/g, function (_, c) { return c.toUpperCase(); })
|
---|
309 | .replace(/^./, function (c) { return c.toLowerCase(); });
|
---|
310 | }
|
---|
311 | function find(node, test) {
|
---|
312 | return test(node) ? node : node.forEachChild(function (child) { return find(child, test); });
|
---|
313 | }
|
---|
314 | function oneOfBinaryConditions(node, test) {
|
---|
315 | return test(node.left) || test(node.right);
|
---|
316 | }
|
---|
317 | function isTypeOf(node) {
|
---|
318 | var types = [];
|
---|
319 | for (var _i = 1; _i < arguments.length; _i++) {
|
---|
320 | types[_i - 1] = arguments[_i];
|
---|
321 | }
|
---|
322 | return ts.isBinaryExpression(node) && ts.isTypeOfExpression(node.left) &&
|
---|
323 | ts.isIdentifier(node.left.expression) && types.indexOf(node.left.expression.text) !== -1;
|
---|
324 | }
|
---|
325 | });
|
---|
326 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"umd_rendering_formatter.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/rendering/umd_rendering_formatter.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 MagicString from 'magic-string';\nimport * as ts from 'typescript';\n\nimport {PathManipulation} from '../../../src/ngtsc/file_system';\nimport {Reexport} from '../../../src/ngtsc/imports';\nimport {Import, ImportManager} from '../../../src/ngtsc/translator';\nimport {ExportInfo} from '../analysis/private_declarations_analyzer';\nimport {UmdReflectionHost} from '../host/umd_host';\n\nimport {Esm5RenderingFormatter} from './esm5_rendering_formatter';\nimport {stripExtension} from './utils';\n\ntype CommonJsConditional = ts.ConditionalExpression&{whenTrue: ts.CallExpression};\ntype AmdConditional = ts.ConditionalExpression&{whenTrue: ts.CallExpression};\n\n/**\n * A RenderingFormatter that works with UMD files, instead of `import` and `export` statements\n * the module is an IIFE with a factory function call with dependencies, which are defined in a\n * wrapper function for AMD, CommonJS and global module formats.\n */\nexport class UmdRenderingFormatter extends Esm5RenderingFormatter {\n  constructor(fs: PathManipulation, protected umdHost: UmdReflectionHost, isCore: boolean) {\n    super(fs, umdHost, isCore);\n  }\n\n  /**\n   * Add the imports to the UMD module IIFE.\n   *\n   * Note that imports at \"prepended\" to the start of the parameter list of the factory function,\n   * and so also to the arguments passed to it when it is called.\n   * This is because there are scenarios where the factory function does not accept as many\n   * parameters as are passed as argument in the call. For example:\n   *\n   * ```\n   * (function (global, factory) {\n   *     typeof exports === 'object' && typeof module !== 'undefined' ?\n   *         factory(exports,require('x'),require('z')) :\n   *     typeof define === 'function' && define.amd ?\n   *         define(['exports', 'x', 'z'], factory) :\n   *     (global = global || self, factory(global.myBundle = {}, global.x));\n   * }(this, (function (exports, x) { ... }\n   * ```\n   *\n   * (See that the `z` import is not being used by the factory function.)\n   */\n  override addImports(output: MagicString, imports: Import[], file: ts.SourceFile): void {\n    if (imports.length === 0) {\n      return;\n    }\n\n    // Assume there is only one UMD module in the file\n    const umdModule = this.umdHost.getUmdModule(file);\n    if (!umdModule) {\n      return;\n    }\n\n    const wrapperFunction = umdModule.wrapperFn;\n\n    // We need to add new `require()` calls for each import in the CommonJS initializer\n    renderCommonJsDependencies(output, wrapperFunction, imports);\n    renderAmdDependencies(output, wrapperFunction, imports);\n    renderGlobalDependencies(output, wrapperFunction, imports);\n    renderFactoryParameters(output, wrapperFunction, imports);\n  }\n\n  /**\n   * Add the exports to the bottom of the UMD module factory function.\n   */\n  override addExports(\n      output: MagicString, entryPointBasePath: string, exports: ExportInfo[],\n      importManager: ImportManager, file: ts.SourceFile): void {\n    const umdModule = this.umdHost.getUmdModule(file);\n    if (!umdModule) {\n      return;\n    }\n    const factoryFunction = umdModule.factoryFn;\n    const lastStatement =\n        factoryFunction.body.statements[factoryFunction.body.statements.length - 1];\n    const insertionPoint =\n        lastStatement ? lastStatement.getEnd() : factoryFunction.body.getEnd() - 1;\n    exports.forEach(e => {\n      const basePath = stripExtension(e.from);\n      const relativePath = './' + this.fs.relative(this.fs.dirname(entryPointBasePath), basePath);\n      const namedImport = entryPointBasePath !== basePath ?\n          importManager.generateNamedImport(relativePath, e.identifier) :\n          {symbol: e.identifier, moduleImport: null};\n      const importNamespace = namedImport.moduleImport ? `${namedImport.moduleImport.text}.` : '';\n      const exportStr = `\\nexports.${e.identifier} = ${importNamespace}${namedImport.symbol};`;\n      output.appendRight(insertionPoint, exportStr);\n    });\n  }\n\n  override addDirectExports(\n      output: MagicString, exports: Reexport[], importManager: ImportManager,\n      file: ts.SourceFile): void {\n    const umdModule = this.umdHost.getUmdModule(file);\n    if (!umdModule) {\n      return;\n    }\n    const factoryFunction = umdModule.factoryFn;\n    const lastStatement =\n        factoryFunction.body.statements[factoryFunction.body.statements.length - 1];\n    const insertionPoint =\n        lastStatement ? lastStatement.getEnd() : factoryFunction.body.getEnd() - 1;\n    for (const e of exports) {\n      const namedImport = importManager.generateNamedImport(e.fromModule, e.symbolName);\n      const importNamespace = namedImport.moduleImport ? `${namedImport.moduleImport.text}.` : '';\n      const exportStr = `\\nexports.${e.asAlias} = ${importNamespace}${namedImport.symbol};`;\n      output.appendRight(insertionPoint, exportStr);\n    }\n  }\n\n  /**\n   * Add the constants to the top of the UMD factory function.\n   */\n  override addConstants(output: MagicString, constants: string, file: ts.SourceFile): void {\n    if (constants === '') {\n      return;\n    }\n    const umdModule = this.umdHost.getUmdModule(file);\n    if (!umdModule) {\n      return;\n    }\n    const factoryFunction = umdModule.factoryFn;\n    const firstStatement = factoryFunction.body.statements[0];\n    const insertionPoint =\n        firstStatement ? firstStatement.getStart() : factoryFunction.body.getStart() + 1;\n    output.appendLeft(insertionPoint, '\\n' + constants + '\\n');\n  }\n}\n\n/**\n * Add dependencies to the CommonJS part of the UMD wrapper function.\n */\nfunction renderCommonJsDependencies(\n    output: MagicString, wrapperFunction: ts.FunctionExpression, imports: Import[]) {\n  const conditional = find(wrapperFunction.body.statements[0], isCommonJSConditional);\n  if (!conditional) {\n    return;\n  }\n  const factoryCall = conditional.whenTrue;\n  const injectionPoint = factoryCall.arguments.length > 0 ?\n      // Add extra dependencies before the first argument\n      factoryCall.arguments[0].getFullStart() :\n      // Backup one char to account for the closing parenthesis on the call\n      factoryCall.getEnd() - 1;\n  const importString = imports.map(i => `require('${i.specifier}')`).join(',');\n  output.appendLeft(injectionPoint, importString + (factoryCall.arguments.length > 0 ? ',' : ''));\n}\n\n/**\n * Add dependencies to the AMD part of the UMD wrapper function.\n */\nfunction renderAmdDependencies(\n    output: MagicString, wrapperFunction: ts.FunctionExpression, imports: Import[]) {\n  const conditional = find(wrapperFunction.body.statements[0], isAmdConditional);\n  if (!conditional) {\n    return;\n  }\n  const amdDefineCall = conditional.whenTrue;\n  const importString = imports.map(i => `'${i.specifier}'`).join(',');\n  // The dependency array (if it exists) is the second to last argument\n  // `define(id?, dependencies?, factory);`\n  const factoryIndex = amdDefineCall.arguments.length - 1;\n  const dependencyArray = amdDefineCall.arguments[factoryIndex - 1];\n  if (dependencyArray === undefined || !ts.isArrayLiteralExpression(dependencyArray)) {\n    // No array provided: `define(factory)` or `define(id, factory)`.\n    // Insert a new array in front the `factory` call.\n    const injectionPoint = amdDefineCall.arguments[factoryIndex].getFullStart();\n    output.appendLeft(injectionPoint, `[${importString}],`);\n  } else {\n    // Already an array\n    const injectionPoint = dependencyArray.elements.length > 0 ?\n        // Add imports before the first item.\n        dependencyArray.elements[0].getFullStart() :\n        // Backup one char to account for the closing square bracket on the array\n        dependencyArray.getEnd() - 1;\n    output.appendLeft(\n        injectionPoint, importString + (dependencyArray.elements.length > 0 ? ',' : ''));\n  }\n}\n\n/**\n * Add dependencies to the global part of the UMD wrapper function.\n */\nfunction renderGlobalDependencies(\n    output: MagicString, wrapperFunction: ts.FunctionExpression, imports: Import[]) {\n  const globalFactoryCall = find(wrapperFunction.body.statements[0], isGlobalFactoryCall);\n  if (!globalFactoryCall) {\n    return;\n  }\n  const injectionPoint = globalFactoryCall.arguments.length > 0 ?\n      // Add extra dependencies before the first argument\n      globalFactoryCall.arguments[0].getFullStart() :\n      // Backup one char to account for the closing parenthesis on the call\n      globalFactoryCall.getEnd() - 1;\n  const importString = imports.map(i => `global.${getGlobalIdentifier(i)}`).join(',');\n  output.appendLeft(\n      injectionPoint, importString + (globalFactoryCall.arguments.length > 0 ? ',' : ''));\n}\n\n/**\n * Add dependency parameters to the UMD factory function.\n */\nfunction renderFactoryParameters(\n    output: MagicString, wrapperFunction: ts.FunctionExpression, imports: Import[]) {\n  const wrapperCall = wrapperFunction.parent as ts.CallExpression;\n  const secondArgument = wrapperCall.arguments[1];\n  if (!secondArgument) {\n    return;\n  }\n\n  // Be resilient to the factory being inside parentheses\n  const factoryFunction =\n      ts.isParenthesizedExpression(secondArgument) ? secondArgument.expression : secondArgument;\n  if (!ts.isFunctionExpression(factoryFunction)) {\n    return;\n  }\n\n  const parameters = factoryFunction.parameters;\n  const parameterString = imports.map(i => i.qualifier.text).join(',');\n  if (parameters.length > 0) {\n    const injectionPoint = parameters[0].getFullStart();\n    output.appendLeft(injectionPoint, parameterString + ',');\n  } else {\n    // If there are no parameters then the factory function will look like:\n    // function () { ... }\n    // The AST does not give us a way to find the insertion point - between the two parentheses.\n    // So we must use a regular expression on the text of the function.\n    const injectionPoint = factoryFunction.getStart() + factoryFunction.getText().indexOf('()') + 1;\n    output.appendLeft(injectionPoint, parameterString);\n  }\n}\n\n/**\n * Is this node the CommonJS conditional expression in the UMD wrapper?\n */\nfunction isCommonJSConditional(value: ts.Node): value is CommonJsConditional {\n  if (!ts.isConditionalExpression(value)) {\n    return false;\n  }\n  if (!ts.isBinaryExpression(value.condition) ||\n      value.condition.operatorToken.kind !== ts.SyntaxKind.AmpersandAmpersandToken) {\n    return false;\n  }\n  if (!oneOfBinaryConditions(value.condition, (exp) => isTypeOf(exp, 'exports', 'module'))) {\n    return false;\n  }\n  if (!ts.isCallExpression(value.whenTrue) || !ts.isIdentifier(value.whenTrue.expression)) {\n    return false;\n  }\n  return value.whenTrue.expression.text === 'factory';\n}\n\n/**\n * Is this node the AMD conditional expression in the UMD wrapper?\n */\nfunction isAmdConditional(value: ts.Node): value is AmdConditional {\n  if (!ts.isConditionalExpression(value)) {\n    return false;\n  }\n  if (!ts.isBinaryExpression(value.condition) ||\n      value.condition.operatorToken.kind !== ts.SyntaxKind.AmpersandAmpersandToken) {\n    return false;\n  }\n  if (!oneOfBinaryConditions(value.condition, (exp) => isTypeOf(exp, 'define'))) {\n    return false;\n  }\n  if (!ts.isCallExpression(value.whenTrue) || !ts.isIdentifier(value.whenTrue.expression)) {\n    return false;\n  }\n  return value.whenTrue.expression.text === 'define';\n}\n\n/**\n * Is this node the call to setup the global dependencies in the UMD wrapper?\n */\nfunction isGlobalFactoryCall(value: ts.Node): value is ts.CallExpression {\n  if (ts.isCallExpression(value) && !!value.parent) {\n    // Be resilient to the value being part of a comma list\n    value = isCommaExpression(value.parent) ? value.parent : value;\n    // Be resilient to the value being inside parentheses\n    value = ts.isParenthesizedExpression(value.parent) ? value.parent : value;\n    return !!value.parent && ts.isConditionalExpression(value.parent) &&\n        value.parent.whenFalse === value;\n  } else {\n    return false;\n  }\n}\n\nfunction isCommaExpression(value: ts.Node): value is ts.BinaryExpression {\n  return ts.isBinaryExpression(value) && value.operatorToken.kind === ts.SyntaxKind.CommaToken;\n}\n\n/**\n * Compute a global identifier for the given import (`i`).\n *\n * The identifier used to access a package when using the \"global\" form of a UMD bundle usually\n * follows a special format where snake-case is conveted to camelCase and path separators are\n * converted to dots. In addition there are special cases such as `@angular` is mapped to `ng`.\n *\n * For example\n *\n * * `@ns/package/entry-point` => `ns.package.entryPoint`\n * * `@angular/common/testing` => `ng.common.testing`\n * * `@angular/platform-browser-dynamic` => `ng.platformBrowserDynamic`\n *\n * It is possible for packages to specify completely different identifiers for attaching the package\n * to the global, and so there is no guaranteed way to compute this.\n * Currently, this approach appears to work for the known scenarios; also it is not known how common\n * it is to use globals for importing packages.\n *\n * If it turns out that there are packages that are being used via globals, where this approach\n * fails, we should consider implementing a configuration based solution, similar to what would go\n * in a rollup configuration for mapping import paths to global indentifiers.\n */\nfunction getGlobalIdentifier(i: Import): string {\n  return i.specifier.replace(/^@angular\\//, 'ng.')\n      .replace(/^@/, '')\n      .replace(/\\//g, '.')\n      .replace(/[-_]+(.?)/g, (_, c) => c.toUpperCase())\n      .replace(/^./, c => c.toLowerCase());\n}\n\nfunction find<T>(node: ts.Node, test: (node: ts.Node) => node is ts.Node & T): T|undefined {\n  return test(node) ? node : node.forEachChild(child => find<T>(child, test));\n}\n\nfunction oneOfBinaryConditions(\n    node: ts.BinaryExpression, test: (expression: ts.Expression) => boolean) {\n  return test(node.left) || test(node.right);\n}\n\nfunction isTypeOf(node: ts.Expression, ...types: string[]): boolean {\n  return ts.isBinaryExpression(node) && ts.isTypeOfExpression(node.left) &&\n      ts.isIdentifier(node.left.expression) && types.indexOf(node.left.expression.text) !== -1;\n}\n"]} |
---|