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/src/ast/typescript/typescript_ast_host", ["require", "exports", "tslib", "typescript", "@angular/compiler-cli/linker/src/fatal_linker_error", "@angular/compiler-cli/linker/src/ast/utils"], factory);
|
---|
15 | }
|
---|
16 | })(function (require, exports) {
|
---|
17 | "use strict";
|
---|
18 | Object.defineProperty(exports, "__esModule", { value: true });
|
---|
19 | exports.TypeScriptAstHost = void 0;
|
---|
20 | var tslib_1 = require("tslib");
|
---|
21 | var ts = require("typescript");
|
---|
22 | var fatal_linker_error_1 = require("@angular/compiler-cli/linker/src/fatal_linker_error");
|
---|
23 | var utils_1 = require("@angular/compiler-cli/linker/src/ast/utils");
|
---|
24 | /**
|
---|
25 | * This implementation of `AstHost` is able to get information from TypeScript AST nodes.
|
---|
26 | *
|
---|
27 | * This host is not actually used at runtime in the current code.
|
---|
28 | *
|
---|
29 | * It is implemented here to ensure that the `AstHost` abstraction is not unfairly skewed towards
|
---|
30 | * the Babel implementation. It could also provide a basis for a 3rd TypeScript compiler plugin to
|
---|
31 | * do linking in the future.
|
---|
32 | */
|
---|
33 | var TypeScriptAstHost = /** @class */ (function () {
|
---|
34 | function TypeScriptAstHost() {
|
---|
35 | this.isStringLiteral = ts.isStringLiteral;
|
---|
36 | this.isNumericLiteral = ts.isNumericLiteral;
|
---|
37 | this.isArrayLiteral = ts.isArrayLiteralExpression;
|
---|
38 | this.isObjectLiteral = ts.isObjectLiteralExpression;
|
---|
39 | this.isCallExpression = ts.isCallExpression;
|
---|
40 | }
|
---|
41 | TypeScriptAstHost.prototype.getSymbolName = function (node) {
|
---|
42 | if (ts.isIdentifier(node)) {
|
---|
43 | return node.text;
|
---|
44 | }
|
---|
45 | else if (ts.isPropertyAccessExpression(node) && ts.isIdentifier(node.name)) {
|
---|
46 | return node.name.text;
|
---|
47 | }
|
---|
48 | else {
|
---|
49 | return null;
|
---|
50 | }
|
---|
51 | };
|
---|
52 | TypeScriptAstHost.prototype.parseStringLiteral = function (str) {
|
---|
53 | utils_1.assert(str, this.isStringLiteral, 'a string literal');
|
---|
54 | return str.text;
|
---|
55 | };
|
---|
56 | TypeScriptAstHost.prototype.parseNumericLiteral = function (num) {
|
---|
57 | utils_1.assert(num, this.isNumericLiteral, 'a numeric literal');
|
---|
58 | return parseInt(num.text);
|
---|
59 | };
|
---|
60 | TypeScriptAstHost.prototype.isBooleanLiteral = function (node) {
|
---|
61 | return isBooleanLiteral(node) || isMinifiedBooleanLiteral(node);
|
---|
62 | };
|
---|
63 | TypeScriptAstHost.prototype.parseBooleanLiteral = function (bool) {
|
---|
64 | if (isBooleanLiteral(bool)) {
|
---|
65 | return bool.kind === ts.SyntaxKind.TrueKeyword;
|
---|
66 | }
|
---|
67 | else if (isMinifiedBooleanLiteral(bool)) {
|
---|
68 | return !(+bool.operand.text);
|
---|
69 | }
|
---|
70 | else {
|
---|
71 | throw new fatal_linker_error_1.FatalLinkerError(bool, 'Unsupported syntax, expected a boolean literal.');
|
---|
72 | }
|
---|
73 | };
|
---|
74 | TypeScriptAstHost.prototype.parseArrayLiteral = function (array) {
|
---|
75 | utils_1.assert(array, this.isArrayLiteral, 'an array literal');
|
---|
76 | return array.elements.map(function (element) {
|
---|
77 | utils_1.assert(element, isNotEmptyElement, 'element in array not to be empty');
|
---|
78 | utils_1.assert(element, isNotSpreadElement, 'element in array not to use spread syntax');
|
---|
79 | return element;
|
---|
80 | });
|
---|
81 | };
|
---|
82 | TypeScriptAstHost.prototype.parseObjectLiteral = function (obj) {
|
---|
83 | var e_1, _a;
|
---|
84 | utils_1.assert(obj, this.isObjectLiteral, 'an object literal');
|
---|
85 | var result = new Map();
|
---|
86 | try {
|
---|
87 | for (var _b = tslib_1.__values(obj.properties), _c = _b.next(); !_c.done; _c = _b.next()) {
|
---|
88 | var property = _c.value;
|
---|
89 | utils_1.assert(property, ts.isPropertyAssignment, 'a property assignment');
|
---|
90 | utils_1.assert(property.name, isPropertyName, 'a property name');
|
---|
91 | result.set(property.name.text, property.initializer);
|
---|
92 | }
|
---|
93 | }
|
---|
94 | catch (e_1_1) { e_1 = { error: e_1_1 }; }
|
---|
95 | finally {
|
---|
96 | try {
|
---|
97 | if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
|
---|
98 | }
|
---|
99 | finally { if (e_1) throw e_1.error; }
|
---|
100 | }
|
---|
101 | return result;
|
---|
102 | };
|
---|
103 | TypeScriptAstHost.prototype.isFunctionExpression = function (node) {
|
---|
104 | return ts.isFunctionExpression(node) || ts.isArrowFunction(node);
|
---|
105 | };
|
---|
106 | TypeScriptAstHost.prototype.parseReturnValue = function (fn) {
|
---|
107 | utils_1.assert(fn, this.isFunctionExpression, 'a function');
|
---|
108 | if (!ts.isBlock(fn.body)) {
|
---|
109 | // it is a simple array function expression: `(...) => expr`
|
---|
110 | return fn.body;
|
---|
111 | }
|
---|
112 | // it is a function (arrow or normal) with a body. E.g.:
|
---|
113 | // * `(...) => { stmt; ... }`
|
---|
114 | // * `function(...) { stmt; ... }`
|
---|
115 | if (fn.body.statements.length !== 1) {
|
---|
116 | throw new fatal_linker_error_1.FatalLinkerError(fn.body, 'Unsupported syntax, expected a function body with a single return statement.');
|
---|
117 | }
|
---|
118 | var stmt = fn.body.statements[0];
|
---|
119 | utils_1.assert(stmt, ts.isReturnStatement, 'a function body with a single return statement');
|
---|
120 | if (stmt.expression === undefined) {
|
---|
121 | throw new fatal_linker_error_1.FatalLinkerError(stmt, 'Unsupported syntax, expected function to return a value.');
|
---|
122 | }
|
---|
123 | return stmt.expression;
|
---|
124 | };
|
---|
125 | TypeScriptAstHost.prototype.parseCallee = function (call) {
|
---|
126 | utils_1.assert(call, ts.isCallExpression, 'a call expression');
|
---|
127 | return call.expression;
|
---|
128 | };
|
---|
129 | TypeScriptAstHost.prototype.parseArguments = function (call) {
|
---|
130 | utils_1.assert(call, ts.isCallExpression, 'a call expression');
|
---|
131 | return call.arguments.map(function (arg) {
|
---|
132 | utils_1.assert(arg, isNotSpreadElement, 'argument not to use spread syntax');
|
---|
133 | return arg;
|
---|
134 | });
|
---|
135 | };
|
---|
136 | TypeScriptAstHost.prototype.getRange = function (node) {
|
---|
137 | var file = node.getSourceFile();
|
---|
138 | if (file === undefined) {
|
---|
139 | throw new fatal_linker_error_1.FatalLinkerError(node, 'Unable to read range for node - it is missing parent information.');
|
---|
140 | }
|
---|
141 | var startPos = node.getStart();
|
---|
142 | var endPos = node.getEnd();
|
---|
143 | var _a = ts.getLineAndCharacterOfPosition(file, startPos), startLine = _a.line, startCol = _a.character;
|
---|
144 | return { startLine: startLine, startCol: startCol, startPos: startPos, endPos: endPos };
|
---|
145 | };
|
---|
146 | return TypeScriptAstHost;
|
---|
147 | }());
|
---|
148 | exports.TypeScriptAstHost = TypeScriptAstHost;
|
---|
149 | /**
|
---|
150 | * Return true if the expression does not represent an empty element in an array literal.
|
---|
151 | * For example in `[,foo]` the first element is "empty".
|
---|
152 | */
|
---|
153 | function isNotEmptyElement(e) {
|
---|
154 | return !ts.isOmittedExpression(e);
|
---|
155 | }
|
---|
156 | /**
|
---|
157 | * Return true if the expression is not a spread element of an array literal.
|
---|
158 | * For example in `[x, ...rest]` the `...rest` expression is a spread element.
|
---|
159 | */
|
---|
160 | function isNotSpreadElement(e) {
|
---|
161 | return !ts.isSpreadElement(e);
|
---|
162 | }
|
---|
163 | /**
|
---|
164 | * Return true if the expression can be considered a text based property name.
|
---|
165 | */
|
---|
166 | function isPropertyName(e) {
|
---|
167 | return ts.isIdentifier(e) || ts.isStringLiteral(e) || ts.isNumericLiteral(e);
|
---|
168 | }
|
---|
169 | /**
|
---|
170 | * Return true if the node is either `true` or `false` literals.
|
---|
171 | */
|
---|
172 | function isBooleanLiteral(node) {
|
---|
173 | return node.kind === ts.SyntaxKind.TrueKeyword || node.kind === ts.SyntaxKind.FalseKeyword;
|
---|
174 | }
|
---|
175 | /**
|
---|
176 | * Return true if the node is either `!0` or `!1`.
|
---|
177 | */
|
---|
178 | function isMinifiedBooleanLiteral(node) {
|
---|
179 | return ts.isPrefixUnaryExpression(node) && node.operator === ts.SyntaxKind.ExclamationToken &&
|
---|
180 | ts.isNumericLiteral(node.operand) && (node.operand.text === '0' || node.operand.text === '1');
|
---|
181 | }
|
---|
182 | });
|
---|
183 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"typescript_ast_host.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler-cli/linker/src/ast/typescript/typescript_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 ts from 'typescript';\n\nimport {FatalLinkerError} from '../../fatal_linker_error';\nimport {AstHost, Range} from '../ast_host';\nimport {assert} from '../utils';\n\n\n/**\n * This implementation of `AstHost` is able to get information from TypeScript AST nodes.\n *\n * This host is not actually used at runtime in the current code.\n *\n * It is implemented here to ensure that the `AstHost` abstraction is not unfairly skewed towards\n * the Babel implementation. It could also provide a basis for a 3rd TypeScript compiler plugin to\n * do linking in the future.\n */\nexport class TypeScriptAstHost implements AstHost<ts.Expression> {\n  getSymbolName(node: ts.Expression): string|null {\n    if (ts.isIdentifier(node)) {\n      return node.text;\n    } else if (ts.isPropertyAccessExpression(node) && ts.isIdentifier(node.name)) {\n      return node.name.text;\n    } else {\n      return null;\n    }\n  }\n\n  isStringLiteral = ts.isStringLiteral;\n\n  parseStringLiteral(str: ts.Expression): string {\n    assert(str, this.isStringLiteral, 'a string literal');\n    return str.text;\n  }\n\n  isNumericLiteral = ts.isNumericLiteral;\n\n  parseNumericLiteral(num: ts.Expression): number {\n    assert(num, this.isNumericLiteral, 'a numeric literal');\n    return parseInt(num.text);\n  }\n\n  isBooleanLiteral(node: ts.Expression): boolean {\n    return isBooleanLiteral(node) || isMinifiedBooleanLiteral(node);\n  }\n\n  parseBooleanLiteral(bool: ts.Expression): boolean {\n    if (isBooleanLiteral(bool)) {\n      return bool.kind === ts.SyntaxKind.TrueKeyword;\n    } else if (isMinifiedBooleanLiteral(bool)) {\n      return !(+bool.operand.text);\n    } else {\n      throw new FatalLinkerError(bool, 'Unsupported syntax, expected a boolean literal.');\n    }\n  }\n\n  isArrayLiteral = ts.isArrayLiteralExpression;\n\n  parseArrayLiteral(array: ts.Expression): ts.Expression[] {\n    assert(array, this.isArrayLiteral, '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 = ts.isObjectLiteralExpression;\n\n  parseObjectLiteral(obj: ts.Expression): Map<string, ts.Expression> {\n    assert(obj, this.isObjectLiteral, 'an object literal');\n\n    const result = new Map<string, ts.Expression>();\n    for (const property of obj.properties) {\n      assert(property, ts.isPropertyAssignment, 'a property assignment');\n      assert(property.name, isPropertyName, 'a property name');\n      result.set(property.name.text, property.initializer);\n    }\n    return result;\n  }\n\n  isFunctionExpression(node: ts.Expression): node is ts.FunctionExpression|ts.ArrowFunction {\n    return ts.isFunctionExpression(node) || ts.isArrowFunction(node);\n  }\n\n  parseReturnValue(fn: ts.Expression): ts.Expression {\n    assert(fn, this.isFunctionExpression, 'a function');\n    if (!ts.isBlock(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.statements.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.statements[0];\n    assert(stmt, ts.isReturnStatement, 'a function body with a single return statement');\n    if (stmt.expression === undefined) {\n      throw new FatalLinkerError(stmt, 'Unsupported syntax, expected function to return a value.');\n    }\n\n    return stmt.expression;\n  }\n\n  isCallExpression = ts.isCallExpression;\n\n  parseCallee(call: ts.Expression): ts.Expression {\n    assert(call, ts.isCallExpression, 'a call expression');\n    return call.expression;\n  }\n\n  parseArguments(call: ts.Expression): ts.Expression[] {\n    assert(call, ts.isCallExpression, 'a call expression');\n    return call.arguments.map(arg => {\n      assert(arg, isNotSpreadElement, 'argument not to use spread syntax');\n      return arg;\n    });\n  }\n\n  getRange(node: ts.Expression): Range {\n    const file = node.getSourceFile();\n    if (file === undefined) {\n      throw new FatalLinkerError(\n          node, 'Unable to read range for node - it is missing parent information.');\n    }\n    const startPos = node.getStart();\n    const endPos = node.getEnd();\n    const {line: startLine, character: startCol} = ts.getLineAndCharacterOfPosition(file, startPos);\n    return {startLine, startCol, startPos, endPos};\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: ts.Expression|ts.SpreadElement|\n                           ts.OmittedExpression): e is ts.Expression|ts.SpreadElement {\n  return !ts.isOmittedExpression(e);\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: ts.Expression|ts.SpreadElement): e is ts.Expression {\n  return !ts.isSpreadElement(e);\n}\n\n/**\n * Return true if the expression can be considered a text based property name.\n */\nfunction isPropertyName(e: ts.PropertyName): e is ts.Identifier|ts.StringLiteral|ts.NumericLiteral {\n  return ts.isIdentifier(e) || ts.isStringLiteral(e) || ts.isNumericLiteral(e);\n}\n\n/**\n * Return true if the node is either `true` or `false` literals.\n */\nfunction isBooleanLiteral(node: ts.Expression): node is ts.TrueLiteral|ts.FalseLiteral {\n  return node.kind === ts.SyntaxKind.TrueKeyword || node.kind === ts.SyntaxKind.FalseKeyword;\n}\n\ntype MinifiedBooleanLiteral = ts.PrefixUnaryExpression&{operand: ts.NumericLiteral};\n\n/**\n * Return true if the node is either `!0` or `!1`.\n */\nfunction isMinifiedBooleanLiteral(node: ts.Expression): node is MinifiedBooleanLiteral {\n  return ts.isPrefixUnaryExpression(node) && node.operator === ts.SyntaxKind.ExclamationToken &&\n      ts.isNumericLiteral(node.operand) && (node.operand.text === '0' || node.operand.text === '1');\n}\n"]} |
---|