mirror of
https://github.com/logos-messaging/lab.waku.org.git
synced 2026-01-06 15:53:12 +00:00
25 lines
28 KiB
JavaScript
25 lines
28 KiB
JavaScript
"use strict";
|
||
/*
|
||
* ATTENTION: An "eval-source-map" devtool has been used.
|
||
* This devtool is neither made for production nor for readable output files.
|
||
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
||
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
||
* or disable the default devtool with "devtool: false".
|
||
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
||
*/
|
||
exports.id = "vendor-chunks/micromark-util-subtokenize";
|
||
exports.ids = ["vendor-chunks/micromark-util-subtokenize"];
|
||
exports.modules = {
|
||
|
||
/***/ "(ssr)/./node_modules/micromark-util-subtokenize/dev/index.js":
|
||
/*!**************************************************************!*\
|
||
!*** ./node_modules/micromark-util-subtokenize/dev/index.js ***!
|
||
\**************************************************************/
|
||
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
||
|
||
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ subtokenize: () => (/* binding */ subtokenize)\n/* harmony export */ });\n/* harmony import */ var micromark_util_chunked__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! micromark-util-chunked */ \"(ssr)/./node_modules/micromark-util-chunked/dev/index.js\");\n/* harmony import */ var micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! micromark-util-symbol */ \"(ssr)/./node_modules/micromark-util-symbol/lib/types.js\");\n/* harmony import */ var micromark_util_symbol__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! micromark-util-symbol */ \"(ssr)/./node_modules/micromark-util-symbol/lib/codes.js\");\n/* harmony import */ var devlop__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! devlop */ \"(ssr)/./node_modules/devlop/lib/development.js\");\n/**\n * @typedef {import('micromark-util-types').Chunk} Chunk\n * @typedef {import('micromark-util-types').Event} Event\n * @typedef {import('micromark-util-types').Token} Token\n */ \n\n\n/**\n * Tokenize subcontent.\n *\n * @param {Array<Event>} events\n * List of events.\n * @returns {boolean}\n * Whether subtokens were found.\n */ // eslint-disable-next-line complexity\nfunction subtokenize(events) {\n /** @type {Record<string, number>} */ const jumps = {};\n let index = -1;\n /** @type {Event} */ let event;\n /** @type {number | undefined} */ let lineIndex;\n /** @type {number} */ let otherIndex;\n /** @type {Event} */ let otherEvent;\n /** @type {Array<Event>} */ let parameters;\n /** @type {Array<Event>} */ let subevents;\n /** @type {boolean | undefined} */ let more;\n while(++index < events.length){\n while(index in jumps){\n index = jumps[index];\n }\n event = events[index];\n // Add a hook for the GFM tasklist extension, which needs to know if text\n // is in the first content of a list item.\n if (index && event[1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.chunkFlow && events[index - 1][1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.listItemPrefix) {\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(event[1]._tokenizer, \"expected `_tokenizer` on subtokens\");\n subevents = event[1]._tokenizer.events;\n otherIndex = 0;\n if (otherIndex < subevents.length && subevents[otherIndex][1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.lineEndingBlank) {\n otherIndex += 2;\n }\n if (otherIndex < subevents.length && subevents[otherIndex][1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.content) {\n while(++otherIndex < subevents.length){\n if (subevents[otherIndex][1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.content) {\n break;\n }\n if (subevents[otherIndex][1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.chunkText) {\n subevents[otherIndex][1]._isInFirstContentOfListItem = true;\n otherIndex++;\n }\n }\n }\n }\n // Enter.\n if (event[0] === \"enter\") {\n if (event[1].contentType) {\n Object.assign(jumps, subcontent(events, index));\n index = jumps[index];\n more = true;\n }\n } else if (event[1]._container) {\n otherIndex = index;\n lineIndex = undefined;\n while(otherIndex--){\n otherEvent = events[otherIndex];\n if (otherEvent[1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.lineEnding || otherEvent[1].type === micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.lineEndingBlank) {\n if (otherEvent[0] === \"enter\") {\n if (lineIndex) {\n events[lineIndex][1].type = micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.lineEndingBlank;\n }\n otherEvent[1].type = micromark_util_symbol__WEBPACK_IMPORTED_MODULE_0__.types.lineEnding;\n lineIndex = otherIndex;\n }\n } else {\n break;\n }\n }\n if (lineIndex) {\n // Fix position.\n event[1].end = Object.assign({}, events[lineIndex][1].start);\n // Switch container exit w/ line endings.\n parameters = events.slice(lineIndex, index);\n parameters.unshift(event);\n (0,micromark_util_chunked__WEBPACK_IMPORTED_MODULE_2__.splice)(events, lineIndex, index - lineIndex + 1, parameters);\n }\n }\n }\n return !more;\n}\n/**\n * Tokenize embedded tokens.\n *\n * @param {Array<Event>} events\n * @param {number} eventIndex\n * @returns {Record<string, number>}\n */ function subcontent(events, eventIndex) {\n const token = events[eventIndex][1];\n const context = events[eventIndex][2];\n let startPosition = eventIndex - 1;\n /** @type {Array<number>} */ const startPositions = [];\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(token.contentType, \"expected `contentType` on subtokens\");\n const tokenizer = token._tokenizer || context.parser[token.contentType](token.start);\n const childEvents = tokenizer.events;\n /** @type {Array<[number, number]>} */ const jumps = [];\n /** @type {Record<string, number>} */ const gaps = {};\n /** @type {Array<Chunk>} */ let stream;\n /** @type {Token | undefined} */ let previous;\n let index = -1;\n /** @type {Token | undefined} */ let current = token;\n let adjust = 0;\n let start = 0;\n const breaks = [\n start\n ];\n // Loop forward through the linked tokens to pass them in order to the\n // subtokenizer.\n while(current){\n // Find the position of the event for this token.\n while(events[++startPosition][1] !== current){\n // Empty.\n }\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(!previous || current.previous === previous, \"expected previous to match\");\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(!previous || previous.next === current, \"expected next to match\");\n startPositions.push(startPosition);\n if (!current._tokenizer) {\n stream = context.sliceStream(current);\n if (!current.next) {\n stream.push(micromark_util_symbol__WEBPACK_IMPORTED_MODULE_3__.codes.eof);\n }\n if (previous) {\n tokenizer.defineSkip(current.start);\n }\n if (current._isInFirstContentOfListItem) {\n tokenizer._gfmTasklistFirstContentOfListItem = true;\n }\n tokenizer.write(stream);\n if (current._isInFirstContentOfListItem) {\n tokenizer._gfmTasklistFirstContentOfListItem = undefined;\n }\n }\n // Unravel the next token.\n previous = current;\n current = current.next;\n }\n // Now, loop back through all events (and linked tokens), to figure out which\n // parts belong where.\n current = token;\n while(++index < childEvents.length){\n if (// Find a void token that includes a break.\n childEvents[index][0] === \"exit\" && childEvents[index - 1][0] === \"enter\" && childEvents[index][1].type === childEvents[index - 1][1].type && childEvents[index][1].start.line !== childEvents[index][1].end.line) {\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(current, \"expected a current token\");\n start = index + 1;\n breaks.push(start);\n // Help GC.\n current._tokenizer = undefined;\n current.previous = undefined;\n current = current.next;\n }\n }\n // Help GC.\n tokenizer.events = [];\n // If there’s one more token (which is the cases for lines that end in an\n // EOF), that’s perfect: the last point we found starts it.\n // If there isn’t then make sure any remaining content is added to it.\n if (current) {\n // Help GC.\n current._tokenizer = undefined;\n current.previous = undefined;\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(!current.next, \"expected no next token\");\n } else {\n breaks.pop();\n }\n // Now splice the events from the subtokenizer into the current events,\n // moving back to front so that splice indices aren’t affected.\n index = breaks.length;\n while(index--){\n const slice = childEvents.slice(breaks[index], breaks[index + 1]);\n const start = startPositions.pop();\n (0,devlop__WEBPACK_IMPORTED_MODULE_1__.ok)(start !== undefined, \"expected a start position when splicing\");\n jumps.unshift([\n start,\n start + slice.length - 1\n ]);\n (0,micromark_util_chunked__WEBPACK_IMPORTED_MODULE_2__.splice)(events, start, 2, slice);\n }\n index = -1;\n while(++index < jumps.length){\n gaps[adjust + jumps[index][0]] = adjust + jumps[index][1];\n adjust += jumps[index][1] - jumps[index][0] - 1;\n }\n return gaps;\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/micromark-util-subtokenize/dev/index.js","mappings":";;;;;;;;AAAA;;;;CAIC,GAE4C;AACK;AACf;AAEnC;;;;;;;CAOC,GACD,sCAAsC;AAC/B,SAASK,YAAYC,MAAM;IAChC,mCAAmC,GACnC,MAAMC,QAAQ,CAAC;IACf,IAAIC,QAAQ,CAAC;IACb,kBAAkB,GAClB,IAAIC;IACJ,+BAA+B,GAC/B,IAAIC;IACJ,mBAAmB,GACnB,IAAIC;IACJ,kBAAkB,GAClB,IAAIC;IACJ,yBAAyB,GACzB,IAAIC;IACJ,yBAAyB,GACzB,IAAIC;IACJ,gCAAgC,GAChC,IAAIC;IAEJ,MAAO,EAAEP,QAAQF,OAAOU,MAAM,CAAE;QAC9B,MAAOR,SAASD,MAAO;YACrBC,QAAQD,KAAK,CAACC,MAAM;QACtB;QAEAC,QAAQH,MAAM,CAACE,MAAM;QAErB,yEAAyE;QACzE,0CAA0C;QAC1C,IACEA,SACAC,KAAK,CAAC,EAAE,CAACQ,IAAI,KAAKf,wDAAKA,CAACgB,SAAS,IACjCZ,MAAM,CAACE,QAAQ,EAAE,CAAC,EAAE,CAACS,IAAI,KAAKf,wDAAKA,CAACiB,cAAc,EAClD;YACAf,0CAAMA,CAACK,KAAK,CAAC,EAAE,CAACW,UAAU,EAAE;YAC5BN,YAAYL,KAAK,CAAC,EAAE,CAACW,UAAU,CAACd,MAAM;YACtCK,aAAa;YAEb,IACEA,aAAaG,UAAUE,MAAM,IAC7BF,SAAS,CAACH,WAAW,CAAC,EAAE,CAACM,IAAI,KAAKf,wDAAKA,CAACmB,eAAe,EACvD;gBACAV,cAAc;YAChB;YAEA,IACEA,aAAaG,UAAUE,MAAM,IAC7BF,SAAS,CAACH,WAAW,CAAC,EAAE,CAACM,IAAI,KAAKf,wDAAKA,CAACoB,OAAO,EAC/C;gBACA,MAAO,EAAEX,aAAaG,UAAUE,MAAM,CAAE;oBACtC,IAAIF,SAAS,CAACH,WAAW,CAAC,EAAE,CAACM,IAAI,KAAKf,wDAAKA,CAACoB,OAAO,EAAE;wBACnD;oBACF;oBAEA,IAAIR,SAAS,CAACH,WAAW,CAAC,EAAE,CAACM,IAAI,KAAKf,wDAAKA,CAACqB,SAAS,EAAE;wBACrDT,SAAS,CAACH,WAAW,CAAC,EAAE,CAACa,2BAA2B,GAAG;wBACvDb;oBACF;gBACF;YACF;QACF;QAEA,SAAS;QACT,IAAIF,KAAK,CAAC,EAAE,KAAK,SAAS;YACxB,IAAIA,KAAK,CAAC,EAAE,CAACgB,WAAW,EAAE;gBACxBC,OAAOC,MAAM,CAACpB,OAAOqB,WAAWtB,QAAQE;gBACxCA,QAAQD,KAAK,CAACC,MAAM;gBACpBO,OAAO;YACT;QACF,OAEK,IAAIN,KAAK,CAAC,EAAE,CAACoB,UAAU,EAAE;YAC5BlB,aAAaH;YACbE,YAAYoB;YAEZ,MAAOnB,aAAc;gBACnBC,aAAaN,MAAM,CAACK,WAAW;gBAE/B,IACEC,UAAU,CAAC,EAAE,CAACK,IAAI,KAAKf,wDAAKA,CAAC6B,UAAU,IACvCnB,UAAU,CAAC,EAAE,CAACK,IAAI,KAAKf,wDAAKA,CAACmB,eAAe,EAC5C;oBACA,IAAIT,UAAU,CAAC,EAAE,KAAK,SAAS;wBAC7B,IAAIF,WAAW;4BACbJ,MAAM,CAACI,UAAU,CAAC,EAAE,CAACO,IAAI,GAAGf,wDAAKA,CAACmB,eAAe;wBACnD;wBAEAT,UAAU,CAAC,EAAE,CAACK,IAAI,GAAGf,wDAAKA,CAAC6B,UAAU;wBACrCrB,YAAYC;oBACd;gBACF,OAAO;oBACL;gBACF;YACF;YAEA,IAAID,WAAW;gBACb,gBAAgB;gBAChBD,KAAK,CAAC,EAAE,CAACuB,GAAG,GAAGN,OAAOC,MAAM,CAAC,CAAC,GAAGrB,MAAM,CAACI,UAAU,CAAC,EAAE,CAACuB,KAAK;gBAE3D,yCAAyC;gBACzCpB,aAAaP,OAAO4B,KAAK,CAACxB,WAAWF;gBACrCK,WAAWsB,OAAO,CAAC1B;gBACnBT,8DAAMA,CAACM,QAAQI,WAAWF,QAAQE,YAAY,GAAGG;YACnD;QACF;IACF;IAEA,OAAO,CAACE;AACV;AAEA;;;;;;CAMC,GACD,SAASa,WAAWtB,MAAM,EAAE8B,UAAU;IACpC,MAAMC,QAAQ/B,MAAM,CAAC8B,WAAW,CAAC,EAAE;IACnC,MAAME,UAAUhC,MAAM,CAAC8B,WAAW,CAAC,EAAE;IACrC,IAAIG,gBAAgBH,aAAa;IACjC,0BAA0B,GAC1B,MAAMI,iBAAiB,EAAE;IACzBpC,0CAAMA,CAACiC,MAAMZ,WAAW,EAAE;IAC1B,MAAMgB,YACJJ,MAAMjB,UAAU,IAAIkB,QAAQI,MAAM,CAACL,MAAMZ,WAAW,CAAC,CAACY,MAAMJ,KAAK;IACnE,MAAMU,cAAcF,UAAUnC,MAAM;IACpC,oCAAoC,GACpC,MAAMC,QAAQ,EAAE;IAChB,mCAAmC,GACnC,MAAMqC,OAAO,CAAC;IACd,yBAAyB,GACzB,IAAIC;IACJ,8BAA8B,GAC9B,IAAIC;IACJ,IAAItC,QAAQ,CAAC;IACb,8BAA8B,GAC9B,IAAIuC,UAAUV;IACd,IAAIW,SAAS;IACb,IAAIf,QAAQ;IACZ,MAAMgB,SAAS;QAAChB;KAAM;IAEtB,sEAAsE;IACtE,gBAAgB;IAChB,MAAOc,QAAS;QACd,iDAAiD;QACjD,MAAOzC,MAAM,CAAC,EAAEiC,cAAc,CAAC,EAAE,KAAKQ,QAAS;QAC7C,SAAS;QACX;QAEA3C,0CAAMA,CACJ,CAAC0C,YAAYC,QAAQD,QAAQ,KAAKA,UAClC;QAEF1C,0CAAMA,CAAC,CAAC0C,YAAYA,SAASI,IAAI,KAAKH,SAAS;QAE/CP,eAAeW,IAAI,CAACZ;QAEpB,IAAI,CAACQ,QAAQ3B,UAAU,EAAE;YACvByB,SAASP,QAAQc,WAAW,CAACL;YAE7B,IAAI,CAACA,QAAQG,IAAI,EAAE;gBACjBL,OAAOM,IAAI,CAAClD,wDAAKA,CAACoD,GAAG;YACvB;YAEA,IAAIP,UAAU;gBACZL,UAAUa,UAAU,CAACP,QAAQd,KAAK;YACpC;YAEA,IAAIc,QAAQvB,2BAA2B,EAAE;gBACvCiB,UAAUc,kCAAkC,GAAG;YACjD;YAEAd,UAAUe,KAAK,CAACX;YAEhB,IAAIE,QAAQvB,2BAA2B,EAAE;gBACvCiB,UAAUc,kCAAkC,GAAGzB;YACjD;QACF;QAEA,0BAA0B;QAC1BgB,WAAWC;QACXA,UAAUA,QAAQG,IAAI;IACxB;IAEA,6EAA6E;IAC7E,sBAAsB;IACtBH,UAAUV;IAEV,MAAO,EAAE7B,QAAQmC,YAAY3B,MAAM,CAAE;QACnC,IACE,2CAA2C;QAC3C2B,WAAW,CAACnC,MAAM,CAAC,EAAE,KAAK,UAC1BmC,WAAW,CAACnC,QAAQ,EAAE,CAAC,EAAE,KAAK,WAC9BmC,WAAW,CAACnC,MAAM,CAAC,EAAE,CAACS,IAAI,KAAK0B,WAAW,CAACnC,QAAQ,EAAE,CAAC,EAAE,CAACS,IAAI,IAC7D0B,WAAW,CAACnC,MAAM,CAAC,EAAE,CAACyB,KAAK,CAACwB,IAAI,KAAKd,WAAW,CAACnC,MAAM,CAAC,EAAE,CAACwB,GAAG,CAACyB,IAAI,EACnE;YACArD,0CAAMA,CAAC2C,SAAS;YAChBd,QAAQzB,QAAQ;YAChByC,OAAOE,IAAI,CAAClB;YACZ,WAAW;YACXc,QAAQ3B,UAAU,GAAGU;YACrBiB,QAAQD,QAAQ,GAAGhB;YACnBiB,UAAUA,QAAQG,IAAI;QACxB;IACF;IAEA,WAAW;IACXT,UAAUnC,MAAM,GAAG,EAAE;IAErB,yEAAyE;IACzE,2DAA2D;IAC3D,sEAAsE;IACtE,IAAIyC,SAAS;QACX,WAAW;QACXA,QAAQ3B,UAAU,GAAGU;QACrBiB,QAAQD,QAAQ,GAAGhB;QACnB1B,0CAAMA,CAAC,CAAC2C,QAAQG,IAAI,EAAE;IACxB,OAAO;QACLD,OAAOS,GAAG;IACZ;IAEA,uEAAuE;IACvE,+DAA+D;IAC/DlD,QAAQyC,OAAOjC,MAAM;IAErB,MAAOR,QAAS;QACd,MAAM0B,QAAQS,YAAYT,KAAK,CAACe,MAAM,CAACzC,MAAM,EAAEyC,MAAM,CAACzC,QAAQ,EAAE;QAChE,MAAMyB,QAAQO,eAAekB,GAAG;QAChCtD,0CAAMA,CAAC6B,UAAUH,WAAW;QAC5BvB,MAAM4B,OAAO,CAAC;YAACF;YAAOA,QAAQC,MAAMlB,MAAM,GAAG;SAAE;QAC/ChB,8DAAMA,CAACM,QAAQ2B,OAAO,GAAGC;IAC3B;IAEA1B,QAAQ,CAAC;IAET,MAAO,EAAEA,QAAQD,MAAMS,MAAM,CAAE;QAC7B4B,IAAI,CAACI,SAASzC,KAAK,CAACC,MAAM,CAAC,EAAE,CAAC,GAAGwC,SAASzC,KAAK,CAACC,MAAM,CAAC,EAAE;QACzDwC,UAAUzC,KAAK,CAACC,MAAM,CAAC,EAAE,GAAGD,KAAK,CAACC,MAAM,CAAC,EAAE,GAAG;IAChD;IAEA,OAAOoC;AACT","sources":["webpack://flush-notes/./node_modules/micromark-util-subtokenize/dev/index.js?e1ca"],"sourcesContent":["/**\n * @typedef {import('micromark-util-types').Chunk} Chunk\n * @typedef {import('micromark-util-types').Event} Event\n * @typedef {import('micromark-util-types').Token} Token\n */\n\nimport {splice} from 'micromark-util-chunked'\nimport {codes, types} from 'micromark-util-symbol'\nimport {ok as assert} from 'devlop'\n\n/**\n * Tokenize subcontent.\n *\n * @param {Array<Event>} events\n *   List of events.\n * @returns {boolean}\n *   Whether subtokens were found.\n */\n// eslint-disable-next-line complexity\nexport function subtokenize(events) {\n  /** @type {Record<string, number>} */\n  const jumps = {}\n  let index = -1\n  /** @type {Event} */\n  let event\n  /** @type {number | undefined} */\n  let lineIndex\n  /** @type {number} */\n  let otherIndex\n  /** @type {Event} */\n  let otherEvent\n  /** @type {Array<Event>} */\n  let parameters\n  /** @type {Array<Event>} */\n  let subevents\n  /** @type {boolean | undefined} */\n  let more\n\n  while (++index < events.length) {\n    while (index in jumps) {\n      index = jumps[index]\n    }\n\n    event = events[index]\n\n    // Add a hook for the GFM tasklist extension, which needs to know if text\n    // is in the first content of a list item.\n    if (\n      index &&\n      event[1].type === types.chunkFlow &&\n      events[index - 1][1].type === types.listItemPrefix\n    ) {\n      assert(event[1]._tokenizer, 'expected `_tokenizer` on subtokens')\n      subevents = event[1]._tokenizer.events\n      otherIndex = 0\n\n      if (\n        otherIndex < subevents.length &&\n        subevents[otherIndex][1].type === types.lineEndingBlank\n      ) {\n        otherIndex += 2\n      }\n\n      if (\n        otherIndex < subevents.length &&\n        subevents[otherIndex][1].type === types.content\n      ) {\n        while (++otherIndex < subevents.length) {\n          if (subevents[otherIndex][1].type === types.content) {\n            break\n          }\n\n          if (subevents[otherIndex][1].type === types.chunkText) {\n            subevents[otherIndex][1]._isInFirstContentOfListItem = true\n            otherIndex++\n          }\n        }\n      }\n    }\n\n    // Enter.\n    if (event[0] === 'enter') {\n      if (event[1].contentType) {\n        Object.assign(jumps, subcontent(events, index))\n        index = jumps[index]\n        more = true\n      }\n    }\n    // Exit.\n    else if (event[1]._container) {\n      otherIndex = index\n      lineIndex = undefined\n\n      while (otherIndex--) {\n        otherEvent = events[otherIndex]\n\n        if (\n          otherEvent[1].type === types.lineEnding ||\n          otherEvent[1].type === types.lineEndingBlank\n        ) {\n          if (otherEvent[0] === 'enter') {\n            if (lineIndex) {\n              events[lineIndex][1].type = types.lineEndingBlank\n            }\n\n            otherEvent[1].type = types.lineEnding\n            lineIndex = otherIndex\n          }\n        } else {\n          break\n        }\n      }\n\n      if (lineIndex) {\n        // Fix position.\n        event[1].end = Object.assign({}, events[lineIndex][1].start)\n\n        // Switch container exit w/ line endings.\n        parameters = events.slice(lineIndex, index)\n        parameters.unshift(event)\n        splice(events, lineIndex, index - lineIndex + 1, parameters)\n      }\n    }\n  }\n\n  return !more\n}\n\n/**\n * Tokenize embedded tokens.\n *\n * @param {Array<Event>} events\n * @param {number} eventIndex\n * @returns {Record<string, number>}\n */\nfunction subcontent(events, eventIndex) {\n  const token = events[eventIndex][1]\n  const context = events[eventIndex][2]\n  let startPosition = eventIndex - 1\n  /** @type {Array<number>} */\n  const startPositions = []\n  assert(token.contentType, 'expected `contentType` on subtokens')\n  const tokenizer =\n    token._tokenizer || context.parser[token.contentType](token.start)\n  const childEvents = tokenizer.events\n  /** @type {Array<[number, number]>} */\n  const jumps = []\n  /** @type {Record<string, number>} */\n  const gaps = {}\n  /** @type {Array<Chunk>} */\n  let stream\n  /** @type {Token | undefined} */\n  let previous\n  let index = -1\n  /** @type {Token | undefined} */\n  let current = token\n  let adjust = 0\n  let start = 0\n  const breaks = [start]\n\n  // Loop forward through the linked tokens to pass them in order to the\n  // subtokenizer.\n  while (current) {\n    // Find the position of the event for this token.\n    while (events[++startPosition][1] !== current) {\n      // Empty.\n    }\n\n    assert(\n      !previous || current.previous === previous,\n      'expected previous to match'\n    )\n    assert(!previous || previous.next === current, 'expected next to match')\n\n    startPositions.push(startPosition)\n\n    if (!current._tokenizer) {\n      stream = context.sliceStream(current)\n\n      if (!current.next) {\n        stream.push(codes.eof)\n      }\n\n      if (previous) {\n        tokenizer.defineSkip(current.start)\n      }\n\n      if (current._isInFirstContentOfListItem) {\n        tokenizer._gfmTasklistFirstContentOfListItem = true\n      }\n\n      tokenizer.write(stream)\n\n      if (current._isInFirstContentOfListItem) {\n        tokenizer._gfmTasklistFirstContentOfListItem = undefined\n      }\n    }\n\n    // Unravel the next token.\n    previous = current\n    current = current.next\n  }\n\n  // Now, loop back through all events (and linked tokens), to figure out which\n  // parts belong where.\n  current = token\n\n  while (++index < childEvents.length) {\n    if (\n      // Find a void token that includes a break.\n      childEvents[index][0] === 'exit' &&\n      childEvents[index - 1][0] === 'enter' &&\n      childEvents[index][1].type === childEvents[index - 1][1].type &&\n      childEvents[index][1].start.line !== childEvents[index][1].end.line\n    ) {\n      assert(current, 'expected a current token')\n      start = index + 1\n      breaks.push(start)\n      // Help GC.\n      current._tokenizer = undefined\n      current.previous = undefined\n      current = current.next\n    }\n  }\n\n  // Help GC.\n  tokenizer.events = []\n\n  // If there’s one more token (which is the cases for lines that end in an\n  // EOF), that’s perfect: the last point we found starts it.\n  // If there isn’t then make sure any remaining content is added to it.\n  if (current) {\n    // Help GC.\n    current._tokenizer = undefined\n    current.previous = undefined\n    assert(!current.next, 'expected no next token')\n  } else {\n    breaks.pop()\n  }\n\n  // Now splice the events from the subtokenizer into the current events,\n  // moving back to front so that splice indices aren’t affected.\n  index = breaks.length\n\n  while (index--) {\n    const slice = childEvents.slice(breaks[index], breaks[index + 1])\n    const start = startPositions.pop()\n    assert(start !== undefined, 'expected a start position when splicing')\n    jumps.unshift([start, start + slice.length - 1])\n    splice(events, start, 2, slice)\n  }\n\n  index = -1\n\n  while (++index < jumps.length) {\n    gaps[adjust + jumps[index][0]] = adjust + jumps[index][1]\n    adjust += jumps[index][1] - jumps[index][0] - 1\n  }\n\n  return gaps\n}\n"],"names":["splice","codes","types","ok","assert","subtokenize","events","jumps","index","event","lineIndex","otherIndex","otherEvent","parameters","subevents","more","length","type","chunkFlow","listItemPrefix","_tokenizer","lineEndingBlank","content","chunkText","_isInFirstContentOfListItem","contentType","Object","assign","subcontent","_container","undefined","lineEnding","end","start","slice","unshift","eventIndex","token","context","startPosition","startPositions","tokenizer","parser","childEvents","gaps","stream","previous","current","adjust","breaks","next","push","sliceStream","eof","defineSkip","_gfmTasklistFirstContentOfListItem","write","line","pop"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/micromark-util-subtokenize/dev/index.js\n");
|
||
|
||
/***/ })
|
||
|
||
};
|
||
; |