You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

25 lines
30 KiB
JavaScript

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

"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/mdast-util-math";
exports.ids = ["vendor-chunks/mdast-util-math"];
exports.modules = {
/***/ "(ssr)/./node_modules/mdast-util-math/lib/index.js":
/*!***************************************************!*\
!*** ./node_modules/mdast-util-math/lib/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 */ mathFromMarkdown: () => (/* binding */ mathFromMarkdown),\n/* harmony export */ mathToMarkdown: () => (/* binding */ mathToMarkdown)\n/* harmony export */ });\n/* harmony import */ var longest_streak__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! longest-streak */ \"(ssr)/./node_modules/longest-streak/index.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_util_safe_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/safe.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/safe.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_util_track_js__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/track.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/track.js\");\n/* harmony import */ var mdast_util_to_markdown_lib_util_pattern_compile_js__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! mdast-util-to-markdown/lib/util/pattern-compile.js */ \"(ssr)/./node_modules/mdast-util-to-markdown/lib/util/pattern-compile.js\");\n/**\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('../index.js').Math} Math\n * @typedef {import('../index.js').InlineMath} InlineMath\n *\n * @typedef ToOptions\n * Configuration.\n * @property {boolean | null | undefined} [singleDollarTextMath=true]\n * Whether to support math (text) with a single dollar.\n *\n * Single dollars work in Pandoc and many other places, but often interfere\n * with “normal” dollars in text.\n * If you turn this off, you can still use two or more dollars for text math.\n */ \n\n\n\n/**\n * Create an extension for `mdast-util-from-markdown`.\n *\n * @returns {FromMarkdownExtension}\n * Extension for `mdast-util-from-markdown`.\n */ function mathFromMarkdown() {\n return {\n enter: {\n mathFlow: enterMathFlow,\n mathFlowFenceMeta: enterMathFlowMeta,\n mathText: enterMathText\n },\n exit: {\n mathFlow: exitMathFlow,\n mathFlowFence: exitMathFlowFence,\n mathFlowFenceMeta: exitMathFlowMeta,\n mathFlowValue: exitMathData,\n mathText: exitMathText,\n mathTextData: exitMathData\n }\n };\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterMathFlow(token) {\n this.enter({\n type: \"math\",\n meta: null,\n value: \"\",\n data: {\n hName: \"div\",\n hProperties: {\n className: [\n \"math\",\n \"math-display\"\n ]\n },\n hChildren: [\n {\n type: \"text\",\n value: \"\"\n }\n ]\n }\n }, token);\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterMathFlowMeta() {\n this.buffer();\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathFlowMeta() {\n const data = this.resume();\n const node = /** @type {Math} */ this.stack[this.stack.length - 1];\n node.meta = data;\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathFlowFence() {\n // Exit if this is the closing fence.\n if (this.getData(\"mathFlowInside\")) return;\n this.buffer();\n this.setData(\"mathFlowInside\", true);\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathFlow(token) {\n const data = this.resume().replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, \"\");\n const node = /** @type {Math} */ this.exit(token);\n node.value = data;\n // @ts-expect-error: we defined it.\n node.data.hChildren[0].value = data;\n this.setData(\"mathFlowInside\");\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function enterMathText(token) {\n this.enter({\n type: \"inlineMath\",\n value: \"\",\n data: {\n hName: \"span\",\n hProperties: {\n className: [\n \"math\",\n \"math-inline\"\n ]\n },\n hChildren: [\n {\n type: \"text\",\n value: \"\"\n }\n ]\n }\n }, token);\n this.buffer();\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathText(token) {\n const data = this.resume();\n const node = /** @type {Math} */ this.exit(token);\n node.value = data;\n // @ts-expect-error: we defined it.\n node.data.hChildren[0].value = data;\n }\n /**\n * @this {CompileContext}\n * @type {FromMarkdownHandle}\n */ function exitMathData(token) {\n this.config.enter.data.call(this, token);\n this.config.exit.data.call(this, token);\n }\n}\n/**\n * Create an extension for `mdast-util-to-markdown`.\n *\n * @param {ToOptions | null | undefined} [options]\n * Configuration.\n * @returns {ToMarkdownExtension}\n * Extension for `mdast-util-to-markdown`.\n */ function mathToMarkdown(options) {\n let single = (options || {}).singleDollarTextMath;\n if (single === null || single === undefined) {\n single = true;\n }\n inlineMath.peek = inlineMathPeek;\n return {\n unsafe: [\n {\n character: \"\\r\",\n inConstruct: \"mathFlowMeta\"\n },\n {\n character: \"\\n\",\n inConstruct: \"mathFlowMeta\"\n },\n {\n character: \"$\",\n after: single ? undefined : \"\\\\$\",\n inConstruct: \"phrasing\"\n },\n {\n character: \"$\",\n inConstruct: \"mathFlowMeta\"\n },\n {\n atBreak: true,\n character: \"$\",\n after: \"\\\\$\"\n }\n ],\n handlers: {\n math,\n inlineMath\n }\n };\n /**\n * @type {ToMarkdownHandle}\n * @param {Math} node\n */ // To do: next major: rename `context` to state, `safeOptions` to info.\n // Note: fixing this code? Please also fix the similar code for code:\n // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/code.js>\n function math(node, _, context, safeOptions) {\n const raw = node.value || \"\";\n const tracker = (0,mdast_util_to_markdown_lib_util_track_js__WEBPACK_IMPORTED_MODULE_0__.track)(safeOptions);\n const sequence = \"$\".repeat(Math.max((0,longest_streak__WEBPACK_IMPORTED_MODULE_1__.longestStreak)(raw, \"$\") + 1, 2));\n const exit = context.enter(\"mathFlow\");\n let value = tracker.move(sequence);\n if (node.meta) {\n const subexit = context.enter(\"mathFlowMeta\");\n value += tracker.move((0,mdast_util_to_markdown_lib_util_safe_js__WEBPACK_IMPORTED_MODULE_2__.safe)(context, node.meta, {\n before: value,\n after: \"\\n\",\n encode: [\n \"$\"\n ],\n ...tracker.current()\n }));\n subexit();\n }\n value += tracker.move(\"\\n\");\n if (raw) {\n value += tracker.move(raw + \"\\n\");\n }\n value += tracker.move(sequence);\n exit();\n return value;\n }\n /**\n * @type {ToMarkdownHandle}\n * @param {InlineMath} node\n */ // Note: fixing this code? Please also fix the similar code for inline code:\n // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/inline-code.js>\n //\n // To do: next major: rename `context` to state.\n // To do: next major: use `state` (`safe`, `track`, `patternCompile`).\n function inlineMath(node, _, context) {\n let value = node.value || \"\";\n let size = 1;\n if (!single) size++;\n // If there is a single dollar sign on its own in the math, use a fence of\n // two.\n // If there are two in a row, use one.\n while(new RegExp(\"(^|[^$])\" + \"\\\\$\".repeat(size) + \"([^$]|$)\").test(value)){\n size++;\n }\n const sequence = \"$\".repeat(size);\n // If this is not just spaces or eols (tabs dont count), and either the\n // first and last character are a space or eol, or the first or last\n // character are dollar signs, then pad with spaces.\n if (// Contains non-space.\n /[^ \\r\\n]/.test(value) && // Starts with space and ends with space.\n (/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value) || // Starts or ends with dollar.\n /^\\$|\\$$/.test(value))) {\n value = \" \" + value + \" \";\n }\n let index = -1;\n // We have a potential problem: certain characters after eols could result in\n // blocks being seen.\n // For example, if someone injected the string `'\\n# b'`, then that would\n // result in an ATX heading.\n // We cant escape characters in `inlineMath`, but because eols are\n // transformed to spaces when going from markdown to HTML anyway, we can swap\n // them out.\n while(++index < context.unsafe.length){\n const pattern = context.unsafe[index];\n const expression = (0,mdast_util_to_markdown_lib_util_pattern_compile_js__WEBPACK_IMPORTED_MODULE_3__.patternCompile)(pattern);\n /** @type {RegExpExecArray | null} */ let match;\n // Only look for `atBreak`s.\n // Btw: note that `atBreak` patterns will always start the regex at LF or\n // CR.\n if (!pattern.atBreak) continue;\n while(match = expression.exec(value)){\n let position = match.index;\n // Support CRLF (patterns only look for one of the characters).\n if (value.codePointAt(position) === 10 /* `\\n` */ && value.codePointAt(position - 1) === 13 /* `\\r` */ ) {\n position--;\n }\n value = value.slice(0, position) + \" \" + value.slice(match.index + 1);\n }\n }\n return sequence + value + sequence;\n }\n /**\n * @returns {string}\n */ function inlineMathPeek() {\n return \"$\";\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/mdast-util-math/lib/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/mdast-util-math/lib/index.js?0fa3"],"sourcesContent":["/**\n * @typedef {import('mdast-util-from-markdown').CompileContext} CompileContext\n * @typedef {import('mdast-util-from-markdown').Extension} FromMarkdownExtension\n * @typedef {import('mdast-util-from-markdown').Handle} FromMarkdownHandle\n * @typedef {import('mdast-util-to-markdown').Options} ToMarkdownExtension\n * @typedef {import('mdast-util-to-markdown').Handle} ToMarkdownHandle\n * @typedef {import('../index.js').Math} Math\n * @typedef {import('../index.js').InlineMath} InlineMath\n *\n * @typedef ToOptions\n *   Configuration.\n * @property {boolean | null | undefined} [singleDollarTextMath=true]\n *   Whether to support math (text) with a single dollar.\n *\n *   Single dollars work in Pandoc and many other places, but often interfere\n *   with “normal” dollars in text.\n *   If you turn this off, you can still use two or more dollars for text math.\n */\n\nimport {longestStreak} from 'longest-streak'\nimport {safe} from 'mdast-util-to-markdown/lib/util/safe.js'\nimport {track} from 'mdast-util-to-markdown/lib/util/track.js'\nimport {patternCompile} from 'mdast-util-to-markdown/lib/util/pattern-compile.js'\n\n/**\n * Create an extension for `mdast-util-from-markdown`.\n *\n * @returns {FromMarkdownExtension}\n *   Extension for `mdast-util-from-markdown`.\n */\nexport function mathFromMarkdown() {\n  return {\n    enter: {\n      mathFlow: enterMathFlow,\n      mathFlowFenceMeta: enterMathFlowMeta,\n      mathText: enterMathText\n    },\n    exit: {\n      mathFlow: exitMathFlow,\n      mathFlowFence: exitMathFlowFence,\n      mathFlowFenceMeta: exitMathFlowMeta,\n      mathFlowValue: exitMathData,\n      mathText: exitMathText,\n      mathTextData: exitMathData\n    }\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function enterMathFlow(token) {\n    this.enter(\n      {\n        type: 'math',\n        meta: null,\n        value: '',\n        data: {\n          hName: 'div',\n          hProperties: {className: ['math', 'math-display']},\n          hChildren: [{type: 'text', value: ''}]\n        }\n      },\n      token\n    )\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function enterMathFlowMeta() {\n    this.buffer()\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathFlowMeta() {\n    const data = this.resume()\n    const node = /** @type {Math} */ (this.stack[this.stack.length - 1])\n    node.meta = data\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathFlowFence() {\n    // Exit if this is the closing fence.\n    if (this.getData('mathFlowInside')) return\n    this.buffer()\n    this.setData('mathFlowInside', true)\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathFlow(token) {\n    const data = this.resume().replace(/^(\\r?\\n|\\r)|(\\r?\\n|\\r)$/g, '')\n    const node = /** @type {Math} */ (this.exit(token))\n    node.value = data\n    // @ts-expect-error: we defined it.\n    node.data.hChildren[0].value = data\n    this.setData('mathFlowInside')\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function enterMathText(token) {\n    this.enter(\n      {\n        type: 'inlineMath',\n        value: '',\n        data: {\n          hName: 'span',\n          hProperties: {className: ['math', 'math-inline']},\n          hChildren: [{type: 'text', value: ''}]\n        }\n      },\n      token\n    )\n    this.buffer()\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathText(token) {\n    const data = this.resume()\n    const node = /** @type {Math} */ (this.exit(token))\n    node.value = data\n    // @ts-expect-error: we defined it.\n    node.data.hChildren[0].value = data\n  }\n\n  /**\n   * @this {CompileContext}\n   * @type {FromMarkdownHandle}\n   */\n  function exitMathData(token) {\n    this.config.enter.data.call(this, token)\n    this.config.exit.data.call(this, token)\n  }\n}\n\n/**\n * Create an extension for `mdast-util-to-markdown`.\n *\n * @param {ToOptions | null | undefined} [options]\n *   Configuration.\n * @returns {ToMarkdownExtension}\n *   Extension for `mdast-util-to-markdown`.\n */\nexport function mathToMarkdown(options) {\n  let single = (options || {}).singleDollarTextMath\n\n  if (single === null || single === undefined) {\n    single = true\n  }\n\n  inlineMath.peek = inlineMathPeek\n\n  return {\n    unsafe: [\n      {character: '\\r', inConstruct: 'mathFlowMeta'},\n      {character: '\\n', inConstruct: 'mathFlowMeta'},\n      {\n        character: '$',\n        after: single ? undefined : '\\\\$',\n        inConstruct: 'phrasing'\n      },\n      {character: '$', inConstruct: 'mathFlowMeta'},\n      {atBreak: true, character: '$', after: '\\\\$'}\n    ],\n    handlers: {math, inlineMath}\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {Math} node\n   */\n  // To do: next major: rename `context` to state, `safeOptions` to info.\n  // Note: fixing this code? Please also fix the similar code for code:\n  // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/code.js>\n  function math(node, _, context, safeOptions) {\n    const raw = node.value || ''\n    const tracker = track(safeOptions)\n    const sequence = '$'.repeat(Math.max(longestStreak(raw, '$') + 1, 2))\n    const exit = context.enter('mathFlow')\n    let value = tracker.move(sequence)\n\n    if (node.meta) {\n      const subexit = context.enter('mathFlowMeta')\n      value += tracker.move(\n        safe(context, node.meta, {\n          before: value,\n          after: '\\n',\n          encode: ['$'],\n          ...tracker.current()\n        })\n      )\n      subexit()\n    }\n\n    value += tracker.move('\\n')\n\n    if (raw) {\n      value += tracker.move(raw + '\\n')\n    }\n\n    value += tracker.move(sequence)\n    exit()\n    return value\n  }\n\n  /**\n   * @type {ToMarkdownHandle}\n   * @param {InlineMath} node\n   */\n  // Note: fixing this code? Please also fix the similar code for inline code:\n  // <https://github.com/syntax-tree/mdast-util-to-markdown/blob/main/lib/handle/inline-code.js>\n  //\n  // To do: next major: rename `context` to state.\n  // To do: next major: use `state` (`safe`, `track`, `patternCompile`).\n  function inlineMath(node, _, context) {\n    let value = node.value || ''\n    let size = 1\n\n    if (!single) size++\n\n    // If there is a single dollar sign on its own in the math, use a fence of\n    // two.\n    // If there are two in a row, use one.\n    while (\n      new RegExp('(^|[^$])' + '\\\\$'.repeat(size) + '([^$]|$)').test(value)\n    ) {\n      size++\n    }\n\n    const sequence = '$'.repeat(size)\n\n    // If this is not just spaces or eols (tabs don’t count), and either the\n    // first and last character are a space or eol, or the first or last\n    // character are dollar signs, then pad with spaces.\n    if (\n      // Contains non-space.\n      /[^ \\r\\n]/.test(value) &&\n      // Starts with space and ends with space.\n      ((/^[ \\r\\n]/.test(value) && /[ \\r\\n]$/.test(value)) ||\n        // Starts or ends with dollar.\n        /^\\$|\\$$/.test(value))\n    ) {\n      value = ' ' + value + ' '\n    }\n\n    let index = -1\n\n    // We have a potential problem: certain characters after eols could result in\n    // blocks being seen.\n    // For example, if someone injected the string `'\\n# b'`, then that would\n    // result in an ATX heading.\n    // We can’t escape characters in `inlineMath`, but because eols are\n    // transformed to spaces when going from markdown to HTML anyway, we can swap\n    // them out.\n    while (++index < context.unsafe.length) {\n      const pattern = context.unsafe[index]\n      const expression = patternCompile(pattern)\n      /** @type {RegExpExecArray | null} */\n      let match\n\n      // Only look for `atBreak`s.\n      // Btw: note that `atBreak` patterns will always start the regex at LF or\n      // CR.\n      if (!pattern.atBreak) continue\n\n      while ((match = expression.exec(value))) {\n        let position = match.index\n\n        // Support CRLF (patterns only look for one of the characters).\n        if (\n          value.codePointAt(position) === 10 /* `\\n` */ &&\n          value.codePointAt(position - 1) === 13 /* `\\r` */\n        ) {\n          position--\n        }\n\n        value = value.slice(0, position) + ' ' + value.slice(match.index + 1)\n      }\n    }\n\n    return sequence + value + sequence\n  }\n\n  /**\n   * @returns {string}\n   */\n  function inlineMathPeek() {\n    return '$'\n  }\n}\n"],"names":["longestStreak","safe","track","patternCompile","mathFromMarkdown","enter","mathFlow","enterMathFlow","mathFlowFenceMeta","enterMathFlowMeta","mathText","enterMathText","exit","exitMathFlow","mathFlowFence","exitMathFlowFence","exitMathFlowMeta","mathFlowValue","exitMathData","exitMathText","mathTextData","token","type","meta","value","data","hName","hProperties","className","hChildren","buffer","resume","node","stack","length","getData","setData","replace","config","call","mathToMarkdown","options","single","singleDollarTextMath","undefined","inlineMath","peek","inlineMathPeek","unsafe","character","inConstruct","after","atBreak","handlers","math","_","context","safeOptions","raw","tracker","sequence","repeat","Math","max","move","subexit","before","encode","current","size","RegExp","test","index","pattern","expression","match","exec","position","codePointAt","slice"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/mdast-util-math/lib/index.js\n");
/***/ })
};
;