source: trip-planner-front/node_modules/@angular/compiler-cli/linker/babel/src/ast/babel_ast_factory.js@ fa375fe

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

initial commit

  • Property mode set to 100644
File size: 22.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/linker/babel/src/ast/babel_ast_factory", ["require", "exports", "@babel/types", "@angular/compiler-cli/linker"], factory);
8 }
9})(function (require, exports) {
10 "use strict";
11 Object.defineProperty(exports, "__esModule", { value: true });
12 exports.BabelAstFactory = void 0;
13 /**
14 * @license
15 * Copyright Google LLC All Rights Reserved.
16 *
17 * Use of this source code is governed by an MIT-style license that can be
18 * found in the LICENSE file at https://angular.io/license
19 */
20 var t = require("@babel/types");
21 var linker_1 = require("@angular/compiler-cli/linker");
22 /**
23 * A Babel flavored implementation of the AstFactory.
24 */
25 var BabelAstFactory = /** @class */ (function () {
26 function BabelAstFactory(
27 /** The absolute path to the source file being compiled. */
28 sourceUrl) {
29 this.sourceUrl = sourceUrl;
30 this.createArrayLiteral = t.arrayExpression;
31 this.createBlock = t.blockStatement;
32 this.createConditional = t.conditionalExpression;
33 this.createExpressionStatement = t.expressionStatement;
34 this.createIdentifier = t.identifier;
35 this.createIfStatement = t.ifStatement;
36 this.createNewExpression = t.newExpression;
37 this.createParenthesizedExpression = t.parenthesizedExpression;
38 this.createReturnStatement = t.returnStatement;
39 this.createThrowStatement = t.throwStatement;
40 this.createUnaryExpression = t.unaryExpression;
41 }
42 BabelAstFactory.prototype.attachComments = function (statement, leadingComments) {
43 // We must process the comments in reverse because `t.addComment()` will add new ones in front.
44 for (var i = leadingComments.length - 1; i >= 0; i--) {
45 var comment = leadingComments[i];
46 t.addComment(statement, 'leading', comment.toString(), !comment.multiline);
47 }
48 };
49 BabelAstFactory.prototype.createAssignment = function (target, value) {
50 linker_1.assert(target, isLExpression, 'must be a left hand side expression');
51 return t.assignmentExpression('=', target, value);
52 };
53 BabelAstFactory.prototype.createBinaryExpression = function (leftOperand, operator, rightOperand) {
54 switch (operator) {
55 case '&&':
56 case '||':
57 case '??':
58 return t.logicalExpression(operator, leftOperand, rightOperand);
59 default:
60 return t.binaryExpression(operator, leftOperand, rightOperand);
61 }
62 };
63 BabelAstFactory.prototype.createCallExpression = function (callee, args, pure) {
64 var call = t.callExpression(callee, args);
65 if (pure) {
66 t.addComment(call, 'leading', ' @__PURE__ ', /* line */ false);
67 }
68 return call;
69 };
70 BabelAstFactory.prototype.createElementAccess = function (expression, element) {
71 return t.memberExpression(expression, element, /* computed */ true);
72 };
73 BabelAstFactory.prototype.createFunctionDeclaration = function (functionName, parameters, body) {
74 linker_1.assert(body, t.isBlockStatement, 'a block');
75 return t.functionDeclaration(t.identifier(functionName), parameters.map(function (param) { return t.identifier(param); }), body);
76 };
77 BabelAstFactory.prototype.createFunctionExpression = function (functionName, parameters, body) {
78 linker_1.assert(body, t.isBlockStatement, 'a block');
79 var name = functionName !== null ? t.identifier(functionName) : null;
80 return t.functionExpression(name, parameters.map(function (param) { return t.identifier(param); }), body);
81 };
82 BabelAstFactory.prototype.createLiteral = function (value) {
83 if (typeof value === 'string') {
84 return t.stringLiteral(value);
85 }
86 else if (typeof value === 'number') {
87 return t.numericLiteral(value);
88 }
89 else if (typeof value === 'boolean') {
90 return t.booleanLiteral(value);
91 }
92 else if (value === undefined) {
93 return t.identifier('undefined');
94 }
95 else if (value === null) {
96 return t.nullLiteral();
97 }
98 else {
99 throw new Error("Invalid literal: " + value + " (" + typeof value + ")");
100 }
101 };
102 BabelAstFactory.prototype.createObjectLiteral = function (properties) {
103 return t.objectExpression(properties.map(function (prop) {
104 var key = prop.quoted ? t.stringLiteral(prop.propertyName) : t.identifier(prop.propertyName);
105 return t.objectProperty(key, prop.value);
106 }));
107 };
108 BabelAstFactory.prototype.createPropertyAccess = function (expression, propertyName) {
109 return t.memberExpression(expression, t.identifier(propertyName), /* computed */ false);
110 };
111 BabelAstFactory.prototype.createTaggedTemplate = function (tag, template) {
112 var _this = this;
113 var elements = template.elements.map(function (element, i) { return _this.setSourceMapRange(t.templateElement(element, i === template.elements.length - 1), element.range); });
114 return t.taggedTemplateExpression(tag, t.templateLiteral(elements, template.expressions));
115 };
116 BabelAstFactory.prototype.createTypeOfExpression = function (expression) {
117 return t.unaryExpression('typeof', expression);
118 };
119 BabelAstFactory.prototype.createVariableDeclaration = function (variableName, initializer, type) {
120 return t.variableDeclaration(type, [t.variableDeclarator(t.identifier(variableName), initializer)]);
121 };
122 BabelAstFactory.prototype.setSourceMapRange = function (node, sourceMapRange) {
123 if (sourceMapRange === null) {
124 return node;
125 }
126 node.loc = {
127 // Add in the filename so that we can map to external template files.
128 // Note that Babel gets confused if you specify a filename when it is the original source
129 // file. This happens when the template is inline, in which case just use `undefined`.
130 filename: sourceMapRange.url !== this.sourceUrl ? sourceMapRange.url : undefined,
131 start: {
132 line: sourceMapRange.start.line + 1,
133 column: sourceMapRange.start.column,
134 },
135 end: {
136 line: sourceMapRange.end.line + 1,
137 column: sourceMapRange.end.column,
138 },
139 }; // Needed because the Babel typings for `loc` don't include `filename`.
140 node.start = sourceMapRange.start.offset;
141 node.end = sourceMapRange.end.offset;
142 return node;
143 };
144 return BabelAstFactory;
145 }());
146 exports.BabelAstFactory = BabelAstFactory;
147 function isLExpression(expr) {
148 // Some LVal types are not expressions, which prevents us from using `t.isLVal()`
149 // directly with `assert()`.
150 return t.isLVal(expr);
151 }
152});
153//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"babel_ast_factory.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/linker/babel/src/ast/babel_ast_factory.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 * as t from '@babel/types';\n\nimport {assert} from '../../../../linker';\nimport {AstFactory, BinaryOperator, LeadingComment, ObjectLiteralProperty, SourceMapRange, TemplateLiteral, VariableDeclarationType} from '../../../../src/ngtsc/translator';\n\n/**\n * A Babel flavored implementation of the AstFactory.\n */\nexport class BabelAstFactory implements AstFactory<t.Statement, t.Expression> {\n  constructor(\n      /** The absolute path to the source file being compiled. */\n      private sourceUrl: string) {}\n\n  attachComments(statement: t.Statement, leadingComments: LeadingComment[]): void {\n    // We must process the comments in reverse because `t.addComment()` will add new ones in front.\n    for (let i = leadingComments.length - 1; i >= 0; i--) {\n      const comment = leadingComments[i];\n      t.addComment(statement, 'leading', comment.toString(), !comment.multiline);\n    }\n  }\n\n  createArrayLiteral = t.arrayExpression;\n\n  createAssignment(target: t.Expression, value: t.Expression): t.Expression {\n    assert(target, isLExpression, 'must be a left hand side expression');\n    return t.assignmentExpression('=', target, value);\n  }\n\n  createBinaryExpression(\n      leftOperand: t.Expression, operator: BinaryOperator,\n      rightOperand: t.Expression): t.Expression {\n    switch (operator) {\n      case '&&':\n      case '||':\n      case '??':\n        return t.logicalExpression(operator, leftOperand, rightOperand);\n      default:\n        return t.binaryExpression(operator, leftOperand, rightOperand);\n    }\n  }\n\n  createBlock = t.blockStatement;\n\n  createCallExpression(callee: t.Expression, args: t.Expression[], pure: boolean): t.Expression {\n    const call = t.callExpression(callee, args);\n    if (pure) {\n      t.addComment(call, 'leading', ' @__PURE__ ', /* line */ false);\n    }\n    return call;\n  }\n\n  createConditional = t.conditionalExpression;\n\n  createElementAccess(expression: t.Expression, element: t.Expression): t.Expression {\n    return t.memberExpression(expression, element, /* computed */ true);\n  }\n\n  createExpressionStatement = t.expressionStatement;\n\n  createFunctionDeclaration(functionName: string, parameters: string[], body: t.Statement):\n      t.Statement {\n    assert(body, t.isBlockStatement, 'a block');\n    return t.functionDeclaration(\n        t.identifier(functionName), parameters.map(param => t.identifier(param)), body);\n  }\n\n  createFunctionExpression(functionName: string|null, parameters: string[], body: t.Statement):\n      t.Expression {\n    assert(body, t.isBlockStatement, 'a block');\n    const name = functionName !== null ? t.identifier(functionName) : null;\n    return t.functionExpression(name, parameters.map(param => t.identifier(param)), body);\n  }\n\n  createIdentifier = t.identifier;\n\n  createIfStatement = t.ifStatement;\n\n  createLiteral(value: string|number|boolean|null|undefined): t.Expression {\n    if (typeof value === 'string') {\n      return t.stringLiteral(value);\n    } else if (typeof value === 'number') {\n      return t.numericLiteral(value);\n    } else if (typeof value === 'boolean') {\n      return t.booleanLiteral(value);\n    } else if (value === undefined) {\n      return t.identifier('undefined');\n    } else if (value === null) {\n      return t.nullLiteral();\n    } else {\n      throw new Error(`Invalid literal: ${value} (${typeof value})`);\n    }\n  }\n\n  createNewExpression = t.newExpression;\n\n  createObjectLiteral(properties: ObjectLiteralProperty<t.Expression>[]): t.Expression {\n    return t.objectExpression(properties.map(prop => {\n      const key =\n          prop.quoted ? t.stringLiteral(prop.propertyName) : t.identifier(prop.propertyName);\n      return t.objectProperty(key, prop.value);\n    }));\n  }\n\n  createParenthesizedExpression = t.parenthesizedExpression;\n\n  createPropertyAccess(expression: t.Expression, propertyName: string): t.Expression {\n    return t.memberExpression(expression, t.identifier(propertyName), /* computed */ false);\n  }\n\n  createReturnStatement = t.returnStatement;\n\n  createTaggedTemplate(tag: t.Expression, template: TemplateLiteral<t.Expression>): t.Expression {\n    const elements = template.elements.map(\n        (element, i) => this.setSourceMapRange(\n            t.templateElement(element, i === template.elements.length - 1), element.range));\n    return t.taggedTemplateExpression(tag, t.templateLiteral(elements, template.expressions));\n  }\n\n  createThrowStatement = t.throwStatement;\n\n  createTypeOfExpression(expression: t.Expression): t.Expression {\n    return t.unaryExpression('typeof', expression);\n  }\n\n  createUnaryExpression = t.unaryExpression;\n\n  createVariableDeclaration(\n      variableName: string, initializer: t.Expression|null,\n      type: VariableDeclarationType): t.Statement {\n    return t.variableDeclaration(\n        type, [t.variableDeclarator(t.identifier(variableName), initializer)]);\n  }\n\n  setSourceMapRange<T extends t.Statement|t.Expression|t.TemplateElement>(\n      node: T, sourceMapRange: SourceMapRange|null): T {\n    if (sourceMapRange === null) {\n      return node;\n    }\n    node.loc = {\n      // Add in the filename so that we can map to external template files.\n      // Note that Babel gets confused if you specify a filename when it is the original source\n      // file. This happens when the template is inline, in which case just use `undefined`.\n      filename: sourceMapRange.url !== this.sourceUrl ? sourceMapRange.url : undefined,\n      start: {\n        line: sourceMapRange.start.line + 1,  // lines are 1-based in Babel.\n        column: sourceMapRange.start.column,\n      },\n      end: {\n        line: sourceMapRange.end.line + 1,  // lines are 1-based in Babel.\n        column: sourceMapRange.end.column,\n      },\n    } as any;  // Needed because the Babel typings for `loc` don't include `filename`.\n    node.start = sourceMapRange.start.offset;\n    node.end = sourceMapRange.end.offset;\n\n    return node;\n  }\n}\n\nfunction isLExpression(expr: t.Expression): expr is Extract<t.LVal, t.Expression> {\n  // Some LVal types are not expressions, which prevents us from using `t.isLVal()`\n  // directly with `assert()`.\n  return t.isLVal(expr);\n}\n"]}
Note: See TracBrowser for help on using the repository browser.