source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/rendering/umd_rendering_formatter.js@ e29cc2e

Last change on this file since e29cc2e was e29cc2e, checked in by Ema <ema_spirova@…>, 3 years ago

primeNG components

  • Property mode set to 100644
File size: 46.7 KB
Line 
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 wrapperFn = umdModule.wrapperFn, factoryFn = umdModule.factoryFn;
59 // We need to add new `require()` calls for each import in the CommonJS initializer
60 renderCommonJsDependencies(output, wrapperFn, imports);
61 renderAmdDependencies(output, wrapperFn, imports);
62 renderGlobalDependencies(output, wrapperFn, imports);
63 renderFactoryParameters(output, factoryFn, 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, factoryFunction, imports) {
200 var parameters = factoryFunction.parameters;
201 var parameterString = imports.map(function (i) { return i.qualifier.text; }).join(',');
202 if (parameters.length > 0) {
203 var injectionPoint = parameters[0].getFullStart();
204 output.appendLeft(injectionPoint, parameterString + ',');
205 }
206 else {
207 // If there are no parameters then the factory function will look like:
208 // function () { ... }
209 // The AST does not give us a way to find the insertion point - between the two parentheses.
210 // So we must use a regular expression on the text of the function.
211 var injectionPoint = factoryFunction.getStart() + factoryFunction.getText().indexOf('()') + 1;
212 output.appendLeft(injectionPoint, parameterString);
213 }
214 }
215 /**
216 * Is this node the CommonJS conditional expression in the UMD wrapper?
217 */
218 function isCommonJSConditional(value) {
219 if (!ts.isConditionalExpression(value)) {
220 return false;
221 }
222 if (!ts.isBinaryExpression(value.condition) ||
223 value.condition.operatorToken.kind !== ts.SyntaxKind.AmpersandAmpersandToken) {
224 return false;
225 }
226 if (!oneOfBinaryConditions(value.condition, function (exp) { return isTypeOf(exp, 'exports', 'module'); })) {
227 return false;
228 }
229 if (!ts.isCallExpression(value.whenTrue) || !ts.isIdentifier(value.whenTrue.expression)) {
230 return false;
231 }
232 return value.whenTrue.expression.text === 'factory';
233 }
234 /**
235 * Is this node the AMD conditional expression in the UMD wrapper?
236 */
237 function isAmdConditional(value) {
238 if (!ts.isConditionalExpression(value)) {
239 return false;
240 }
241 if (!ts.isBinaryExpression(value.condition) ||
242 value.condition.operatorToken.kind !== ts.SyntaxKind.AmpersandAmpersandToken) {
243 return false;
244 }
245 if (!oneOfBinaryConditions(value.condition, function (exp) { return isTypeOf(exp, 'define'); })) {
246 return false;
247 }
248 if (!ts.isCallExpression(value.whenTrue) || !ts.isIdentifier(value.whenTrue.expression)) {
249 return false;
250 }
251 return value.whenTrue.expression.text === 'define';
252 }
253 /**
254 * Is this node the call to setup the global dependencies in the UMD wrapper?
255 */
256 function isGlobalFactoryCall(value) {
257 if (ts.isCallExpression(value) && !!value.parent) {
258 // Be resilient to the value being part of a comma list
259 value = isCommaExpression(value.parent) ? value.parent : value;
260 // Be resilient to the value being inside parentheses
261 value = ts.isParenthesizedExpression(value.parent) ? value.parent : value;
262 return !!value.parent && ts.isConditionalExpression(value.parent) &&
263 value.parent.whenFalse === value;
264 }
265 else {
266 return false;
267 }
268 }
269 function isCommaExpression(value) {
270 return ts.isBinaryExpression(value) && value.operatorToken.kind === ts.SyntaxKind.CommaToken;
271 }
272 /**
273 * Compute a global identifier for the given import (`i`).
274 *
275 * The identifier used to access a package when using the "global" form of a UMD bundle usually
276 * follows a special format where snake-case is conveted to camelCase and path separators are
277 * converted to dots. In addition there are special cases such as `@angular` is mapped to `ng`.
278 *
279 * For example
280 *
281 * * `@ns/package/entry-point` => `ns.package.entryPoint`
282 * * `@angular/common/testing` => `ng.common.testing`
283 * * `@angular/platform-browser-dynamic` => `ng.platformBrowserDynamic`
284 *
285 * It is possible for packages to specify completely different identifiers for attaching the package
286 * to the global, and so there is no guaranteed way to compute this.
287 * Currently, this approach appears to work for the known scenarios; also it is not known how common
288 * it is to use globals for importing packages.
289 *
290 * If it turns out that there are packages that are being used via globals, where this approach
291 * fails, we should consider implementing a configuration based solution, similar to what would go
292 * in a rollup configuration for mapping import paths to global indentifiers.
293 */
294 function getGlobalIdentifier(i) {
295 return i.specifier.replace(/^@angular\//, 'ng.')
296 .replace(/^@/, '')
297 .replace(/\//g, '.')
298 .replace(/[-_]+(.?)/g, function (_, c) { return c.toUpperCase(); })
299 .replace(/^./, function (c) { return c.toLowerCase(); });
300 }
301 function find(node, test) {
302 return test(node) ? node : node.forEachChild(function (child) { return find(child, test); });
303 }
304 function oneOfBinaryConditions(node, test) {
305 return test(node.left) || test(node.right);
306 }
307 function isTypeOf(node) {
308 var types = [];
309 for (var _i = 1; _i < arguments.length; _i++) {
310 types[_i - 1] = arguments[_i];
311 }
312 return ts.isBinaryExpression(node) && ts.isTypeOfExpression(node.left) &&
313 ts.isIdentifier(node.left.expression) && types.indexOf(node.left.expression.text) !== -1;
314 }
315});
316//# 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 {wrapperFn, factoryFn} = umdModule;\n\n    // We need to add new `require()` calls for each import in the CommonJS initializer\n    renderCommonJsDependencies(output, wrapperFn, imports);\n    renderAmdDependencies(output, wrapperFn, imports);\n    renderGlobalDependencies(output, wrapperFn, imports);\n    renderFactoryParameters(output, factoryFn, 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, factoryFunction: ts.FunctionExpression, imports: Import[]) {\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"]}
Note: See TracBrowser for help on using the repository browser.