|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ gfmTableHtml: () => (/* binding */ gfmTableHtml)\n/* harmony export */ });\n/**\n * @typedef {import('micromark-util-types').HtmlExtension} HtmlExtension\n * @typedef {import('./syntax.js').Align} Align\n */ const alignment = {\n none: \"\",\n left: ' align=\"left\"',\n right: ' align=\"right\"',\n center: ' align=\"center\"'\n};\n/** @type {HtmlExtension} */ const gfmTableHtml = {\n enter: {\n table (token) {\n /** @type {Array<Align>} */ // @ts-expect-error Custom.\n const tableAlign = token._align;\n this.lineEndingIfNeeded();\n this.tag(\"<table>\");\n this.setData(\"tableAlign\", tableAlign);\n },\n tableBody () {\n // Clear slurping line ending from the delimiter row.\n this.setData(\"slurpOneLineEnding\");\n this.tag(\"<tbody>\");\n },\n tableData () {\n const tableAlign = /** @type {Array<Align>} */ this.getData(\"tableAlign\");\n const tableColumn = /** @type {number} */ this.getData(\"tableColumn\");\n const align = alignment[tableAlign[tableColumn]];\n if (align === undefined) {\n // Capture results to ignore them.\n this.buffer();\n } else {\n this.lineEndingIfNeeded();\n this.tag(\"<td\" + align + \">\");\n }\n },\n tableHead () {\n this.lineEndingIfNeeded();\n this.tag(\"<thead>\");\n },\n tableHeader () {\n const tableAlign = /** @type {Array<Align>} */ this.getData(\"tableAlign\");\n const tableColumn = /** @type {number} */ this.getData(\"tableColumn\");\n const align = alignment[tableAlign[tableColumn]];\n this.lineEndingIfNeeded();\n this.tag(\"<th\" + align + \">\");\n },\n tableRow () {\n this.setData(\"tableColumn\", 0);\n this.lineEndingIfNeeded();\n this.tag(\"<tr>\");\n }\n },\n exit: {\n // Overwrite the default code text data handler to unescape escaped pipes when\n // they are in tables.\n codeTextData (token) {\n let value = this.sliceSerialize(token);\n if (this.getData(\"tableAlign\")) {\n value = value.replace(/\\\\([\\\\|])/g, replace);\n }\n this.raw(this.encode(value));\n },\n table () {\n this.setData(\"tableAlign\");\n // If there was no table body, make sure the slurping from the delimiter row\n // is cleared.\n this.setData(\"slurpAllLineEndings\");\n this.lineEndingIfNeeded();\n this.tag(\"</table>\");\n },\n tableBody () {\n this.lineEndingIfNeeded();\n this.tag(\"</tbody>\");\n },\n tableData () {\n const tableAlign = /** @type {Array<Align>} */ this.getData(\"tableAlign\");\n const tableColumn = /** @type {number} */ this.getData(\"tableColumn\");\n if (tableColumn in tableAlign) {\n this.tag(\"</td>\");\n this.setData(\"tableColumn\", tableColumn + 1);\n } else {\n // Stop capturing.\n this.resume();\n }\n },\n tableHead () {\n this.lineEndingIfNeeded();\n this.tag(\"</thead>\");\n this.setData(\"slurpOneLineEnding\", true);\n // Slurp the line ending from the delimiter row.\n },\n tableHeader () {\n const tableColumn = /** @type {number} */ this.getData(\"tableColumn\");\n this.tag(\"</th>\");\n this.setData(\"tableColumn\", tableColumn + 1);\n },\n tableRow () {\n const tableAlign = /** @type {Array<Align>} */ this.getData(\"tableAlign\");\n let tableColumn = /** @type {number} */ this.getData(\"tableColumn\");\n while(tableColumn < tableAlign.length){\n this.lineEndingIfNeeded();\n this.tag(\"<td\" + alignment[tableAlign[tableColumn]] + \"></td>\");\n tableColumn++;\n }\n this.setData(\"tableColumn\", tableColumn);\n this.lineEndingIfNeeded();\n this.tag(\"</tr>\");\n }\n }\n};\n/**\n * @param {string} $0\n * @param {string} $1\n * @returns {string}\n */ function replace($0, $1) {\n // Pipes work, backslashes don’t (but can’t escape pipes).\n return $1 === \"|\" ? $1 : $0;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/micromark-extension-gfm-table/dev/lib/html.js","mappings":"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","sources":["webpack://nextchat/./node_modules/micromark-extension-gfm-table/dev/lib/html.js?ea6e"],"sourcesContent":["/**\n * @typedef {import('micromark-util-types').HtmlExtension} HtmlExtension\n * @typedef {import('./syntax.js').Align} Align\n */\n\nconst alignment = {\n  none: '',\n  left: ' align=\"left\"',\n  right: ' align=\"right\"',\n  center: ' align=\"center\"'\n}\n\n/** @type {HtmlExtension} */\nexport const gfmTableHtml = {\n  enter: {\n    table(token) {\n      /** @type {Array<Align>} */\n      // @ts-expect-error Custom.\n      const tableAlign = token._align\n      this.lineEndingIfNeeded()\n      this.tag('<table>')\n      this.setData('tableAlign', tableAlign)\n    },\n    tableBody() {\n      // Clear slurping line ending from the delimiter row.\n      this.setData('slurpOneLineEnding')\n      this.tag('<tbody>')\n    },\n    tableData() {\n      const tableAlign = /** @type {Array<Align>} */ (\n        this.getData('tableAlign')\n      )\n      const tableColumn = /** @type {number} */ (this.getData('tableColumn'))\n      const align = alignment[tableAlign[tableColumn]]\n\n      if (align === undefined) {\n        // Capture results to ignore them.\n        this.buffer()\n      } else {\n        this.lineEndingIfNeeded()\n        this.tag('<td' + align + '>')\n      }\n    },\n    tableHead() {\n      this.lineEndingIfNeeded()\n      this.tag('<thead>')\n    },\n    tableHeader() {\n      const tableAlign = /** @type {Array<Align>} */ (\n        this.getData('tableAlign')\n      )\n      const tableColumn = /** @type {number} */ (this.getData('tableColumn'))\n      const align = alignment[tableAlign[tableColumn]]\n\n      this.lineEndingIfNeeded()\n      this.tag('<th' + align + '>')\n    },\n    tableRow() {\n      this.setData('tableColumn', 0)\n      this.lineEndingIfNeeded()\n      this.tag('<tr>')\n    }\n  },\n  exit: {\n    // Overwrite the default code text data handler to unescape escaped pipes when\n    // they are in tables.\n    codeTextData(token) {\n      let value = this.sliceSerialize(token)\n\n      if (this.getData('tableAlign')) {\n        value = value.replace(/\\\\([\\\\|])/g, replace)\n      }\n\n      this.raw(this.encode(value))\n    },\n    table() {\n      this.setData('tableAlign')\n      // If there was no table body, make sure the slurping from the delimiter row\n      // is cleared.\n      this.setData('slurpAllLineEndings')\n      this.lineEndingIfNeeded()\n      this.tag('</table>')\n    },\n    tableBody() {\n      this.lineEndingIfNeeded()\n      this.tag('</tbody>')\n    },\n    tableData() {\n      const tableAlign = /** @type {Array<Align>} */ (\n        this.getData('tableAlign')\n      )\n      const tableColumn = /** @type {number} */ (this.getData('tableColumn'))\n\n      if (tableColumn in tableAlign) {\n        this.tag('</td>')\n        this.setData('tableColumn', tableColumn + 1)\n      } else {\n        // Stop capturing.\n        this.resume()\n      }\n    },\n    tableHead() {\n      this.lineEndingIfNeeded()\n      this.tag('</thead>')\n      this.setData('slurpOneLineEnding', true)\n      // Slurp the line ending from the delimiter row.\n    },\n    tableHeader() {\n      const tableColumn = /** @type {number} */ (this.getData('tableColumn'))\n      this.tag('</th>')\n      this.setData('tableColumn', tableColumn + 1)\n    },\n    tableRow() {\n      const tableAlign = /** @type {Array<Align>} */ (\n        this.getData('tableAlign')\n      )\n      let tableColumn = /** @type {number} */ (this.getData('tableColumn'))\n\n      while (tableColumn < tableAlign.length) {\n        this.lineEndingIfNeeded()\n        this.tag('<td' + alignment[tableAlign[tableColumn]] + '></td>')\n        tableColumn++\n      }\n\n      this.setData('tableColumn', tableColumn)\n      this.lineEndingIfNeeded()\n      this.tag('</tr>')\n    }\n  }\n}\n\n/**\n * @param {string} $0\n * @param {string} $1\n * @returns {string}\n */\nfunction replace($0, $1) {\n  // Pipes work, backslashes don’t (but can’t escape pipes).\n  return $1 === '|' ? $1 : $0\n}\n"],"names":["alignment","none","left","right","center","gfmTableHtml","enter","table","token","tableAlign","_align","lineEndingIfNeeded","tag","setData","tableBody","tableData","getData","tableColumn","align","undefined","buffer","tableHead","tableHeader","tableRow","exit","codeTextData","value","sliceSerialize","replace","raw","encode","resume","length","$0","$1"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/micromark-extension-gfm-table/dev/lib/html.js\n");
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ gfmTable: () => (/* binding */ gfmTable)\n/* harmony export */ });\n/* harmony import */ var uvu_assert__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! uvu/assert */ \"(ssr)/./node_modules/uvu/assert/index.mjs\");\n/* harmony import */ var micromark_factory_space__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! micromark-factory-space */ \"(ssr)/./node_modules/micromark-factory-space/dev/index.js\");\n/* harmony import */ var micromark_util_character__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! micromark-util-character */ \"(ssr)/./node_modules/micromark-util-character/dev/index.js\");\n/* harmony import */ var micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! micromark-util-symbol/codes.js */ \"(ssr)/./node_modules/micromark-util-symbol/codes.js\");\n/* harmony import */ var micromark_util_symbol_constants_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! micromark-util-symbol/constants.js */ \"(ssr)/./node_modules/micromark-util-symbol/constants.js\");\n/* harmony import */ var micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! micromark-util-symbol/types.js */ \"(ssr)/./node_modules/micromark-util-symbol/types.js\");\n/**\n * @typedef {import('micromark-util-types').Extension} Extension\n * @typedef {import('micromark-util-types').Resolver} Resolver\n * @typedef {import('micromark-util-types').Tokenizer} Tokenizer\n * @typedef {import('micromark-util-types').State} State\n * @typedef {import('micromark-util-types').Token} Token\n */ /**\n * @typedef {'left'|'center'|'right'|'none'} Align\n */ \n\n\n\n\n\n/** @type {Extension} */ const gfmTable = {\n flow: {\n null: {\n tokenize: tokenizeTable,\n resolve: resolveTable\n }\n }\n};\nconst nextPrefixedOrBlank = {\n tokenize: tokenizeNextPrefixedOrBlank,\n partial: true\n};\n/** @type {Resolver} */ function resolveTable(events, context) {\n let index = -1;\n /** @type {boolean|undefined} */ let inHead;\n /** @type {boolean|undefined} */ let inDelimiterRow;\n /** @type {boolean|undefined} */ let inRow;\n /** @type {number|undefined} */ let contentStart;\n /** @type {number|undefined} */ let contentEnd;\n /** @type {number|undefined} */ let cellStart;\n /** @type {boolean|undefined} */ let seenCellInRow;\n while(++index < events.length){\n const token = events[index][1];\n if (inRow) {\n if (token.type === \"temporaryTableCellContent\") {\n contentStart = contentStart || index;\n contentEnd = index;\n }\n if (// Combine separate content parts into one.\n (token.type === \"tableCellDivider\" || token.type === \"tableRow\") && contentEnd) {\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)(contentStart, \"expected `contentStart` to be defined if `contentEnd` is\");\n const content = {\n type: \"tableContent\",\n start: events[contentStart][1].start,\n end: events[contentEnd][1].end\n };\n /** @type {Token} */ const text = {\n type: micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.chunkText,\n start: content.start,\n end: content.end,\n // @ts-expect-error It’s fine.\n contentType: micromark_util_symbol_constants_js__WEBPACK_IMPORTED_MODULE_2__.constants.contentTypeText\n };\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)(contentStart, \"expected `contentStart` to be defined if `contentEnd` is\");\n events.splice(contentStart, contentEnd - contentStart + 1, [\n \"enter\",\n content,\n context\n ], [\n \"enter\",\n text,\n context\n ], [\n \"exit\",\n text,\n context\n ], [\n \"exit\",\n content,\n context\n ]);\n index -= contentEnd - contentStart - 3;\n contentStart = undefined;\n contentEnd = undefined;\n }\n }\n if (events[index][0] === \"exit\" && cellStart !== undefined && cellStart + (seenCellInRow ? 0 : 1) < index && (token.type === \"tableCellDivider\" || token.type === \"tableRow\" && (cellStart + 3 < index || events[cellStart][1].type !== micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace))) {\n const cell = {\n type: inDelimiterRow ? \"tableDelimiter\" : inHead ? \"tableHeader\" : \"tableData\",\n start: events[cellStart][1].start,\n end: events[index][1].end\n };\n events.splice(index + (token.type === \"tableCellDivider\" ? 1 : 0), 0, [\n \"exit\",\n cell,\n context\n ]);\n events.splice(cellStart, 0, [\n \"enter\",\n cell,\n context\n ]);\n index += 2;\n cellStart = index + 1;\n seenCellInRow = true;\n }\n if (token.type === \"tableRow\") {\n inRow = events[index][0] === \"enter\";\n if (inRow) {\n cellStart = index + 1;\n seenCellInRow = false;\n }\n }\n if (token.type === \"tableDelimiterRow\") {\n inDelimiterRow = events[index][0] === \"enter\";\n if (inDelimiterRow) {\n cellStart = index + 1;\n seenCellInRow = false;\n }\n }\n if (token.type === \"tableHead\") {\n inHead = events[index][0] === \"enter\";\n }\n }\n return events;\n}\n/** @type {Tokenizer} */ function tokenizeTable(effects, ok, nok) {\n const self = this;\n /** @type {Array<Align>} */ const align = [];\n let tableHeaderCount = 0;\n /** @type {boolean|undefined} */ let seenDelimiter;\n /** @type {boolean|undefined} */ let hasDash;\n return start;\n /** @type {State} */ function start(code) {\n // @ts-expect-error Custom.\n effects.enter(\"table\")._align = align;\n effects.enter(\"tableHead\");\n effects.enter(\"tableRow\");\n // If we start with a pipe, we open a cell marker.\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n return cellDividerHead(code);\n }\n tableHeaderCount++;\n effects.enter(\"temporaryTableCellContent\");\n // Can’t be space or eols at the start of a construct, so we’re in a cell.\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)(!(0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEndingOrSpace)(code), \"expected non-space\");\n return inCellContentHead(code);\n }\n /** @type {State} */ function cellDividerHead(code) {\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)(code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar, \"expected `|`\");\n effects.enter(\"tableCellDivider\");\n effects.consume(code);\n effects.exit(\"tableCellDivider\");\n seenDelimiter = true;\n return cellBreakHead;\n }\n /** @type {State} */ function cellBreakHead(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code)) {\n return atRowEndHead(code);\n }\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.enter(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n effects.consume(code);\n return inWhitespaceHead;\n }\n if (seenDelimiter) {\n seenDelimiter = undefined;\n tableHeaderCount++;\n }\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n return cellDividerHead(code);\n }\n // Anything else is cell content.\n effects.enter(\"temporaryTableCellContent\");\n return inCellContentHead(code);\n }\n /** @type {State} */ function inWhitespaceHead(code) {\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.consume(code);\n return inWhitespaceHead;\n }\n effects.exit(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n return cellBreakHead(code);\n }\n /** @type {State} */ function inCellContentHead(code) {\n // EOF, whitespace, pipe\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEndingOrSpace)(code)) {\n effects.exit(\"temporaryTableCellContent\");\n return cellBreakHead(code);\n }\n effects.consume(code);\n return code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.backslash ? inCellContentEscapeHead : inCellContentHead;\n }\n /** @type {State} */ function inCellContentEscapeHead(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.backslash || code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n effects.consume(code);\n return inCellContentHead;\n }\n // Anything else.\n return inCellContentHead(code);\n }\n /** @type {State} */ function atRowEndHead(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof) {\n return nok(code);\n }\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code), \"expected eol\");\n effects.exit(\"tableRow\");\n effects.exit(\"tableHead\");\n const originalInterrupt = self.interrupt;\n self.interrupt = true;\n return effects.attempt({\n tokenize: tokenizeRowEnd,\n partial: true\n }, function(code) {\n self.interrupt = originalInterrupt;\n effects.enter(\"tableDelimiterRow\");\n return atDelimiterRowBreak(code);\n }, function(code) {\n self.interrupt = originalInterrupt;\n return nok(code);\n })(code);\n }\n /** @type {State} */ function atDelimiterRowBreak(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code)) {\n return rowEndDelimiter(code);\n }\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.enter(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n effects.consume(code);\n return inWhitespaceDelimiter;\n }\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.dash) {\n effects.enter(\"tableDelimiterFiller\");\n effects.consume(code);\n hasDash = true;\n align.push(\"none\");\n return inFillerDelimiter;\n }\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.colon) {\n effects.enter(\"tableDelimiterAlignment\");\n effects.consume(code);\n effects.exit(\"tableDelimiterAlignment\");\n align.push(\"left\");\n return afterLeftAlignment;\n }\n // If we start with a pipe, we open a cell marker.\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n effects.enter(\"tableCellDivider\");\n effects.consume(code);\n effects.exit(\"tableCellDivider\");\n return atDelimiterRowBreak;\n }\n return nok(code);\n }\n /** @type {State} */ function inWhitespaceDelimiter(code) {\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.consume(code);\n return inWhitespaceDelimiter;\n }\n effects.exit(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n return atDelimiterRowBreak(code);\n }\n /** @type {State} */ function inFillerDelimiter(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.dash) {\n effects.consume(code);\n return inFillerDelimiter;\n }\n effects.exit(\"tableDelimiterFiller\");\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.colon) {\n effects.enter(\"tableDelimiterAlignment\");\n effects.consume(code);\n effects.exit(\"tableDelimiterAlignment\");\n align[align.length - 1] = align[align.length - 1] === \"left\" ? \"center\" : \"right\";\n return afterRightAlignment;\n }\n return atDelimiterRowBreak(code);\n }\n /** @type {State} */ function afterLeftAlignment(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.dash) {\n effects.enter(\"tableDelimiterFiller\");\n effects.consume(code);\n hasDash = true;\n return inFillerDelimiter;\n }\n // Anything else is not ok.\n return nok(code);\n }\n /** @type {State} */ function afterRightAlignment(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code)) {\n return rowEndDelimiter(code);\n }\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.enter(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n effects.consume(code);\n return inWhitespaceDelimiter;\n }\n // `|`\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n effects.enter(\"tableCellDivider\");\n effects.consume(code);\n effects.exit(\"tableCellDivider\");\n return atDelimiterRowBreak;\n }\n return nok(code);\n }\n /** @type {State} */ function rowEndDelimiter(code) {\n effects.exit(\"tableDelimiterRow\");\n // Exit if there was no dash at all, or if the header cell count is not the\n // delimiter cell count.\n if (!hasDash || tableHeaderCount !== align.length) {\n return nok(code);\n }\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof) {\n return tableClose(code);\n }\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code), \"expected eol\");\n return effects.check(nextPrefixedOrBlank, tableClose, effects.attempt({\n tokenize: tokenizeRowEnd,\n partial: true\n }, (0,micromark_factory_space__WEBPACK_IMPORTED_MODULE_5__.factorySpace)(effects, bodyStart, micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.linePrefix, micromark_util_symbol_constants_js__WEBPACK_IMPORTED_MODULE_2__.constants.tabSize), tableClose))(code);\n }\n /** @type {State} */ function tableClose(code) {\n effects.exit(\"table\");\n return ok(code);\n }\n /** @type {State} */ function bodyStart(code) {\n effects.enter(\"tableBody\");\n return rowStartBody(code);\n }\n /** @type {State} */ function rowStartBody(code) {\n effects.enter(\"tableRow\");\n // If we start with a pipe, we open a cell marker.\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n return cellDividerBody(code);\n }\n effects.enter(\"temporaryTableCellContent\");\n // Can’t be space or eols at the start of a construct, so we’re in a cell.\n return inCellContentBody(code);\n }\n /** @type {State} */ function cellDividerBody(code) {\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)(code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar, \"expected `|`\");\n effects.enter(\"tableCellDivider\");\n effects.consume(code);\n effects.exit(\"tableCellDivider\");\n return cellBreakBody;\n }\n /** @type {State} */ function cellBreakBody(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code)) {\n return atRowEndBody(code);\n }\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.enter(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n effects.consume(code);\n return inWhitespaceBody;\n }\n // `|`\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n return cellDividerBody(code);\n }\n // Anything else is cell content.\n effects.enter(\"temporaryTableCellContent\");\n return inCellContentBody(code);\n }\n /** @type {State} */ function inWhitespaceBody(code) {\n if ((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownSpace)(code)) {\n effects.consume(code);\n return inWhitespaceBody;\n }\n effects.exit(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.whitespace);\n return cellBreakBody(code);\n }\n /** @type {State} */ function inCellContentBody(code) {\n // EOF, whitespace, pipe\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEndingOrSpace)(code)) {\n effects.exit(\"temporaryTableCellContent\");\n return cellBreakBody(code);\n }\n effects.consume(code);\n return code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.backslash ? inCellContentEscapeBody : inCellContentBody;\n }\n /** @type {State} */ function inCellContentEscapeBody(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.backslash || code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.verticalBar) {\n effects.consume(code);\n return inCellContentBody;\n }\n // Anything else.\n return inCellContentBody(code);\n }\n /** @type {State} */ function atRowEndBody(code) {\n effects.exit(\"tableRow\");\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof) {\n return tableBodyClose(code);\n }\n return effects.check(nextPrefixedOrBlank, tableBodyClose, effects.attempt({\n tokenize: tokenizeRowEnd,\n partial: true\n }, (0,micromark_factory_space__WEBPACK_IMPORTED_MODULE_5__.factorySpace)(effects, rowStartBody, micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.linePrefix, micromark_util_symbol_constants_js__WEBPACK_IMPORTED_MODULE_2__.constants.tabSize), tableBodyClose))(code);\n }\n /** @type {State} */ function tableBodyClose(code) {\n effects.exit(\"tableBody\");\n return tableClose(code);\n }\n /** @type {Tokenizer} */ function tokenizeRowEnd(effects, ok, nok) {\n return start;\n /** @type {State} */ function start(code) {\n (0,uvu_assert__WEBPACK_IMPORTED_MODULE_0__.ok)((0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code), \"expected eol\");\n effects.enter(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.lineEnding);\n effects.consume(code);\n effects.exit(micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.lineEnding);\n return (0,micromark_factory_space__WEBPACK_IMPORTED_MODULE_5__.factorySpace)(effects, prefixed, micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.linePrefix);\n }\n /** @type {State} */ function prefixed(code) {\n // Blank or interrupting line.\n if (self.parser.lazy[self.now().line] || code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEnding)(code)) {\n return nok(code);\n }\n const tail = self.events[self.events.length - 1];\n // Indented code can interrupt delimiter and body rows.\n if (!self.parser.constructs.disable.null.includes(\"codeIndented\") && tail && tail[1].type === micromark_util_symbol_types_js__WEBPACK_IMPORTED_MODULE_1__.types.linePrefix && tail[2].sliceSerialize(tail[1], true).length >= micromark_util_symbol_constants_js__WEBPACK_IMPORTED_MODULE_2__.constants.tabSize) {\n return nok(code);\n }\n self._gfmTableDynamicInterruptHack = true;\n return effects.check(self.parser.constructs.flow, function(code) {\n self._gfmTableDynamicInterruptHack = false;\n return nok(code);\n }, function(code) {\n self._gfmTableDynamicInterruptHack = false;\n return ok(code);\n })(code);\n }\n }\n}\n/** @type {Tokenizer} */ function tokenizeNextPrefixedOrBlank(effects, ok, nok) {\n let size = 0;\n return start;\n /** @type {State} */ function start(code) {\n // This is a check, so we don’t care about tokens, but we open a bogus one\n // so we’re valid.\n effects.enter(\"check\");\n // EOL.\n effects.consume(code);\n return whitespace;\n }\n /** @type {State} */ function whitespace(code) {\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.virtualSpace || code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.space) {\n effects.consume(code);\n size++;\n return size === micromark_util_symbol_constants_js__WEBPACK_IMPORTED_MODULE_2__.constants.tabSize ? ok : whitespace;\n }\n // EOF or whitespace\n if (code === micromark_util_symbol_codes_js__WEBPACK_IMPORTED_MODULE_3__.codes.eof || (0,micromark_util_character__WEBPACK_IMPORTED_MODULE_4__.markdownLineEndingOrSpace)(code)) {\n return ok(code);\n }\n // Anything else.\n return nok(code);\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/micromark-extension-gfm-table/dev/lib/syntax.js","mappings":"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","sources":["webpack://nextchat/./node_modules/micromark-extension-gfm-table/dev/lib/syntax.js?f410"],"sourcesContent":["/**\n * @typedef {import('micromark-util-types').Extension} Extension\n * @typedef {import('micromark-util-types').Resolver} Resolver\n * @typedef {import('micromark-util-types').Tokenizer} Tokenizer\n * @typedef {import('micromark-util-types').State} State\n * @typedef {import('micromark-util-types').Token} Token\n */\n\n/**\n * @typedef {'left'|'center'|'right'|'none'} Align\n */\n\nimport {ok as assert} from 'uvu/assert'\nimport {factorySpace} from 'micromark-factory-space'\nimport {\n  markdownLineEnding,\n  markdownLineEndingOrSpace,\n  markdownSpace\n} from 'micromark-util-character'\nimport {codes} from 'micromark-util-symbol/codes.js'\nimport {constants} from 'micromark-util-symbol/constants.js'\nimport {types} from 'micromark-util-symbol/types.js'\n\n/** @type {Extension} */\nexport const gfmTable = {\n  flow: {null: {tokenize: tokenizeTable, resolve: resolveTable}}\n}\n\nconst nextPrefixedOrBlank = {\n  tokenize: tokenizeNextPrefixedOrBlank,\n  partial: true\n}\n\n/** @type {Resolver} */\nfunction resolveTable(events, context) {\n  let index = -1\n  /** @type {boolean|undefined} */\n  let inHead\n  /** @type {boolean|undefined} */\n  let inDelimiterRow\n  /** @type {boolean|undefined} */\n  let inRow\n  /** @type {number|undefined} */\n  let contentStart\n  /** @type {number|undefined} */\n  let contentEnd\n  /** @type {number|undefined} */\n  let cellStart\n  /** @type {boolean|undefined} */\n  let seenCellInRow\n\n  while (++index < events.length) {\n    const token = events[index][1]\n\n    if (inRow) {\n      if (token.type === 'temporaryTableCellContent') {\n        contentStart = contentStart || index\n        contentEnd = index\n      }\n\n      if (\n        // Combine separate content parts into one.\n        (token.type === 'tableCellDivider' || token.type === 'tableRow') &&\n        contentEnd\n      ) {\n        assert(\n          contentStart,\n          'expected `contentStart` to be defined if `contentEnd` is'\n        )\n        const content = {\n          type: 'tableContent',\n          start: events[contentStart][1].start,\n          end: events[contentEnd][1].end\n        }\n        /** @type {Token} */\n        const text = {\n          type: types.chunkText,\n          start: content.start,\n          end: content.end,\n          // @ts-expect-error It’s fine.\n          contentType: constants.contentTypeText\n        }\n\n        assert(\n          contentStart,\n          'expected `contentStart` to be defined if `contentEnd` is'\n        )\n\n        events.splice(\n          contentStart,\n          contentEnd - contentStart + 1,\n          ['enter', content, context],\n          ['enter', text, context],\n          ['exit', text, context],\n          ['exit', content, context]\n        )\n\n        index -= contentEnd - contentStart - 3\n        contentStart = undefined\n        contentEnd = undefined\n      }\n    }\n\n    if (\n      events[index][0] === 'exit' &&\n      cellStart !== undefined &&\n      cellStart + (seenCellInRow ? 0 : 1) < index &&\n      (token.type === 'tableCellDivider' ||\n        (token.type === 'tableRow' &&\n          (cellStart + 3 < index ||\n            events[cellStart][1].type !== types.whitespace)))\n    ) {\n      const cell = {\n        type: inDelimiterRow\n          ? 'tableDelimiter'\n          : inHead\n          ? 'tableHeader'\n          : 'tableData',\n        start: events[cellStart][1].start,\n        end: events[index][1].end\n      }\n      events.splice(index + (token.type === 'tableCellDivider' ? 1 : 0), 0, [\n        'exit',\n        cell,\n        context\n      ])\n      events.splice(cellStart, 0, ['enter', cell, context])\n      index += 2\n      cellStart = index + 1\n      seenCellInRow = true\n    }\n\n    if (token.type === 'tableRow') {\n      inRow = events[index][0] === 'enter'\n\n      if (inRow) {\n        cellStart = index + 1\n        seenCellInRow = false\n      }\n    }\n\n    if (token.type === 'tableDelimiterRow') {\n      inDelimiterRow = events[index][0] === 'enter'\n\n      if (inDelimiterRow) {\n        cellStart = index + 1\n        seenCellInRow = false\n      }\n    }\n\n    if (token.type === 'tableHead') {\n      inHead = events[index][0] === 'enter'\n    }\n  }\n\n  return events\n}\n\n/** @type {Tokenizer} */\nfunction tokenizeTable(effects, ok, nok) {\n  const self = this\n  /** @type {Array<Align>} */\n  const align = []\n  let tableHeaderCount = 0\n  /** @type {boolean|undefined} */\n  let seenDelimiter\n  /** @type {boolean|undefined} */\n  let hasDash\n\n  return start\n\n  /** @type {State} */\n  function start(code) {\n    // @ts-expect-error Custom.\n    effects.enter('table')._align = align\n    effects.enter('tableHead')\n    effects.enter('tableRow')\n\n    // If we start with a pipe, we open a cell marker.\n    if (code === codes.verticalBar) {\n      return cellDividerHead(code)\n    }\n\n    tableHeaderCount++\n    effects.enter('temporaryTableCellContent')\n    // Can’t be space or eols at the start of a construct, so we’re in a cell.\n    assert(!markdownLineEndingOrSpace(code), 'expected non-space')\n    return inCellContentHead(code)\n  }\n\n  /** @type {State} */\n  function cellDividerHead(code) {\n    assert(code === codes.verticalBar, 'expected `|`')\n    effects.enter('tableCellDivider')\n    effects.consume(code)\n    effects.exit('tableCellDivider')\n    seenDelimiter = true\n    return cellBreakHead\n  }\n\n  /** @type {State} */\n  function cellBreakHead(code) {\n    if (code === codes.eof || markdownLineEnding(code)) {\n      return atRowEndHead(code)\n    }\n\n    if (markdownSpace(code)) {\n      effects.enter(types.whitespace)\n      effects.consume(code)\n      return inWhitespaceHead\n    }\n\n    if (seenDelimiter) {\n      seenDelimiter = undefined\n      tableHeaderCount++\n    }\n\n    if (code === codes.verticalBar) {\n      return cellDividerHead(code)\n    }\n\n    // Anything else is cell content.\n    effects.enter('temporaryTableCellContent')\n    return inCellContentHead(code)\n  }\n\n  /** @type {State} */\n  function inWhitespaceHead(code) {\n    if (markdownSpace(code)) {\n      effects.consume(code)\n      return inWhitespaceHead\n    }\n\n    effects.exit(types.whitespace)\n    return cellBreakHead(code)\n  }\n\n  /** @type {State} */\n  function inCellContentHead(code) {\n    // EOF, whitespace, pipe\n    if (\n      code === codes.eof ||\n      code === codes.verticalBar ||\n      markdownLineEndingOrSpace(code)\n    ) {\n      effects.exit('temporaryTableCellContent')\n      return cellBreakHead(code)\n    }\n\n    effects.consume(code)\n    return code === codes.backslash\n      ? inCellContentEscapeHead\n      : inCellContentHead\n  }\n\n  /** @type {State} */\n  function inCellContentEscapeHead(code) {\n    if (code === codes.backslash || code === codes.verticalBar) {\n      effects.consume(code)\n      return inCellContentHead\n    }\n\n    // Anything else.\n    return inCellContentHead(code)\n  }\n\n  /** @type {State} */\n  function atRowEndHead(code) {\n    if (code === codes.eof) {\n      return nok(code)\n    }\n\n    assert(markdownLineEnding(code), 'expected eol')\n    effects.exit('tableRow')\n    effects.exit('tableHead')\n    const originalInterrupt = self.interrupt\n    self.interrupt = true\n    return effects.attempt(\n      {tokenize: tokenizeRowEnd, partial: true},\n      function (code) {\n        self.interrupt = originalInterrupt\n        effects.enter('tableDelimiterRow')\n        return atDelimiterRowBreak(code)\n      },\n      function (code) {\n        self.interrupt = originalInterrupt\n        return nok(code)\n      }\n    )(code)\n  }\n\n  /** @type {State} */\n  function atDelimiterRowBreak(code) {\n    if (code === codes.eof || markdownLineEnding(code)) {\n      return rowEndDelimiter(code)\n    }\n\n    if (markdownSpace(code)) {\n      effects.enter(types.whitespace)\n      effects.consume(code)\n      return inWhitespaceDelimiter\n    }\n\n    if (code === codes.dash) {\n      effects.enter('tableDelimiterFiller')\n      effects.consume(code)\n      hasDash = true\n      align.push('none')\n      return inFillerDelimiter\n    }\n\n    if (code === codes.colon) {\n      effects.enter('tableDelimiterAlignment')\n      effects.consume(code)\n      effects.exit('tableDelimiterAlignment')\n      align.push('left')\n      return afterLeftAlignment\n    }\n\n    // If we start with a pipe, we open a cell marker.\n    if (code === codes.verticalBar) {\n      effects.enter('tableCellDivider')\n      effects.consume(code)\n      effects.exit('tableCellDivider')\n      return atDelimiterRowBreak\n    }\n\n    return nok(code)\n  }\n\n  /** @type {State} */\n  function inWhitespaceDelimiter(code) {\n    if (markdownSpace(code)) {\n      effects.consume(code)\n      return inWhitespaceDelimiter\n    }\n\n    effects.exit(types.whitespace)\n    return atDelimiterRowBreak(code)\n  }\n\n  /** @type {State} */\n  function inFillerDelimiter(code) {\n    if (code === codes.dash) {\n      effects.consume(code)\n      return inFillerDelimiter\n    }\n\n    effects.exit('tableDelimiterFiller')\n\n    if (code === codes.colon) {\n      effects.enter('tableDelimiterAlignment')\n      effects.consume(code)\n      effects.exit('tableDelimiterAlignment')\n\n      align[align.length - 1] =\n        align[align.length - 1] === 'left' ? 'center' : 'right'\n\n      return afterRightAlignment\n    }\n\n    return atDelimiterRowBreak(code)\n  }\n\n  /** @type {State} */\n  function afterLeftAlignment(code) {\n    if (code === codes.dash) {\n      effects.enter('tableDelimiterFiller')\n      effects.consume(code)\n      hasDash = true\n      return inFillerDelimiter\n    }\n\n    // Anything else is not ok.\n    return nok(code)\n  }\n\n  /** @type {State} */\n  function afterRightAlignment(code) {\n    if (code === codes.eof || markdownLineEnding(code)) {\n      return rowEndDelimiter(code)\n    }\n\n    if (markdownSpace(code)) {\n      effects.enter(types.whitespace)\n      effects.consume(code)\n      return inWhitespaceDelimiter\n    }\n\n    // `|`\n    if (code === codes.verticalBar) {\n      effects.enter('tableCellDivider')\n      effects.consume(code)\n      effects.exit('tableCellDivider')\n      return atDelimiterRowBreak\n    }\n\n    return nok(code)\n  }\n\n  /** @type {State} */\n  function rowEndDelimiter(code) {\n    effects.exit('tableDelimiterRow')\n\n    // Exit if there was no dash at all, or if the header cell count is not the\n    // delimiter cell count.\n    if (!hasDash || tableHeaderCount !== align.length) {\n      return nok(code)\n    }\n\n    if (code === codes.eof) {\n      return tableClose(code)\n    }\n\n    assert(markdownLineEnding(code), 'expected eol')\n    return effects.check(\n      nextPrefixedOrBlank,\n      tableClose,\n      effects.attempt(\n        {tokenize: tokenizeRowEnd, partial: true},\n        factorySpace(effects, bodyStart, types.linePrefix, constants.tabSize),\n        tableClose\n      )\n    )(code)\n  }\n\n  /** @type {State} */\n  function tableClose(code) {\n    effects.exit('table')\n    return ok(code)\n  }\n\n  /** @type {State} */\n  function bodyStart(code) {\n    effects.enter('tableBody')\n    return rowStartBody(code)\n  }\n\n  /** @type {State} */\n  function rowStartBody(code) {\n    effects.enter('tableRow')\n\n    // If we start with a pipe, we open a cell marker.\n    if (code === codes.verticalBar) {\n      return cellDividerBody(code)\n    }\n\n    effects.enter('temporaryTableCellContent')\n    // Can’t be space or eols at the start of a construct, so we’re in a cell.\n    return inCellContentBody(code)\n  }\n\n  /** @type {State} */\n  function cellDividerBody(code) {\n    assert(code === codes.verticalBar, 'expected `|`')\n    effects.enter('tableCellDivider')\n    effects.consume(code)\n    effects.exit('tableCellDivider')\n    return cellBreakBody\n  }\n\n  /** @type {State} */\n  function cellBreakBody(code) {\n    if (code === codes.eof || markdownLineEnding(code)) {\n      return atRowEndBody(code)\n    }\n\n    if (markdownSpace(code)) {\n      effects.enter(types.whitespace)\n      effects.consume(code)\n      return inWhitespaceBody\n    }\n\n    // `|`\n    if (code === codes.verticalBar) {\n      return cellDividerBody(code)\n    }\n\n    // Anything else is cell content.\n    effects.enter('temporaryTableCellContent')\n    return inCellContentBody(code)\n  }\n\n  /** @type {State} */\n  function inWhitespaceBody(code) {\n    if (markdownSpace(code)) {\n      effects.consume(code)\n      return inWhitespaceBody\n    }\n\n    effects.exit(types.whitespace)\n    return cellBreakBody(code)\n  }\n\n  /** @type {State} */\n  function inCellContentBody(code) {\n    // EOF, whitespace, pipe\n    if (\n      code === codes.eof ||\n      code === codes.verticalBar ||\n      markdownLineEndingOrSpace(code)\n    ) {\n      effects.exit('temporaryTableCellContent')\n      return cellBreakBody(code)\n    }\n\n    effects.consume(code)\n    return code === codes.backslash\n      ? inCellContentEscapeBody\n      : inCellContentBody\n  }\n\n  /** @type {State} */\n  function inCellContentEscapeBody(code) {\n    if (code === codes.backslash || code === codes.verticalBar) {\n      effects.consume(code)\n      return inCellContentBody\n    }\n\n    // Anything else.\n    return inCellContentBody(code)\n  }\n\n  /** @type {State} */\n  function atRowEndBody(code) {\n    effects.exit('tableRow')\n\n    if (code === codes.eof) {\n      return tableBodyClose(code)\n    }\n\n    return effects.check(\n      nextPrefixedOrBlank,\n      tableBodyClose,\n      effects.attempt(\n        {tokenize: tokenizeRowEnd, partial: true},\n        factorySpace(\n          effects,\n          rowStartBody,\n          types.linePrefix,\n          constants.tabSize\n        ),\n        tableBodyClose\n      )\n    )(code)\n  }\n\n  /** @type {State} */\n  function tableBodyClose(code) {\n    effects.exit('tableBody')\n    return tableClose(code)\n  }\n\n  /** @type {Tokenizer} */\n  function tokenizeRowEnd(effects, ok, nok) {\n    return start\n\n    /** @type {State} */\n    function start(code) {\n      assert(markdownLineEnding(code), 'expected eol')\n      effects.enter(types.lineEnding)\n      effects.consume(code)\n      effects.exit(types.lineEnding)\n      return factorySpace(effects, prefixed, types.linePrefix)\n    }\n\n    /** @type {State} */\n    function prefixed(code) {\n      // Blank or interrupting line.\n      if (\n        self.parser.lazy[self.now().line] ||\n        code === codes.eof ||\n        markdownLineEnding(code)\n      ) {\n        return nok(code)\n      }\n\n      const tail = self.events[self.events.length - 1]\n\n      // Indented code can interrupt delimiter and body rows.\n      if (\n        !self.parser.constructs.disable.null.includes('codeIndented') &&\n        tail &&\n        tail[1].type === types.linePrefix &&\n        tail[2].sliceSerialize(tail[1], true).length >= constants.tabSize\n      ) {\n        return nok(code)\n      }\n\n      self._gfmTableDynamicInterruptHack = true\n\n      return effects.check(\n        self.parser.constructs.flow,\n        function (code) {\n          self._gfmTableDynamicInterruptHack = false\n          return nok(code)\n        },\n        function (code) {\n          self._gfmTableDynamicInterruptHack = false\n          return ok(code)\n        }\n      )(code)\n    }\n  }\n}\n\n/** @type {Tokenizer} */\nfunction tokenizeNextPrefixedOrBlank(effects, ok, nok) {\n  let size = 0\n\n  return start\n\n  /** @type {State} */\n  function start(code) {\n    // This is a check, so we don’t care about tokens, but we open a bogus one\n    // so we’re valid.\n    effects.enter('check')\n    // EOL.\n    effects.consume(code)\n    return whitespace\n  }\n\n  /** @type {State} */\n  function whitespace(code) {\n    if (code === codes.virtualSpace || code === codes.space) {\n      effects.consume(code)\n      size++\n      return size === constants.tabSize ? ok : whitespace\n    }\n\n    // EOF or whitespace\n    if (code === codes.eof || markdownLineEndingOrSpace(code)) {\n      return ok(code)\n    }\n\n    // Anything else.\n    return nok(code)\n  }\n}\n"],"names":["ok","assert","factorySpace","markdownLineEnding","markdownLineEndingOrSpace","markdownSpace","codes","constants","types","gfmTable","flow","null","tokenize","tokenizeTable","resolve","resolveTable","nextPrefixedOrBlank","tokenizeNextPrefixedOrBlank","partial","events","context","index","inHead","inDelimiterRow","inRow","contentStart","contentEnd","cellStart","seenCellInRow","length","token","type","content","start","end","text","chunkText","contentType","contentTypeText","splice","undefined","whitespace","cell","effects","nok","self","align","tableHeaderCount","seenDelimiter","hasDash","code","enter","_align","verticalBar","cellDividerHead","inCellContentHead","consume","exit","cellBreakHead","eof","atRowEndHead","inWhitespaceHead","backslash","inCellContentEscapeHead","originalInterrupt","interrupt","attempt","tokenizeRowEnd","atDelimiterRowBreak","rowEndDelimiter","inWhitespaceDelimiter","dash","push","inFillerDelimiter","colon","afterLeftAlignment","afterRightAlignment","tableClose","check","bodyStart","linePrefix","tabSize","rowStartBody","cellDividerBody","inCellContentBody","cellBreakBody","atRowEndBody","inWhitespaceBody","inCellContentEscapeBody","tableBodyClose","lineEnding","prefixed","parser","lazy","now","line","tail","constructs","disable","includes","sliceSerialize","_gfmTableDynamicInterruptHack","size","virtualSpace","space"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/micromark-extension-gfm-table/dev/lib/syntax.js\n");
|