782 lines
		
	
	
		
			27 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			782 lines
		
	
	
		
			27 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
"use strict";
 | 
						|
 | 
						|
Object.defineProperty(exports, "__esModule", {
 | 
						|
  value: true
 | 
						|
});
 | 
						|
exports.default = void 0;
 | 
						|
var _buffer = require("./buffer.js");
 | 
						|
var _index = require("./node/index.js");
 | 
						|
var n = _index;
 | 
						|
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.tokenContext = _index.TokenContext.normal;
 | 
						|
    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() {
 | 
						|
    this.tokenContext |= _index.TokenContext.forInitHead | _index.TokenContext.forInOrInitHeadAccumulate;
 | 
						|
    return () => this.tokenContext = _index.TokenContext.normal;
 | 
						|
  }
 | 
						|
  enterForXStatementInit(isForOf) {
 | 
						|
    if (isForOf) {
 | 
						|
      this.tokenContext |= _index.TokenContext.forOfHead;
 | 
						|
      return null;
 | 
						|
    } else {
 | 
						|
      this.tokenContext |= _index.TokenContext.forInHead | _index.TokenContext.forInOrInitHeadAccumulate;
 | 
						|
      return () => this.tokenContext = _index.TokenContext.normal;
 | 
						|
    }
 | 
						|
  }
 | 
						|
  enterDelimited() {
 | 
						|
    const oldTokenContext = this.tokenContext;
 | 
						|
    const oldNoLineTerminatorAfterNode = this._noLineTerminatorAfterNode;
 | 
						|
    if (!(oldTokenContext & _index.TokenContext.forInOrInitHeadAccumulate) && oldNoLineTerminatorAfterNode === null) {
 | 
						|
      return () => {};
 | 
						|
    }
 | 
						|
    this._noLineTerminatorAfterNode = null;
 | 
						|
    this.tokenContext = _index.TokenContext.normal;
 | 
						|
    return () => {
 | 
						|
      this._noLineTerminatorAfterNode = oldNoLineTerminatorAfterNode;
 | 
						|
      this.tokenContext = oldTokenContext;
 | 
						|
    };
 | 
						|
  }
 | 
						|
  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 &= _index.TokenContext.forInOrInitHeadAccumulatePassThroughMask;
 | 
						|
    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 &= _index.TokenContext.forInOrInitHeadAccumulatePassThroughMask;
 | 
						|
    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 &= _index.TokenContext.forInOrInitHeadAccumulatePassThroughMask;
 | 
						|
    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, 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 oldTokenContext;
 | 
						|
    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.tokenContext & _index.TokenContext.forInOrInitHeadAccumulate) {
 | 
						|
        oldTokenContext = this.tokenContext;
 | 
						|
        this.tokenContext = _index.TokenContext.normal;
 | 
						|
      }
 | 
						|
      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 (oldTokenContext) this.tokenContext = oldTokenContext;
 | 
						|
    } 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
 |