source: trip-planner-front/node_modules/@angular/compiler-cli/linker/babel/src/ast/babel_ast_host.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: 22.4 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/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"]}
Note: See TracBrowser for help on using the repository browser.