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/linker/babel/src/ast/babel_ast_host", ["require", "exports", "tslib", "@babel/types", "@angular/compiler-cli/linker"], factory);
|
---|
15 | }
|
---|
16 | })(function (require, exports) {
|
---|
17 | "use strict";
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.BabelAstHost = void 0;
|
---|
20 | var tslib_1 = require("tslib");
|
---|
21 | var t = require("@babel/types");
|
---|
22 | var linker_1 = require("@angular/compiler-cli/linker");
|
---|
23 | /**
|
---|
24 | * This implementation of `AstHost` is able to get information from Babel AST nodes.
|
---|
25 | */
|
---|
26 | var BabelAstHost = /** @class */ (function () {
|
---|
27 | function BabelAstHost() {
|
---|
28 | this.isStringLiteral = t.isStringLiteral;
|
---|
29 | this.isNumericLiteral = t.isNumericLiteral;
|
---|
30 | this.isArrayLiteral = t.isArrayExpression;
|
---|
31 | this.isObjectLiteral = t.isObjectExpression;
|
---|
32 | this.isCallExpression = t.isCallExpression;
|
---|
33 | }
|
---|
34 | BabelAstHost.prototype.getSymbolName = function (node) {
|
---|
35 | if (t.isIdentifier(node)) {
|
---|
36 | return node.name;
|
---|
37 | }
|
---|
38 | else if (t.isMemberExpression(node) && t.isIdentifier(node.property)) {
|
---|
39 | return node.property.name;
|
---|
40 | }
|
---|
41 | else {
|
---|
42 | return null;
|
---|
43 | }
|
---|
44 | };
|
---|
45 | BabelAstHost.prototype.parseStringLiteral = function (str) {
|
---|
46 | linker_1.assert(str, t.isStringLiteral, 'a string literal');
|
---|
47 | return str.value;
|
---|
48 | };
|
---|
49 | BabelAstHost.prototype.parseNumericLiteral = function (num) {
|
---|
50 | linker_1.assert(num, t.isNumericLiteral, 'a numeric literal');
|
---|
51 | return num.value;
|
---|
52 | };
|
---|
53 | BabelAstHost.prototype.isBooleanLiteral = function (bool) {
|
---|
54 | return t.isBooleanLiteral(bool) || isMinifiedBooleanLiteral(bool);
|
---|
55 | };
|
---|
56 | BabelAstHost.prototype.parseBooleanLiteral = function (bool) {
|
---|
57 | if (t.isBooleanLiteral(bool)) {
|
---|
58 | return bool.value;
|
---|
59 | }
|
---|
60 | else if (isMinifiedBooleanLiteral(bool)) {
|
---|
61 | return !bool.argument.value;
|
---|
62 | }
|
---|
63 | else {
|
---|
64 | throw new linker_1.FatalLinkerError(bool, 'Unsupported syntax, expected a boolean literal.');
|
---|
65 | }
|
---|
66 | };
|
---|
67 | BabelAstHost.prototype.parseArrayLiteral = function (array) {
|
---|
68 | linker_1.assert(array, t.isArrayExpression, 'an array literal');
|
---|
69 | return array.elements.map(function (element) {
|
---|
70 | linker_1.assert(element, isNotEmptyElement, 'element in array not to be empty');
|
---|
71 | linker_1.assert(element, isNotSpreadElement, 'element in array not to use spread syntax');
|
---|
72 | return element;
|
---|
73 | });
|
---|
74 | };
|
---|
75 | BabelAstHost.prototype.parseObjectLiteral = function (obj) {
|
---|
76 | var e_1, _a;
|
---|
77 | linker_1.assert(obj, t.isObjectExpression, 'an object literal');
|
---|
78 | var result = new Map();
|
---|
79 | try {
|
---|
80 | for (var _b = tslib_1.__values(obj.properties), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
81 | var property = _c.value;
|
---|
82 | linker_1.assert(property, t.isObjectProperty, 'a property assignment');
|
---|
83 | linker_1.assert(property.value, t.isExpression, 'an expression');
|
---|
84 | linker_1.assert(property.key, isPropertyName, 'a property name');
|
---|
85 | var key = t.isIdentifier(property.key) ? property.key.name : property.key.value;
|
---|
86 | result.set(key, property.value);
|
---|
87 | }
|
---|
88 | }
|
---|
89 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
90 | finally {
|
---|
91 | try {
|
---|
92 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
93 | }
|
---|
94 | finally { if (e_1) throw e_1.error; }
|
---|
95 | }
|
---|
96 | return result;
|
---|
97 | };
|
---|
98 | BabelAstHost.prototype.isFunctionExpression = function (node) {
|
---|
99 | return t.isFunction(node);
|
---|
100 | };
|
---|
101 | BabelAstHost.prototype.parseReturnValue = function (fn) {
|
---|
102 | linker_1.assert(fn, this.isFunctionExpression, 'a function');
|
---|
103 | if (!t.isBlockStatement(fn.body)) {
|
---|
104 | // it is a simple array function expression: `(...) => expr`
|
---|
105 | return fn.body;
|
---|
106 | }
|
---|
107 | // it is a function (arrow or normal) with a body. E.g.:
|
---|
108 | // * `(...) => { stmt; ... }`
|
---|
109 | // * `function(...) { stmt; ... }`
|
---|
110 | if (fn.body.body.length !== 1) {
|
---|
111 | throw new linker_1.FatalLinkerError(fn.body, 'Unsupported syntax, expected a function body with a single return statement.');
|
---|
112 | }
|
---|
113 | var stmt = fn.body.body[0];
|
---|
114 | linker_1.assert(stmt, t.isReturnStatement, 'a function body with a single return statement');
|
---|
115 | if (stmt.argument === null) {
|
---|
116 | throw new linker_1.FatalLinkerError(stmt, 'Unsupported syntax, expected function to return a value.');
|
---|
117 | }
|
---|
118 | return stmt.argument;
|
---|
119 | };
|
---|
120 | BabelAstHost.prototype.parseCallee = function (call) {
|
---|
121 | linker_1.assert(call, t.isCallExpression, 'a call expression');
|
---|
122 | linker_1.assert(call.callee, t.isExpression, 'an expression');
|
---|
123 | return call.callee;
|
---|
124 | };
|
---|
125 | BabelAstHost.prototype.parseArguments = function (call) {
|
---|
126 | linker_1.assert(call, t.isCallExpression, 'a call expression');
|
---|
127 | return call.arguments.map(function (arg) {
|
---|
128 | linker_1.assert(arg, isNotSpreadArgument, 'argument not to use spread syntax');
|
---|
129 | linker_1.assert(arg, t.isExpression, 'argument to be an expression');
|
---|
130 | return arg;
|
---|
131 | });
|
---|
132 | };
|
---|
133 | BabelAstHost.prototype.getRange = function (node) {
|
---|
134 | if (node.loc == null || node.start === null || node.end === null) {
|
---|
135 | throw new linker_1.FatalLinkerError(node, 'Unable to read range for node - it is missing location information.');
|
---|
136 | }
|
---|
137 | return {
|
---|
138 | startLine: node.loc.start.line - 1,
|
---|
139 | startCol: node.loc.start.column,
|
---|
140 | startPos: node.start,
|
---|
141 | endPos: node.end,
|
---|
142 | };
|
---|
143 | };
|
---|
144 | return BabelAstHost;
|
---|
145 | }());
|
---|
146 | exports.BabelAstHost = BabelAstHost;
|
---|
147 | /**
|
---|
148 | * Return true if the expression does not represent an empty element in an array literal.
|
---|
149 | * For example in `[,foo]` the first element is "empty".
|
---|
150 | */
|
---|
151 | function isNotEmptyElement(e) {
|
---|
152 | return e !== null;
|
---|
153 | }
|
---|
154 | /**
|
---|
155 | * Return true if the expression is not a spread element of an array literal.
|
---|
156 | * For example in `[x, ...rest]` the `...rest` expression is a spread element.
|
---|
157 | */
|
---|
158 | function isNotSpreadElement(e) {
|
---|
159 | return !t.isSpreadElement(e);
|
---|
160 | }
|
---|
161 | /**
|
---|
162 | * Return true if the expression can be considered a text based property name.
|
---|
163 | */
|
---|
164 | function isPropertyName(e) {
|
---|
165 | return t.isIdentifier(e) || t.isStringLiteral(e) || t.isNumericLiteral(e);
|
---|
166 | }
|
---|
167 | /**
|
---|
168 | * Return true if the argument is not a spread element.
|
---|
169 | */
|
---|
170 | function isNotSpreadArgument(arg) {
|
---|
171 | return !t.isSpreadElement(arg);
|
---|
172 | }
|
---|
173 | /**
|
---|
174 | * Return true if the node is either `!0` or `!1`.
|
---|
175 | */
|
---|
176 | function isMinifiedBooleanLiteral(node) {
|
---|
177 | return t.isUnaryExpression(node) && node.prefix && node.operator === '!' &&
|
---|
178 | t.isNumericLiteral(node.argument) && (node.argument.value === 0 || node.argument.value === 1);
|
---|
179 | }
|
---|
180 | });
|
---|
181 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babel_ast_host.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/linker/babel/src/ast/babel_ast_host.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 t from '@babel/types';\n\nimport {assert, AstHost, FatalLinkerError, Range} from '../../../../linker';\n\n/**\n * This implementation of `AstHost` is able to get information from Babel AST nodes.\n */\nexport class BabelAstHost implements AstHost<t.Expression> {\n  getSymbolName(node: t.Expression): string|null {\n    if (t.isIdentifier(node)) {\n      return node.name;\n    } else if (t.isMemberExpression(node) && t.isIdentifier(node.property)) {\n      return node.property.name;\n    } else {\n      return null;\n    }\n  }\n\n  isStringLiteral = t.isStringLiteral;\n\n  parseStringLiteral(str: t.Expression): string {\n    assert(str, t.isStringLiteral, 'a string literal');\n    return str.value;\n  }\n\n  isNumericLiteral = t.isNumericLiteral;\n\n  parseNumericLiteral(num: t.Expression): number {\n    assert(num, t.isNumericLiteral, 'a numeric literal');\n    return num.value;\n  }\n\n  isBooleanLiteral(bool: t.Expression): boolean {\n    return t.isBooleanLiteral(bool) || isMinifiedBooleanLiteral(bool);\n  }\n\n  parseBooleanLiteral(bool: t.Expression): boolean {\n    if (t.isBooleanLiteral(bool)) {\n      return bool.value;\n    } else if (isMinifiedBooleanLiteral(bool)) {\n      return !bool.argument.value;\n    } else {\n      throw new FatalLinkerError(bool, 'Unsupported syntax, expected a boolean literal.');\n    }\n  }\n\n  isArrayLiteral = t.isArrayExpression;\n\n  parseArrayLiteral(array: t.Expression): t.Expression[] {\n    assert(array, t.isArrayExpression, 'an array literal');\n    return array.elements.map(element => {\n      assert(element, isNotEmptyElement, 'element in array not to be empty');\n      assert(element, isNotSpreadElement, 'element in array not to use spread syntax');\n      return element;\n    });\n  }\n\n  isObjectLiteral = t.isObjectExpression;\n\n  parseObjectLiteral(obj: t.Expression): Map<string, t.Expression> {\n    assert(obj, t.isObjectExpression, 'an object literal');\n\n    const result = new Map<string, t.Expression>();\n    for (const property of obj.properties) {\n      assert(property, t.isObjectProperty, 'a property assignment');\n      assert(property.value, t.isExpression, 'an expression');\n      assert(property.key, isPropertyName, 'a property name');\n      const key = t.isIdentifier(property.key) ? property.key.name : property.key.value;\n      result.set(key, property.value);\n    }\n    return result;\n  }\n\n  isFunctionExpression(node: t.Expression): node is Extract<t.Function, t.Expression> {\n    return t.isFunction(node);\n  }\n\n  parseReturnValue(fn: t.Expression): t.Expression {\n    assert(fn, this.isFunctionExpression, 'a function');\n    if (!t.isBlockStatement(fn.body)) {\n      // it is a simple array function expression: `(...) => expr`\n      return fn.body;\n    }\n\n    // it is a function (arrow or normal) with a body. E.g.:\n    // * `(...) => { stmt; ... }`\n    // * `function(...) { stmt; ... }`\n\n    if (fn.body.body.length !== 1) {\n      throw new FatalLinkerError(\n          fn.body, 'Unsupported syntax, expected a function body with a single return statement.');\n    }\n    const stmt = fn.body.body[0];\n    assert(stmt, t.isReturnStatement, 'a function body with a single return statement');\n    if (stmt.argument === null) {\n      throw new FatalLinkerError(stmt, 'Unsupported syntax, expected function to return a value.');\n    }\n\n    return stmt.argument;\n  }\n\n  isCallExpression = t.isCallExpression;\n  parseCallee(call: t.Expression): t.Expression {\n    assert(call, t.isCallExpression, 'a call expression');\n    assert(call.callee, t.isExpression, 'an expression');\n    return call.callee;\n  }\n  parseArguments(call: t.Expression): t.Expression[] {\n    assert(call, t.isCallExpression, 'a call expression');\n    return call.arguments.map(arg => {\n      assert(arg, isNotSpreadArgument, 'argument not to use spread syntax');\n      assert(arg, t.isExpression, 'argument to be an expression');\n      return arg;\n    });\n  }\n\n  getRange(node: t.Expression): Range {\n    if (node.loc == null || node.start === null || node.end === null) {\n      throw new FatalLinkerError(\n          node, 'Unable to read range for node - it is missing location information.');\n    }\n    return {\n      startLine: node.loc.start.line - 1,  // Babel lines are 1-based\n      startCol: node.loc.start.column,\n      startPos: node.start,\n      endPos: node.end,\n    };\n  }\n}\n\n/**\n * Return true if the expression does not represent an empty element in an array literal.\n * For example in `[,foo]` the first element is \"empty\".\n */\nfunction isNotEmptyElement(e: t.Expression|t.SpreadElement|null): e is t.Expression|\n    t.SpreadElement {\n  return e !== null;\n}\n\n/**\n * Return true if the expression is not a spread element of an array literal.\n * For example in `[x, ...rest]` the `...rest` expression is a spread element.\n */\nfunction isNotSpreadElement(e: t.Expression|t.SpreadElement): e is t.Expression {\n  return !t.isSpreadElement(e);\n}\n\n\n/**\n * Return true if the expression can be considered a text based property name.\n */\nfunction isPropertyName(e: t.Expression): e is t.Identifier|t.StringLiteral|t.NumericLiteral {\n  return t.isIdentifier(e) || t.isStringLiteral(e) || t.isNumericLiteral(e);\n}\n\n/**\n * The declared type of an argument to a call expression.\n */\ntype ArgumentType = t.CallExpression['arguments'][number];\n\n/**\n * Return true if the argument is not a spread element.\n */\nfunction isNotSpreadArgument(arg: ArgumentType): arg is Exclude<ArgumentType, t.SpreadElement> {\n  return !t.isSpreadElement(arg);\n}\n\ntype MinifiedBooleanLiteral = t.Expression&t.UnaryExpression&{argument: t.NumericLiteral};\n\n/**\n * Return true if the node is either `!0` or `!1`.\n */\nfunction isMinifiedBooleanLiteral(node: t.Expression): node is MinifiedBooleanLiteral {\n  return t.isUnaryExpression(node) && node.prefix && node.operator === '!' &&\n      t.isNumericLiteral(node.argument) && (node.argument.value === 0 || node.argument.value === 1);\n}\n"]} |
---|