| "use strict"; |
| |
| Object.defineProperty(exports, "__esModule", { |
| value: true |
| }); |
| exports.BreakStatement = BreakStatement; |
| exports.CatchClause = CatchClause; |
| exports.ContinueStatement = ContinueStatement; |
| exports.DebuggerStatement = DebuggerStatement; |
| exports.DoWhileStatement = DoWhileStatement; |
| exports.ForOfStatement = exports.ForInStatement = void 0; |
| exports.ForStatement = ForStatement; |
| exports.IfStatement = IfStatement; |
| exports.LabeledStatement = LabeledStatement; |
| exports.ReturnStatement = ReturnStatement; |
| exports.SwitchCase = SwitchCase; |
| exports.SwitchStatement = SwitchStatement; |
| exports.ThrowStatement = ThrowStatement; |
| exports.TryStatement = TryStatement; |
| exports.VariableDeclaration = VariableDeclaration; |
| exports.VariableDeclarator = VariableDeclarator; |
| exports.WhileStatement = WhileStatement; |
| exports.WithStatement = WithStatement; |
| var _t = require("@babel/types"); |
| var _index = require("../node/index.js"); |
| const { |
| isFor, |
| isForStatement, |
| isIfStatement, |
| isStatement |
| } = _t; |
| function WithStatement(node) { |
| this.word("with"); |
| this.space(); |
| this.tokenChar(40); |
| this.print(node.object); |
| this.tokenChar(41); |
| this.printBlock(node); |
| } |
| function IfStatement(node) { |
| this.word("if"); |
| this.space(); |
| this.tokenChar(40); |
| this.print(node.test); |
| this.tokenChar(41); |
| this.space(); |
| const needsBlock = node.alternate && isIfStatement(getLastStatement(node.consequent)); |
| if (needsBlock) { |
| this.tokenChar(123); |
| this.newline(); |
| this.indent(); |
| } |
| this.printAndIndentOnComments(node.consequent); |
| if (needsBlock) { |
| this.dedent(); |
| this.newline(); |
| this.tokenChar(125); |
| } |
| if (node.alternate) { |
| if (this.endsWith(125)) this.space(); |
| this.word("else"); |
| this.space(); |
| this.printAndIndentOnComments(node.alternate); |
| } |
| } |
| function getLastStatement(statement) { |
| const { |
| body |
| } = statement; |
| if (isStatement(body) === false) { |
| return statement; |
| } |
| return getLastStatement(body); |
| } |
| function ForStatement(node) { |
| this.word("for"); |
| this.space(); |
| this.tokenChar(40); |
| { |
| const exit = this.enterForStatementInit(); |
| this.tokenContext |= _index.TokenContext.forHead; |
| this.print(node.init); |
| exit(); |
| } |
| this.tokenChar(59); |
| if (node.test) { |
| this.space(); |
| this.print(node.test); |
| } |
| this.token(";", false, 1); |
| if (node.update) { |
| this.space(); |
| this.print(node.update); |
| } |
| this.tokenChar(41); |
| this.printBlock(node); |
| } |
| function WhileStatement(node) { |
| this.word("while"); |
| this.space(); |
| this.tokenChar(40); |
| this.print(node.test); |
| this.tokenChar(41); |
| this.printBlock(node); |
| } |
| function ForXStatement(node) { |
| this.word("for"); |
| this.space(); |
| const isForOf = node.type === "ForOfStatement"; |
| if (isForOf && node.await) { |
| this.word("await"); |
| this.space(); |
| } |
| this.noIndentInnerCommentsHere(); |
| this.tokenChar(40); |
| { |
| const exit = isForOf ? null : this.enterForStatementInit(); |
| this.tokenContext |= isForOf ? _index.TokenContext.forOfHead : _index.TokenContext.forInHead; |
| this.print(node.left); |
| exit == null || exit(); |
| } |
| this.space(); |
| this.word(isForOf ? "of" : "in"); |
| this.space(); |
| this.print(node.right); |
| this.tokenChar(41); |
| this.printBlock(node); |
| } |
| const ForInStatement = exports.ForInStatement = ForXStatement; |
| const ForOfStatement = exports.ForOfStatement = ForXStatement; |
| function DoWhileStatement(node) { |
| this.word("do"); |
| this.space(); |
| this.print(node.body); |
| this.space(); |
| this.word("while"); |
| this.space(); |
| this.tokenChar(40); |
| this.print(node.test); |
| this.tokenChar(41); |
| this.semicolon(); |
| } |
| function printStatementAfterKeyword(printer, node) { |
| if (node) { |
| printer.space(); |
| printer.printTerminatorless(node); |
| } |
| printer.semicolon(); |
| } |
| function BreakStatement(node) { |
| this.word("break"); |
| printStatementAfterKeyword(this, node.label); |
| } |
| function ContinueStatement(node) { |
| this.word("continue"); |
| printStatementAfterKeyword(this, node.label); |
| } |
| function ReturnStatement(node) { |
| this.word("return"); |
| printStatementAfterKeyword(this, node.argument); |
| } |
| function ThrowStatement(node) { |
| this.word("throw"); |
| printStatementAfterKeyword(this, node.argument); |
| } |
| function LabeledStatement(node) { |
| this.print(node.label); |
| this.tokenChar(58); |
| this.space(); |
| this.print(node.body); |
| } |
| function TryStatement(node) { |
| this.word("try"); |
| this.space(); |
| this.print(node.block); |
| this.space(); |
| if (node.handlers) { |
| this.print(node.handlers[0]); |
| } else { |
| this.print(node.handler); |
| } |
| if (node.finalizer) { |
| this.space(); |
| this.word("finally"); |
| this.space(); |
| this.print(node.finalizer); |
| } |
| } |
| function CatchClause(node) { |
| this.word("catch"); |
| this.space(); |
| if (node.param) { |
| this.tokenChar(40); |
| this.print(node.param); |
| this.print(node.param.typeAnnotation); |
| this.tokenChar(41); |
| this.space(); |
| } |
| this.print(node.body); |
| } |
| function SwitchStatement(node) { |
| this.word("switch"); |
| this.space(); |
| this.tokenChar(40); |
| this.print(node.discriminant); |
| this.tokenChar(41); |
| this.space(); |
| this.tokenChar(123); |
| this.printSequence(node.cases, true, undefined, function addNewlines(leading, cas) { |
| if (!leading && node.cases[node.cases.length - 1] === cas) return -1; |
| }); |
| this.rightBrace(node); |
| } |
| function SwitchCase(node) { |
| if (node.test) { |
| this.word("case"); |
| this.space(); |
| this.print(node.test); |
| this.tokenChar(58); |
| } else { |
| this.word("default"); |
| this.tokenChar(58); |
| } |
| if (node.consequent.length) { |
| this.newline(); |
| this.printSequence(node.consequent, true); |
| } |
| } |
| function DebuggerStatement() { |
| this.word("debugger"); |
| this.semicolon(); |
| } |
| function VariableDeclaration(node, parent) { |
| if (node.declare) { |
| this.word("declare"); |
| this.space(); |
| } |
| const { |
| kind |
| } = node; |
| if (kind === "await using") { |
| this.word("await"); |
| this.space(); |
| this.word("using", true); |
| } else { |
| this.word(kind, kind === "using"); |
| } |
| this.space(); |
| let hasInits = false; |
| if (!isFor(parent)) { |
| for (const declar of node.declarations) { |
| if (declar.init) { |
| hasInits = true; |
| } |
| } |
| } |
| this.printList(node.declarations, undefined, undefined, node.declarations.length > 1, hasInits ? function (occurrenceCount) { |
| this.token(",", false, occurrenceCount); |
| this.newline(); |
| } : undefined); |
| if (isFor(parent)) { |
| if (isForStatement(parent)) { |
| if (parent.init === node) return; |
| } else { |
| if (parent.left === node) return; |
| } |
| } |
| this.semicolon(); |
| } |
| function VariableDeclarator(node) { |
| this.print(node.id); |
| if (node.definite) this.tokenChar(33); |
| this.print(node.id.typeAnnotation); |
| if (node.init) { |
| this.space(); |
| this.tokenChar(61); |
| this.space(); |
| this.print(node.init); |
| } |
| } |
| |
| //# sourceMappingURL=statements.js.map |