source: trip-planner-front/node_modules/@angular/compiler-cli/ngcc/src/host/commonjs_umd_utils.js@ 6a3a178

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

initial commit

  • Property mode set to 100644
File size: 30.0 KB
Line 
1/**
2 * @license
3 * Copyright Google LLC 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/host/commonjs_umd_utils", ["require", "exports", "typescript", "@angular/compiler-cli/src/ngtsc/util/src/typescript"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 exports.skipAliases = exports.isExportsStatement = exports.isExportsAssignment = exports.isExportsDeclaration = exports.isExternalImport = exports.isRequireCall = exports.extractGetterFnExpression = exports.isDefinePropertyReexportStatement = exports.isWildcardReexportStatement = exports.findRequireCallReference = exports.findNamespaceOfIdentifier = void 0;
20 var ts = require("typescript");
21 var typescript_1 = require("@angular/compiler-cli/src/ngtsc/util/src/typescript");
22 /**
23 * Return the "namespace" of the specified `ts.Identifier` if the identifier is the RHS of a
24 * property access expression, i.e. an expression of the form `<namespace>.<id>` (in which case a
25 * `ts.Identifier` corresponding to `<namespace>` will be returned). Otherwise return `null`.
26 */
27 function findNamespaceOfIdentifier(id) {
28 return id.parent && ts.isPropertyAccessExpression(id.parent) && id.parent.name === id &&
29 ts.isIdentifier(id.parent.expression) ?
30 id.parent.expression :
31 null;
32 }
33 exports.findNamespaceOfIdentifier = findNamespaceOfIdentifier;
34 /**
35 * Return the `RequireCall` that is used to initialize the specified `ts.Identifier`, if the
36 * specified indentifier was indeed initialized with a require call in a declaration of the form:
37 * `var <id> = require('...')`
38 */
39 function findRequireCallReference(id, checker) {
40 var _a, _b;
41 var symbol = checker.getSymbolAtLocation(id) || null;
42 var declaration = (_a = symbol === null || symbol === void 0 ? void 0 : symbol.valueDeclaration) !== null && _a !== void 0 ? _a : (_b = symbol === null || symbol === void 0 ? void 0 : symbol.declarations) === null || _b === void 0 ? void 0 : _b[0];
43 var initializer = declaration && ts.isVariableDeclaration(declaration) && declaration.initializer || null;
44 return initializer && isRequireCall(initializer) ? initializer : null;
45 }
46 exports.findRequireCallReference = findRequireCallReference;
47 /**
48 * Check whether the specified `ts.Statement` is a wildcard re-export statement.
49 * I.E. an expression statement of one of the following forms:
50 * - `__export(<foo>)`
51 * - `__exportStar(<foo>)`
52 * - `tslib.__export(<foo>, exports)`
53 * - `tslib.__exportStar(<foo>, exports)`
54 */
55 function isWildcardReexportStatement(stmt) {
56 // Ensure it is a call expression statement.
57 if (!ts.isExpressionStatement(stmt) || !ts.isCallExpression(stmt.expression)) {
58 return false;
59 }
60 // Get the called function identifier.
61 // NOTE: Currently, it seems that `__export()` is used when emitting helpers inline and
62 // `__exportStar()` when importing them
63 // ([source](https://github.com/microsoft/TypeScript/blob/d7c83f023/src/compiler/transformers/module/module.ts#L1796-L1797)).
64 // So, theoretically, we only care about the formats `__export(<foo>)` and
65 // `tslib.__exportStar(<foo>, exports)`.
66 // The current implementation accepts the other two formats (`__exportStar(...)` and
67 // `tslib.__export(...)`) as well to be more future-proof (given that it is unlikely that
68 // they will introduce false positives).
69 var fnName = null;
70 if (ts.isIdentifier(stmt.expression.expression)) {
71 // Statement of the form `someFn(...)`.
72 fnName = stmt.expression.expression.text;
73 }
74 else if (ts.isPropertyAccessExpression(stmt.expression.expression) &&
75 ts.isIdentifier(stmt.expression.expression.name)) {
76 // Statement of the form `tslib.someFn(...)`.
77 fnName = stmt.expression.expression.name.text;
78 }
79 // Ensure the called function is either `__export()` or `__exportStar()`.
80 if ((fnName !== '__export') && (fnName !== '__exportStar')) {
81 return false;
82 }
83 // Ensure there is at least one argument.
84 // (The first argument is the exported thing and there will be a second `exports` argument in the
85 // case of imported helpers).
86 return stmt.expression.arguments.length > 0;
87 }
88 exports.isWildcardReexportStatement = isWildcardReexportStatement;
89 /**
90 * Check whether the statement is a re-export of the form:
91 *
92 * ```
93 * Object.defineProperty(exports, "<export-name>",
94 * { enumerable: true, get: function () { return <import-name>; } });
95 * ```
96 */
97 function isDefinePropertyReexportStatement(stmt) {
98 if (!ts.isExpressionStatement(stmt) || !ts.isCallExpression(stmt.expression)) {
99 return false;
100 }
101 // Check for Object.defineProperty
102 if (!ts.isPropertyAccessExpression(stmt.expression.expression) ||
103 !ts.isIdentifier(stmt.expression.expression.expression) ||
104 stmt.expression.expression.expression.text !== 'Object' ||
105 !ts.isIdentifier(stmt.expression.expression.name) ||
106 stmt.expression.expression.name.text !== 'defineProperty') {
107 return false;
108 }
109 var args = stmt.expression.arguments;
110 if (args.length !== 3) {
111 return false;
112 }
113 var exportsObject = args[0];
114 if (!ts.isIdentifier(exportsObject) || exportsObject.text !== 'exports') {
115 return false;
116 }
117 var propertyKey = args[1];
118 if (!ts.isStringLiteral(propertyKey)) {
119 return false;
120 }
121 var propertyDescriptor = args[2];
122 if (!ts.isObjectLiteralExpression(propertyDescriptor)) {
123 return false;
124 }
125 return (propertyDescriptor.properties.some(function (prop) { return prop.name !== undefined && ts.isIdentifier(prop.name) && prop.name.text === 'get'; }));
126 }
127 exports.isDefinePropertyReexportStatement = isDefinePropertyReexportStatement;
128 /**
129 * Extract the "value" of the getter in a `defineProperty` statement.
130 *
131 * This will return the `ts.Expression` value of a single `return` statement in the `get` method
132 * of the property definition object, or `null` if that is not possible.
133 */
134 function extractGetterFnExpression(statement) {
135 var args = statement.expression.arguments;
136 var getterFn = args[2].properties.find(function (prop) { return prop.name !== undefined && ts.isIdentifier(prop.name) && prop.name.text === 'get'; });
137 if (getterFn === undefined || !ts.isPropertyAssignment(getterFn) ||
138 !ts.isFunctionExpression(getterFn.initializer)) {
139 return null;
140 }
141 var returnStatement = getterFn.initializer.body.statements[0];
142 if (!ts.isReturnStatement(returnStatement) || returnStatement.expression === undefined) {
143 return null;
144 }
145 return returnStatement.expression;
146 }
147 exports.extractGetterFnExpression = extractGetterFnExpression;
148 /**
149 * Check whether the specified `ts.Node` represents a `require()` call, i.e. an call expression of
150 * the form: `require('<foo>')`
151 */
152 function isRequireCall(node) {
153 return ts.isCallExpression(node) && ts.isIdentifier(node.expression) &&
154 node.expression.text === 'require' && node.arguments.length === 1 &&
155 ts.isStringLiteral(node.arguments[0]);
156 }
157 exports.isRequireCall = isRequireCall;
158 /**
159 * Check whether the specified `path` is an "external" import.
160 * In other words, that it comes from a entry-point outside the current one.
161 */
162 function isExternalImport(path) {
163 return !/^\.\.?(\/|$)/.test(path);
164 }
165 exports.isExternalImport = isExternalImport;
166 /**
167 * Check whether the specified `node` is a property access expression of the form
168 * `exports.<foo>`.
169 */
170 function isExportsDeclaration(expr) {
171 return expr.parent && isExportsAssignment(expr.parent);
172 }
173 exports.isExportsDeclaration = isExportsDeclaration;
174 /**
175 * Check whether the specified `node` is an assignment expression of the form
176 * `exports.<foo> = <bar>`.
177 */
178 function isExportsAssignment(expr) {
179 return typescript_1.isAssignment(expr) && ts.isPropertyAccessExpression(expr.left) &&
180 ts.isIdentifier(expr.left.expression) && expr.left.expression.text === 'exports' &&
181 ts.isIdentifier(expr.left.name);
182 }
183 exports.isExportsAssignment = isExportsAssignment;
184 /**
185 * Check whether the specified `stmt` is an expression statement of the form
186 * `exports.<foo> = <bar>;`.
187 */
188 function isExportsStatement(stmt) {
189 return ts.isExpressionStatement(stmt) && isExportsAssignment(stmt.expression);
190 }
191 exports.isExportsStatement = isExportsStatement;
192 /**
193 * Find the far right hand side of a sequence of aliased assignements of the form
194 *
195 * ```
196 * exports.MyClass = alias1 = alias2 = <<declaration>>
197 * ```
198 *
199 * @param node the expression to parse
200 * @returns the original `node` or the far right expression of a series of assignments.
201 */
202 function skipAliases(node) {
203 while (typescript_1.isAssignment(node)) {
204 node = node.right;
205 }
206 return node;
207 }
208 exports.skipAliases = skipAliases;
209});
210//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"commonjs_umd_utils.js","sourceRoot":"","sources":["../../../../../../../../packages/compiler-cli/ngcc/src/host/commonjs_umd_utils.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\nimport * as ts from 'typescript';\nimport {Declaration} from '../../../src/ngtsc/reflection';\nimport {isAssignment} from '../../../src/ngtsc/util/src/typescript';\n\nexport interface ExportDeclaration {\n  name: string;\n  declaration: Declaration;\n}\n\n/**\n * A CommonJS or UMD wildcard re-export statement.\n *\n * The CommonJS or UMD version of `export * from 'blah';`.\n *\n * These statements can have several forms (depending, for example, on whether\n * the TypeScript helpers are imported or emitted inline). The expression can have one of the\n * following forms:\n * - `__export(firstArg)`\n * - `__exportStar(firstArg)`\n * - `tslib.__export(firstArg, exports)`\n * - `tslib.__exportStar(firstArg, exports)`\n *\n * In all cases, we only care about `firstArg`, which is the first argument of the re-export call\n * expression and can be either a `require('...')` call or an identifier (initialized via a\n * `require('...')` call).\n */\nexport interface WildcardReexportStatement extends ts.ExpressionStatement {\n  expression: ts.CallExpression;\n}\n\n/**\n * A CommonJS or UMD re-export statement using an `Object.defineProperty()` call.\n * For example:\n *\n * ```\n * Object.defineProperty(exports, \"<exported-id>\",\n *     { enumerable: true, get: function () { return <imported-id>; } });\n * ```\n */\nexport interface DefinePropertyReexportStatement extends ts.ExpressionStatement {\n  expression: ts.CallExpression&\n      {arguments: [ts.Identifier, ts.StringLiteral, ts.ObjectLiteralExpression]};\n}\n\n/**\n * A call expression that has a string literal for its first argument.\n */\nexport interface RequireCall extends ts.CallExpression {\n  arguments: ts.CallExpression['arguments']&[ts.StringLiteral];\n}\n\n\n/**\n * Return the \"namespace\" of the specified `ts.Identifier` if the identifier is the RHS of a\n * property access expression, i.e. an expression of the form `<namespace>.<id>` (in which case a\n * `ts.Identifier` corresponding to `<namespace>` will be returned). Otherwise return `null`.\n */\nexport function findNamespaceOfIdentifier(id: ts.Identifier): ts.Identifier|null {\n  return id.parent && ts.isPropertyAccessExpression(id.parent) && id.parent.name === id &&\n          ts.isIdentifier(id.parent.expression) ?\n      id.parent.expression :\n      null;\n}\n\n/**\n * Return the `RequireCall` that is used to initialize the specified `ts.Identifier`, if the\n * specified indentifier was indeed initialized with a require call in a declaration of the form:\n * `var <id> = require('...')`\n */\nexport function findRequireCallReference(id: ts.Identifier, checker: ts.TypeChecker): RequireCall|\n    null {\n  const symbol = checker.getSymbolAtLocation(id) || null;\n  const declaration = symbol?.valueDeclaration ?? symbol?.declarations?.[0];\n  const initializer =\n      declaration && ts.isVariableDeclaration(declaration) && declaration.initializer || null;\n  return initializer && isRequireCall(initializer) ? initializer : null;\n}\n\n/**\n * Check whether the specified `ts.Statement` is a wildcard re-export statement.\n * I.E. an expression statement of one of the following forms:\n * - `__export(<foo>)`\n * - `__exportStar(<foo>)`\n * - `tslib.__export(<foo>, exports)`\n * - `tslib.__exportStar(<foo>, exports)`\n */\nexport function isWildcardReexportStatement(stmt: ts.Statement): stmt is WildcardReexportStatement {\n  // Ensure it is a call expression statement.\n  if (!ts.isExpressionStatement(stmt) || !ts.isCallExpression(stmt.expression)) {\n    return false;\n  }\n\n  // Get the called function identifier.\n  // NOTE: Currently, it seems that `__export()` is used when emitting helpers inline and\n  //       `__exportStar()` when importing them\n  //       ([source](https://github.com/microsoft/TypeScript/blob/d7c83f023/src/compiler/transformers/module/module.ts#L1796-L1797)).\n  //       So, theoretically, we only care about the formats `__export(<foo>)` and\n  //       `tslib.__exportStar(<foo>, exports)`.\n  //       The current implementation accepts the other two formats (`__exportStar(...)` and\n  //       `tslib.__export(...)`) as well to be more future-proof (given that it is unlikely that\n  //       they will introduce false positives).\n  let fnName: string|null = null;\n  if (ts.isIdentifier(stmt.expression.expression)) {\n    // Statement of the form `someFn(...)`.\n    fnName = stmt.expression.expression.text;\n  } else if (\n      ts.isPropertyAccessExpression(stmt.expression.expression) &&\n      ts.isIdentifier(stmt.expression.expression.name)) {\n    // Statement of the form `tslib.someFn(...)`.\n    fnName = stmt.expression.expression.name.text;\n  }\n\n  // Ensure the called function is either `__export()` or `__exportStar()`.\n  if ((fnName !== '__export') && (fnName !== '__exportStar')) {\n    return false;\n  }\n\n  // Ensure there is at least one argument.\n  // (The first argument is the exported thing and there will be a second `exports` argument in the\n  // case of imported helpers).\n  return stmt.expression.arguments.length > 0;\n}\n\n\n/**\n * Check whether the statement is a re-export of the form:\n *\n * ```\n * Object.defineProperty(exports, \"<export-name>\",\n *     { enumerable: true, get: function () { return <import-name>; } });\n * ```\n */\nexport function isDefinePropertyReexportStatement(stmt: ts.Statement):\n    stmt is DefinePropertyReexportStatement {\n  if (!ts.isExpressionStatement(stmt) || !ts.isCallExpression(stmt.expression)) {\n    return false;\n  }\n\n  // Check for Object.defineProperty\n  if (!ts.isPropertyAccessExpression(stmt.expression.expression) ||\n      !ts.isIdentifier(stmt.expression.expression.expression) ||\n      stmt.expression.expression.expression.text !== 'Object' ||\n      !ts.isIdentifier(stmt.expression.expression.name) ||\n      stmt.expression.expression.name.text !== 'defineProperty') {\n    return false;\n  }\n\n  const args = stmt.expression.arguments;\n  if (args.length !== 3) {\n    return false;\n  }\n  const exportsObject = args[0];\n  if (!ts.isIdentifier(exportsObject) || exportsObject.text !== 'exports') {\n    return false;\n  }\n\n  const propertyKey = args[1];\n  if (!ts.isStringLiteral(propertyKey)) {\n    return false;\n  }\n\n  const propertyDescriptor = args[2];\n  if (!ts.isObjectLiteralExpression(propertyDescriptor)) {\n    return false;\n  }\n\n  return (propertyDescriptor.properties.some(\n      prop => prop.name !== undefined && ts.isIdentifier(prop.name) && prop.name.text === 'get'));\n}\n\n/**\n * Extract the \"value\" of the getter in a `defineProperty` statement.\n *\n * This will return the `ts.Expression` value of a single `return` statement in the `get` method\n * of the property definition object, or `null` if that is not possible.\n */\nexport function extractGetterFnExpression(statement: DefinePropertyReexportStatement):\n    ts.Expression|null {\n  const args = statement.expression.arguments;\n  const getterFn = args[2].properties.find(\n      prop => prop.name !== undefined && ts.isIdentifier(prop.name) && prop.name.text === 'get');\n  if (getterFn === undefined || !ts.isPropertyAssignment(getterFn) ||\n      !ts.isFunctionExpression(getterFn.initializer)) {\n    return null;\n  }\n  const returnStatement = getterFn.initializer.body.statements[0];\n  if (!ts.isReturnStatement(returnStatement) || returnStatement.expression === undefined) {\n    return null;\n  }\n  return returnStatement.expression;\n}\n\n/**\n * Check whether the specified `ts.Node` represents a `require()` call, i.e. an call expression of\n * the form: `require('<foo>')`\n */\nexport function isRequireCall(node: ts.Node): node is RequireCall {\n  return ts.isCallExpression(node) && ts.isIdentifier(node.expression) &&\n      node.expression.text === 'require' && node.arguments.length === 1 &&\n      ts.isStringLiteral(node.arguments[0]);\n}\n\n/**\n * Check whether the specified `path` is an \"external\" import.\n * In other words, that it comes from a entry-point outside the current one.\n */\nexport function isExternalImport(path: string): boolean {\n  return !/^\\.\\.?(\\/|$)/.test(path);\n}\n\n/**\n * A UMD/CommonJS style export declaration of the form `exports.<name>`.\n */\nexport interface ExportsDeclaration extends ts.PropertyAccessExpression {\n  name: ts.Identifier;\n  expression: ts.Identifier;\n  parent: ExportsAssignment;\n}\n\n/**\n * Check whether the specified `node` is a property access expression of the form\n * `exports.<foo>`.\n */\nexport function isExportsDeclaration(expr: ts.Node): expr is ExportsDeclaration {\n  return expr.parent && isExportsAssignment(expr.parent);\n}\n\n/**\n * A UMD/CommonJS style export assignment of the form `exports.<foo> = <bar>`.\n */\nexport interface ExportsAssignment extends ts.BinaryExpression {\n  left: ExportsDeclaration;\n}\n\n/**\n * Check whether the specified `node` is an assignment expression of the form\n * `exports.<foo> = <bar>`.\n */\nexport function isExportsAssignment(expr: ts.Node): expr is ExportsAssignment {\n  return isAssignment(expr) && ts.isPropertyAccessExpression(expr.left) &&\n      ts.isIdentifier(expr.left.expression) && expr.left.expression.text === 'exports' &&\n      ts.isIdentifier(expr.left.name);\n}\n\n/**\n * An expression statement of the form `exports.<foo> = <bar>;`.\n */\nexport interface ExportsStatement extends ts.ExpressionStatement {\n  expression: ExportsAssignment;\n}\n\n/**\n * Check whether the specified `stmt` is an expression statement of the form\n * `exports.<foo> = <bar>;`.\n */\nexport function isExportsStatement(stmt: ts.Node): stmt is ExportsStatement {\n  return ts.isExpressionStatement(stmt) && isExportsAssignment(stmt.expression);\n}\n\n/**\n * Find the far right hand side of a sequence of aliased assignements of the form\n *\n * ```\n * exports.MyClass = alias1 = alias2 = <<declaration>>\n * ```\n *\n * @param node the expression to parse\n * @returns the original `node` or the far right expression of a series of assignments.\n */\nexport function skipAliases(node: ts.Expression): ts.Expression {\n  while (isAssignment(node)) {\n    node = node.right;\n  }\n  return node;\n}\n"]}
Note: See TracBrowser for help on using the repository browser.