You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
331 lines
6.8 KiB
331 lines
6.8 KiB
"use strict"; |
|
|
|
Object.defineProperty(exports, "__esModule", { |
|
value: true |
|
}); |
|
exports.BreakStatement = void 0; |
|
exports.CatchClause = CatchClause; |
|
exports.ContinueStatement = void 0; |
|
exports.DebuggerStatement = DebuggerStatement; |
|
exports.DoWhileStatement = DoWhileStatement; |
|
exports.ForOfStatement = exports.ForInStatement = void 0; |
|
exports.ForStatement = ForStatement; |
|
exports.IfStatement = IfStatement; |
|
exports.LabeledStatement = LabeledStatement; |
|
exports.ReturnStatement = void 0; |
|
exports.SwitchCase = SwitchCase; |
|
exports.SwitchStatement = SwitchStatement; |
|
exports.ThrowStatement = void 0; |
|
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.token("("); |
|
this.print(node.object, node); |
|
this.token(")"); |
|
this.printBlock(node); |
|
} |
|
|
|
function IfStatement(node) { |
|
this.word("if"); |
|
this.space(); |
|
this.token("("); |
|
this.print(node.test, node); |
|
this.token(")"); |
|
this.space(); |
|
const needsBlock = node.alternate && isIfStatement(getLastStatement(node.consequent)); |
|
|
|
if (needsBlock) { |
|
this.token("{"); |
|
this.newline(); |
|
this.indent(); |
|
} |
|
|
|
this.printAndIndentOnComments(node.consequent, node); |
|
|
|
if (needsBlock) { |
|
this.dedent(); |
|
this.newline(); |
|
this.token("}"); |
|
} |
|
|
|
if (node.alternate) { |
|
if (this.endsWith(125)) this.space(); |
|
this.word("else"); |
|
this.space(); |
|
this.printAndIndentOnComments(node.alternate, node); |
|
} |
|
} |
|
|
|
function getLastStatement(statement) { |
|
if (!isStatement(statement.body)) return statement; |
|
return getLastStatement(statement.body); |
|
} |
|
|
|
function ForStatement(node) { |
|
this.word("for"); |
|
this.space(); |
|
this.token("("); |
|
this.inForStatementInitCounter++; |
|
this.print(node.init, node); |
|
this.inForStatementInitCounter--; |
|
this.token(";"); |
|
|
|
if (node.test) { |
|
this.space(); |
|
this.print(node.test, node); |
|
} |
|
|
|
this.token(";"); |
|
|
|
if (node.update) { |
|
this.space(); |
|
this.print(node.update, node); |
|
} |
|
|
|
this.token(")"); |
|
this.printBlock(node); |
|
} |
|
|
|
function WhileStatement(node) { |
|
this.word("while"); |
|
this.space(); |
|
this.token("("); |
|
this.print(node.test, node); |
|
this.token(")"); |
|
this.printBlock(node); |
|
} |
|
|
|
const buildForXStatement = function (op) { |
|
return function (node) { |
|
this.word("for"); |
|
this.space(); |
|
|
|
if (op === "of" && node.await) { |
|
this.word("await"); |
|
this.space(); |
|
} |
|
|
|
this.token("("); |
|
this.print(node.left, node); |
|
this.space(); |
|
this.word(op); |
|
this.space(); |
|
this.print(node.right, node); |
|
this.token(")"); |
|
this.printBlock(node); |
|
}; |
|
}; |
|
|
|
const ForInStatement = buildForXStatement("in"); |
|
exports.ForInStatement = ForInStatement; |
|
const ForOfStatement = buildForXStatement("of"); |
|
exports.ForOfStatement = ForOfStatement; |
|
|
|
function DoWhileStatement(node) { |
|
this.word("do"); |
|
this.space(); |
|
this.print(node.body, node); |
|
this.space(); |
|
this.word("while"); |
|
this.space(); |
|
this.token("("); |
|
this.print(node.test, node); |
|
this.token(")"); |
|
this.semicolon(); |
|
} |
|
|
|
function buildLabelStatement(prefix, key = "label") { |
|
return function (node) { |
|
this.word(prefix); |
|
const label = node[key]; |
|
|
|
if (label) { |
|
this.space(); |
|
const isLabel = key == "label"; |
|
const terminatorState = this.startTerminatorless(isLabel); |
|
this.print(label, node); |
|
this.endTerminatorless(terminatorState); |
|
} |
|
|
|
this.semicolon(); |
|
}; |
|
} |
|
|
|
const ContinueStatement = buildLabelStatement("continue"); |
|
exports.ContinueStatement = ContinueStatement; |
|
const ReturnStatement = buildLabelStatement("return", "argument"); |
|
exports.ReturnStatement = ReturnStatement; |
|
const BreakStatement = buildLabelStatement("break"); |
|
exports.BreakStatement = BreakStatement; |
|
const ThrowStatement = buildLabelStatement("throw", "argument"); |
|
exports.ThrowStatement = ThrowStatement; |
|
|
|
function LabeledStatement(node) { |
|
this.print(node.label, node); |
|
this.token(":"); |
|
this.space(); |
|
this.print(node.body, node); |
|
} |
|
|
|
function TryStatement(node) { |
|
this.word("try"); |
|
this.space(); |
|
this.print(node.block, node); |
|
this.space(); |
|
|
|
if (node.handlers) { |
|
this.print(node.handlers[0], node); |
|
} else { |
|
this.print(node.handler, node); |
|
} |
|
|
|
if (node.finalizer) { |
|
this.space(); |
|
this.word("finally"); |
|
this.space(); |
|
this.print(node.finalizer, node); |
|
} |
|
} |
|
|
|
function CatchClause(node) { |
|
this.word("catch"); |
|
this.space(); |
|
|
|
if (node.param) { |
|
this.token("("); |
|
this.print(node.param, node); |
|
this.print(node.param.typeAnnotation, node); |
|
this.token(")"); |
|
this.space(); |
|
} |
|
|
|
this.print(node.body, node); |
|
} |
|
|
|
function SwitchStatement(node) { |
|
this.word("switch"); |
|
this.space(); |
|
this.token("("); |
|
this.print(node.discriminant, node); |
|
this.token(")"); |
|
this.space(); |
|
this.token("{"); |
|
this.printSequence(node.cases, node, { |
|
indent: true, |
|
|
|
addNewlines(leading, cas) { |
|
if (!leading && node.cases[node.cases.length - 1] === cas) return -1; |
|
} |
|
|
|
}); |
|
this.token("}"); |
|
} |
|
|
|
function SwitchCase(node) { |
|
if (node.test) { |
|
this.word("case"); |
|
this.space(); |
|
this.print(node.test, node); |
|
this.token(":"); |
|
} else { |
|
this.word("default"); |
|
this.token(":"); |
|
} |
|
|
|
if (node.consequent.length) { |
|
this.newline(); |
|
this.printSequence(node.consequent, node, { |
|
indent: true |
|
}); |
|
} |
|
} |
|
|
|
function DebuggerStatement() { |
|
this.word("debugger"); |
|
this.semicolon(); |
|
} |
|
|
|
function variableDeclarationIndent() { |
|
this.token(","); |
|
this.newline(); |
|
|
|
if (this.endsWith(10)) { |
|
for (let i = 0; i < 4; i++) this.space(true); |
|
} |
|
} |
|
|
|
function constDeclarationIndent() { |
|
this.token(","); |
|
this.newline(); |
|
|
|
if (this.endsWith(10)) { |
|
for (let i = 0; i < 6; i++) this.space(true); |
|
} |
|
} |
|
|
|
function VariableDeclaration(node, parent) { |
|
if (node.declare) { |
|
this.word("declare"); |
|
this.space(); |
|
} |
|
|
|
this.word(node.kind); |
|
this.space(); |
|
let hasInits = false; |
|
|
|
if (!isFor(parent)) { |
|
for (const declar of node.declarations) { |
|
if (declar.init) { |
|
hasInits = true; |
|
} |
|
} |
|
} |
|
|
|
let separator; |
|
|
|
if (hasInits) { |
|
separator = node.kind === "const" ? constDeclarationIndent : variableDeclarationIndent; |
|
} |
|
|
|
this.printList(node.declarations, node, { |
|
separator |
|
}); |
|
|
|
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, node); |
|
if (node.definite) this.token("!"); |
|
this.print(node.id.typeAnnotation, node); |
|
|
|
if (node.init) { |
|
this.space(); |
|
this.token("="); |
|
this.space(); |
|
this.print(node.init, node); |
|
} |
|
} |