UNPKG

111 kBJavaScriptView Raw
1/**
2 * @license
3 * Copyright Google Inc. 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/src/transformers/node_emitter", ["require", "exports", "tslib", "@angular/compiler", "typescript", "@angular/compiler-cli/src/transformers/util"], factory);
15 }
16})(function (require, exports) {
17 "use strict";
18 Object.defineProperty(exports, "__esModule", { value: true });
19 var tslib_1 = require("tslib");
20 var compiler_1 = require("@angular/compiler");
21 var ts = require("typescript");
22 var util_1 = require("@angular/compiler-cli/src/transformers/util");
23 var METHOD_THIS_NAME = 'this';
24 var CATCH_ERROR_NAME = 'error';
25 var CATCH_STACK_NAME = 'stack';
26 var _VALID_IDENTIFIER_RE = /^[$A-Z_][0-9A-Z_$]*$/i;
27 var TypeScriptNodeEmitter = /** @class */ (function () {
28 function TypeScriptNodeEmitter() {
29 }
30 TypeScriptNodeEmitter.prototype.updateSourceFile = function (sourceFile, stmts, preamble) {
31 var converter = new NodeEmitterVisitor();
32 // [].concat flattens the result so that each `visit...` method can also return an array of
33 // stmts.
34 var statements = [].concat.apply([], tslib_1.__spread(stmts.map(function (stmt) { return stmt.visitStatement(converter, null); }).filter(function (stmt) { return stmt != null; })));
35 var preambleStmts = [];
36 if (preamble) {
37 var commentStmt = this.createCommentStatement(sourceFile, preamble);
38 preambleStmts.push(commentStmt);
39 }
40 var sourceStatements = tslib_1.__spread(preambleStmts, converter.getReexports(), converter.getImports(), statements);
41 converter.updateSourceMap(sourceStatements);
42 var newSourceFile = ts.updateSourceFileNode(sourceFile, sourceStatements);
43 return [newSourceFile, converter.getNodeMap()];
44 };
45 /** Creates a not emitted statement containing the given comment. */
46 TypeScriptNodeEmitter.prototype.createCommentStatement = function (sourceFile, comment) {
47 if (comment.startsWith('/*') && comment.endsWith('*/')) {
48 comment = comment.substr(2, comment.length - 4);
49 }
50 var commentStmt = ts.createNotEmittedStatement(sourceFile);
51 ts.setSyntheticLeadingComments(commentStmt, [{ kind: ts.SyntaxKind.MultiLineCommentTrivia, text: comment, pos: -1, end: -1 }]);
52 ts.setEmitFlags(commentStmt, ts.EmitFlags.CustomPrologue);
53 return commentStmt;
54 };
55 return TypeScriptNodeEmitter;
56 }());
57 exports.TypeScriptNodeEmitter = TypeScriptNodeEmitter;
58 /**
59 * Update the given source file to include the changes specified in module.
60 *
61 * The module parameter is treated as a partial module meaning that the statements are added to
62 * the module instead of replacing the module. Also, any classes are treated as partial classes
63 * and the included members are added to the class with the same name instead of a new class
64 * being created.
65 */
66 function updateSourceFile(sourceFile, module, context) {
67 var converter = new NodeEmitterVisitor();
68 converter.loadExportedVariableIdentifiers(sourceFile);
69 var prefixStatements = module.statements.filter(function (statement) { return !(statement instanceof compiler_1.ClassStmt); });
70 var classes = module.statements.filter(function (statement) { return statement instanceof compiler_1.ClassStmt; });
71 var classMap = new Map(classes.map(function (classStatement) { return [classStatement.name, classStatement]; }));
72 var classNames = new Set(classes.map(function (classStatement) { return classStatement.name; }));
73 var prefix = prefixStatements.map(function (statement) { return statement.visitStatement(converter, sourceFile); });
74 // Add static methods to all the classes referenced in module.
75 var newStatements = sourceFile.statements.map(function (node) {
76 if (node.kind == ts.SyntaxKind.ClassDeclaration) {
77 var classDeclaration = node;
78 var name = classDeclaration.name;
79 if (name) {
80 var classStatement = classMap.get(name.text);
81 if (classStatement) {
82 classNames.delete(name.text);
83 var classMemberHolder = converter.visitDeclareClassStmt(classStatement);
84 var newMethods = classMemberHolder.members.filter(function (member) { return member.kind !== ts.SyntaxKind.Constructor; });
85 var newMembers = tslib_1.__spread(classDeclaration.members, newMethods);
86 return ts.updateClassDeclaration(classDeclaration,
87 /* decorators */ classDeclaration.decorators,
88 /* modifiers */ classDeclaration.modifiers,
89 /* name */ classDeclaration.name,
90 /* typeParameters */ classDeclaration.typeParameters,
91 /* heritageClauses */ classDeclaration.heritageClauses || [],
92 /* members */ newMembers);
93 }
94 }
95 }
96 return node;
97 });
98 // Validate that all the classes have been generated
99 classNames.size == 0 ||
100 util_1.error((classNames.size == 1 ? 'Class' : 'Classes') + " \"" + Array.from(classNames.keys()).join(', ') + "\" not generated");
101 // Add imports to the module required by the new methods
102 var imports = converter.getImports();
103 if (imports && imports.length) {
104 // Find where the new imports should go
105 var index = firstAfter(newStatements, function (statement) { return statement.kind === ts.SyntaxKind.ImportDeclaration ||
106 statement.kind === ts.SyntaxKind.ImportEqualsDeclaration; });
107 newStatements = tslib_1.__spread(newStatements.slice(0, index), imports, prefix, newStatements.slice(index));
108 }
109 else {
110 newStatements = tslib_1.__spread(prefix, newStatements);
111 }
112 converter.updateSourceMap(newStatements);
113 var newSourceFile = ts.updateSourceFileNode(sourceFile, newStatements);
114 return [newSourceFile, converter.getNodeMap()];
115 }
116 exports.updateSourceFile = updateSourceFile;
117 // Return the index after the first value in `a` that doesn't match the predicate after a value that
118 // does or 0 if no values match.
119 function firstAfter(a, predicate) {
120 var index = 0;
121 var len = a.length;
122 for (; index < len; index++) {
123 var value = a[index];
124 if (predicate(value))
125 break;
126 }
127 if (index >= len)
128 return 0;
129 for (; index < len; index++) {
130 var value = a[index];
131 if (!predicate(value))
132 break;
133 }
134 return index;
135 }
136 function escapeLiteral(value) {
137 return value.replace(/(\"|\\)/g, '\\$1').replace(/(\n)|(\r)/g, function (v, n, r) {
138 return n ? '\\n' : '\\r';
139 });
140 }
141 function createLiteral(value) {
142 if (value === null) {
143 return ts.createNull();
144 }
145 else if (value === undefined) {
146 return ts.createIdentifier('undefined');
147 }
148 else {
149 var result = ts.createLiteral(value);
150 if (ts.isStringLiteral(result) && result.text.indexOf('\\') >= 0) {
151 // Hack to avoid problems cause indirectly by:
152 // https://github.com/Microsoft/TypeScript/issues/20192
153 // This avoids the string escaping normally performed for a string relying on that
154 // TypeScript just emits the text raw for a numeric literal.
155 result.kind = ts.SyntaxKind.NumericLiteral;
156 result.text = "\"" + escapeLiteral(result.text) + "\"";
157 }
158 return result;
159 }
160 }
161 function isExportTypeStatement(statement) {
162 return !!statement.modifiers &&
163 statement.modifiers.some(function (mod) { return mod.kind === ts.SyntaxKind.ExportKeyword; });
164 }
165 /**
166 * Visits an output ast and produces the corresponding TypeScript synthetic nodes.
167 */
168 var NodeEmitterVisitor = /** @class */ (function () {
169 function NodeEmitterVisitor() {
170 this._nodeMap = new Map();
171 this._importsWithPrefixes = new Map();
172 this._reexports = new Map();
173 this._templateSources = new Map();
174 this._exportedVariableIdentifiers = new Map();
175 }
176 /**
177 * Process the source file and collect exported identifiers that refer to variables.
178 *
179 * Only variables are collected because exported classes still exist in the module scope in
180 * CommonJS, whereas variables have their declarations moved onto the `exports` object, and all
181 * references are updated accordingly.
182 */
183 NodeEmitterVisitor.prototype.loadExportedVariableIdentifiers = function (sourceFile) {
184 var _this = this;
185 sourceFile.statements.forEach(function (statement) {
186 if (ts.isVariableStatement(statement) && isExportTypeStatement(statement)) {
187 statement.declarationList.declarations.forEach(function (declaration) {
188 if (ts.isIdentifier(declaration.name)) {
189 _this._exportedVariableIdentifiers.set(declaration.name.text, declaration.name);
190 }
191 });
192 }
193 });
194 };
195 NodeEmitterVisitor.prototype.getReexports = function () {
196 return Array.from(this._reexports.entries())
197 .map(function (_a) {
198 var _b = tslib_1.__read(_a, 2), exportedFilePath = _b[0], reexports = _b[1];
199 return ts.createExportDeclaration(
200 /* decorators */ undefined,
201 /* modifiers */ undefined, ts.createNamedExports(reexports.map(function (_a) {
202 var name = _a.name, as = _a.as;
203 return ts.createExportSpecifier(name, as);
204 })),
205 /* moduleSpecifier */ createLiteral(exportedFilePath));
206 });
207 };
208 NodeEmitterVisitor.prototype.getImports = function () {
209 return Array.from(this._importsWithPrefixes.entries())
210 .map(function (_a) {
211 var _b = tslib_1.__read(_a, 2), namespace = _b[0], prefix = _b[1];
212 return ts.createImportDeclaration(
213 /* decorators */ undefined,
214 /* modifiers */ undefined,
215 /* importClause */ ts.createImportClause(
216 /* name */ undefined, ts.createNamespaceImport(ts.createIdentifier(prefix))),
217 /* moduleSpecifier */ createLiteral(namespace));
218 });
219 };
220 NodeEmitterVisitor.prototype.getNodeMap = function () { return this._nodeMap; };
221 NodeEmitterVisitor.prototype.updateSourceMap = function (statements) {
222 var _this = this;
223 var lastRangeStartNode = undefined;
224 var lastRangeEndNode = undefined;
225 var lastRange = undefined;
226 var recordLastSourceRange = function () {
227 if (lastRange && lastRangeStartNode && lastRangeEndNode) {
228 if (lastRangeStartNode == lastRangeEndNode) {
229 ts.setSourceMapRange(lastRangeEndNode, lastRange);
230 }
231 else {
232 ts.setSourceMapRange(lastRangeStartNode, lastRange);
233 // Only emit the pos for the first node emitted in the range.
234 ts.setEmitFlags(lastRangeStartNode, ts.EmitFlags.NoTrailingSourceMap);
235 ts.setSourceMapRange(lastRangeEndNode, lastRange);
236 // Only emit emit end for the last node emitted in the range.
237 ts.setEmitFlags(lastRangeEndNode, ts.EmitFlags.NoLeadingSourceMap);
238 }
239 }
240 };
241 var visitNode = function (tsNode) {
242 var ngNode = _this._nodeMap.get(tsNode);
243 if (ngNode) {
244 var range = _this.sourceRangeOf(ngNode);
245 if (range) {
246 if (!lastRange || range.source != lastRange.source || range.pos != lastRange.pos ||
247 range.end != lastRange.end) {
248 recordLastSourceRange();
249 lastRangeStartNode = tsNode;
250 lastRange = range;
251 }
252 lastRangeEndNode = tsNode;
253 }
254 }
255 ts.forEachChild(tsNode, visitNode);
256 };
257 statements.forEach(visitNode);
258 recordLastSourceRange();
259 };
260 NodeEmitterVisitor.prototype.record = function (ngNode, tsNode) {
261 if (tsNode && !this._nodeMap.has(tsNode)) {
262 this._nodeMap.set(tsNode, ngNode);
263 }
264 return tsNode;
265 };
266 NodeEmitterVisitor.prototype.sourceRangeOf = function (node) {
267 if (node.sourceSpan) {
268 var span = node.sourceSpan;
269 if (span.start.file == span.end.file) {
270 var file = span.start.file;
271 if (file.url) {
272 var source = this._templateSources.get(file);
273 if (!source) {
274 source = ts.createSourceMapSource(file.url, file.content, function (pos) { return pos; });
275 this._templateSources.set(file, source);
276 }
277 return { pos: span.start.offset, end: span.end.offset, source: source };
278 }
279 }
280 }
281 return null;
282 };
283 NodeEmitterVisitor.prototype.getModifiers = function (stmt) {
284 var modifiers = [];
285 if (stmt.hasModifier(compiler_1.StmtModifier.Exported)) {
286 modifiers.push(ts.createToken(ts.SyntaxKind.ExportKeyword));
287 }
288 return modifiers;
289 };
290 // StatementVisitor
291 NodeEmitterVisitor.prototype.visitDeclareVarStmt = function (stmt) {
292 if (stmt.hasModifier(compiler_1.StmtModifier.Exported) && stmt.value instanceof compiler_1.ExternalExpr &&
293 !stmt.type) {
294 // check for a reexport
295 var _a = stmt.value.value, name = _a.name, moduleName = _a.moduleName;
296 if (moduleName) {
297 var reexports = this._reexports.get(moduleName);
298 if (!reexports) {
299 reexports = [];
300 this._reexports.set(moduleName, reexports);
301 }
302 reexports.push({ name: name, as: stmt.name });
303 return null;
304 }
305 }
306 var varDeclList = ts.createVariableDeclarationList([ts.createVariableDeclaration(ts.createIdentifier(stmt.name),
307 /* type */ undefined, (stmt.value && stmt.value.visitExpression(this, null)) || undefined)]);
308 if (stmt.hasModifier(compiler_1.StmtModifier.Exported)) {
309 // Note: We need to add an explicit variable and export declaration so that
310 // the variable can be referred in the same file as well.
311 var tsVarStmt = this.record(stmt, ts.createVariableStatement(/* modifiers */ [], varDeclList));
312 var exportStmt = this.record(stmt, ts.createExportDeclaration(
313 /*decorators*/ undefined, /*modifiers*/ undefined, ts.createNamedExports([ts.createExportSpecifier(stmt.name, stmt.name)])));
314 return [tsVarStmt, exportStmt];
315 }
316 return this.record(stmt, ts.createVariableStatement(this.getModifiers(stmt), varDeclList));
317 };
318 NodeEmitterVisitor.prototype.visitDeclareFunctionStmt = function (stmt) {
319 return this.record(stmt, ts.createFunctionDeclaration(
320 /* decorators */ undefined, this.getModifiers(stmt),
321 /* asteriskToken */ undefined, stmt.name, /* typeParameters */ undefined, stmt.params.map(function (p) { return ts.createParameter(
322 /* decorators */ undefined, /* modifiers */ undefined,
323 /* dotDotDotToken */ undefined, p.name); }),
324 /* type */ undefined, this._visitStatements(stmt.statements)));
325 };
326 NodeEmitterVisitor.prototype.visitExpressionStmt = function (stmt) {
327 return this.record(stmt, ts.createStatement(stmt.expr.visitExpression(this, null)));
328 };
329 NodeEmitterVisitor.prototype.visitReturnStmt = function (stmt) {
330 return this.record(stmt, ts.createReturn(stmt.value ? stmt.value.visitExpression(this, null) : undefined));
331 };
332 NodeEmitterVisitor.prototype.visitDeclareClassStmt = function (stmt) {
333 var _this = this;
334 var modifiers = this.getModifiers(stmt);
335 var fields = stmt.fields.map(function (field) { return ts.createProperty(
336 /* decorators */ undefined, /* modifiers */ translateModifiers(field.modifiers), field.name,
337 /* questionToken */ undefined,
338 /* type */ undefined, field.initializer == null ? ts.createNull() :
339 field.initializer.visitExpression(_this, null)); });
340 var getters = stmt.getters.map(function (getter) { return ts.createGetAccessor(
341 /* decorators */ undefined, /* modifiers */ undefined, getter.name, /* parameters */ [],
342 /* type */ undefined, _this._visitStatements(getter.body)); });
343 var constructor = (stmt.constructorMethod && [ts.createConstructor(
344 /* decorators */ undefined,
345 /* modifiers */ undefined,
346 /* parameters */ stmt.constructorMethod.params.map(function (p) { return ts.createParameter(
347 /* decorators */ undefined,
348 /* modifiers */ undefined,
349 /* dotDotDotToken */ undefined, p.name); }), this._visitStatements(stmt.constructorMethod.body))]) ||
350 [];
351 // TODO {chuckj}: Determine what should be done for a method with a null name.
352 var methods = stmt.methods.filter(function (method) { return method.name; })
353 .map(function (method) { return ts.createMethod(
354 /* decorators */ undefined,
355 /* modifiers */ translateModifiers(method.modifiers),
356 /* astriskToken */ undefined, method.name /* guarded by filter */,
357 /* questionToken */ undefined, /* typeParameters */ undefined, method.params.map(function (p) { return ts.createParameter(
358 /* decorators */ undefined, /* modifiers */ undefined,
359 /* dotDotDotToken */ undefined, p.name); }),
360 /* type */ undefined, _this._visitStatements(method.body)); });
361 return this.record(stmt, ts.createClassDeclaration(
362 /* decorators */ undefined, modifiers, stmt.name, /* typeParameters*/ undefined, stmt.parent && [ts.createHeritageClause(ts.SyntaxKind.ExtendsKeyword, [stmt.parent.visitExpression(this, null)])] ||
363 [], tslib_1.__spread(fields, getters, constructor, methods)));
364 };
365 NodeEmitterVisitor.prototype.visitIfStmt = function (stmt) {
366 return this.record(stmt, ts.createIf(stmt.condition.visitExpression(this, null), this._visitStatements(stmt.trueCase), stmt.falseCase && stmt.falseCase.length && this._visitStatements(stmt.falseCase) ||
367 undefined));
368 };
369 NodeEmitterVisitor.prototype.visitTryCatchStmt = function (stmt) {
370 return this.record(stmt, ts.createTry(this._visitStatements(stmt.bodyStmts), ts.createCatchClause(CATCH_ERROR_NAME, this._visitStatementsPrefix([ts.createVariableStatement(
371 /* modifiers */ undefined, [ts.createVariableDeclaration(CATCH_STACK_NAME, /* type */ undefined, ts.createPropertyAccess(ts.createIdentifier(CATCH_ERROR_NAME), ts.createIdentifier(CATCH_STACK_NAME)))])], stmt.catchStmts)),
372 /* finallyBlock */ undefined));
373 };
374 NodeEmitterVisitor.prototype.visitThrowStmt = function (stmt) {
375 return this.record(stmt, ts.createThrow(stmt.error.visitExpression(this, null)));
376 };
377 NodeEmitterVisitor.prototype.visitCommentStmt = function (stmt, sourceFile) {
378 var text = stmt.multiline ? " " + stmt.comment + " " : " " + stmt.comment;
379 return this.createCommentStmt(text, stmt.multiline, sourceFile);
380 };
381 NodeEmitterVisitor.prototype.visitJSDocCommentStmt = function (stmt, sourceFile) {
382 return this.createCommentStmt(stmt.toString(), true, sourceFile);
383 };
384 NodeEmitterVisitor.prototype.createCommentStmt = function (text, multiline, sourceFile) {
385 var commentStmt = ts.createNotEmittedStatement(sourceFile);
386 var kind = multiline ? ts.SyntaxKind.MultiLineCommentTrivia : ts.SyntaxKind.SingleLineCommentTrivia;
387 ts.setSyntheticLeadingComments(commentStmt, [{ kind: kind, text: text, pos: -1, end: -1 }]);
388 return commentStmt;
389 };
390 // ExpressionVisitor
391 NodeEmitterVisitor.prototype.visitWrappedNodeExpr = function (expr) { return this.record(expr, expr.node); };
392 NodeEmitterVisitor.prototype.visitTypeofExpr = function (expr) {
393 var typeOf = ts.createTypeOf(expr.expr.visitExpression(this, null));
394 return this.record(expr, typeOf);
395 };
396 // ExpressionVisitor
397 NodeEmitterVisitor.prototype.visitReadVarExpr = function (expr) {
398 switch (expr.builtin) {
399 case compiler_1.BuiltinVar.This:
400 return this.record(expr, ts.createIdentifier(METHOD_THIS_NAME));
401 case compiler_1.BuiltinVar.CatchError:
402 return this.record(expr, ts.createIdentifier(CATCH_ERROR_NAME));
403 case compiler_1.BuiltinVar.CatchStack:
404 return this.record(expr, ts.createIdentifier(CATCH_STACK_NAME));
405 case compiler_1.BuiltinVar.Super:
406 return this.record(expr, ts.createSuper());
407 }
408 if (expr.name) {
409 return this.record(expr, ts.createIdentifier(expr.name));
410 }
411 throw Error("Unexpected ReadVarExpr form");
412 };
413 NodeEmitterVisitor.prototype.visitWriteVarExpr = function (expr) {
414 return this.record(expr, ts.createAssignment(ts.createIdentifier(expr.name), expr.value.visitExpression(this, null)));
415 };
416 NodeEmitterVisitor.prototype.visitWriteKeyExpr = function (expr) {
417 return this.record(expr, ts.createAssignment(ts.createElementAccess(expr.receiver.visitExpression(this, null), expr.index.visitExpression(this, null)), expr.value.visitExpression(this, null)));
418 };
419 NodeEmitterVisitor.prototype.visitWritePropExpr = function (expr) {
420 return this.record(expr, ts.createAssignment(ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name), expr.value.visitExpression(this, null)));
421 };
422 NodeEmitterVisitor.prototype.visitInvokeMethodExpr = function (expr) {
423 var _this = this;
424 var methodName = getMethodName(expr);
425 return this.record(expr, ts.createCall(ts.createPropertyAccess(expr.receiver.visitExpression(this, null), methodName),
426 /* typeArguments */ undefined, expr.args.map(function (arg) { return arg.visitExpression(_this, null); })));
427 };
428 NodeEmitterVisitor.prototype.visitInvokeFunctionExpr = function (expr) {
429 var _this = this;
430 return this.record(expr, ts.createCall(expr.fn.visitExpression(this, null), /* typeArguments */ undefined, expr.args.map(function (arg) { return arg.visitExpression(_this, null); })));
431 };
432 NodeEmitterVisitor.prototype.visitInstantiateExpr = function (expr) {
433 var _this = this;
434 return this.record(expr, ts.createNew(expr.classExpr.visitExpression(this, null), /* typeArguments */ undefined, expr.args.map(function (arg) { return arg.visitExpression(_this, null); })));
435 };
436 NodeEmitterVisitor.prototype.visitLiteralExpr = function (expr) { return this.record(expr, createLiteral(expr.value)); };
437 NodeEmitterVisitor.prototype.visitExternalExpr = function (expr) {
438 return this.record(expr, this._visitIdentifier(expr.value));
439 };
440 NodeEmitterVisitor.prototype.visitConditionalExpr = function (expr) {
441 // TODO {chuckj}: Review use of ! on falseCase. Should it be non-nullable?
442 return this.record(expr, ts.createParen(ts.createConditional(expr.condition.visitExpression(this, null), expr.trueCase.visitExpression(this, null), expr.falseCase.visitExpression(this, null))));
443 };
444 NodeEmitterVisitor.prototype.visitNotExpr = function (expr) {
445 return this.record(expr, ts.createPrefix(ts.SyntaxKind.ExclamationToken, expr.condition.visitExpression(this, null)));
446 };
447 NodeEmitterVisitor.prototype.visitAssertNotNullExpr = function (expr) {
448 return expr.condition.visitExpression(this, null);
449 };
450 NodeEmitterVisitor.prototype.visitCastExpr = function (expr) {
451 return expr.value.visitExpression(this, null);
452 };
453 NodeEmitterVisitor.prototype.visitFunctionExpr = function (expr) {
454 return this.record(expr, ts.createFunctionExpression(
455 /* modifiers */ undefined, /* astriskToken */ undefined,
456 /* name */ expr.name || undefined,
457 /* typeParameters */ undefined, expr.params.map(function (p) { return ts.createParameter(
458 /* decorators */ undefined, /* modifiers */ undefined,
459 /* dotDotDotToken */ undefined, p.name); }),
460 /* type */ undefined, this._visitStatements(expr.statements)));
461 };
462 NodeEmitterVisitor.prototype.visitBinaryOperatorExpr = function (expr) {
463 var binaryOperator;
464 switch (expr.operator) {
465 case compiler_1.BinaryOperator.And:
466 binaryOperator = ts.SyntaxKind.AmpersandAmpersandToken;
467 break;
468 case compiler_1.BinaryOperator.BitwiseAnd:
469 binaryOperator = ts.SyntaxKind.AmpersandToken;
470 break;
471 case compiler_1.BinaryOperator.Bigger:
472 binaryOperator = ts.SyntaxKind.GreaterThanToken;
473 break;
474 case compiler_1.BinaryOperator.BiggerEquals:
475 binaryOperator = ts.SyntaxKind.GreaterThanEqualsToken;
476 break;
477 case compiler_1.BinaryOperator.Divide:
478 binaryOperator = ts.SyntaxKind.SlashToken;
479 break;
480 case compiler_1.BinaryOperator.Equals:
481 binaryOperator = ts.SyntaxKind.EqualsEqualsToken;
482 break;
483 case compiler_1.BinaryOperator.Identical:
484 binaryOperator = ts.SyntaxKind.EqualsEqualsEqualsToken;
485 break;
486 case compiler_1.BinaryOperator.Lower:
487 binaryOperator = ts.SyntaxKind.LessThanToken;
488 break;
489 case compiler_1.BinaryOperator.LowerEquals:
490 binaryOperator = ts.SyntaxKind.LessThanEqualsToken;
491 break;
492 case compiler_1.BinaryOperator.Minus:
493 binaryOperator = ts.SyntaxKind.MinusToken;
494 break;
495 case compiler_1.BinaryOperator.Modulo:
496 binaryOperator = ts.SyntaxKind.PercentToken;
497 break;
498 case compiler_1.BinaryOperator.Multiply:
499 binaryOperator = ts.SyntaxKind.AsteriskToken;
500 break;
501 case compiler_1.BinaryOperator.NotEquals:
502 binaryOperator = ts.SyntaxKind.ExclamationEqualsToken;
503 break;
504 case compiler_1.BinaryOperator.NotIdentical:
505 binaryOperator = ts.SyntaxKind.ExclamationEqualsEqualsToken;
506 break;
507 case compiler_1.BinaryOperator.Or:
508 binaryOperator = ts.SyntaxKind.BarBarToken;
509 break;
510 case compiler_1.BinaryOperator.Plus:
511 binaryOperator = ts.SyntaxKind.PlusToken;
512 break;
513 default:
514 throw new Error("Unknown operator: " + expr.operator);
515 }
516 var binary = ts.createBinary(expr.lhs.visitExpression(this, null), binaryOperator, expr.rhs.visitExpression(this, null));
517 return this.record(expr, expr.parens ? ts.createParen(binary) : binary);
518 };
519 NodeEmitterVisitor.prototype.visitReadPropExpr = function (expr) {
520 return this.record(expr, ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name));
521 };
522 NodeEmitterVisitor.prototype.visitReadKeyExpr = function (expr) {
523 return this.record(expr, ts.createElementAccess(expr.receiver.visitExpression(this, null), expr.index.visitExpression(this, null)));
524 };
525 NodeEmitterVisitor.prototype.visitLiteralArrayExpr = function (expr) {
526 var _this = this;
527 return this.record(expr, ts.createArrayLiteral(expr.entries.map(function (entry) { return entry.visitExpression(_this, null); })));
528 };
529 NodeEmitterVisitor.prototype.visitLiteralMapExpr = function (expr) {
530 var _this = this;
531 return this.record(expr, ts.createObjectLiteral(expr.entries.map(function (entry) { return ts.createPropertyAssignment(entry.quoted || !_VALID_IDENTIFIER_RE.test(entry.key) ?
532 ts.createLiteral(entry.key) :
533 entry.key, entry.value.visitExpression(_this, null)); })));
534 };
535 NodeEmitterVisitor.prototype.visitCommaExpr = function (expr) {
536 var _this = this;
537 return this.record(expr, expr.parts.map(function (e) { return e.visitExpression(_this, null); })
538 .reduce(function (left, right) {
539 return left ? ts.createBinary(left, ts.SyntaxKind.CommaToken, right) : right;
540 }, null));
541 };
542 NodeEmitterVisitor.prototype._visitStatements = function (statements) {
543 return this._visitStatementsPrefix([], statements);
544 };
545 NodeEmitterVisitor.prototype._visitStatementsPrefix = function (prefix, statements) {
546 var _this = this;
547 return ts.createBlock(tslib_1.__spread(prefix, statements.map(function (stmt) { return stmt.visitStatement(_this, null); }).filter(function (f) { return f != null; })));
548 };
549 NodeEmitterVisitor.prototype._visitIdentifier = function (value) {
550 // name can only be null during JIT which never executes this code.
551 var moduleName = value.moduleName, name = value.name;
552 var prefixIdent = null;
553 if (moduleName) {
554 var prefix = this._importsWithPrefixes.get(moduleName);
555 if (prefix == null) {
556 prefix = "i" + this._importsWithPrefixes.size;
557 this._importsWithPrefixes.set(moduleName, prefix);
558 }
559 prefixIdent = ts.createIdentifier(prefix);
560 }
561 if (prefixIdent) {
562 return ts.createPropertyAccess(prefixIdent, name);
563 }
564 else {
565 var id = ts.createIdentifier(name);
566 if (this._exportedVariableIdentifiers.has(name)) {
567 // In order for this new identifier node to be properly rewritten in CommonJS output,
568 // it must have its original node set to a parsed instance of the same identifier.
569 ts.setOriginalNode(id, this._exportedVariableIdentifiers.get(name));
570 }
571 return id;
572 }
573 };
574 return NodeEmitterVisitor;
575 }());
576 exports.NodeEmitterVisitor = NodeEmitterVisitor;
577 function getMethodName(methodRef) {
578 if (methodRef.name) {
579 return methodRef.name;
580 }
581 else {
582 switch (methodRef.builtin) {
583 case compiler_1.BuiltinMethod.Bind:
584 return 'bind';
585 case compiler_1.BuiltinMethod.ConcatArray:
586 return 'concat';
587 case compiler_1.BuiltinMethod.SubscribeObservable:
588 return 'subscribe';
589 }
590 }
591 throw new Error('Unexpected method reference form');
592 }
593 function modifierFromModifier(modifier) {
594 switch (modifier) {
595 case compiler_1.StmtModifier.Exported:
596 return ts.createToken(ts.SyntaxKind.ExportKeyword);
597 case compiler_1.StmtModifier.Final:
598 return ts.createToken(ts.SyntaxKind.ConstKeyword);
599 case compiler_1.StmtModifier.Private:
600 return ts.createToken(ts.SyntaxKind.PrivateKeyword);
601 case compiler_1.StmtModifier.Static:
602 return ts.createToken(ts.SyntaxKind.StaticKeyword);
603 }
604 return util_1.error("unknown statement modifier");
605 }
606 function translateModifiers(modifiers) {
607 return modifiers == null ? undefined : modifiers.map(modifierFromModifier);
608 }
609});
610//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node_emitter.js","sourceRoot":"","sources":["../../../../../../../packages/compiler-cli/src/transformers/node_emitter.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. 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 {AssertNotNull, BinaryOperator, BinaryOperatorExpr, BuiltinMethod, BuiltinVar, CastExpr, ClassStmt, CommaExpr, CommentStmt, ConditionalExpr, DeclareFunctionStmt, DeclareVarStmt, ExpressionStatement, ExpressionVisitor, ExternalExpr, ExternalReference, FunctionExpr, IfStmt, InstantiateExpr, InvokeFunctionExpr, InvokeMethodExpr, JSDocCommentStmt, LiteralArrayExpr, LiteralExpr, LiteralMapExpr, NotExpr, ParseSourceFile, ParseSourceSpan, PartialModule, ReadKeyExpr, ReadPropExpr, ReadVarExpr, ReturnStatement, Statement, StatementVisitor, StmtModifier, ThrowStmt, TryCatchStmt, TypeofExpr, WrappedNodeExpr, WriteKeyExpr, WritePropExpr, WriteVarExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {error} from './util';\n\nexport interface Node { sourceSpan: ParseSourceSpan|null; }\n\nconst METHOD_THIS_NAME = 'this';\nconst CATCH_ERROR_NAME = 'error';\nconst CATCH_STACK_NAME = 'stack';\nconst _VALID_IDENTIFIER_RE = /^[$A-Z_][0-9A-Z_$]*$/i;\n\nexport class TypeScriptNodeEmitter {\n  updateSourceFile(sourceFile: ts.SourceFile, stmts: Statement[], preamble?: string):\n      [ts.SourceFile, Map<ts.Node, Node>] {\n    const converter = new NodeEmitterVisitor();\n    // [].concat flattens the result so that each `visit...` method can also return an array of\n    // stmts.\n    const statements: any[] = [].concat(\n        ...stmts.map(stmt => stmt.visitStatement(converter, null)).filter(stmt => stmt != null));\n    const preambleStmts: ts.Statement[] = [];\n    if (preamble) {\n      const commentStmt = this.createCommentStatement(sourceFile, preamble);\n      preambleStmts.push(commentStmt);\n    }\n    const sourceStatements =\n        [...preambleStmts, ...converter.getReexports(), ...converter.getImports(), ...statements];\n    converter.updateSourceMap(sourceStatements);\n    const newSourceFile = ts.updateSourceFileNode(sourceFile, sourceStatements);\n    return [newSourceFile, converter.getNodeMap()];\n  }\n\n  /** Creates a not emitted statement containing the given comment. */\n  createCommentStatement(sourceFile: ts.SourceFile, comment: string): ts.Statement {\n    if (comment.startsWith('/*') && comment.endsWith('*/')) {\n      comment = comment.substr(2, comment.length - 4);\n    }\n    const commentStmt = ts.createNotEmittedStatement(sourceFile);\n    ts.setSyntheticLeadingComments(\n        commentStmt,\n        [{kind: ts.SyntaxKind.MultiLineCommentTrivia, text: comment, pos: -1, end: -1}]);\n    ts.setEmitFlags(commentStmt, ts.EmitFlags.CustomPrologue);\n    return commentStmt;\n  }\n}\n\n/**\n * Update the given source file to include the changes specified in module.\n *\n * The module parameter is treated as a partial module meaning that the statements are added to\n * the module instead of replacing the module. Also, any classes are treated as partial classes\n * and the included members are added to the class with the same name instead of a new class\n * being created.\n */\nexport function updateSourceFile(\n    sourceFile: ts.SourceFile, module: PartialModule,\n    context: ts.TransformationContext): [ts.SourceFile, Map<ts.Node, Node>] {\n  const converter = new NodeEmitterVisitor();\n  converter.loadExportedVariableIdentifiers(sourceFile);\n\n  const prefixStatements = module.statements.filter(statement => !(statement instanceof ClassStmt));\n  const classes =\n      module.statements.filter(statement => statement instanceof ClassStmt) as ClassStmt[];\n  const classMap = new Map(\n      classes.map<[string, ClassStmt]>(classStatement => [classStatement.name, classStatement]));\n  const classNames = new Set(classes.map(classStatement => classStatement.name));\n\n  const prefix: ts.Statement[] =\n      prefixStatements.map(statement => statement.visitStatement(converter, sourceFile));\n\n  // Add static methods to all the classes referenced in module.\n  let newStatements = sourceFile.statements.map(node => {\n    if (node.kind == ts.SyntaxKind.ClassDeclaration) {\n      const classDeclaration = node as ts.ClassDeclaration;\n      const name = classDeclaration.name;\n      if (name) {\n        const classStatement = classMap.get(name.text);\n        if (classStatement) {\n          classNames.delete(name.text);\n          const classMemberHolder =\n              converter.visitDeclareClassStmt(classStatement) as ts.ClassDeclaration;\n          const newMethods =\n              classMemberHolder.members.filter(member => member.kind !== ts.SyntaxKind.Constructor);\n          const newMembers = [...classDeclaration.members, ...newMethods];\n\n          return ts.updateClassDeclaration(\n              classDeclaration,\n              /* decorators */ classDeclaration.decorators,\n              /* modifiers */ classDeclaration.modifiers,\n              /* name */ classDeclaration.name,\n              /* typeParameters */ classDeclaration.typeParameters,\n              /* heritageClauses */ classDeclaration.heritageClauses || [],\n              /* members */ newMembers);\n        }\n      }\n    }\n    return node;\n  });\n\n  // Validate that all the classes have been generated\n  classNames.size == 0 ||\n      error(\n          `${classNames.size == 1 ? 'Class' : 'Classes'} \"${Array.from(classNames.keys()).join(', ')}\" not generated`);\n\n  // Add imports to the module required by the new methods\n  const imports = converter.getImports();\n  if (imports && imports.length) {\n    // Find where the new imports should go\n    const index = firstAfter(\n        newStatements, statement => statement.kind === ts.SyntaxKind.ImportDeclaration ||\n            statement.kind === ts.SyntaxKind.ImportEqualsDeclaration);\n    newStatements =\n        [...newStatements.slice(0, index), ...imports, ...prefix, ...newStatements.slice(index)];\n  } else {\n    newStatements = [...prefix, ...newStatements];\n  }\n\n  converter.updateSourceMap(newStatements);\n  const newSourceFile = ts.updateSourceFileNode(sourceFile, newStatements);\n\n  return [newSourceFile, converter.getNodeMap()];\n}\n\n// Return the index after the first value in `a` that doesn't match the predicate after a value that\n// does or 0 if no values match.\nfunction firstAfter<T>(a: T[], predicate: (value: T) => boolean) {\n  let index = 0;\n  const len = a.length;\n  for (; index < len; index++) {\n    const value = a[index];\n    if (predicate(value)) break;\n  }\n  if (index >= len) return 0;\n  for (; index < len; index++) {\n    const value = a[index];\n    if (!predicate(value)) break;\n  }\n  return index;\n}\n\n// A recorded node is a subtype of the node that is marked as being recorded. This is used\n// to ensure that NodeEmitterVisitor.record has been called on all nodes returned by the\n// NodeEmitterVisitor\nexport type RecordedNode<T extends ts.Node = ts.Node> = (T & { __recorded: any;}) | null;\n\nfunction escapeLiteral(value: string): string {\n  return value.replace(/(\\\"|\\\\)/g, '\\\\$1').replace(/(\\n)|(\\r)/g, function(v, n, r) {\n    return n ? '\\\\n' : '\\\\r';\n  });\n}\n\nfunction createLiteral(value: any) {\n  if (value === null) {\n    return ts.createNull();\n  } else if (value === undefined) {\n    return ts.createIdentifier('undefined');\n  } else {\n    const result = ts.createLiteral(value);\n    if (ts.isStringLiteral(result) && result.text.indexOf('\\\\') >= 0) {\n      // Hack to avoid problems cause indirectly by:\n      //    https://github.com/Microsoft/TypeScript/issues/20192\n      // This avoids the string escaping normally performed for a string relying on that\n      // TypeScript just emits the text raw for a numeric literal.\n      (result as any).kind = ts.SyntaxKind.NumericLiteral;\n      result.text = `\"${escapeLiteral(result.text)}\"`;\n    }\n    return result;\n  }\n}\n\nfunction isExportTypeStatement(statement: ts.Statement): boolean {\n  return !!statement.modifiers &&\n      statement.modifiers.some(mod => mod.kind === ts.SyntaxKind.ExportKeyword);\n}\n\n/**\n * Visits an output ast and produces the corresponding TypeScript synthetic nodes.\n */\nexport class NodeEmitterVisitor implements StatementVisitor, ExpressionVisitor {\n  private _nodeMap = new Map<ts.Node, Node>();\n  private _importsWithPrefixes = new Map<string, string>();\n  private _reexports = new Map<string, {name: string, as: string}[]>();\n  private _templateSources = new Map<ParseSourceFile, ts.SourceMapSource>();\n  private _exportedVariableIdentifiers = new Map<string, ts.Identifier>();\n\n  /**\n   * Process the source file and collect exported identifiers that refer to variables.\n   *\n   * Only variables are collected because exported classes still exist in the module scope in\n   * CommonJS, whereas variables have their declarations moved onto the `exports` object, and all\n   * references are updated accordingly.\n   */\n  loadExportedVariableIdentifiers(sourceFile: ts.SourceFile): void {\n    sourceFile.statements.forEach(statement => {\n      if (ts.isVariableStatement(statement) && isExportTypeStatement(statement)) {\n        statement.declarationList.declarations.forEach(declaration => {\n          if (ts.isIdentifier(declaration.name)) {\n            this._exportedVariableIdentifiers.set(declaration.name.text, declaration.name);\n          }\n        });\n      }\n    });\n  }\n\n  getReexports(): ts.Statement[] {\n    return Array.from(this._reexports.entries())\n        .map(\n            ([exportedFilePath, reexports]) => ts.createExportDeclaration(\n                /* decorators */ undefined,\n                /* modifiers */ undefined, ts.createNamedExports(reexports.map(\n                                               ({name, as}) => ts.createExportSpecifier(name, as))),\n                /* moduleSpecifier */ createLiteral(exportedFilePath)));\n  }\n\n  getImports(): ts.Statement[] {\n    return Array.from(this._importsWithPrefixes.entries())\n        .map(\n            ([namespace, prefix]) => ts.createImportDeclaration(\n                /* decorators */ undefined,\n                /* modifiers */ undefined,\n                /* importClause */ ts.createImportClause(\n                    /* name */<ts.Identifier>(undefined as any),\n                    ts.createNamespaceImport(ts.createIdentifier(prefix))),\n                /* moduleSpecifier */ createLiteral(namespace)));\n  }\n\n  getNodeMap() { return this._nodeMap; }\n\n  updateSourceMap(statements: ts.Statement[]) {\n    let lastRangeStartNode: ts.Node|undefined = undefined;\n    let lastRangeEndNode: ts.Node|undefined = undefined;\n    let lastRange: ts.SourceMapRange|undefined = undefined;\n\n    const recordLastSourceRange = () => {\n      if (lastRange && lastRangeStartNode && lastRangeEndNode) {\n        if (lastRangeStartNode == lastRangeEndNode) {\n          ts.setSourceMapRange(lastRangeEndNode, lastRange);\n        } else {\n          ts.setSourceMapRange(lastRangeStartNode, lastRange);\n          // Only emit the pos for the first node emitted in the range.\n          ts.setEmitFlags(lastRangeStartNode, ts.EmitFlags.NoTrailingSourceMap);\n          ts.setSourceMapRange(lastRangeEndNode, lastRange);\n          // Only emit emit end for the last node emitted in the range.\n          ts.setEmitFlags(lastRangeEndNode, ts.EmitFlags.NoLeadingSourceMap);\n        }\n      }\n    };\n\n    const visitNode = (tsNode: ts.Node) => {\n      const ngNode = this._nodeMap.get(tsNode);\n      if (ngNode) {\n        const range = this.sourceRangeOf(ngNode);\n        if (range) {\n          if (!lastRange || range.source != lastRange.source || range.pos != lastRange.pos ||\n              range.end != lastRange.end) {\n            recordLastSourceRange();\n            lastRangeStartNode = tsNode;\n            lastRange = range;\n          }\n          lastRangeEndNode = tsNode;\n        }\n      }\n      ts.forEachChild(tsNode, visitNode);\n    };\n    statements.forEach(visitNode);\n    recordLastSourceRange();\n  }\n\n  private record<T extends ts.Node>(ngNode: Node, tsNode: T|null): RecordedNode<T> {\n    if (tsNode && !this._nodeMap.has(tsNode)) {\n      this._nodeMap.set(tsNode, ngNode);\n    }\n    return tsNode as RecordedNode<T>;\n  }\n\n  private sourceRangeOf(node: Node): ts.SourceMapRange|null {\n    if (node.sourceSpan) {\n      const span = node.sourceSpan;\n      if (span.start.file == span.end.file) {\n        const file = span.start.file;\n        if (file.url) {\n          let source = this._templateSources.get(file);\n          if (!source) {\n            source = ts.createSourceMapSource(file.url, file.content, pos => pos);\n            this._templateSources.set(file, source);\n          }\n          return {pos: span.start.offset, end: span.end.offset, source};\n        }\n      }\n    }\n    return null;\n  }\n\n  private getModifiers(stmt: Statement) {\n    let modifiers: ts.Modifier[] = [];\n    if (stmt.hasModifier(StmtModifier.Exported)) {\n      modifiers.push(ts.createToken(ts.SyntaxKind.ExportKeyword));\n    }\n    return modifiers;\n  }\n\n  // StatementVisitor\n  visitDeclareVarStmt(stmt: DeclareVarStmt) {\n    if (stmt.hasModifier(StmtModifier.Exported) && stmt.value instanceof ExternalExpr &&\n        !stmt.type) {\n      // check for a reexport\n      const {name, moduleName} = stmt.value.value;\n      if (moduleName) {\n        let reexports = this._reexports.get(moduleName);\n        if (!reexports) {\n          reexports = [];\n          this._reexports.set(moduleName, reexports);\n        }\n        reexports.push({name: name !, as: stmt.name});\n        return null;\n      }\n    }\n\n    const varDeclList = ts.createVariableDeclarationList([ts.createVariableDeclaration(\n        ts.createIdentifier(stmt.name),\n        /* type */ undefined,\n        (stmt.value && stmt.value.visitExpression(this, null)) || undefined)]);\n\n    if (stmt.hasModifier(StmtModifier.Exported)) {\n      // Note: We need to add an explicit variable and export declaration so that\n      // the variable can be referred in the same file as well.\n      const tsVarStmt =\n          this.record(stmt, ts.createVariableStatement(/* modifiers */[], varDeclList));\n      const exportStmt = this.record(\n          stmt, ts.createExportDeclaration(\n                    /*decorators*/ undefined, /*modifiers*/ undefined,\n                    ts.createNamedExports([ts.createExportSpecifier(stmt.name, stmt.name)])));\n      return [tsVarStmt, exportStmt];\n    }\n    return this.record(stmt, ts.createVariableStatement(this.getModifiers(stmt), varDeclList));\n  }\n\n  visitDeclareFunctionStmt(stmt: DeclareFunctionStmt) {\n    return this.record(\n        stmt, ts.createFunctionDeclaration(\n                  /* decorators */ undefined, this.getModifiers(stmt),\n                  /* asteriskToken */ undefined, stmt.name, /* typeParameters */ undefined,\n                  stmt.params.map(\n                      p => ts.createParameter(\n                          /* decorators */ undefined, /* modifiers */ undefined,\n                          /* dotDotDotToken */ undefined, p.name)),\n                  /* type */ undefined, this._visitStatements(stmt.statements)));\n  }\n\n  visitExpressionStmt(stmt: ExpressionStatement) {\n    return this.record(stmt, ts.createStatement(stmt.expr.visitExpression(this, null)));\n  }\n\n  visitReturnStmt(stmt: ReturnStatement) {\n    return this.record(\n        stmt, ts.createReturn(stmt.value ? stmt.value.visitExpression(this, null) : undefined));\n  }\n\n  visitDeclareClassStmt(stmt: ClassStmt) {\n    const modifiers = this.getModifiers(stmt);\n    const fields = stmt.fields.map(\n        field => ts.createProperty(\n            /* decorators */ undefined, /* modifiers */ translateModifiers(field.modifiers),\n            field.name,\n            /* questionToken */ undefined,\n            /* type */ undefined,\n            field.initializer == null ? ts.createNull() :\n                                        field.initializer.visitExpression(this, null)));\n    const getters = stmt.getters.map(\n        getter => ts.createGetAccessor(\n            /* decorators */ undefined, /* modifiers */ undefined, getter.name, /* parameters */[],\n            /* type */ undefined, this._visitStatements(getter.body)));\n\n    const constructor =\n        (stmt.constructorMethod && [ts.createConstructor(\n                                       /* decorators */ undefined,\n                                       /* modifiers */ undefined,\n                                       /* parameters */ stmt.constructorMethod.params.map(\n                                           p => ts.createParameter(\n                                               /* decorators */ undefined,\n                                               /* modifiers */ undefined,\n                                               /* dotDotDotToken */ undefined, p.name)),\n                                       this._visitStatements(stmt.constructorMethod.body))]) ||\n        [];\n\n    // TODO {chuckj}: Determine what should be done for a method with a null name.\n    const methods = stmt.methods.filter(method => method.name)\n                        .map(\n                            method => ts.createMethod(\n                                /* decorators */ undefined,\n                                /* modifiers */ translateModifiers(method.modifiers),\n                                /* astriskToken */ undefined, method.name !/* guarded by filter */,\n                                /* questionToken */ undefined, /* typeParameters */ undefined,\n                                method.params.map(\n                                    p => ts.createParameter(\n                                        /* decorators */ undefined, /* modifiers */ undefined,\n                                        /* dotDotDotToken */ undefined, p.name)),\n                                /* type */ undefined, this._visitStatements(method.body)));\n    return this.record(\n        stmt, ts.createClassDeclaration(\n                  /* decorators */ undefined, modifiers, stmt.name, /* typeParameters*/ undefined,\n                  stmt.parent && [ts.createHeritageClause(\n                                     ts.SyntaxKind.ExtendsKeyword,\n                                     [stmt.parent.visitExpression(this, null)])] ||\n                      [],\n                  [...fields, ...getters, ...constructor, ...methods]));\n  }\n\n  visitIfStmt(stmt: IfStmt) {\n    return this.record(\n        stmt,\n        ts.createIf(\n            stmt.condition.visitExpression(this, null), this._visitStatements(stmt.trueCase),\n            stmt.falseCase && stmt.falseCase.length && this._visitStatements(stmt.falseCase) ||\n                undefined));\n  }\n\n  visitTryCatchStmt(stmt: TryCatchStmt): RecordedNode<ts.TryStatement> {\n    return this.record(\n        stmt, ts.createTry(\n                  this._visitStatements(stmt.bodyStmts),\n                  ts.createCatchClause(\n                      CATCH_ERROR_NAME, this._visitStatementsPrefix(\n                                            [ts.createVariableStatement(\n                                                /* modifiers */ undefined,\n                                                [ts.createVariableDeclaration(\n                                                    CATCH_STACK_NAME, /* type */ undefined,\n                                                    ts.createPropertyAccess(\n                                                        ts.createIdentifier(CATCH_ERROR_NAME),\n                                                        ts.createIdentifier(CATCH_STACK_NAME)))])],\n                                            stmt.catchStmts)),\n                  /* finallyBlock */ undefined));\n  }\n\n  visitThrowStmt(stmt: ThrowStmt) {\n    return this.record(stmt, ts.createThrow(stmt.error.visitExpression(this, null)));\n  }\n\n  visitCommentStmt(stmt: CommentStmt, sourceFile: ts.SourceFile) {\n    const text = stmt.multiline ? ` ${stmt.comment} ` : ` ${stmt.comment}`;\n    return this.createCommentStmt(text, stmt.multiline, sourceFile);\n  }\n\n  visitJSDocCommentStmt(stmt: JSDocCommentStmt, sourceFile: ts.SourceFile) {\n    return this.createCommentStmt(stmt.toString(), true, sourceFile);\n  }\n\n  private createCommentStmt(text: string, multiline: boolean, sourceFile: ts.SourceFile):\n      ts.NotEmittedStatement {\n    const commentStmt = ts.createNotEmittedStatement(sourceFile);\n    const kind =\n        multiline ? ts.SyntaxKind.MultiLineCommentTrivia : ts.SyntaxKind.SingleLineCommentTrivia;\n    ts.setSyntheticLeadingComments(commentStmt, [{kind, text, pos: -1, end: -1}]);\n    return commentStmt;\n  }\n\n  // ExpressionVisitor\n  visitWrappedNodeExpr(expr: WrappedNodeExpr<any>) { return this.record(expr, expr.node); }\n\n  visitTypeofExpr(expr: TypeofExpr) {\n    const typeOf = ts.createTypeOf(expr.expr.visitExpression(this, null));\n    return this.record(expr, typeOf);\n  }\n\n  // ExpressionVisitor\n  visitReadVarExpr(expr: ReadVarExpr) {\n    switch (expr.builtin) {\n      case BuiltinVar.This:\n        return this.record(expr, ts.createIdentifier(METHOD_THIS_NAME));\n      case BuiltinVar.CatchError:\n        return this.record(expr, ts.createIdentifier(CATCH_ERROR_NAME));\n      case BuiltinVar.CatchStack:\n        return this.record(expr, ts.createIdentifier(CATCH_STACK_NAME));\n      case BuiltinVar.Super:\n        return this.record(expr, ts.createSuper());\n    }\n    if (expr.name) {\n      return this.record(expr, ts.createIdentifier(expr.name));\n    }\n    throw Error(`Unexpected ReadVarExpr form`);\n  }\n\n  visitWriteVarExpr(expr: WriteVarExpr): RecordedNode<ts.BinaryExpression> {\n    return this.record(\n        expr, ts.createAssignment(\n                  ts.createIdentifier(expr.name), expr.value.visitExpression(this, null)));\n  }\n\n  visitWriteKeyExpr(expr: WriteKeyExpr): RecordedNode<ts.BinaryExpression> {\n    return this.record(\n        expr,\n        ts.createAssignment(\n            ts.createElementAccess(\n                expr.receiver.visitExpression(this, null), expr.index.visitExpression(this, null)),\n            expr.value.visitExpression(this, null)));\n  }\n\n  visitWritePropExpr(expr: WritePropExpr): RecordedNode<ts.BinaryExpression> {\n    return this.record(\n        expr, ts.createAssignment(\n                  ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name),\n                  expr.value.visitExpression(this, null)));\n  }\n\n  visitInvokeMethodExpr(expr: InvokeMethodExpr): RecordedNode<ts.CallExpression> {\n    const methodName = getMethodName(expr);\n    return this.record(\n        expr,\n        ts.createCall(\n            ts.createPropertyAccess(expr.receiver.visitExpression(this, null), methodName),\n            /* typeArguments */ undefined, expr.args.map(arg => arg.visitExpression(this, null))));\n  }\n\n  visitInvokeFunctionExpr(expr: InvokeFunctionExpr): RecordedNode<ts.CallExpression> {\n    return this.record(\n        expr, ts.createCall(\n                  expr.fn.visitExpression(this, null), /* typeArguments */ undefined,\n                  expr.args.map(arg => arg.visitExpression(this, null))));\n  }\n\n  visitInstantiateExpr(expr: InstantiateExpr): RecordedNode<ts.NewExpression> {\n    return this.record(\n        expr, ts.createNew(\n                  expr.classExpr.visitExpression(this, null), /* typeArguments */ undefined,\n                  expr.args.map(arg => arg.visitExpression(this, null))));\n  }\n\n  visitLiteralExpr(expr: LiteralExpr) { return this.record(expr, createLiteral(expr.value)); }\n\n  visitExternalExpr(expr: ExternalExpr) {\n    return this.record(expr, this._visitIdentifier(expr.value));\n  }\n\n  visitConditionalExpr(expr: ConditionalExpr): RecordedNode<ts.ParenthesizedExpression> {\n    // TODO {chuckj}: Review use of ! on falseCase. Should it be non-nullable?\n    return this.record(\n        expr,\n        ts.createParen(ts.createConditional(\n            expr.condition.visitExpression(this, null), expr.trueCase.visitExpression(this, null),\n            expr.falseCase !.visitExpression(this, null))));\n  }\n\n  visitNotExpr(expr: NotExpr): RecordedNode<ts.PrefixUnaryExpression> {\n    return this.record(\n        expr, ts.createPrefix(\n                  ts.SyntaxKind.ExclamationToken, expr.condition.visitExpression(this, null)));\n  }\n\n  visitAssertNotNullExpr(expr: AssertNotNull): RecordedNode<ts.Expression> {\n    return expr.condition.visitExpression(this, null);\n  }\n\n  visitCastExpr(expr: CastExpr): RecordedNode<ts.Expression> {\n    return expr.value.visitExpression(this, null);\n  }\n\n  visitFunctionExpr(expr: FunctionExpr) {\n    return this.record(\n        expr, ts.createFunctionExpression(\n                  /* modifiers */ undefined, /* astriskToken */ undefined,\n                  /* name */ expr.name || undefined,\n                  /* typeParameters */ undefined,\n                  expr.params.map(\n                      p => ts.createParameter(\n                          /* decorators */ undefined, /* modifiers */ undefined,\n                          /* dotDotDotToken */ undefined, p.name)),\n                  /* type */ undefined, this._visitStatements(expr.statements)));\n  }\n\n  visitBinaryOperatorExpr(expr: BinaryOperatorExpr):\n      RecordedNode<ts.BinaryExpression|ts.ParenthesizedExpression> {\n    let binaryOperator: ts.BinaryOperator;\n    switch (expr.operator) {\n      case BinaryOperator.And:\n        binaryOperator = ts.SyntaxKind.AmpersandAmpersandToken;\n        break;\n      case BinaryOperator.BitwiseAnd:\n        binaryOperator = ts.SyntaxKind.AmpersandToken;\n        break;\n      case BinaryOperator.Bigger:\n        binaryOperator = ts.SyntaxKind.GreaterThanToken;\n        break;\n      case BinaryOperator.BiggerEquals:\n        binaryOperator = ts.SyntaxKind.GreaterThanEqualsToken;\n        break;\n      case BinaryOperator.Divide:\n        binaryOperator = ts.SyntaxKind.SlashToken;\n        break;\n      case BinaryOperator.Equals:\n        binaryOperator = ts.SyntaxKind.EqualsEqualsToken;\n        break;\n      case BinaryOperator.Identical:\n        binaryOperator = ts.SyntaxKind.EqualsEqualsEqualsToken;\n        break;\n      case BinaryOperator.Lower:\n        binaryOperator = ts.SyntaxKind.LessThanToken;\n        break;\n      case BinaryOperator.LowerEquals:\n        binaryOperator = ts.SyntaxKind.LessThanEqualsToken;\n        break;\n      case BinaryOperator.Minus:\n        binaryOperator = ts.SyntaxKind.MinusToken;\n        break;\n      case BinaryOperator.Modulo:\n        binaryOperator = ts.SyntaxKind.PercentToken;\n        break;\n      case BinaryOperator.Multiply:\n        binaryOperator = ts.SyntaxKind.AsteriskToken;\n        break;\n      case BinaryOperator.NotEquals:\n        binaryOperator = ts.SyntaxKind.ExclamationEqualsToken;\n        break;\n      case BinaryOperator.NotIdentical:\n        binaryOperator = ts.SyntaxKind.ExclamationEqualsEqualsToken;\n        break;\n      case BinaryOperator.Or:\n        binaryOperator = ts.SyntaxKind.BarBarToken;\n        break;\n      case BinaryOperator.Plus:\n        binaryOperator = ts.SyntaxKind.PlusToken;\n        break;\n      default:\n        throw new Error(`Unknown operator: ${expr.operator}`);\n    }\n    const binary = ts.createBinary(\n        expr.lhs.visitExpression(this, null), binaryOperator, expr.rhs.visitExpression(this, null));\n    return this.record(expr, expr.parens ? ts.createParen(binary) : binary);\n  }\n\n  visitReadPropExpr(expr: ReadPropExpr): RecordedNode<ts.PropertyAccessExpression> {\n    return this.record(\n        expr, ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name));\n  }\n\n  visitReadKeyExpr(expr: ReadKeyExpr): RecordedNode<ts.ElementAccessExpression> {\n    return this.record(\n        expr,\n        ts.createElementAccess(\n            expr.receiver.visitExpression(this, null), expr.index.visitExpression(this, null)));\n  }\n\n  visitLiteralArrayExpr(expr: LiteralArrayExpr): RecordedNode<ts.ArrayLiteralExpression> {\n    return this.record(\n        expr, ts.createArrayLiteral(expr.entries.map(entry => entry.visitExpression(this, null))));\n  }\n\n  visitLiteralMapExpr(expr: LiteralMapExpr): RecordedNode<ts.ObjectLiteralExpression> {\n    return this.record(\n        expr, ts.createObjectLiteral(expr.entries.map(\n                  entry => ts.createPropertyAssignment(\n                      entry.quoted || !_VALID_IDENTIFIER_RE.test(entry.key) ?\n                          ts.createLiteral(entry.key) :\n                          entry.key,\n                      entry.value.visitExpression(this, null)))));\n  }\n\n  visitCommaExpr(expr: CommaExpr): RecordedNode<ts.Expression> {\n    return this.record(\n        expr, expr.parts.map(e => e.visitExpression(this, null))\n                  .reduce<ts.Expression|null>(\n                      (left, right) =>\n                          left ? ts.createBinary(left, ts.SyntaxKind.CommaToken, right) : right,\n                      null));\n  }\n\n  private _visitStatements(statements: Statement[]): ts.Block {\n    return this._visitStatementsPrefix([], statements);\n  }\n\n  private _visitStatementsPrefix(prefix: ts.Statement[], statements: Statement[]) {\n    return ts.createBlock([\n      ...prefix, ...statements.map(stmt => stmt.visitStatement(this, null)).filter(f => f != null)\n    ]);\n  }\n\n  private _visitIdentifier(value: ExternalReference): ts.Expression {\n    // name can only be null during JIT which never executes this code.\n    const moduleName = value.moduleName, name = value.name !;\n    let prefixIdent: ts.Identifier|null = null;\n    if (moduleName) {\n      let prefix = this._importsWithPrefixes.get(moduleName);\n      if (prefix == null) {\n        prefix = `i${this._importsWithPrefixes.size}`;\n        this._importsWithPrefixes.set(moduleName, prefix);\n      }\n      prefixIdent = ts.createIdentifier(prefix);\n    }\n    if (prefixIdent) {\n      return ts.createPropertyAccess(prefixIdent, name);\n    } else {\n      const id = ts.createIdentifier(name);\n      if (this._exportedVariableIdentifiers.has(name)) {\n        // In order for this new identifier node to be properly rewritten in CommonJS output,\n        // it must have its original node set to a parsed instance of the same identifier.\n        ts.setOriginalNode(id, this._exportedVariableIdentifiers.get(name));\n      }\n      return id;\n    }\n  }\n}\n\n\nfunction getMethodName(methodRef: {name: string | null; builtin: BuiltinMethod | null}): string {\n  if (methodRef.name) {\n    return methodRef.name;\n  } else {\n    switch (methodRef.builtin) {\n      case BuiltinMethod.Bind:\n        return 'bind';\n      case BuiltinMethod.ConcatArray:\n        return 'concat';\n      case BuiltinMethod.SubscribeObservable:\n        return 'subscribe';\n    }\n  }\n  throw new Error('Unexpected method reference form');\n}\n\nfunction modifierFromModifier(modifier: StmtModifier): ts.Modifier {\n  switch (modifier) {\n    case StmtModifier.Exported:\n      return ts.createToken(ts.SyntaxKind.ExportKeyword);\n    case StmtModifier.Final:\n      return ts.createToken(ts.SyntaxKind.ConstKeyword);\n    case StmtModifier.Private:\n      return ts.createToken(ts.SyntaxKind.PrivateKeyword);\n    case StmtModifier.Static:\n      return ts.createToken(ts.SyntaxKind.StaticKeyword);\n  }\n  return error(`unknown statement modifier`);\n}\n\nfunction translateModifiers(modifiers: StmtModifier[] | null): ts.Modifier[]|undefined {\n  return modifiers == null ? undefined : modifiers !.map(modifierFromModifier);\n}\n"]}
\No newline at end of file