|
|
"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"); |
|
|
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.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 = this.enterForXStatementInit(isForOf); |
|
|
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); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|