/** * @license * Copyright Google LLC All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://angular.io/license */ (function (factory) { if (typeof module === "object" && typeof module.exports === "object") { var v = factory(require, exports); if (v !== undefined) module.exports = v; } else if (typeof define === "function" && define.amd) { define("@angular/compiler-cli/src/transformers/node_emitter", ["require", "exports", "tslib", "@angular/compiler", "typescript", "@angular/compiler-cli/src/ngtsc/translator", "@angular/compiler-cli/src/transformers/util"], factory); } })(function (require, exports) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.NodeEmitterVisitor = exports.updateSourceFile = exports.TypeScriptNodeEmitter = void 0; var tslib_1 = require("tslib"); var compiler_1 = require("@angular/compiler"); var ts = require("typescript"); var translator_1 = require("@angular/compiler-cli/src/ngtsc/translator"); var util_1 = require("@angular/compiler-cli/src/transformers/util"); var METHOD_THIS_NAME = 'this'; var CATCH_ERROR_NAME = 'error'; var CATCH_STACK_NAME = 'stack'; var _VALID_IDENTIFIER_RE = /^[$A-Z_][0-9A-Z_$]*$/i; var TypeScriptNodeEmitter = /** @class */ (function () { function TypeScriptNodeEmitter(annotateForClosureCompiler) { this.annotateForClosureCompiler = annotateForClosureCompiler; } TypeScriptNodeEmitter.prototype.updateSourceFile = function (sourceFile, stmts, preamble) { var converter = new NodeEmitterVisitor(this.annotateForClosureCompiler); // [].concat flattens the result so that each `visit...` method can also return an array of // stmts. var statements = [].concat.apply([], tslib_1.__spreadArray([], tslib_1.__read(stmts.map(function (stmt) { return stmt.visitStatement(converter, null); }).filter(function (stmt) { return stmt != null; })))); var sourceStatements = tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(converter.getReexports())), tslib_1.__read(converter.getImports())), tslib_1.__read(statements)); if (preamble) { // We always attach the preamble comment to a `NotEmittedStatement` node, because tsickle uses // this node type as a marker of the preamble to ensure that it adds its own new nodes after // the preamble. var preambleCommentHolder = ts.createNotEmittedStatement(sourceFile); // Preamble comments are passed through as-is, which means that they must already contain a // leading `*` if they should be a JSDOC comment. ts.addSyntheticLeadingComment(preambleCommentHolder, ts.SyntaxKind.MultiLineCommentTrivia, preamble, /* hasTrailingNewline */ true); sourceStatements.unshift(preambleCommentHolder); } converter.updateSourceMap(sourceStatements); var newSourceFile = ts.updateSourceFileNode(sourceFile, sourceStatements); return [newSourceFile, converter.getNodeMap()]; }; return TypeScriptNodeEmitter; }()); exports.TypeScriptNodeEmitter = TypeScriptNodeEmitter; /** * Update the given source file to include the changes specified in module. * * The module parameter is treated as a partial module meaning that the statements are added to * the module instead of replacing the module. Also, any classes are treated as partial classes * and the included members are added to the class with the same name instead of a new class * being created. */ function updateSourceFile(sourceFile, module, annotateForClosureCompiler) { var converter = new NodeEmitterVisitor(annotateForClosureCompiler); converter.loadExportedVariableIdentifiers(sourceFile); var prefixStatements = module.statements.filter(function (statement) { return !(statement instanceof compiler_1.ClassStmt); }); var classes = module.statements.filter(function (statement) { return statement instanceof compiler_1.ClassStmt; }); var classMap = new Map(classes.map(function (classStatement) { return [classStatement.name, classStatement]; })); var classNames = new Set(classes.map(function (classStatement) { return classStatement.name; })); var prefix = prefixStatements.map(function (statement) { return statement.visitStatement(converter, sourceFile); }); // Add static methods to all the classes referenced in module. var newStatements = sourceFile.statements.map(function (node) { if (node.kind == ts.SyntaxKind.ClassDeclaration) { var classDeclaration = node; var name = classDeclaration.name; if (name) { var classStatement = classMap.get(name.text); if (classStatement) { classNames.delete(name.text); var classMemberHolder = converter.visitDeclareClassStmt(classStatement); var newMethods = classMemberHolder.members.filter(function (member) { return member.kind !== ts.SyntaxKind.Constructor; }); var newMembers = tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(classDeclaration.members)), tslib_1.__read(newMethods)); return ts.updateClassDeclaration(classDeclaration, /* decorators */ classDeclaration.decorators, /* modifiers */ classDeclaration.modifiers, /* name */ classDeclaration.name, /* typeParameters */ classDeclaration.typeParameters, /* heritageClauses */ classDeclaration.heritageClauses || [], /* members */ newMembers); } } } return node; }); // Validate that all the classes have been generated classNames.size == 0 || util_1.error((classNames.size == 1 ? 'Class' : 'Classes') + " \"" + Array.from(classNames.keys()).join(', ') + "\" not generated"); // Add imports to the module required by the new methods var imports = converter.getImports(); if (imports && imports.length) { // Find where the new imports should go var index = firstAfter(newStatements, function (statement) { return statement.kind === ts.SyntaxKind.ImportDeclaration || statement.kind === ts.SyntaxKind.ImportEqualsDeclaration; }); newStatements = tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(newStatements.slice(0, index))), tslib_1.__read(imports)), tslib_1.__read(prefix)), tslib_1.__read(newStatements.slice(index))); } else { newStatements = tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(prefix)), tslib_1.__read(newStatements)); } converter.updateSourceMap(newStatements); var newSourceFile = ts.updateSourceFileNode(sourceFile, newStatements); return [newSourceFile, converter.getNodeMap()]; } exports.updateSourceFile = updateSourceFile; // Return the index after the first value in `a` that doesn't match the predicate after a value that // does or 0 if no values match. function firstAfter(a, predicate) { var index = 0; var len = a.length; for (; index < len; index++) { var value = a[index]; if (predicate(value)) break; } if (index >= len) return 0; for (; index < len; index++) { var value = a[index]; if (!predicate(value)) break; } return index; } function escapeLiteral(value) { return value.replace(/(\"|\\)/g, '\\$1').replace(/(\n)|(\r)/g, function (v, n, r) { return n ? '\\n' : '\\r'; }); } function createLiteral(value) { if (value === null) { return ts.createNull(); } else if (value === undefined) { return ts.createIdentifier('undefined'); } else { var result = ts.createLiteral(value); if (ts.isStringLiteral(result) && result.text.indexOf('\\') >= 0) { // Hack to avoid problems cause indirectly by: // https://github.com/Microsoft/TypeScript/issues/20192 // This avoids the string escaping normally performed for a string relying on that // TypeScript just emits the text raw for a numeric literal. result.kind = ts.SyntaxKind.NumericLiteral; result.text = "\"" + escapeLiteral(result.text) + "\""; } return result; } } function isExportTypeStatement(statement) { return !!statement.modifiers && statement.modifiers.some(function (mod) { return mod.kind === ts.SyntaxKind.ExportKeyword; }); } /** * Visits an output ast and produces the corresponding TypeScript synthetic nodes. */ var NodeEmitterVisitor = /** @class */ (function () { function NodeEmitterVisitor(annotateForClosureCompiler) { this.annotateForClosureCompiler = annotateForClosureCompiler; this._nodeMap = new Map(); this._importsWithPrefixes = new Map(); this._reexports = new Map(); this._templateSources = new Map(); this._exportedVariableIdentifiers = new Map(); } /** * Process the source file and collect exported identifiers that refer to variables. * * Only variables are collected because exported classes still exist in the module scope in * CommonJS, whereas variables have their declarations moved onto the `exports` object, and all * references are updated accordingly. */ NodeEmitterVisitor.prototype.loadExportedVariableIdentifiers = function (sourceFile) { var _this = this; sourceFile.statements.forEach(function (statement) { if (ts.isVariableStatement(statement) && isExportTypeStatement(statement)) { statement.declarationList.declarations.forEach(function (declaration) { if (ts.isIdentifier(declaration.name)) { _this._exportedVariableIdentifiers.set(declaration.name.text, declaration.name); } }); } }); }; NodeEmitterVisitor.prototype.getReexports = function () { return Array.from(this._reexports.entries()) .map(function (_a) { var _b = tslib_1.__read(_a, 2), exportedFilePath = _b[0], reexports = _b[1]; return ts.createExportDeclaration( /* decorators */ undefined, /* modifiers */ undefined, ts.createNamedExports(reexports.map(function (_a) { var name = _a.name, as = _a.as; return ts.createExportSpecifier(name, as); })), /* moduleSpecifier */ createLiteral(exportedFilePath)); }); }; NodeEmitterVisitor.prototype.getImports = function () { return Array.from(this._importsWithPrefixes.entries()) .map(function (_a) { var _b = tslib_1.__read(_a, 2), namespace = _b[0], prefix = _b[1]; return ts.createImportDeclaration( /* decorators */ undefined, /* modifiers */ undefined, /* importClause */ ts.createImportClause( /* name */ undefined, ts.createNamespaceImport(ts.createIdentifier(prefix))), /* moduleSpecifier */ createLiteral(namespace)); }); }; NodeEmitterVisitor.prototype.getNodeMap = function () { return this._nodeMap; }; NodeEmitterVisitor.prototype.updateSourceMap = function (statements) { var _this = this; var lastRangeStartNode = undefined; var lastRangeEndNode = undefined; var lastRange = undefined; var recordLastSourceRange = function () { if (lastRange && lastRangeStartNode && lastRangeEndNode) { if (lastRangeStartNode == lastRangeEndNode) { ts.setSourceMapRange(lastRangeEndNode, lastRange); } else { ts.setSourceMapRange(lastRangeStartNode, lastRange); // Only emit the pos for the first node emitted in the range. ts.setEmitFlags(lastRangeStartNode, ts.EmitFlags.NoTrailingSourceMap); ts.setSourceMapRange(lastRangeEndNode, lastRange); // Only emit emit end for the last node emitted in the range. ts.setEmitFlags(lastRangeEndNode, ts.EmitFlags.NoLeadingSourceMap); } } }; var visitNode = function (tsNode) { var ngNode = _this._nodeMap.get(tsNode); if (ngNode) { var range = _this.sourceRangeOf(ngNode); if (range) { if (!lastRange || range.source != lastRange.source || range.pos != lastRange.pos || range.end != lastRange.end) { recordLastSourceRange(); lastRangeStartNode = tsNode; lastRange = range; } lastRangeEndNode = tsNode; } } ts.forEachChild(tsNode, visitNode); }; statements.forEach(visitNode); recordLastSourceRange(); }; NodeEmitterVisitor.prototype.postProcess = function (ngNode, tsNode) { if (tsNode && !this._nodeMap.has(tsNode)) { this._nodeMap.set(tsNode, ngNode); } if (tsNode !== null && ngNode instanceof compiler_1.Statement && ngNode.leadingComments !== undefined) { translator_1.attachComments(tsNode, ngNode.leadingComments); } return tsNode; }; NodeEmitterVisitor.prototype.sourceRangeOf = function (node) { if (node.sourceSpan) { var span = node.sourceSpan; if (span.start.file == span.end.file) { var file = span.start.file; if (file.url) { var source = this._templateSources.get(file); if (!source) { source = ts.createSourceMapSource(file.url, file.content, function (pos) { return pos; }); this._templateSources.set(file, source); } return { pos: span.start.offset, end: span.end.offset, source: source }; } } } return null; }; NodeEmitterVisitor.prototype.getModifiers = function (stmt) { var modifiers = []; if (stmt.hasModifier(compiler_1.StmtModifier.Exported)) { modifiers.push(ts.createToken(ts.SyntaxKind.ExportKeyword)); } return modifiers; }; // StatementVisitor NodeEmitterVisitor.prototype.visitDeclareVarStmt = function (stmt) { if (stmt.hasModifier(compiler_1.StmtModifier.Exported) && stmt.value instanceof compiler_1.ExternalExpr && !stmt.type) { // check for a reexport var _a = stmt.value.value, name = _a.name, moduleName = _a.moduleName; if (moduleName) { var reexports = this._reexports.get(moduleName); if (!reexports) { reexports = []; this._reexports.set(moduleName, reexports); } reexports.push({ name: name, as: stmt.name }); return null; } } var varDeclList = ts.createVariableDeclarationList([ts.createVariableDeclaration(ts.createIdentifier(stmt.name), /* type */ undefined, (stmt.value && stmt.value.visitExpression(this, null)) || undefined)]); if (stmt.hasModifier(compiler_1.StmtModifier.Exported)) { // Note: We need to add an explicit variable and export declaration so that // the variable can be referred in the same file as well. var tsVarStmt = this.postProcess(stmt, ts.createVariableStatement(/* modifiers */ [], varDeclList)); var exportStmt = this.postProcess(stmt, ts.createExportDeclaration( /*decorators*/ undefined, /*modifiers*/ undefined, ts.createNamedExports([ts.createExportSpecifier(stmt.name, stmt.name)]))); return [tsVarStmt, exportStmt]; } return this.postProcess(stmt, ts.createVariableStatement(this.getModifiers(stmt), varDeclList)); }; NodeEmitterVisitor.prototype.visitDeclareFunctionStmt = function (stmt) { return this.postProcess(stmt, ts.createFunctionDeclaration( /* decorators */ undefined, this.getModifiers(stmt), /* asteriskToken */ undefined, stmt.name, /* typeParameters */ undefined, stmt.params.map(function (p) { return ts.createParameter( /* decorators */ undefined, /* modifiers */ undefined, /* dotDotDotToken */ undefined, p.name); }), /* type */ undefined, this._visitStatements(stmt.statements))); }; NodeEmitterVisitor.prototype.visitExpressionStmt = function (stmt) { return this.postProcess(stmt, ts.createStatement(stmt.expr.visitExpression(this, null))); }; NodeEmitterVisitor.prototype.visitReturnStmt = function (stmt) { return this.postProcess(stmt, ts.createReturn(stmt.value ? stmt.value.visitExpression(this, null) : undefined)); }; NodeEmitterVisitor.prototype.visitDeclareClassStmt = function (stmt) { var _this = this; var modifiers = this.getModifiers(stmt); var fields = stmt.fields.map(function (field) { var property = ts.createProperty( /* decorators */ undefined, /* modifiers */ translateModifiers(field.modifiers), field.name, /* questionToken */ undefined, /* type */ undefined, field.initializer == null ? ts.createNull() : field.initializer.visitExpression(_this, null)); if (_this.annotateForClosureCompiler) { // Closure compiler transforms the form `Service.ɵprov = X` into `Service$ɵprov = X`. To // prevent this transformation, such assignments need to be annotated with @nocollapse. // Note that tsickle is typically responsible for adding such annotations, however it // doesn't yet handle synthetic fields added during other transformations. ts.addSyntheticLeadingComment(property, ts.SyntaxKind.MultiLineCommentTrivia, '* @nocollapse ', /* hasTrailingNewLine */ false); } return property; }); var getters = stmt.getters.map(function (getter) { return ts.createGetAccessor( /* decorators */ undefined, /* modifiers */ undefined, getter.name, /* parameters */ [], /* type */ undefined, _this._visitStatements(getter.body)); }); var constructor = (stmt.constructorMethod && [ts.createConstructor( /* decorators */ undefined, /* modifiers */ undefined, /* parameters */ stmt.constructorMethod.params.map(function (p) { return ts.createParameter( /* decorators */ undefined, /* modifiers */ undefined, /* dotDotDotToken */ undefined, p.name); }), this._visitStatements(stmt.constructorMethod.body))]) || []; // TODO {chuckj}: Determine what should be done for a method with a null name. var methods = stmt.methods.filter(function (method) { return method.name; }) .map(function (method) { return ts.createMethod( /* decorators */ undefined, /* modifiers */ translateModifiers(method.modifiers), /* astriskToken */ undefined, method.name /* guarded by filter */, /* questionToken */ undefined, /* typeParameters */ undefined, method.params.map(function (p) { return ts.createParameter( /* decorators */ undefined, /* modifiers */ undefined, /* dotDotDotToken */ undefined, p.name); }), /* type */ undefined, _this._visitStatements(method.body)); }); return this.postProcess(stmt, ts.createClassDeclaration( /* decorators */ undefined, modifiers, stmt.name, /* typeParameters*/ undefined, stmt.parent && [ts.createHeritageClause(ts.SyntaxKind.ExtendsKeyword, [stmt.parent.visitExpression(this, null)])] || [], tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(fields)), tslib_1.__read(getters)), tslib_1.__read(constructor)), tslib_1.__read(methods)))); }; NodeEmitterVisitor.prototype.visitIfStmt = function (stmt) { return this.postProcess(stmt, ts.createIf(stmt.condition.visitExpression(this, null), this._visitStatements(stmt.trueCase), stmt.falseCase && stmt.falseCase.length && this._visitStatements(stmt.falseCase) || undefined)); }; NodeEmitterVisitor.prototype.visitTryCatchStmt = function (stmt) { return this.postProcess(stmt, ts.createTry(this._visitStatements(stmt.bodyStmts), ts.createCatchClause(CATCH_ERROR_NAME, this._visitStatementsPrefix([ts.createVariableStatement( /* modifiers */ undefined, [ts.createVariableDeclaration(CATCH_STACK_NAME, /* type */ undefined, ts.createPropertyAccess(ts.createIdentifier(CATCH_ERROR_NAME), ts.createIdentifier(CATCH_STACK_NAME)))])], stmt.catchStmts)), /* finallyBlock */ undefined)); }; NodeEmitterVisitor.prototype.visitThrowStmt = function (stmt) { return this.postProcess(stmt, ts.createThrow(stmt.error.visitExpression(this, null))); }; // ExpressionVisitor NodeEmitterVisitor.prototype.visitWrappedNodeExpr = function (expr) { return this.postProcess(expr, expr.node); }; NodeEmitterVisitor.prototype.visitTypeofExpr = function (expr) { var typeOf = ts.createTypeOf(expr.expr.visitExpression(this, null)); return this.postProcess(expr, typeOf); }; // ExpressionVisitor NodeEmitterVisitor.prototype.visitReadVarExpr = function (expr) { switch (expr.builtin) { case compiler_1.BuiltinVar.This: return this.postProcess(expr, ts.createIdentifier(METHOD_THIS_NAME)); case compiler_1.BuiltinVar.CatchError: return this.postProcess(expr, ts.createIdentifier(CATCH_ERROR_NAME)); case compiler_1.BuiltinVar.CatchStack: return this.postProcess(expr, ts.createIdentifier(CATCH_STACK_NAME)); case compiler_1.BuiltinVar.Super: return this.postProcess(expr, ts.createSuper()); } if (expr.name) { return this.postProcess(expr, ts.createIdentifier(expr.name)); } throw Error("Unexpected ReadVarExpr form"); }; NodeEmitterVisitor.prototype.visitWriteVarExpr = function (expr) { return this.postProcess(expr, ts.createAssignment(ts.createIdentifier(expr.name), expr.value.visitExpression(this, null))); }; NodeEmitterVisitor.prototype.visitWriteKeyExpr = function (expr) { return this.postProcess(expr, ts.createAssignment(ts.createElementAccess(expr.receiver.visitExpression(this, null), expr.index.visitExpression(this, null)), expr.value.visitExpression(this, null))); }; NodeEmitterVisitor.prototype.visitWritePropExpr = function (expr) { return this.postProcess(expr, ts.createAssignment(ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name), expr.value.visitExpression(this, null))); }; NodeEmitterVisitor.prototype.visitInvokeMethodExpr = function (expr) { var _this = this; var methodName = getMethodName(expr); return this.postProcess(expr, ts.createCall(ts.createPropertyAccess(expr.receiver.visitExpression(this, null), methodName), /* typeArguments */ undefined, expr.args.map(function (arg) { return arg.visitExpression(_this, null); }))); }; NodeEmitterVisitor.prototype.visitInvokeFunctionExpr = function (expr) { var _this = this; return this.postProcess(expr, ts.createCall(expr.fn.visitExpression(this, null), /* typeArguments */ undefined, expr.args.map(function (arg) { return arg.visitExpression(_this, null); }))); }; NodeEmitterVisitor.prototype.visitTaggedTemplateExpr = function (expr) { throw new Error('tagged templates are not supported in pre-ivy mode.'); }; NodeEmitterVisitor.prototype.visitInstantiateExpr = function (expr) { var _this = this; return this.postProcess(expr, ts.createNew(expr.classExpr.visitExpression(this, null), /* typeArguments */ undefined, expr.args.map(function (arg) { return arg.visitExpression(_this, null); }))); }; NodeEmitterVisitor.prototype.visitLiteralExpr = function (expr) { return this.postProcess(expr, createLiteral(expr.value)); }; NodeEmitterVisitor.prototype.visitLocalizedString = function (expr, context) { throw new Error('localized strings are not supported in pre-ivy mode.'); }; NodeEmitterVisitor.prototype.visitExternalExpr = function (expr) { return this.postProcess(expr, this._visitIdentifier(expr.value)); }; NodeEmitterVisitor.prototype.visitConditionalExpr = function (expr) { // TODO {chuckj}: Review use of ! on falseCase. Should it be non-nullable? return this.postProcess(expr, ts.createParen(ts.createConditional(expr.condition.visitExpression(this, null), expr.trueCase.visitExpression(this, null), expr.falseCase.visitExpression(this, null)))); }; NodeEmitterVisitor.prototype.visitNotExpr = function (expr) { return this.postProcess(expr, ts.createPrefix(ts.SyntaxKind.ExclamationToken, expr.condition.visitExpression(this, null))); }; NodeEmitterVisitor.prototype.visitAssertNotNullExpr = function (expr) { return expr.condition.visitExpression(this, null); }; NodeEmitterVisitor.prototype.visitCastExpr = function (expr) { return expr.value.visitExpression(this, null); }; NodeEmitterVisitor.prototype.visitFunctionExpr = function (expr) { return this.postProcess(expr, ts.createFunctionExpression( /* modifiers */ undefined, /* astriskToken */ undefined, /* name */ expr.name || undefined, /* typeParameters */ undefined, expr.params.map(function (p) { return ts.createParameter( /* decorators */ undefined, /* modifiers */ undefined, /* dotDotDotToken */ undefined, p.name); }), /* type */ undefined, this._visitStatements(expr.statements))); }; NodeEmitterVisitor.prototype.visitUnaryOperatorExpr = function (expr) { var unaryOperator; switch (expr.operator) { case compiler_1.UnaryOperator.Minus: unaryOperator = ts.SyntaxKind.MinusToken; break; case compiler_1.UnaryOperator.Plus: unaryOperator = ts.SyntaxKind.PlusToken; break; default: throw new Error("Unknown operator: " + expr.operator); } var binary = ts.createPrefix(unaryOperator, expr.expr.visitExpression(this, null)); return this.postProcess(expr, expr.parens ? ts.createParen(binary) : binary); }; NodeEmitterVisitor.prototype.visitBinaryOperatorExpr = function (expr) { var binaryOperator; switch (expr.operator) { case compiler_1.BinaryOperator.And: binaryOperator = ts.SyntaxKind.AmpersandAmpersandToken; break; case compiler_1.BinaryOperator.BitwiseAnd: binaryOperator = ts.SyntaxKind.AmpersandToken; break; case compiler_1.BinaryOperator.Bigger: binaryOperator = ts.SyntaxKind.GreaterThanToken; break; case compiler_1.BinaryOperator.BiggerEquals: binaryOperator = ts.SyntaxKind.GreaterThanEqualsToken; break; case compiler_1.BinaryOperator.Divide: binaryOperator = ts.SyntaxKind.SlashToken; break; case compiler_1.BinaryOperator.Equals: binaryOperator = ts.SyntaxKind.EqualsEqualsToken; break; case compiler_1.BinaryOperator.Identical: binaryOperator = ts.SyntaxKind.EqualsEqualsEqualsToken; break; case compiler_1.BinaryOperator.Lower: binaryOperator = ts.SyntaxKind.LessThanToken; break; case compiler_1.BinaryOperator.LowerEquals: binaryOperator = ts.SyntaxKind.LessThanEqualsToken; break; case compiler_1.BinaryOperator.Minus: binaryOperator = ts.SyntaxKind.MinusToken; break; case compiler_1.BinaryOperator.Modulo: binaryOperator = ts.SyntaxKind.PercentToken; break; case compiler_1.BinaryOperator.Multiply: binaryOperator = ts.SyntaxKind.AsteriskToken; break; case compiler_1.BinaryOperator.NotEquals: binaryOperator = ts.SyntaxKind.ExclamationEqualsToken; break; case compiler_1.BinaryOperator.NotIdentical: binaryOperator = ts.SyntaxKind.ExclamationEqualsEqualsToken; break; case compiler_1.BinaryOperator.Or: binaryOperator = ts.SyntaxKind.BarBarToken; break; case compiler_1.BinaryOperator.NullishCoalesce: binaryOperator = ts.SyntaxKind.QuestionQuestionToken; break; case compiler_1.BinaryOperator.Plus: binaryOperator = ts.SyntaxKind.PlusToken; break; default: throw new Error("Unknown operator: " + expr.operator); } var binary = ts.createBinary(expr.lhs.visitExpression(this, null), binaryOperator, expr.rhs.visitExpression(this, null)); return this.postProcess(expr, expr.parens ? ts.createParen(binary) : binary); }; NodeEmitterVisitor.prototype.visitReadPropExpr = function (expr) { return this.postProcess(expr, ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name)); }; NodeEmitterVisitor.prototype.visitReadKeyExpr = function (expr) { return this.postProcess(expr, ts.createElementAccess(expr.receiver.visitExpression(this, null), expr.index.visitExpression(this, null))); }; NodeEmitterVisitor.prototype.visitLiteralArrayExpr = function (expr) { var _this = this; return this.postProcess(expr, ts.createArrayLiteral(expr.entries.map(function (entry) { return entry.visitExpression(_this, null); }))); }; NodeEmitterVisitor.prototype.visitLiteralMapExpr = function (expr) { var _this = this; return this.postProcess(expr, ts.createObjectLiteral(expr.entries.map(function (entry) { return ts.createPropertyAssignment(entry.quoted || !_VALID_IDENTIFIER_RE.test(entry.key) ? ts.createLiteral(entry.key) : entry.key, entry.value.visitExpression(_this, null)); }))); }; NodeEmitterVisitor.prototype.visitCommaExpr = function (expr) { var _this = this; return this.postProcess(expr, expr.parts.map(function (e) { return e.visitExpression(_this, null); }) .reduce(function (left, right) { return left ? ts.createBinary(left, ts.SyntaxKind.CommaToken, right) : right; }, null)); }; NodeEmitterVisitor.prototype._visitStatements = function (statements) { return this._visitStatementsPrefix([], statements); }; NodeEmitterVisitor.prototype._visitStatementsPrefix = function (prefix, statements) { var _this = this; return ts.createBlock(tslib_1.__spreadArray(tslib_1.__spreadArray([], tslib_1.__read(prefix)), tslib_1.__read(statements.map(function (stmt) { return stmt.visitStatement(_this, null); }).filter(function (f) { return f != null; })))); }; NodeEmitterVisitor.prototype._visitIdentifier = function (value) { // name can only be null during JIT which never executes this code. var moduleName = value.moduleName, name = value.name; var prefixIdent = null; if (moduleName) { var prefix = this._importsWithPrefixes.get(moduleName); if (prefix == null) { prefix = "i" + this._importsWithPrefixes.size; this._importsWithPrefixes.set(moduleName, prefix); } prefixIdent = ts.createIdentifier(prefix); } if (prefixIdent) { return ts.createPropertyAccess(prefixIdent, name); } else { var id = ts.createIdentifier(name); if (this._exportedVariableIdentifiers.has(name)) { // In order for this new identifier node to be properly rewritten in CommonJS output, // it must have its original node set to a parsed instance of the same identifier. ts.setOriginalNode(id, this._exportedVariableIdentifiers.get(name)); } return id; } }; return NodeEmitterVisitor; }()); exports.NodeEmitterVisitor = NodeEmitterVisitor; function getMethodName(methodRef) { if (methodRef.name) { return methodRef.name; } else { switch (methodRef.builtin) { case compiler_1.BuiltinMethod.Bind: return 'bind'; case compiler_1.BuiltinMethod.ConcatArray: return 'concat'; case compiler_1.BuiltinMethod.SubscribeObservable: return 'subscribe'; } } throw new Error('Unexpected method reference form'); } function modifierFromModifier(modifier) { switch (modifier) { case compiler_1.StmtModifier.Exported: return ts.createToken(ts.SyntaxKind.ExportKeyword); case compiler_1.StmtModifier.Final: return ts.createToken(ts.SyntaxKind.ConstKeyword); case compiler_1.StmtModifier.Private: return ts.createToken(ts.SyntaxKind.PrivateKeyword); case compiler_1.StmtModifier.Static: return ts.createToken(ts.SyntaxKind.StaticKeyword); } } function translateModifiers(modifiers) { return modifiers == null ? undefined : modifiers.map(modifierFromModifier); } }); //# 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 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 {AssertNotNull, BinaryOperator, BinaryOperatorExpr, BuiltinMethod, BuiltinVar, CastExpr, ClassStmt, CommaExpr, ConditionalExpr, DeclareFunctionStmt, DeclareVarStmt, ExpressionStatement, ExpressionVisitor, ExternalExpr, ExternalReference, FunctionExpr, IfStmt, InstantiateExpr, InvokeFunctionExpr, InvokeMethodExpr, LeadingComment, leadingComment, LiteralArrayExpr, LiteralExpr, LiteralMapExpr, LocalizedString, NotExpr, ParseSourceFile, ParseSourceSpan, PartialModule, ReadKeyExpr, ReadPropExpr, ReadVarExpr, ReturnStatement, Statement, StatementVisitor, StmtModifier, TaggedTemplateExpr, ThrowStmt, TryCatchStmt, TypeofExpr, UnaryOperator, UnaryOperatorExpr, WrappedNodeExpr, WriteKeyExpr, WritePropExpr, WriteVarExpr} from '@angular/compiler';\nimport * as ts from 'typescript';\n\nimport {attachComments} from '../ngtsc/translator';\nimport {error} from './util';\n\nexport interface Node {\n  sourceSpan: ParseSourceSpan|null;\n}\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  constructor(private annotateForClosureCompiler: boolean) {}\n\n  updateSourceFile(sourceFile: ts.SourceFile, stmts: Statement[], preamble?: string):\n      [ts.SourceFile, Map<ts.Node, Node>] {\n    const converter = new NodeEmitterVisitor(this.annotateForClosureCompiler);\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 sourceStatements =\n        [...converter.getReexports(), ...converter.getImports(), ...statements];\n    if (preamble) {\n      // We always attach the preamble comment to a `NotEmittedStatement` node, because tsickle uses\n      // this node type as a marker of the preamble to ensure that it adds its own new nodes after\n      // the preamble.\n      const preambleCommentHolder = ts.createNotEmittedStatement(sourceFile);\n      // Preamble comments are passed through as-is, which means that they must already contain a\n      // leading `*` if they should be a JSDOC comment.\n      ts.addSyntheticLeadingComment(\n          preambleCommentHolder, ts.SyntaxKind.MultiLineCommentTrivia, preamble,\n          /* hasTrailingNewline */ true);\n      sourceStatements.unshift(preambleCommentHolder);\n    }\n\n    converter.updateSourceMap(sourceStatements);\n    const newSourceFile = ts.updateSourceFileNode(sourceFile, sourceStatements);\n    return [newSourceFile, converter.getNodeMap()];\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    annotateForClosureCompiler: boolean): [ts.SourceFile, Map<ts.Node, Node>] {\n  const converter = new NodeEmitterVisitor(annotateForClosureCompiler);\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(`${classNames.size == 1 ? 'Class' : 'Classes'} \"${\n          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,\n        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&{\n  __recorded: any;\n})|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  constructor(private annotateForClosureCompiler: boolean) {}\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,\n                ts.createNamedExports(\n                    reexports.map(({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 */\n                ts.createImportClause(\n                    /* name */<ts.Identifier>(undefined as any),\n                    ts.createNamespaceImport(ts.createIdentifier(prefix))),\n                /* moduleSpecifier */ createLiteral(namespace)));\n  }\n\n  getNodeMap() {\n    return this._nodeMap;\n  }\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 postProcess<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    if (tsNode !== null && ngNode instanceof Statement && ngNode.leadingComments !== undefined) {\n      attachComments(tsNode as unknown as ts.Statement, ngNode.leadingComments);\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.postProcess(stmt, ts.createVariableStatement(/* modifiers */[], varDeclList));\n      const exportStmt = this.postProcess(\n          stmt,\n          ts.createExportDeclaration(\n              /*decorators*/ undefined, /*modifiers*/ undefined,\n              ts.createNamedExports([ts.createExportSpecifier(stmt.name, stmt.name)])));\n      return [tsVarStmt, exportStmt];\n    }\n    return this.postProcess(stmt, ts.createVariableStatement(this.getModifiers(stmt), varDeclList));\n  }\n\n  visitDeclareFunctionStmt(stmt: DeclareFunctionStmt) {\n    return this.postProcess(\n        stmt,\n        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.postProcess(stmt, ts.createStatement(stmt.expr.visitExpression(this, null)));\n  }\n\n  visitReturnStmt(stmt: ReturnStatement) {\n    return this.postProcess(\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(field => {\n      const property = 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\n      if (this.annotateForClosureCompiler) {\n        // Closure compiler transforms the form `Service.ɵprov = X` into `Service$ɵprov = X`. To\n        // prevent this transformation, such assignments need to be annotated with @nocollapse.\n        // Note that tsickle is typically responsible for adding such annotations, however it\n        // doesn't yet handle synthetic fields added during other transformations.\n        ts.addSyntheticLeadingComment(\n            property, ts.SyntaxKind.MultiLineCommentTrivia, '* @nocollapse ',\n            /* hasTrailingNewLine */ false);\n      }\n\n      return property;\n    });\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 */\n                                       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.postProcess(\n        stmt,\n        ts.createClassDeclaration(\n            /* decorators */ undefined, modifiers, stmt.name, /* typeParameters*/ undefined,\n            stmt.parent &&\n                    [ts.createHeritageClause(\n                        ts.SyntaxKind.ExtendsKeyword, [stmt.parent.visitExpression(this, null)])] ||\n                [],\n            [...fields, ...getters, ...constructor, ...methods]));\n  }\n\n  visitIfStmt(stmt: IfStmt) {\n    return this.postProcess(\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.postProcess(\n        stmt,\n        ts.createTry(\n            this._visitStatements(stmt.bodyStmts),\n            ts.createCatchClause(\n                CATCH_ERROR_NAME,\n                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.postProcess(stmt, ts.createThrow(stmt.error.visitExpression(this, null)));\n  }\n\n  // ExpressionVisitor\n  visitWrappedNodeExpr(expr: WrappedNodeExpr<any>) {\n    return this.postProcess(expr, expr.node);\n  }\n\n  visitTypeofExpr(expr: TypeofExpr) {\n    const typeOf = ts.createTypeOf(expr.expr.visitExpression(this, null));\n    return this.postProcess(expr, typeOf);\n  }\n\n  // ExpressionVisitor\n  visitReadVarExpr(expr: ReadVarExpr) {\n    switch (expr.builtin) {\n      case BuiltinVar.This:\n        return this.postProcess(expr, ts.createIdentifier(METHOD_THIS_NAME));\n      case BuiltinVar.CatchError:\n        return this.postProcess(expr, ts.createIdentifier(CATCH_ERROR_NAME));\n      case BuiltinVar.CatchStack:\n        return this.postProcess(expr, ts.createIdentifier(CATCH_STACK_NAME));\n      case BuiltinVar.Super:\n        return this.postProcess(expr, ts.createSuper());\n    }\n    if (expr.name) {\n      return this.postProcess(expr, ts.createIdentifier(expr.name));\n    }\n    throw Error(`Unexpected ReadVarExpr form`);\n  }\n\n  visitWriteVarExpr(expr: WriteVarExpr): RecordedNode<ts.BinaryExpression> {\n    return this.postProcess(\n        expr,\n        ts.createAssignment(\n            ts.createIdentifier(expr.name), expr.value.visitExpression(this, null)));\n  }\n\n  visitWriteKeyExpr(expr: WriteKeyExpr): RecordedNode<ts.BinaryExpression> {\n    return this.postProcess(\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.postProcess(\n        expr,\n        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.postProcess(\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.postProcess(\n        expr,\n        ts.createCall(\n            expr.fn.visitExpression(this, null), /* typeArguments */ undefined,\n            expr.args.map(arg => arg.visitExpression(this, null))));\n  }\n\n  visitTaggedTemplateExpr(expr: TaggedTemplateExpr): RecordedNode<ts.TaggedTemplateExpression> {\n    throw new Error('tagged templates are not supported in pre-ivy mode.');\n  }\n\n  visitInstantiateExpr(expr: InstantiateExpr): RecordedNode<ts.NewExpression> {\n    return this.postProcess(\n        expr,\n        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) {\n    return this.postProcess(expr, createLiteral(expr.value));\n  }\n\n  visitLocalizedString(expr: LocalizedString, context: any) {\n    throw new Error('localized strings are not supported in pre-ivy mode.');\n  }\n\n  visitExternalExpr(expr: ExternalExpr) {\n    return this.postProcess(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.postProcess(\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.postProcess(\n        expr,\n        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.postProcess(\n        expr,\n        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  visitUnaryOperatorExpr(expr: UnaryOperatorExpr):\n      RecordedNode<ts.UnaryExpression|ts.ParenthesizedExpression> {\n    let unaryOperator: ts.BinaryOperator;\n    switch (expr.operator) {\n      case UnaryOperator.Minus:\n        unaryOperator = ts.SyntaxKind.MinusToken;\n        break;\n      case UnaryOperator.Plus:\n        unaryOperator = ts.SyntaxKind.PlusToken;\n        break;\n      default:\n        throw new Error(`Unknown operator: ${expr.operator}`);\n    }\n    const binary = ts.createPrefix(unaryOperator, expr.expr.visitExpression(this, null));\n    return this.postProcess(expr, expr.parens ? ts.createParen(binary) : binary);\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.NullishCoalesce:\n        binaryOperator = ts.SyntaxKind.QuestionQuestionToken;\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.postProcess(expr, expr.parens ? ts.createParen(binary) : binary);\n  }\n\n  visitReadPropExpr(expr: ReadPropExpr): RecordedNode<ts.PropertyAccessExpression> {\n    return this.postProcess(\n        expr, ts.createPropertyAccess(expr.receiver.visitExpression(this, null), expr.name));\n  }\n\n  visitReadKeyExpr(expr: ReadKeyExpr): RecordedNode<ts.ElementAccessExpression> {\n    return this.postProcess(\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.postProcess(\n        expr, ts.createArrayLiteral(expr.entries.map(entry => entry.visitExpression(this, null))));\n  }\n\n  visitLiteralMapExpr(expr: LiteralMapExpr): RecordedNode<ts.ObjectLiteralExpression> {\n    return this.postProcess(\n        expr,\n        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.postProcess(\n        expr,\n        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\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}\n\nfunction translateModifiers(modifiers: StmtModifier[]|null): ts.Modifier[]|undefined {\n  return modifiers == null ? undefined : modifiers!.map(modifierFromModifier);\n}\n"]}