| "use strict"; |
| |
| Object.defineProperty(exports, "__esModule", { |
| value: true |
| }); |
| exports.default = void 0; |
| var _buffer = require("./buffer.js"); |
| var n = require("./node/index.js"); |
| var _t = require("@babel/types"); |
| var _tokenMap = require("./token-map.js"); |
| var generatorFunctions = require("./generators/index.js"); |
| var _deprecated = require("./generators/deprecated.js"); |
| const { |
| isExpression, |
| isFunction, |
| isStatement, |
| isClassBody, |
| isTSInterfaceBody, |
| isTSEnumMember |
| } = _t; |
| const SCIENTIFIC_NOTATION = /e/i; |
| const ZERO_DECIMAL_INTEGER = /\.0+$/; |
| const HAS_NEWLINE = /[\n\r\u2028\u2029]/; |
| const HAS_NEWLINE_OR_BlOCK_COMMENT_END = /[\n\r\u2028\u2029]|\*\//; |
| function commentIsNewline(c) { |
| return c.type === "CommentLine" || HAS_NEWLINE.test(c.value); |
| } |
| const { |
| needsParens |
| } = n; |
| class Printer { |
| constructor(format, map, tokens, originalCode) { |
| this.inForStatementInit = false; |
| this.tokenContext = 0; |
| this._tokens = null; |
| this._originalCode = null; |
| this._currentNode = null; |
| this._indent = 0; |
| this._indentRepeat = 0; |
| this._insideAux = false; |
| this._noLineTerminator = false; |
| this._noLineTerminatorAfterNode = null; |
| this._printAuxAfterOnNextUserNode = false; |
| this._printedComments = new Set(); |
| this._endsWithInteger = false; |
| this._endsWithWord = false; |
| this._endsWithDiv = false; |
| this._lastCommentLine = 0; |
| this._endsWithInnerRaw = false; |
| this._indentInnerComments = true; |
| this.tokenMap = null; |
| this._boundGetRawIdentifier = this._getRawIdentifier.bind(this); |
| this._printSemicolonBeforeNextNode = -1; |
| this._printSemicolonBeforeNextToken = -1; |
| this.format = format; |
| this._tokens = tokens; |
| this._originalCode = originalCode; |
| this._indentRepeat = format.indent.style.length; |
| this._inputMap = map == null ? void 0 : map._inputMap; |
| this._buf = new _buffer.default(map, format.indent.style[0]); |
| } |
| enterForStatementInit() { |
| if (this.inForStatementInit) return () => {}; |
| this.inForStatementInit = true; |
| return () => { |
| this.inForStatementInit = false; |
| }; |
| } |
| enterDelimited() { |
| const oldInForStatementInit = this.inForStatementInit; |
| const oldNoLineTerminatorAfterNode = this._noLineTerminatorAfterNode; |
| if (oldInForStatementInit === false && oldNoLineTerminatorAfterNode === null) { |
| return () => {}; |
| } |
| this.inForStatementInit = false; |
| this._noLineTerminatorAfterNode = null; |
| return () => { |
| this.inForStatementInit = oldInForStatementInit; |
| this._noLineTerminatorAfterNode = oldNoLineTerminatorAfterNode; |
| }; |
| } |
| generate(ast) { |
| if (this.format.preserveFormat) { |
| this.tokenMap = new _tokenMap.TokenMap(ast, this._tokens, this._originalCode); |
| } |
| this.print(ast); |
| this._maybeAddAuxComment(); |
| return this._buf.get(); |
| } |
| indent() { |
| const { |
| format |
| } = this; |
| if (format.preserveFormat || format.compact || format.concise) { |
| return; |
| } |
| this._indent++; |
| } |
| dedent() { |
| const { |
| format |
| } = this; |
| if (format.preserveFormat || format.compact || format.concise) { |
| return; |
| } |
| this._indent--; |
| } |
| semicolon(force = false) { |
| this._maybeAddAuxComment(); |
| if (force) { |
| this._appendChar(59); |
| this._noLineTerminator = false; |
| return; |
| } |
| if (this.tokenMap) { |
| const node = this._currentNode; |
| if (node.start != null && node.end != null) { |
| if (!this.tokenMap.endMatches(node, ";")) { |
| this._printSemicolonBeforeNextNode = this._buf.getCurrentLine(); |
| return; |
| } |
| const indexes = this.tokenMap.getIndexes(this._currentNode); |
| this._catchUpTo(this._tokens[indexes[indexes.length - 1]].loc.start); |
| } |
| } |
| this._queue(59); |
| this._noLineTerminator = false; |
| } |
| rightBrace(node) { |
| if (this.format.minified) { |
| this._buf.removeLastSemicolon(); |
| } |
| this.sourceWithOffset("end", node.loc, -1); |
| this.tokenChar(125); |
| } |
| rightParens(node) { |
| this.sourceWithOffset("end", node.loc, -1); |
| this.tokenChar(41); |
| } |
| space(force = false) { |
| const { |
| format |
| } = this; |
| if (format.compact || format.preserveFormat) return; |
| if (force) { |
| this._space(); |
| } else if (this._buf.hasContent()) { |
| const lastCp = this.getLastChar(); |
| if (lastCp !== 32 && lastCp !== 10) { |
| this._space(); |
| } |
| } |
| } |
| word(str, noLineTerminatorAfter = false) { |
| this.tokenContext = 0; |
| this._maybePrintInnerComments(str); |
| this._maybeAddAuxComment(); |
| if (this.tokenMap) this._catchUpToCurrentToken(str); |
| if (this._endsWithWord || this._endsWithDiv && str.charCodeAt(0) === 47) { |
| this._space(); |
| } |
| this._append(str, false); |
| this._endsWithWord = true; |
| this._noLineTerminator = noLineTerminatorAfter; |
| } |
| number(str, number) { |
| function isNonDecimalLiteral(str) { |
| if (str.length > 2 && str.charCodeAt(0) === 48) { |
| const secondChar = str.charCodeAt(1); |
| return secondChar === 98 || secondChar === 111 || secondChar === 120; |
| } |
| return false; |
| } |
| this.word(str); |
| this._endsWithInteger = Number.isInteger(number) && !isNonDecimalLiteral(str) && !SCIENTIFIC_NOTATION.test(str) && !ZERO_DECIMAL_INTEGER.test(str) && str.charCodeAt(str.length - 1) !== 46; |
| } |
| token(str, maybeNewline = false, occurrenceCount = 0) { |
| this.tokenContext = 0; |
| this._maybePrintInnerComments(str, occurrenceCount); |
| this._maybeAddAuxComment(); |
| if (this.tokenMap) this._catchUpToCurrentToken(str, occurrenceCount); |
| const lastChar = this.getLastChar(); |
| const strFirst = str.charCodeAt(0); |
| if (lastChar === 33 && (str === "--" || strFirst === 61) || strFirst === 43 && lastChar === 43 || strFirst === 45 && lastChar === 45 || strFirst === 46 && this._endsWithInteger) { |
| this._space(); |
| } |
| this._append(str, maybeNewline); |
| this._noLineTerminator = false; |
| } |
| tokenChar(char) { |
| this.tokenContext = 0; |
| const str = String.fromCharCode(char); |
| this._maybePrintInnerComments(str); |
| this._maybeAddAuxComment(); |
| if (this.tokenMap) this._catchUpToCurrentToken(str); |
| const lastChar = this.getLastChar(); |
| if (char === 43 && lastChar === 43 || char === 45 && lastChar === 45 || char === 46 && this._endsWithInteger) { |
| this._space(); |
| } |
| this._appendChar(char); |
| this._noLineTerminator = false; |
| } |
| newline(i = 1, force) { |
| if (i <= 0) return; |
| if (!force) { |
| if (this.format.retainLines || this.format.compact) return; |
| if (this.format.concise) { |
| this.space(); |
| return; |
| } |
| } |
| if (i > 2) i = 2; |
| i -= this._buf.getNewlineCount(); |
| for (let j = 0; j < i; j++) { |
| this._newline(); |
| } |
| return; |
| } |
| endsWith(char) { |
| return this.getLastChar() === char; |
| } |
| getLastChar() { |
| return this._buf.getLastChar(); |
| } |
| endsWithCharAndNewline() { |
| return this._buf.endsWithCharAndNewline(); |
| } |
| removeTrailingNewline() { |
| this._buf.removeTrailingNewline(); |
| } |
| exactSource(loc, cb) { |
| if (!loc) { |
| cb(); |
| return; |
| } |
| this._catchUp("start", loc); |
| this._buf.exactSource(loc, cb); |
| } |
| source(prop, loc) { |
| if (!loc) return; |
| this._catchUp(prop, loc); |
| this._buf.source(prop, loc); |
| } |
| sourceWithOffset(prop, loc, columnOffset) { |
| if (!loc || this.format.preserveFormat) return; |
| this._catchUp(prop, loc); |
| this._buf.sourceWithOffset(prop, loc, columnOffset); |
| } |
| sourceIdentifierName(identifierName, pos) { |
| if (!this._buf._canMarkIdName) return; |
| const sourcePosition = this._buf._sourcePosition; |
| sourcePosition.identifierNamePos = pos; |
| sourcePosition.identifierName = identifierName; |
| } |
| _space() { |
| this._queue(32); |
| } |
| _newline() { |
| this._queue(10); |
| } |
| _catchUpToCurrentToken(str, occurrenceCount = 0) { |
| const token = this.tokenMap.findMatching(this._currentNode, str, occurrenceCount); |
| if (token) this._catchUpTo(token.loc.start); |
| if (this._printSemicolonBeforeNextToken !== -1 && this._printSemicolonBeforeNextToken === this._buf.getCurrentLine()) { |
| this._buf.appendChar(59); |
| this._endsWithWord = false; |
| this._endsWithInteger = false; |
| this._endsWithDiv = false; |
| } |
| this._printSemicolonBeforeNextToken = -1; |
| this._printSemicolonBeforeNextNode = -1; |
| } |
| _append(str, maybeNewline) { |
| this._maybeIndent(str.charCodeAt(0)); |
| this._buf.append(str, maybeNewline); |
| this._endsWithWord = false; |
| this._endsWithInteger = false; |
| this._endsWithDiv = false; |
| } |
| _appendChar(char) { |
| this._maybeIndent(char); |
| this._buf.appendChar(char); |
| this._endsWithWord = false; |
| this._endsWithInteger = false; |
| this._endsWithDiv = false; |
| } |
| _queue(char) { |
| this._maybeIndent(char); |
| this._buf.queue(char); |
| this._endsWithWord = false; |
| this._endsWithInteger = false; |
| } |
| _maybeIndent(firstChar) { |
| if (this._indent && firstChar !== 10 && this.endsWith(10)) { |
| this._buf.queueIndentation(this._getIndent()); |
| } |
| } |
| _shouldIndent(firstChar) { |
| if (this._indent && firstChar !== 10 && this.endsWith(10)) { |
| return true; |
| } |
| } |
| catchUp(line) { |
| if (!this.format.retainLines) return; |
| const count = line - this._buf.getCurrentLine(); |
| for (let i = 0; i < count; i++) { |
| this._newline(); |
| } |
| } |
| _catchUp(prop, loc) { |
| const { |
| format |
| } = this; |
| if (!format.preserveFormat) { |
| if (format.retainLines && loc != null && loc[prop]) { |
| this.catchUp(loc[prop].line); |
| } |
| return; |
| } |
| const pos = loc == null ? void 0 : loc[prop]; |
| if (pos != null) this._catchUpTo(pos); |
| } |
| _catchUpTo({ |
| line, |
| column, |
| index |
| }) { |
| const count = line - this._buf.getCurrentLine(); |
| if (count > 0 && this._noLineTerminator) { |
| return; |
| } |
| for (let i = 0; i < count; i++) { |
| this._newline(); |
| } |
| const spacesCount = count > 0 ? column : column - this._buf.getCurrentColumn(); |
| if (spacesCount > 0) { |
| const spaces = this._originalCode ? this._originalCode.slice(index - spacesCount, index).replace(/[^\t\x0B\f \xA0\u1680\u2000-\u200A\u202F\u205F\u3000\uFEFF]/gu, " ") : " ".repeat(spacesCount); |
| this._append(spaces, false); |
| } |
| } |
| _getIndent() { |
| return this._indentRepeat * this._indent; |
| } |
| printTerminatorless(node) { |
| this._noLineTerminator = true; |
| this.print(node); |
| } |
| print(node, noLineTerminatorAfter, trailingCommentsLineOffset) { |
| var _node$extra, _node$leadingComments, _node$leadingComments2; |
| if (!node) return; |
| this._endsWithInnerRaw = false; |
| const nodeType = node.type; |
| const format = this.format; |
| const oldConcise = format.concise; |
| if (node._compact) { |
| format.concise = true; |
| } |
| const printMethod = this[nodeType]; |
| if (printMethod === undefined) { |
| throw new ReferenceError(`unknown node of type ${JSON.stringify(nodeType)} with constructor ${JSON.stringify(node.constructor.name)}`); |
| } |
| const parent = this._currentNode; |
| this._currentNode = node; |
| if (this.tokenMap) { |
| this._printSemicolonBeforeNextToken = this._printSemicolonBeforeNextNode; |
| } |
| const oldInAux = this._insideAux; |
| this._insideAux = node.loc == null; |
| this._maybeAddAuxComment(this._insideAux && !oldInAux); |
| const parenthesized = (_node$extra = node.extra) == null ? void 0 : _node$extra.parenthesized; |
| let shouldPrintParens = parenthesized && format.preserveFormat || parenthesized && format.retainFunctionParens && nodeType === "FunctionExpression" || needsParens(node, parent, this.tokenContext, this.inForStatementInit, format.preserveFormat ? this._boundGetRawIdentifier : undefined); |
| if (!shouldPrintParens && parenthesized && (_node$leadingComments = node.leadingComments) != null && _node$leadingComments.length && node.leadingComments[0].type === "CommentBlock") { |
| const parentType = parent == null ? void 0 : parent.type; |
| switch (parentType) { |
| case "ExpressionStatement": |
| case "VariableDeclarator": |
| case "AssignmentExpression": |
| case "ReturnStatement": |
| break; |
| case "CallExpression": |
| case "OptionalCallExpression": |
| case "NewExpression": |
| if (parent.callee !== node) break; |
| default: |
| shouldPrintParens = true; |
| } |
| } |
| let indentParenthesized = false; |
| if (!shouldPrintParens && this._noLineTerminator && ((_node$leadingComments2 = node.leadingComments) != null && _node$leadingComments2.some(commentIsNewline) || this.format.retainLines && node.loc && node.loc.start.line > this._buf.getCurrentLine())) { |
| shouldPrintParens = true; |
| indentParenthesized = true; |
| } |
| let oldNoLineTerminatorAfterNode; |
| let oldInForStatementInitWasTrue; |
| if (!shouldPrintParens) { |
| noLineTerminatorAfter || (noLineTerminatorAfter = parent && this._noLineTerminatorAfterNode === parent && n.isLastChild(parent, node)); |
| if (noLineTerminatorAfter) { |
| var _node$trailingComment; |
| if ((_node$trailingComment = node.trailingComments) != null && _node$trailingComment.some(commentIsNewline)) { |
| if (isExpression(node)) shouldPrintParens = true; |
| } else { |
| oldNoLineTerminatorAfterNode = this._noLineTerminatorAfterNode; |
| this._noLineTerminatorAfterNode = node; |
| } |
| } |
| } |
| if (shouldPrintParens) { |
| this.tokenChar(40); |
| if (indentParenthesized) this.indent(); |
| this._endsWithInnerRaw = false; |
| if (this.inForStatementInit) { |
| oldInForStatementInitWasTrue = true; |
| this.inForStatementInit = false; |
| } |
| oldNoLineTerminatorAfterNode = this._noLineTerminatorAfterNode; |
| this._noLineTerminatorAfterNode = null; |
| } |
| this._lastCommentLine = 0; |
| this._printLeadingComments(node, parent); |
| const loc = nodeType === "Program" || nodeType === "File" ? null : node.loc; |
| this.exactSource(loc, printMethod.bind(this, node, parent)); |
| if (shouldPrintParens) { |
| this._printTrailingComments(node, parent); |
| if (indentParenthesized) { |
| this.dedent(); |
| this.newline(); |
| } |
| this.tokenChar(41); |
| this._noLineTerminator = noLineTerminatorAfter; |
| if (oldInForStatementInitWasTrue) this.inForStatementInit = true; |
| } else if (noLineTerminatorAfter && !this._noLineTerminator) { |
| this._noLineTerminator = true; |
| this._printTrailingComments(node, parent); |
| } else { |
| this._printTrailingComments(node, parent, trailingCommentsLineOffset); |
| } |
| this._currentNode = parent; |
| format.concise = oldConcise; |
| this._insideAux = oldInAux; |
| if (oldNoLineTerminatorAfterNode !== undefined) { |
| this._noLineTerminatorAfterNode = oldNoLineTerminatorAfterNode; |
| } |
| this._endsWithInnerRaw = false; |
| } |
| _maybeAddAuxComment(enteredPositionlessNode) { |
| if (enteredPositionlessNode) this._printAuxBeforeComment(); |
| if (!this._insideAux) this._printAuxAfterComment(); |
| } |
| _printAuxBeforeComment() { |
| if (this._printAuxAfterOnNextUserNode) return; |
| this._printAuxAfterOnNextUserNode = true; |
| const comment = this.format.auxiliaryCommentBefore; |
| if (comment) { |
| this._printComment({ |
| type: "CommentBlock", |
| value: comment |
| }, 0); |
| } |
| } |
| _printAuxAfterComment() { |
| if (!this._printAuxAfterOnNextUserNode) return; |
| this._printAuxAfterOnNextUserNode = false; |
| const comment = this.format.auxiliaryCommentAfter; |
| if (comment) { |
| this._printComment({ |
| type: "CommentBlock", |
| value: comment |
| }, 0); |
| } |
| } |
| getPossibleRaw(node) { |
| const extra = node.extra; |
| if ((extra == null ? void 0 : extra.raw) != null && extra.rawValue != null && node.value === extra.rawValue) { |
| return extra.raw; |
| } |
| } |
| printJoin(nodes, statement, indent, separator, printTrailingSeparator, addNewlines, iterator, trailingCommentsLineOffset) { |
| if (!(nodes != null && nodes.length)) return; |
| if (indent == null && this.format.retainLines) { |
| var _nodes$0$loc; |
| const startLine = (_nodes$0$loc = nodes[0].loc) == null ? void 0 : _nodes$0$loc.start.line; |
| if (startLine != null && startLine !== this._buf.getCurrentLine()) { |
| indent = true; |
| } |
| } |
| if (indent) this.indent(); |
| const newlineOpts = { |
| addNewlines: addNewlines, |
| nextNodeStartLine: 0 |
| }; |
| const boundSeparator = separator == null ? void 0 : separator.bind(this); |
| const len = nodes.length; |
| for (let i = 0; i < len; i++) { |
| const node = nodes[i]; |
| if (!node) continue; |
| if (statement) this._printNewline(i === 0, newlineOpts); |
| this.print(node, undefined, trailingCommentsLineOffset || 0); |
| iterator == null || iterator(node, i); |
| if (boundSeparator != null) { |
| if (i < len - 1) boundSeparator(i, false);else if (printTrailingSeparator) boundSeparator(i, true); |
| } |
| if (statement) { |
| var _node$trailingComment2; |
| if (!((_node$trailingComment2 = node.trailingComments) != null && _node$trailingComment2.length)) { |
| this._lastCommentLine = 0; |
| } |
| if (i + 1 === len) { |
| this.newline(1); |
| } else { |
| var _nextNode$loc; |
| const nextNode = nodes[i + 1]; |
| newlineOpts.nextNodeStartLine = ((_nextNode$loc = nextNode.loc) == null ? void 0 : _nextNode$loc.start.line) || 0; |
| this._printNewline(true, newlineOpts); |
| } |
| } |
| } |
| if (indent) this.dedent(); |
| } |
| printAndIndentOnComments(node) { |
| const indent = node.leadingComments && node.leadingComments.length > 0; |
| if (indent) this.indent(); |
| this.print(node); |
| if (indent) this.dedent(); |
| } |
| printBlock(parent) { |
| const node = parent.body; |
| if (node.type !== "EmptyStatement") { |
| this.space(); |
| } |
| this.print(node); |
| } |
| _printTrailingComments(node, parent, lineOffset) { |
| const { |
| innerComments, |
| trailingComments |
| } = node; |
| if (innerComments != null && innerComments.length) { |
| this._printComments(2, innerComments, node, parent, lineOffset); |
| } |
| if (trailingComments != null && trailingComments.length) { |
| this._printComments(2, trailingComments, node, parent, lineOffset); |
| } |
| } |
| _printLeadingComments(node, parent) { |
| const comments = node.leadingComments; |
| if (!(comments != null && comments.length)) return; |
| this._printComments(0, comments, node, parent); |
| } |
| _maybePrintInnerComments(nextTokenStr, nextTokenOccurrenceCount) { |
| if (this._endsWithInnerRaw) { |
| var _this$tokenMap; |
| this.printInnerComments((_this$tokenMap = this.tokenMap) == null ? void 0 : _this$tokenMap.findMatching(this._currentNode, nextTokenStr, nextTokenOccurrenceCount)); |
| } |
| this._endsWithInnerRaw = true; |
| this._indentInnerComments = true; |
| } |
| printInnerComments(nextToken) { |
| const node = this._currentNode; |
| const comments = node.innerComments; |
| if (!(comments != null && comments.length)) return; |
| const hasSpace = this.endsWith(32); |
| const indent = this._indentInnerComments; |
| const printedCommentsCount = this._printedComments.size; |
| if (indent) this.indent(); |
| this._printComments(1, comments, node, undefined, undefined, nextToken); |
| if (hasSpace && printedCommentsCount !== this._printedComments.size) { |
| this.space(); |
| } |
| if (indent) this.dedent(); |
| } |
| noIndentInnerCommentsHere() { |
| this._indentInnerComments = false; |
| } |
| printSequence(nodes, indent, trailingCommentsLineOffset, addNewlines) { |
| this.printJoin(nodes, true, indent != null ? indent : false, undefined, undefined, addNewlines, undefined, trailingCommentsLineOffset); |
| } |
| printList(items, printTrailingSeparator, statement, indent, separator, iterator) { |
| this.printJoin(items, statement, indent, separator != null ? separator : commaSeparator, printTrailingSeparator, undefined, iterator); |
| } |
| shouldPrintTrailingComma(listEnd) { |
| if (!this.tokenMap) return null; |
| const listEndIndex = this.tokenMap.findLastIndex(this._currentNode, token => this.tokenMap.matchesOriginal(token, listEnd)); |
| if (listEndIndex <= 0) return null; |
| return this.tokenMap.matchesOriginal(this._tokens[listEndIndex - 1], ","); |
| } |
| _printNewline(newLine, opts) { |
| const format = this.format; |
| if (format.retainLines || format.compact) return; |
| if (format.concise) { |
| this.space(); |
| return; |
| } |
| if (!newLine) { |
| return; |
| } |
| const startLine = opts.nextNodeStartLine; |
| const lastCommentLine = this._lastCommentLine; |
| if (startLine > 0 && lastCommentLine > 0) { |
| const offset = startLine - lastCommentLine; |
| if (offset >= 0) { |
| this.newline(offset || 1); |
| return; |
| } |
| } |
| if (this._buf.hasContent()) { |
| this.newline(1); |
| } |
| } |
| _shouldPrintComment(comment, nextToken) { |
| if (comment.ignore) return 0; |
| if (this._printedComments.has(comment)) return 0; |
| if (this._noLineTerminator && HAS_NEWLINE_OR_BlOCK_COMMENT_END.test(comment.value)) { |
| return 2; |
| } |
| if (nextToken && this.tokenMap) { |
| const commentTok = this.tokenMap.find(this._currentNode, token => token.value === comment.value); |
| if (commentTok && commentTok.start > nextToken.start) { |
| return 2; |
| } |
| } |
| this._printedComments.add(comment); |
| if (!this.format.shouldPrintComment(comment.value)) { |
| return 0; |
| } |
| return 1; |
| } |
| _printComment(comment, skipNewLines) { |
| const noLineTerminator = this._noLineTerminator; |
| const isBlockComment = comment.type === "CommentBlock"; |
| const printNewLines = isBlockComment && skipNewLines !== 1 && !this._noLineTerminator; |
| if (printNewLines && this._buf.hasContent() && skipNewLines !== 2) { |
| this.newline(1); |
| } |
| const lastCharCode = this.getLastChar(); |
| if (lastCharCode !== 91 && lastCharCode !== 123 && lastCharCode !== 40) { |
| this.space(); |
| } |
| let val; |
| if (isBlockComment) { |
| val = `/*${comment.value}*/`; |
| if (this.format.indent.adjustMultilineComment) { |
| var _comment$loc; |
| const offset = (_comment$loc = comment.loc) == null ? void 0 : _comment$loc.start.column; |
| if (offset) { |
| const newlineRegex = new RegExp("\\n\\s{1," + offset + "}", "g"); |
| val = val.replace(newlineRegex, "\n"); |
| } |
| if (this.format.concise) { |
| val = val.replace(/\n(?!$)/g, `\n`); |
| } else { |
| let indentSize = this.format.retainLines ? 0 : this._buf.getCurrentColumn(); |
| if (this._shouldIndent(47) || this.format.retainLines) { |
| indentSize += this._getIndent(); |
| } |
| val = val.replace(/\n(?!$)/g, `\n${" ".repeat(indentSize)}`); |
| } |
| } |
| } else if (!noLineTerminator) { |
| val = `//${comment.value}`; |
| } else { |
| val = `/*${comment.value}*/`; |
| } |
| if (this._endsWithDiv) this._space(); |
| if (this.tokenMap) { |
| const { |
| _printSemicolonBeforeNextToken, |
| _printSemicolonBeforeNextNode |
| } = this; |
| this._printSemicolonBeforeNextToken = -1; |
| this._printSemicolonBeforeNextNode = -1; |
| this.source("start", comment.loc); |
| this._append(val, isBlockComment); |
| this._printSemicolonBeforeNextNode = _printSemicolonBeforeNextNode; |
| this._printSemicolonBeforeNextToken = _printSemicolonBeforeNextToken; |
| } else { |
| this.source("start", comment.loc); |
| this._append(val, isBlockComment); |
| } |
| if (!isBlockComment && !noLineTerminator) { |
| this.newline(1, true); |
| } |
| if (printNewLines && skipNewLines !== 3) { |
| this.newline(1); |
| } |
| } |
| _printComments(type, comments, node, parent, lineOffset = 0, nextToken) { |
| const nodeLoc = node.loc; |
| const len = comments.length; |
| let hasLoc = !!nodeLoc; |
| const nodeStartLine = hasLoc ? nodeLoc.start.line : 0; |
| const nodeEndLine = hasLoc ? nodeLoc.end.line : 0; |
| let lastLine = 0; |
| let leadingCommentNewline = 0; |
| const maybeNewline = this._noLineTerminator ? function () {} : this.newline.bind(this); |
| for (let i = 0; i < len; i++) { |
| const comment = comments[i]; |
| const shouldPrint = this._shouldPrintComment(comment, nextToken); |
| if (shouldPrint === 2) { |
| hasLoc = false; |
| break; |
| } |
| if (hasLoc && comment.loc && shouldPrint === 1) { |
| const commentStartLine = comment.loc.start.line; |
| const commentEndLine = comment.loc.end.line; |
| if (type === 0) { |
| let offset = 0; |
| if (i === 0) { |
| if (this._buf.hasContent() && (comment.type === "CommentLine" || commentStartLine !== commentEndLine)) { |
| offset = leadingCommentNewline = 1; |
| } |
| } else { |
| offset = commentStartLine - lastLine; |
| } |
| lastLine = commentEndLine; |
| maybeNewline(offset); |
| this._printComment(comment, 1); |
| if (i + 1 === len) { |
| maybeNewline(Math.max(nodeStartLine - lastLine, leadingCommentNewline)); |
| lastLine = nodeStartLine; |
| } |
| } else if (type === 1) { |
| const offset = commentStartLine - (i === 0 ? nodeStartLine : lastLine); |
| lastLine = commentEndLine; |
| maybeNewline(offset); |
| this._printComment(comment, 1); |
| if (i + 1 === len) { |
| maybeNewline(Math.min(1, nodeEndLine - lastLine)); |
| lastLine = nodeEndLine; |
| } |
| } else { |
| const offset = commentStartLine - (i === 0 ? nodeEndLine - lineOffset : lastLine); |
| lastLine = commentEndLine; |
| maybeNewline(offset); |
| this._printComment(comment, 1); |
| } |
| } else { |
| hasLoc = false; |
| if (shouldPrint !== 1) { |
| continue; |
| } |
| if (len === 1) { |
| const singleLine = comment.loc ? comment.loc.start.line === comment.loc.end.line : !HAS_NEWLINE.test(comment.value); |
| const shouldSkipNewline = singleLine && !isStatement(node) && !isClassBody(parent) && !isTSInterfaceBody(parent) && !isTSEnumMember(node); |
| if (type === 0) { |
| this._printComment(comment, shouldSkipNewline && node.type !== "ObjectExpression" || singleLine && isFunction(parent, { |
| body: node |
| }) ? 1 : 0); |
| } else if (shouldSkipNewline && type === 2) { |
| this._printComment(comment, 1); |
| } else { |
| this._printComment(comment, 0); |
| } |
| } else if (type === 1 && !(node.type === "ObjectExpression" && node.properties.length > 1) && node.type !== "ClassBody" && node.type !== "TSInterfaceBody") { |
| this._printComment(comment, i === 0 ? 2 : i === len - 1 ? 3 : 0); |
| } else { |
| this._printComment(comment, 0); |
| } |
| } |
| } |
| if (type === 2 && hasLoc && lastLine) { |
| this._lastCommentLine = lastLine; |
| } |
| } |
| } |
| Object.assign(Printer.prototype, generatorFunctions); |
| { |
| (0, _deprecated.addDeprecatedGenerators)(Printer); |
| } |
| var _default = exports.default = Printer; |
| function commaSeparator(occurrenceCount, last) { |
| this.token(",", false, occurrenceCount); |
| if (!last) this.space(); |
| } |
| |
| //# sourceMappingURL=printer.js.map |