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"]} |
---|