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
17 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/rehype-highlight";
exports.ids = ["vendor-chunks/rehype-highlight"];
exports.modules = {
/***/ "(ssr)/./node_modules/rehype-highlight/lib/index.js":
/*!****************************************************!*\
!*** ./node_modules/rehype-highlight/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 */ \"default\": () => (/* binding */ rehypeHighlight)\n/* harmony export */ });\n/* harmony import */ var lowlight__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! lowlight */ \"(ssr)/./node_modules/lowlight/index.js\");\n/* harmony import */ var hast_util_to_text__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! hast-util-to-text */ \"(ssr)/./node_modules/hast-util-to-text/lib/index.js\");\n/* harmony import */ var unist_util_visit__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! unist-util-visit */ \"(ssr)/./node_modules/unist-util-visit/lib/index.js\");\n/**\n * @typedef {import('lowlight').Root} LowlightRoot\n * @typedef {import('lowlight/lib/core.js').HighlightSyntax} HighlightSyntax\n * @typedef {import('hast').Root} Root\n * @typedef {import('hast').Element} Element\n * @typedef {Root|Root['children'][number]} Node\n *\n * @typedef Options\n * Configuration (optional).\n * @property {string} [prefix='hljs-']\n * Prefix to use before classes.\n * @property {boolean} [detect=false]\n * Whether to detect the programming language on code without a language\n * class.\n * @property {Array<string>} [subset]\n * Scope of languages to check when auto-detecting (default: all languages).\n * @property {boolean} [ignoreMissing=false]\n * Swallow errors for missing languages.\n * By default, unregistered syntaxes throw an error when they are used.\n * Pass `true` to swallow those errors and thus ignore code with unknown code\n * languages.\n * @property {Array<string>} [plainText=[]]\n * List of plain-text languages.\n * Pass any languages you would like to be kept as plain-text instead of\n * getting highlighted.\n * @property {Record<string, string|Array<string>>} [aliases={}]\n * Register more aliases.\n * Passed to `lowlight.registerAlias`.\n * @property {Record<string, HighlightSyntax>} [languages={}]\n * Register more languages.\n * Each key/value pair passed as arguments to `lowlight.registerLanguage`.\n */ \n\n\nconst own = {}.hasOwnProperty;\n/**\n * Plugin to highlight the syntax of code with lowlight (`highlight.js`).\n *\n * @type {import('unified').Plugin<[Options?] | Array<void>, Root>}\n */ function rehypeHighlight(options = {}) {\n const { aliases, languages, prefix, plainText, ignoreMissing, subset, detect } = options;\n let name = \"hljs\";\n if (aliases) {\n lowlight__WEBPACK_IMPORTED_MODULE_0__.lowlight.registerAlias(aliases);\n }\n if (languages) {\n /** @type {string} */ let key;\n for(key in languages){\n if (own.call(languages, key)) {\n lowlight__WEBPACK_IMPORTED_MODULE_0__.lowlight.registerLanguage(key, languages[key]);\n }\n }\n }\n if (prefix) {\n const pos = prefix.indexOf(\"-\");\n name = pos > -1 ? prefix.slice(0, pos) : prefix;\n }\n return (tree, file)=>{\n // eslint-disable-next-line complexity\n (0,unist_util_visit__WEBPACK_IMPORTED_MODULE_1__.visit)(tree, \"element\", (node, _, givenParent)=>{\n const parent = /** @type {Node?} */ givenParent;\n if (!parent || !(\"tagName\" in parent) || parent.tagName !== \"pre\" || node.tagName !== \"code\" || !node.properties) {\n return;\n }\n const lang = language(node);\n if (lang === false || !lang && !detect || lang && plainText && plainText.includes(lang)) {\n return;\n }\n if (!Array.isArray(node.properties.className)) {\n node.properties.className = [];\n }\n if (!node.properties.className.includes(name)) {\n node.properties.className.unshift(name);\n }\n /** @type {LowlightRoot} */ let result;\n try {\n result = lang ? lowlight__WEBPACK_IMPORTED_MODULE_0__.lowlight.highlight(lang, (0,hast_util_to_text__WEBPACK_IMPORTED_MODULE_2__.toText)(parent), {\n prefix\n }) : lowlight__WEBPACK_IMPORTED_MODULE_0__.lowlight.highlightAuto((0,hast_util_to_text__WEBPACK_IMPORTED_MODULE_2__.toText)(parent), {\n prefix,\n subset\n });\n } catch (error) {\n const exception = /** @type {Error} */ error;\n if (!ignoreMissing || !/Unknown language/.test(exception.message)) {\n file.fail(exception, node, \"rehype-highlight:missing-language\");\n }\n return;\n }\n if (!lang && result.data.language) {\n node.properties.className.push(\"language-\" + result.data.language);\n }\n if (Array.isArray(result.children) && result.children.length > 0) {\n node.children = result.children;\n }\n });\n };\n}\n/**\n * Get the programming language of `node`.\n *\n * @param {Element} node\n * @returns {false|string|undefined}\n */ function language(node) {\n const className = node.properties && node.properties.className;\n let index = -1;\n if (!Array.isArray(className)) {\n return;\n }\n while(++index < className.length){\n const value = String(className[index]);\n if (value === \"no-highlight\" || value === \"nohighlight\") {\n return false;\n }\n if (value.slice(0, 5) === \"lang-\") {\n return value.slice(5);\n }\n if (value.slice(0, 9) === \"language-\") {\n return value.slice(9);\n }\n }\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/rehype-highlight/lib/index.js","mappings":";;;;;;;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA+BC,GAEgC;AACO;AACF;AAEtC,MAAMG,MAAM,CAAC,EAAEC,cAAc;AAE7B;;;;CAIC,GACc,SAASC,gBAAgBC,UAAU,CAAC,CAAC;IAClD,MAAM,EAACC,OAAO,EAAEC,SAAS,EAAEC,MAAM,EAAEC,SAAS,EAAEC,aAAa,EAAEC,MAAM,EAAEC,MAAM,EAAC,GAC1EP;IACF,IAAIQ,OAAO;IAEX,IAAIP,SAAS;QACXP,8CAAQA,CAACe,aAAa,CAACR;IACzB;IAEA,IAAIC,WAAW;QACb,mBAAmB,GACnB,IAAIQ;QAEJ,IAAKA,OAAOR,UAAW;YACrB,IAAIL,IAAIc,IAAI,CAACT,WAAWQ,MAAM;gBAC5BhB,8CAAQA,CAACkB,gBAAgB,CAACF,KAAKR,SAAS,CAACQ,IAAI;YAC/C;QACF;IACF;IAEA,IAAIP,QAAQ;QACV,MAAMU,MAAMV,OAAOW,OAAO,CAAC;QAC3BN,OAAOK,MAAM,CAAC,IAAIV,OAAOY,KAAK,CAAC,GAAGF,OAAOV;IAC3C;IAEA,OAAO,CAACa,MAAMC;QACZ,sCAAsC;QACtCrB,uDAAKA,CAACoB,MAAM,WAAW,CAACE,MAAMC,GAAGC;YAC/B,MAAMC,SAAS,kBAAkB,GAAID;YAErC,IACE,CAACC,UACD,CAAE,cAAaA,MAAK,KACpBA,OAAOC,OAAO,KAAK,SACnBJ,KAAKI,OAAO,KAAK,UACjB,CAACJ,KAAKK,UAAU,EAChB;gBACA;YACF;YAEA,MAAMC,OAAOC,SAASP;YAEtB,IACEM,SAAS,SACR,CAACA,QAAQ,CAACjB,UACViB,QAAQpB,aAAaA,UAAUsB,QAAQ,CAACF,OACzC;gBACA;YACF;YAEA,IAAI,CAACG,MAAMC,OAAO,CAACV,KAAKK,UAAU,CAACM,SAAS,GAAG;gBAC7CX,KAAKK,UAAU,CAACM,SAAS,GAAG,EAAE;YAChC;YAEA,IAAI,CAACX,KAAKK,UAAU,CAACM,SAAS,CAACH,QAAQ,CAAClB,OAAO;gBAC7CU,KAAKK,UAAU,CAACM,SAAS,CAACC,OAAO,CAACtB;YACpC;YAEA,yBAAyB,GACzB,IAAIuB;YAEJ,IAAI;gBACFA,SAASP,OACL9B,8CAAQA,CAACsC,SAAS,CAACR,MAAM7B,yDAAMA,CAAC0B,SAAS;oBAAClB;gBAAM,KAChDT,8CAAQA,CAACuC,aAAa,CAACtC,yDAAMA,CAAC0B,SAAS;oBAAClB;oBAAQG;gBAAM;YAC5D,EAAE,OAAO4B,OAAO;gBACd,MAAMC,YAAY,kBAAkB,GAAID;gBACxC,IAAI,CAAC7B,iBAAiB,CAAC,mBAAmB+B,IAAI,CAACD,UAAUE,OAAO,GAAG;oBACjEpB,KAAKqB,IAAI,CAACH,WAAWjB,MAAM;gBAC7B;gBAEA;YACF;YAEA,IAAI,CAACM,QAAQO,OAAOQ,IAAI,CAACd,QAAQ,EAAE;gBACjCP,KAAKK,UAAU,CAACM,SAAS,CAACW,IAAI,CAAC,cAAcT,OAAOQ,IAAI,CAACd,QAAQ;YACnE;YAEA,IAAIE,MAAMC,OAAO,CAACG,OAAOU,QAAQ,KAAKV,OAAOU,QAAQ,CAACC,MAAM,GAAG,GAAG;gBAChExB,KAAKuB,QAAQ,GAAGV,OAAOU,QAAQ;YACjC;QACF;IACF;AACF;AAEA;;;;;CAKC,GACD,SAAShB,SAASP,IAAI;IACpB,MAAMW,YAAYX,KAAKK,UAAU,IAAIL,KAAKK,UAAU,CAACM,SAAS;IAC9D,IAAIc,QAAQ,CAAC;IAEb,IAAI,CAAChB,MAAMC,OAAO,CAACC,YAAY;QAC7B;IACF;IAEA,MAAO,EAAEc,QAAQd,UAAUa,MAAM,CAAE;QACjC,MAAME,QAAQC,OAAOhB,SAAS,CAACc,MAAM;QAErC,IAAIC,UAAU,kBAAkBA,UAAU,eAAe;YACvD,OAAO;QACT;QAEA,IAAIA,MAAM7B,KAAK,CAAC,GAAG,OAAO,SAAS;YACjC,OAAO6B,MAAM7B,KAAK,CAAC;QACrB;QAEA,IAAI6B,MAAM7B,KAAK,CAAC,GAAG,OAAO,aAAa;YACrC,OAAO6B,MAAM7B,KAAK,CAAC;QACrB;IACF;AACF","sources":["webpack://nextchat/./node_modules/rehype-highlight/lib/index.js?fb3a"],"sourcesContent":["/**\n * @typedef {import('lowlight').Root} LowlightRoot\n * @typedef {import('lowlight/lib/core.js').HighlightSyntax} HighlightSyntax\n * @typedef {import('hast').Root} Root\n * @typedef {import('hast').Element} Element\n * @typedef {Root|Root['children'][number]} Node\n *\n * @typedef Options\n *   Configuration (optional).\n * @property {string} [prefix='hljs-']\n *   Prefix to use before classes.\n * @property {boolean} [detect=false]\n *   Whether to detect the programming language on code without a language\n *   class.\n * @property {Array<string>} [subset]\n *   Scope of languages to check when auto-detecting (default: all languages).\n * @property {boolean} [ignoreMissing=false]\n *   Swallow errors for missing languages.\n *   By default, unregistered syntaxes throw an error when they are used.\n *   Pass `true` to swallow those errors and thus ignore code with unknown code\n *   languages.\n * @property {Array<string>} [plainText=[]]\n *   List of plain-text languages.\n *   Pass any languages you would like to be kept as plain-text instead of\n *   getting highlighted.\n * @property {Record<string, string|Array<string>>} [aliases={}]\n *   Register more aliases.\n *   Passed to `lowlight.registerAlias`.\n * @property {Record<string, HighlightSyntax>} [languages={}]\n *   Register more languages.\n *   Each key/value pair passed as arguments to `lowlight.registerLanguage`.\n */\n\nimport {lowlight} from 'lowlight'\nimport {toText} from 'hast-util-to-text'\nimport {visit} from 'unist-util-visit'\n\nconst own = {}.hasOwnProperty\n\n/**\n * Plugin to highlight the syntax of code with lowlight (`highlight.js`).\n *\n * @type {import('unified').Plugin<[Options?] | Array<void>, Root>}\n */\nexport default function rehypeHighlight(options = {}) {\n  const {aliases, languages, prefix, plainText, ignoreMissing, subset, detect} =\n    options\n  let name = 'hljs'\n\n  if (aliases) {\n    lowlight.registerAlias(aliases)\n  }\n\n  if (languages) {\n    /** @type {string} */\n    let key\n\n    for (key in languages) {\n      if (own.call(languages, key)) {\n        lowlight.registerLanguage(key, languages[key])\n      }\n    }\n  }\n\n  if (prefix) {\n    const pos = prefix.indexOf('-')\n    name = pos > -1 ? prefix.slice(0, pos) : prefix\n  }\n\n  return (tree, file) => {\n    // eslint-disable-next-line complexity\n    visit(tree, 'element', (node, _, givenParent) => {\n      const parent = /** @type {Node?} */ (givenParent)\n\n      if (\n        !parent ||\n        !('tagName' in parent) ||\n        parent.tagName !== 'pre' ||\n        node.tagName !== 'code' ||\n        !node.properties\n      ) {\n        return\n      }\n\n      const lang = language(node)\n\n      if (\n        lang === false ||\n        (!lang && !detect) ||\n        (lang && plainText && plainText.includes(lang))\n      ) {\n        return\n      }\n\n      if (!Array.isArray(node.properties.className)) {\n        node.properties.className = []\n      }\n\n      if (!node.properties.className.includes(name)) {\n        node.properties.className.unshift(name)\n      }\n\n      /** @type {LowlightRoot} */\n      let result\n\n      try {\n        result = lang\n          ? lowlight.highlight(lang, toText(parent), {prefix})\n          : lowlight.highlightAuto(toText(parent), {prefix, subset})\n      } catch (error) {\n        const exception = /** @type {Error} */ (error)\n        if (!ignoreMissing || !/Unknown language/.test(exception.message)) {\n          file.fail(exception, node, 'rehype-highlight:missing-language')\n        }\n\n        return\n      }\n\n      if (!lang && result.data.language) {\n        node.properties.className.push('language-' + result.data.language)\n      }\n\n      if (Array.isArray(result.children) && result.children.length > 0) {\n        node.children = result.children\n      }\n    })\n  }\n}\n\n/**\n * Get the programming language of `node`.\n *\n * @param {Element} node\n * @returns {false|string|undefined}\n */\nfunction language(node) {\n  const className = node.properties && node.properties.className\n  let index = -1\n\n  if (!Array.isArray(className)) {\n    return\n  }\n\n  while (++index < className.length) {\n    const value = String(className[index])\n\n    if (value === 'no-highlight' || value === 'nohighlight') {\n      return false\n    }\n\n    if (value.slice(0, 5) === 'lang-') {\n      return value.slice(5)\n    }\n\n    if (value.slice(0, 9) === 'language-') {\n      return value.slice(9)\n    }\n  }\n}\n"],"names":["lowlight","toText","visit","own","hasOwnProperty","rehypeHighlight","options","aliases","languages","prefix","plainText","ignoreMissing","subset","detect","name","registerAlias","key","call","registerLanguage","pos","indexOf","slice","tree","file","node","_","givenParent","parent","tagName","properties","lang","language","includes","Array","isArray","className","unshift","result","highlight","highlightAuto","error","exception","test","message","fail","data","push","children","length","index","value","String"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/rehype-highlight/lib/index.js\n");
/***/ })
};
;