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