1240 lines
54 KiB
JavaScript
1240 lines
54 KiB
JavaScript
import {
|
|
__publicField
|
|
} from "./chunk-JVWSFFO4.js";
|
|
|
|
// node_modules/marked/lib/marked.esm.js
|
|
function M() {
|
|
return { async: false, breaks: false, extensions: null, gfm: true, hooks: null, pedantic: false, renderer: null, silent: false, tokenizer: null, walkTokens: null };
|
|
}
|
|
var T = M();
|
|
function H(u3) {
|
|
T = u3;
|
|
}
|
|
var _ = { exec: () => null };
|
|
function k(u3, e = "") {
|
|
let t = typeof u3 == "string" ? u3 : u3.source, n = { replace: (r, i) => {
|
|
let s = typeof i == "string" ? i : i.source;
|
|
return s = s.replace(m.caret, "$1"), t = t.replace(r, s), n;
|
|
}, getRegex: () => new RegExp(t, e) };
|
|
return n;
|
|
}
|
|
var Re = (() => {
|
|
try {
|
|
return !!new RegExp("(?<=1)(?<!1)");
|
|
} catch {
|
|
return false;
|
|
}
|
|
})();
|
|
var m = { codeRemoveIndent: /^(?: {1,4}| {0,3}\t)/gm, outputLinkReplace: /\\([\[\]])/g, indentCodeCompensation: /^(\s+)(?:```)/, beginningSpace: /^\s+/, endingHash: /#$/, startingSpaceChar: /^ /, endingSpaceChar: / $/, nonSpaceChar: /[^ ]/, newLineCharGlobal: /\n/g, tabCharGlobal: /\t/g, multipleSpaceGlobal: /\s+/g, blankLine: /^[ \t]*$/, doubleBlankLine: /\n[ \t]*\n[ \t]*$/, blockquoteStart: /^ {0,3}>/, blockquoteSetextReplace: /\n {0,3}((?:=+|-+) *)(?=\n|$)/g, blockquoteSetextReplace2: /^ {0,3}>[ \t]?/gm, listReplaceNesting: /^ {1,4}(?=( {4})*[^ ])/g, listIsTask: /^\[[ xX]\] +\S/, listReplaceTask: /^\[[ xX]\] +/, listTaskCheckbox: /\[[ xX]\]/, anyLine: /\n.*\n/, hrefBrackets: /^<(.*)>$/, tableDelimiter: /[:|]/, tableAlignChars: /^\||\| *$/g, tableRowBlankLine: /\n[ \t]*$/, tableAlignRight: /^ *-+: *$/, tableAlignCenter: /^ *:-+: *$/, tableAlignLeft: /^ *:-+ *$/, startATag: /^<a /i, endATag: /^<\/a>/i, startPreScriptTag: /^<(pre|code|kbd|script)(\s|>)/i, endPreScriptTag: /^<\/(pre|code|kbd|script)(\s|>)/i, startAngleBracket: /^</, endAngleBracket: />$/, pedanticHrefTitle: /^([^'"]*[^\s])\s+(['"])(.*)\2/, unicodeAlphaNumeric: /[\p{L}\p{N}]/u, escapeTest: /[&<>"']/, escapeReplace: /[&<>"']/g, escapeTestNoEncode: /[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/, escapeReplaceNoEncode: /[<>"']|&(?!(#\d{1,7}|#[Xx][a-fA-F0-9]{1,6}|\w+);)/g, unescapeTest: /&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/ig, caret: /(^|[^\[])\^/g, percentDecode: /%25/g, findPipe: /\|/g, splitPipe: / \|/, slashPipe: /\\\|/g, carriageReturn: /\r\n|\r/g, spaceLine: /^ +$/gm, notSpaceStart: /^\S*/, endingNewline: /\n$/, listItemRegex: (u3) => new RegExp(`^( {0,3}${u3})((?:[ ][^\\n]*)?(?:\\n|$))`), nextBulletRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}(?:[*+-]|\\d{1,9}[.)])((?:[ ][^\\n]*)?(?:\\n|$))`), hrRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}((?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$)`), fencesBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}(?:\`\`\`|~~~)`), headingBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}#`), htmlBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}<(?:[a-z].*>|!--)`, "i"), blockquoteBeginRegex: (u3) => new RegExp(`^ {0,${Math.min(3, u3 - 1)}}>`) };
|
|
var Te = /^(?:[ \t]*(?:\n|$))+/;
|
|
var Oe = /^((?: {4}| {0,3}\t)[^\n]+(?:\n(?:[ \t]*(?:\n|$))*)?)+/;
|
|
var we = /^ {0,3}(`{3,}(?=[^`\n]*(?:\n|$))|~{3,})([^\n]*)(?:\n|$)(?:|([\s\S]*?)(?:\n|$))(?: {0,3}\1[~`]* *(?=\n|$)|$)/;
|
|
var I = /^ {0,3}((?:-[\t ]*){3,}|(?:_[ \t]*){3,}|(?:\*[ \t]*){3,})(?:\n+|$)/;
|
|
var ye = /^ {0,3}(#{1,6})(?=\s|$)(.*)(?:\n+|$)/;
|
|
var N = / {0,3}(?:[*+-]|\d{1,9}[.)])/;
|
|
var re = /^(?!bull |blockCode|fences|blockquote|heading|html|table)((?:.|\n(?!\s*?\n|bull |blockCode|fences|blockquote|heading|html|table))+?)\n {0,3}(=+|-+) *(?:\n+|$)/;
|
|
var se = k(re).replace(/bull/g, N).replace(/blockCode/g, /(?: {4}| {0,3}\t)/).replace(/fences/g, / {0,3}(?:`{3,}|~{3,})/).replace(/blockquote/g, / {0,3}>/).replace(/heading/g, / {0,3}#{1,6}/).replace(/html/g, / {0,3}<[^\n>]+>\n/).replace(/\|table/g, "").getRegex();
|
|
var Pe = k(re).replace(/bull/g, N).replace(/blockCode/g, /(?: {4}| {0,3}\t)/).replace(/fences/g, / {0,3}(?:`{3,}|~{3,})/).replace(/blockquote/g, / {0,3}>/).replace(/heading/g, / {0,3}#{1,6}/).replace(/html/g, / {0,3}<[^\n>]+>\n/).replace(/table/g, / {0,3}\|?(?:[:\- ]*\|)+[\:\- ]*\n/).getRegex();
|
|
var Q = /^([^\n]+(?:\n(?!hr|heading|lheading|blockquote|fences|list|html|table| +\n)[^\n]+)*)/;
|
|
var Se = /^[^\n]+/;
|
|
var F = /(?!\s*\])(?:\\[\s\S]|[^\[\]\\])+/;
|
|
var $e = k(/^ {0,3}\[(label)\]: *(?:\n[ \t]*)?([^<\s][^\s]*|<.*?>)(?:(?: +(?:\n[ \t]*)?| *\n[ \t]*)(title))? *(?:\n+|$)/).replace("label", F).replace("title", /(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/).getRegex();
|
|
var _e = k(/^(bull)([ \t][^\n]+?)?(?:\n|$)/).replace(/bull/g, N).getRegex();
|
|
var q = "address|article|aside|base|basefont|blockquote|body|caption|center|col|colgroup|dd|details|dialog|dir|div|dl|dt|fieldset|figcaption|figure|footer|form|frame|frameset|h[1-6]|head|header|hr|html|iframe|legend|li|link|main|menu|menuitem|meta|nav|noframes|ol|optgroup|option|p|param|search|section|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul";
|
|
var j = /<!--(?:-?>|[\s\S]*?(?:-->|$))/;
|
|
var Le = k("^ {0,3}(?:<(script|pre|style|textarea)[\\s>][\\s\\S]*?(?:</\\1>[^\\n]*\\n+|$)|comment[^\\n]*(\\n+|$)|<\\?[\\s\\S]*?(?:\\?>\\n*|$)|<![A-Z][\\s\\S]*?(?:>\\n*|$)|<!\\[CDATA\\[[\\s\\S]*?(?:\\]\\]>\\n*|$)|</?(tag)(?: +|\\n|/?>)[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$)|<(?!script|pre|style|textarea)([a-z][\\w-]*)(?:attribute)*? */?>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$)|</(?!script|pre|style|textarea)[a-z][\\w-]*\\s*>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ ]*)+\\n|$))", "i").replace("comment", j).replace("tag", q).replace("attribute", / +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex();
|
|
var ie = k(Q).replace("hr", I).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("|lheading", "").replace("|table", "").replace("blockquote", " {0,3}>").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)])[ \\t]").replace("html", "</?(?:tag)(?: +|\\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag", q).getRegex();
|
|
var Me = k(/^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/).replace("paragraph", ie).getRegex();
|
|
var U = { blockquote: Me, code: Oe, def: $e, fences: we, heading: ye, hr: I, html: Le, lheading: se, list: _e, newline: Te, paragraph: ie, table: _, text: Se };
|
|
var te = k("^ *([^\\n ].*)\\n {0,3}((?:\\| *)?:?-+:? *(?:\\| *:?-+:? *)*(?:\\| *)?)(?:\\n((?:(?! *\\n|hr|heading|blockquote|code|fences|list|html).*(?:\\n|$))*)\\n*|$)").replace("hr", I).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("blockquote", " {0,3}>").replace("code", "(?: {4}| {0,3} )[^\\n]").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)])[ \\t]").replace("html", "</?(?:tag)(?: +|\\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag", q).getRegex();
|
|
var ze = { ...U, lheading: Pe, table: te, paragraph: k(Q).replace("hr", I).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("|lheading", "").replace("table", te).replace("blockquote", " {0,3}>").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)])[ \\t]").replace("html", "</?(?:tag)(?: +|\\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag", q).getRegex() };
|
|
var Ce = { ...U, html: k(`^ *(?:comment *(?:\\n|\\s*$)|<(tag)[\\s\\S]+?</\\1> *(?:\\n{2,}|\\s*$)|<tag(?:"[^"]*"|'[^']*'|\\s[^'"/>\\s]*)*?/?> *(?:\\n{2,}|\\s*$))`).replace("comment", j).replace(/tag/g, "(?!(?:a|em|strong|small|s|cite|q|dfn|abbr|data|time|code|var|samp|kbd|sub|sup|i|b|u|mark|ruby|rt|rp|bdi|bdo|span|br|wbr|ins|del|img)\\b)\\w+(?!:|[^\\w\\s@]*@)\\b").getRegex(), def: /^ *\[([^\]]+)\]: *<?([^\s>]+)>?(?: +(["(][^\n]+[")]))? *(?:\n+|$)/, heading: /^(#{1,6})(.*)(?:\n+|$)/, fences: _, lheading: /^(.+?)\n {0,3}(=+|-+) *(?:\n+|$)/, paragraph: k(Q).replace("hr", I).replace("heading", ` *#{1,6} *[^
|
|
]`).replace("lheading", se).replace("|table", "").replace("blockquote", " {0,3}>").replace("|fences", "").replace("|list", "").replace("|html", "").replace("|tag", "").getRegex() };
|
|
var Ae = /^\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/;
|
|
var Ie = /^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/;
|
|
var oe = /^( {2,}|\\)\n(?!\s*$)/;
|
|
var Ee = /^(`+|[^`])(?:(?= {2,}\n)|[\s\S]*?(?:(?=[\\<!\[`*_]|\b_|$)|[^ ](?= {2,}\n)))/;
|
|
var v = /[\p{P}\p{S}]/u;
|
|
var K = /[\s\p{P}\p{S}]/u;
|
|
var ae = /[^\s\p{P}\p{S}]/u;
|
|
var Be = k(/^((?![*_])punctSpace)/, "u").replace(/punctSpace/g, K).getRegex();
|
|
var le = /(?!~)[\p{P}\p{S}]/u;
|
|
var De = /(?!~)[\s\p{P}\p{S}]/u;
|
|
var qe = /(?:[^\s\p{P}\p{S}]|~)/u;
|
|
var ue = /(?![*_])[\p{P}\p{S}]/u;
|
|
var ve = /(?![*_])[\s\p{P}\p{S}]/u;
|
|
var Ge = /(?:[^\s\p{P}\p{S}]|[*_])/u;
|
|
var He = k(/link|precode-code|html/, "g").replace("link", /\[(?:[^\[\]`]|(?<a>`+)[^`]+\k<a>(?!`))*?\]\((?:\\[\s\S]|[^\\\(\)]|\((?:\\[\s\S]|[^\\\(\)])*\))*\)/).replace("precode-", Re ? "(?<!`)()" : "(^^|[^`])").replace("code", /(?<b>`+)[^`]+\k<b>(?!`)/).replace("html", /<(?! )[^<>]*?>/).getRegex();
|
|
var pe = /^(?:\*+(?:((?!\*)punct)|[^\s*]))|^_+(?:((?!_)punct)|([^\s_]))/;
|
|
var Ze = k(pe, "u").replace(/punct/g, v).getRegex();
|
|
var Ne = k(pe, "u").replace(/punct/g, le).getRegex();
|
|
var ce = "^[^_*]*?__[^_*]*?\\*[^_*]*?(?=__)|[^*]+(?=[^*])|(?!\\*)punct(\\*+)(?=[\\s]|$)|notPunctSpace(\\*+)(?!\\*)(?=punctSpace|$)|(?!\\*)punctSpace(\\*+)(?=notPunctSpace)|[\\s](\\*+)(?!\\*)(?=punct)|(?!\\*)punct(\\*+)(?!\\*)(?=punct)|notPunctSpace(\\*+)(?=notPunctSpace)";
|
|
var Qe = k(ce, "gu").replace(/notPunctSpace/g, ae).replace(/punctSpace/g, K).replace(/punct/g, v).getRegex();
|
|
var Fe = k(ce, "gu").replace(/notPunctSpace/g, qe).replace(/punctSpace/g, De).replace(/punct/g, le).getRegex();
|
|
var je = k("^[^_*]*?\\*\\*[^_*]*?_[^_*]*?(?=\\*\\*)|[^_]+(?=[^_])|(?!_)punct(_+)(?=[\\s]|$)|notPunctSpace(_+)(?!_)(?=punctSpace|$)|(?!_)punctSpace(_+)(?=notPunctSpace)|[\\s](_+)(?!_)(?=punct)|(?!_)punct(_+)(?!_)(?=punct)", "gu").replace(/notPunctSpace/g, ae).replace(/punctSpace/g, K).replace(/punct/g, v).getRegex();
|
|
var Ue = k(/^~~?(?:((?!~)punct)|[^\s~])/, "u").replace(/punct/g, ue).getRegex();
|
|
var Ke = "^[^~]+(?=[^~])|(?!~)punct(~~?)(?=[\\s]|$)|notPunctSpace(~~?)(?!~)(?=punctSpace|$)|(?!~)punctSpace(~~?)(?=notPunctSpace)|[\\s](~~?)(?!~)(?=punct)|(?!~)punct(~~?)(?!~)(?=punct)|notPunctSpace(~~?)(?=notPunctSpace)";
|
|
var We = k(Ke, "gu").replace(/notPunctSpace/g, Ge).replace(/punctSpace/g, ve).replace(/punct/g, ue).getRegex();
|
|
var Xe = k(/\\(punct)/, "gu").replace(/punct/g, v).getRegex();
|
|
var Je = k(/^<(scheme:[^\s\x00-\x1f<>]*|email)>/).replace("scheme", /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/).replace("email", /[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+(@)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)+(?![-_])/).getRegex();
|
|
var Ve = k(j).replace("(?:-->|$)", "-->").getRegex();
|
|
var Ye = k("^comment|^</[a-zA-Z][\\w:-]*\\s*>|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^<![a-zA-Z]+\\s[\\s\\S]*?>|^<!\\[CDATA\\[[\\s\\S]*?\\]\\]>").replace("comment", Ve).replace("attribute", /\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/).getRegex();
|
|
var D = /(?:\[(?:\\[\s\S]|[^\[\]\\])*\]|\\[\s\S]|`+[^`]*?`+(?!`)|[^\[\]\\`])*?/;
|
|
var et = k(/^!?\[(label)\]\(\s*(href)(?:(?:[ \t]*(?:\n[ \t]*)?)(title))?\s*\)/).replace("label", D).replace("href", /<(?:\\.|[^\n<>\\])+>|[^ \t\n\x00-\x1f]*/).replace("title", /"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/).getRegex();
|
|
var he = k(/^!?\[(label)\]\[(ref)\]/).replace("label", D).replace("ref", F).getRegex();
|
|
var ke = k(/^!?\[(ref)\](?:\[\])?/).replace("ref", F).getRegex();
|
|
var tt = k("reflink|nolink(?!\\()", "g").replace("reflink", he).replace("nolink", ke).getRegex();
|
|
var ne = /[hH][tT][tT][pP][sS]?|[fF][tT][pP]/;
|
|
var W = { _backpedal: _, anyPunctuation: Xe, autolink: Je, blockSkip: He, br: oe, code: Ie, del: _, delLDelim: _, delRDelim: _, emStrongLDelim: Ze, emStrongRDelimAst: Qe, emStrongRDelimUnd: je, escape: Ae, link: et, nolink: ke, punctuation: Be, reflink: he, reflinkSearch: tt, tag: Ye, text: Ee, url: _ };
|
|
var nt = { ...W, link: k(/^!?\[(label)\]\((.*?)\)/).replace("label", D).getRegex(), reflink: k(/^!?\[(label)\]\s*\[([^\]]*)\]/).replace("label", D).getRegex() };
|
|
var Z = { ...W, emStrongRDelimAst: Fe, emStrongLDelim: Ne, delLDelim: Ue, delRDelim: We, url: k(/^((?:protocol):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/).replace("protocol", ne).replace("email", /[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/).getRegex(), _backpedal: /(?:[^?!.,:;*_'"~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_'"~)]+(?!$))+/, del: /^(~~?)(?=[^\s~])((?:\\[\s\S]|[^\\])*?(?:\\[\s\S]|[^\s~\\]))\1(?=[^~]|$)/, text: k(/^([`~]+|[^`~])(?:(?= {2,}\n)|(?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)|[\s\S]*?(?:(?=[\\<!\[`*~_]|\b_|protocol:\/\/|www\.|$)|[^ ](?= {2,}\n)|[^a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-](?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)))/).replace("protocol", ne).getRegex() };
|
|
var rt = { ...Z, br: k(oe).replace("{2,}", "*").getRegex(), text: k(Z.text).replace("\\b_", "\\b_| {2,}\\n").replace(/\{2,\}/g, "*").getRegex() };
|
|
var E = { normal: U, gfm: ze, pedantic: Ce };
|
|
var z = { normal: W, gfm: Z, breaks: rt, pedantic: nt };
|
|
var st = { "&": "&", "<": "<", ">": ">", '"': """, "'": "'" };
|
|
var de = (u3) => st[u3];
|
|
function O(u3, e) {
|
|
if (e) {
|
|
if (m.escapeTest.test(u3)) return u3.replace(m.escapeReplace, de);
|
|
} else if (m.escapeTestNoEncode.test(u3)) return u3.replace(m.escapeReplaceNoEncode, de);
|
|
return u3;
|
|
}
|
|
function X(u3) {
|
|
try {
|
|
u3 = encodeURI(u3).replace(m.percentDecode, "%");
|
|
} catch {
|
|
return null;
|
|
}
|
|
return u3;
|
|
}
|
|
function J(u3, e) {
|
|
var _a2;
|
|
let t = u3.replace(m.findPipe, (i, s, a) => {
|
|
let o = false, l = s;
|
|
for (; --l >= 0 && a[l] === "\\"; ) o = !o;
|
|
return o ? "|" : " |";
|
|
}), n = t.split(m.splitPipe), r = 0;
|
|
if (n[0].trim() || n.shift(), n.length > 0 && !((_a2 = n.at(-1)) == null ? void 0 : _a2.trim()) && n.pop(), e) if (n.length > e) n.splice(e);
|
|
else for (; n.length < e; ) n.push("");
|
|
for (; r < n.length; r++) n[r] = n[r].trim().replace(m.slashPipe, "|");
|
|
return n;
|
|
}
|
|
function C(u3, e, t) {
|
|
let n = u3.length;
|
|
if (n === 0) return "";
|
|
let r = 0;
|
|
for (; r < n; ) {
|
|
let i = u3.charAt(n - r - 1);
|
|
if (i === e && !t) r++;
|
|
else if (i !== e && t) r++;
|
|
else break;
|
|
}
|
|
return u3.slice(0, n - r);
|
|
}
|
|
function ge(u3, e) {
|
|
if (u3.indexOf(e[1]) === -1) return -1;
|
|
let t = 0;
|
|
for (let n = 0; n < u3.length; n++) if (u3[n] === "\\") n++;
|
|
else if (u3[n] === e[0]) t++;
|
|
else if (u3[n] === e[1] && (t--, t < 0)) return n;
|
|
return t > 0 ? -2 : -1;
|
|
}
|
|
function fe(u3, e = 0) {
|
|
let t = e, n = "";
|
|
for (let r of u3) if (r === " ") {
|
|
let i = 4 - t % 4;
|
|
n += " ".repeat(i), t += i;
|
|
} else n += r, t++;
|
|
return n;
|
|
}
|
|
function me(u3, e, t, n, r) {
|
|
let i = e.href, s = e.title || null, a = u3[1].replace(r.other.outputLinkReplace, "$1");
|
|
n.state.inLink = true;
|
|
let o = { type: u3[0].charAt(0) === "!" ? "image" : "link", raw: t, href: i, title: s, text: a, tokens: n.inlineTokens(a) };
|
|
return n.state.inLink = false, o;
|
|
}
|
|
function it(u3, e, t) {
|
|
let n = u3.match(t.other.indentCodeCompensation);
|
|
if (n === null) return e;
|
|
let r = n[1];
|
|
return e.split(`
|
|
`).map((i) => {
|
|
let s = i.match(t.other.beginningSpace);
|
|
if (s === null) return i;
|
|
let [a] = s;
|
|
return a.length >= r.length ? i.slice(r.length) : i;
|
|
}).join(`
|
|
`);
|
|
}
|
|
var w = class {
|
|
constructor(e) {
|
|
__publicField(this, "options");
|
|
__publicField(this, "rules");
|
|
__publicField(this, "lexer");
|
|
this.options = e || T;
|
|
}
|
|
space(e) {
|
|
let t = this.rules.block.newline.exec(e);
|
|
if (t && t[0].length > 0) return { type: "space", raw: t[0] };
|
|
}
|
|
code(e) {
|
|
let t = this.rules.block.code.exec(e);
|
|
if (t) {
|
|
let n = t[0].replace(this.rules.other.codeRemoveIndent, "");
|
|
return { type: "code", raw: t[0], codeBlockStyle: "indented", text: this.options.pedantic ? n : C(n, `
|
|
`) };
|
|
}
|
|
}
|
|
fences(e) {
|
|
let t = this.rules.block.fences.exec(e);
|
|
if (t) {
|
|
let n = t[0], r = it(n, t[3] || "", this.rules);
|
|
return { type: "code", raw: n, lang: t[2] ? t[2].trim().replace(this.rules.inline.anyPunctuation, "$1") : t[2], text: r };
|
|
}
|
|
}
|
|
heading(e) {
|
|
let t = this.rules.block.heading.exec(e);
|
|
if (t) {
|
|
let n = t[2].trim();
|
|
if (this.rules.other.endingHash.test(n)) {
|
|
let r = C(n, "#");
|
|
(this.options.pedantic || !r || this.rules.other.endingSpaceChar.test(r)) && (n = r.trim());
|
|
}
|
|
return { type: "heading", raw: t[0], depth: t[1].length, text: n, tokens: this.lexer.inline(n) };
|
|
}
|
|
}
|
|
hr(e) {
|
|
let t = this.rules.block.hr.exec(e);
|
|
if (t) return { type: "hr", raw: C(t[0], `
|
|
`) };
|
|
}
|
|
blockquote(e) {
|
|
let t = this.rules.block.blockquote.exec(e);
|
|
if (t) {
|
|
let n = C(t[0], `
|
|
`).split(`
|
|
`), r = "", i = "", s = [];
|
|
for (; n.length > 0; ) {
|
|
let a = false, o = [], l;
|
|
for (l = 0; l < n.length; l++) if (this.rules.other.blockquoteStart.test(n[l])) o.push(n[l]), a = true;
|
|
else if (!a) o.push(n[l]);
|
|
else break;
|
|
n = n.slice(l);
|
|
let p = o.join(`
|
|
`), c = p.replace(this.rules.other.blockquoteSetextReplace, `
|
|
$1`).replace(this.rules.other.blockquoteSetextReplace2, "");
|
|
r = r ? `${r}
|
|
${p}` : p, i = i ? `${i}
|
|
${c}` : c;
|
|
let d = this.lexer.state.top;
|
|
if (this.lexer.state.top = true, this.lexer.blockTokens(c, s, true), this.lexer.state.top = d, n.length === 0) break;
|
|
let h = s.at(-1);
|
|
if ((h == null ? void 0 : h.type) === "code") break;
|
|
if ((h == null ? void 0 : h.type) === "blockquote") {
|
|
let R = h, f = R.raw + `
|
|
` + n.join(`
|
|
`), S = this.blockquote(f);
|
|
s[s.length - 1] = S, r = r.substring(0, r.length - R.raw.length) + S.raw, i = i.substring(0, i.length - R.text.length) + S.text;
|
|
break;
|
|
} else if ((h == null ? void 0 : h.type) === "list") {
|
|
let R = h, f = R.raw + `
|
|
` + n.join(`
|
|
`), S = this.list(f);
|
|
s[s.length - 1] = S, r = r.substring(0, r.length - h.raw.length) + S.raw, i = i.substring(0, i.length - R.raw.length) + S.raw, n = f.substring(s.at(-1).raw.length).split(`
|
|
`);
|
|
continue;
|
|
}
|
|
}
|
|
return { type: "blockquote", raw: r, tokens: s, text: i };
|
|
}
|
|
}
|
|
list(e) {
|
|
var _a2, _b;
|
|
let t = this.rules.block.list.exec(e);
|
|
if (t) {
|
|
let n = t[1].trim(), r = n.length > 1, i = { type: "list", raw: "", ordered: r, start: r ? +n.slice(0, -1) : "", loose: false, items: [] };
|
|
n = r ? `\\d{1,9}\\${n.slice(-1)}` : `\\${n}`, this.options.pedantic && (n = r ? n : "[*+-]");
|
|
let s = this.rules.other.listItemRegex(n), a = false;
|
|
for (; e; ) {
|
|
let l = false, p = "", c = "";
|
|
if (!(t = s.exec(e)) || this.rules.block.hr.test(e)) break;
|
|
p = t[0], e = e.substring(p.length);
|
|
let d = fe(t[2].split(`
|
|
`, 1)[0], t[1].length), h = e.split(`
|
|
`, 1)[0], R = !d.trim(), f = 0;
|
|
if (this.options.pedantic ? (f = 2, c = d.trimStart()) : R ? f = t[1].length + 1 : (f = d.search(this.rules.other.nonSpaceChar), f = f > 4 ? 1 : f, c = d.slice(f), f += t[1].length), R && this.rules.other.blankLine.test(h) && (p += h + `
|
|
`, e = e.substring(h.length + 1), l = true), !l) {
|
|
let S = this.rules.other.nextBulletRegex(f), V = this.rules.other.hrRegex(f), Y = this.rules.other.fencesBeginRegex(f), ee = this.rules.other.headingBeginRegex(f), xe = this.rules.other.htmlBeginRegex(f), be = this.rules.other.blockquoteBeginRegex(f);
|
|
for (; e; ) {
|
|
let G = e.split(`
|
|
`, 1)[0], A;
|
|
if (h = G, this.options.pedantic ? (h = h.replace(this.rules.other.listReplaceNesting, " "), A = h) : A = h.replace(this.rules.other.tabCharGlobal, " "), Y.test(h) || ee.test(h) || xe.test(h) || be.test(h) || S.test(h) || V.test(h)) break;
|
|
if (A.search(this.rules.other.nonSpaceChar) >= f || !h.trim()) c += `
|
|
` + A.slice(f);
|
|
else {
|
|
if (R || d.replace(this.rules.other.tabCharGlobal, " ").search(this.rules.other.nonSpaceChar) >= 4 || Y.test(d) || ee.test(d) || V.test(d)) break;
|
|
c += `
|
|
` + h;
|
|
}
|
|
R = !h.trim(), p += G + `
|
|
`, e = e.substring(G.length + 1), d = A.slice(f);
|
|
}
|
|
}
|
|
i.loose || (a ? i.loose = true : this.rules.other.doubleBlankLine.test(p) && (a = true)), i.items.push({ type: "list_item", raw: p, task: !!this.options.gfm && this.rules.other.listIsTask.test(c), loose: false, text: c, tokens: [] }), i.raw += p;
|
|
}
|
|
let o = i.items.at(-1);
|
|
if (o) o.raw = o.raw.trimEnd(), o.text = o.text.trimEnd();
|
|
else return;
|
|
i.raw = i.raw.trimEnd();
|
|
for (let l of i.items) {
|
|
if (this.lexer.state.top = false, l.tokens = this.lexer.blockTokens(l.text, []), l.task) {
|
|
if (l.text = l.text.replace(this.rules.other.listReplaceTask, ""), ((_a2 = l.tokens[0]) == null ? void 0 : _a2.type) === "text" || ((_b = l.tokens[0]) == null ? void 0 : _b.type) === "paragraph") {
|
|
l.tokens[0].raw = l.tokens[0].raw.replace(this.rules.other.listReplaceTask, ""), l.tokens[0].text = l.tokens[0].text.replace(this.rules.other.listReplaceTask, "");
|
|
for (let c = this.lexer.inlineQueue.length - 1; c >= 0; c--) if (this.rules.other.listIsTask.test(this.lexer.inlineQueue[c].src)) {
|
|
this.lexer.inlineQueue[c].src = this.lexer.inlineQueue[c].src.replace(this.rules.other.listReplaceTask, "");
|
|
break;
|
|
}
|
|
}
|
|
let p = this.rules.other.listTaskCheckbox.exec(l.raw);
|
|
if (p) {
|
|
let c = { type: "checkbox", raw: p[0] + " ", checked: p[0] !== "[ ]" };
|
|
l.checked = c.checked, i.loose ? l.tokens[0] && ["paragraph", "text"].includes(l.tokens[0].type) && "tokens" in l.tokens[0] && l.tokens[0].tokens ? (l.tokens[0].raw = c.raw + l.tokens[0].raw, l.tokens[0].text = c.raw + l.tokens[0].text, l.tokens[0].tokens.unshift(c)) : l.tokens.unshift({ type: "paragraph", raw: c.raw, text: c.raw, tokens: [c] }) : l.tokens.unshift(c);
|
|
}
|
|
}
|
|
if (!i.loose) {
|
|
let p = l.tokens.filter((d) => d.type === "space"), c = p.length > 0 && p.some((d) => this.rules.other.anyLine.test(d.raw));
|
|
i.loose = c;
|
|
}
|
|
}
|
|
if (i.loose) for (let l of i.items) {
|
|
l.loose = true;
|
|
for (let p of l.tokens) p.type === "text" && (p.type = "paragraph");
|
|
}
|
|
return i;
|
|
}
|
|
}
|
|
html(e) {
|
|
let t = this.rules.block.html.exec(e);
|
|
if (t) return { type: "html", block: true, raw: t[0], pre: t[1] === "pre" || t[1] === "script" || t[1] === "style", text: t[0] };
|
|
}
|
|
def(e) {
|
|
let t = this.rules.block.def.exec(e);
|
|
if (t) {
|
|
let n = t[1].toLowerCase().replace(this.rules.other.multipleSpaceGlobal, " "), r = t[2] ? t[2].replace(this.rules.other.hrefBrackets, "$1").replace(this.rules.inline.anyPunctuation, "$1") : "", i = t[3] ? t[3].substring(1, t[3].length - 1).replace(this.rules.inline.anyPunctuation, "$1") : t[3];
|
|
return { type: "def", tag: n, raw: t[0], href: r, title: i };
|
|
}
|
|
}
|
|
table(e) {
|
|
var _a2;
|
|
let t = this.rules.block.table.exec(e);
|
|
if (!t || !this.rules.other.tableDelimiter.test(t[2])) return;
|
|
let n = J(t[1]), r = t[2].replace(this.rules.other.tableAlignChars, "").split("|"), i = ((_a2 = t[3]) == null ? void 0 : _a2.trim()) ? t[3].replace(this.rules.other.tableRowBlankLine, "").split(`
|
|
`) : [], s = { type: "table", raw: t[0], header: [], align: [], rows: [] };
|
|
if (n.length === r.length) {
|
|
for (let a of r) this.rules.other.tableAlignRight.test(a) ? s.align.push("right") : this.rules.other.tableAlignCenter.test(a) ? s.align.push("center") : this.rules.other.tableAlignLeft.test(a) ? s.align.push("left") : s.align.push(null);
|
|
for (let a = 0; a < n.length; a++) s.header.push({ text: n[a], tokens: this.lexer.inline(n[a]), header: true, align: s.align[a] });
|
|
for (let a of i) s.rows.push(J(a, s.header.length).map((o, l) => ({ text: o, tokens: this.lexer.inline(o), header: false, align: s.align[l] })));
|
|
return s;
|
|
}
|
|
}
|
|
lheading(e) {
|
|
let t = this.rules.block.lheading.exec(e);
|
|
if (t) return { type: "heading", raw: t[0], depth: t[2].charAt(0) === "=" ? 1 : 2, text: t[1], tokens: this.lexer.inline(t[1]) };
|
|
}
|
|
paragraph(e) {
|
|
let t = this.rules.block.paragraph.exec(e);
|
|
if (t) {
|
|
let n = t[1].charAt(t[1].length - 1) === `
|
|
` ? t[1].slice(0, -1) : t[1];
|
|
return { type: "paragraph", raw: t[0], text: n, tokens: this.lexer.inline(n) };
|
|
}
|
|
}
|
|
text(e) {
|
|
let t = this.rules.block.text.exec(e);
|
|
if (t) return { type: "text", raw: t[0], text: t[0], tokens: this.lexer.inline(t[0]) };
|
|
}
|
|
escape(e) {
|
|
let t = this.rules.inline.escape.exec(e);
|
|
if (t) return { type: "escape", raw: t[0], text: t[1] };
|
|
}
|
|
tag(e) {
|
|
let t = this.rules.inline.tag.exec(e);
|
|
if (t) return !this.lexer.state.inLink && this.rules.other.startATag.test(t[0]) ? this.lexer.state.inLink = true : this.lexer.state.inLink && this.rules.other.endATag.test(t[0]) && (this.lexer.state.inLink = false), !this.lexer.state.inRawBlock && this.rules.other.startPreScriptTag.test(t[0]) ? this.lexer.state.inRawBlock = true : this.lexer.state.inRawBlock && this.rules.other.endPreScriptTag.test(t[0]) && (this.lexer.state.inRawBlock = false), { type: "html", raw: t[0], inLink: this.lexer.state.inLink, inRawBlock: this.lexer.state.inRawBlock, block: false, text: t[0] };
|
|
}
|
|
link(e) {
|
|
let t = this.rules.inline.link.exec(e);
|
|
if (t) {
|
|
let n = t[2].trim();
|
|
if (!this.options.pedantic && this.rules.other.startAngleBracket.test(n)) {
|
|
if (!this.rules.other.endAngleBracket.test(n)) return;
|
|
let s = C(n.slice(0, -1), "\\");
|
|
if ((n.length - s.length) % 2 === 0) return;
|
|
} else {
|
|
let s = ge(t[2], "()");
|
|
if (s === -2) return;
|
|
if (s > -1) {
|
|
let o = (t[0].indexOf("!") === 0 ? 5 : 4) + t[1].length + s;
|
|
t[2] = t[2].substring(0, s), t[0] = t[0].substring(0, o).trim(), t[3] = "";
|
|
}
|
|
}
|
|
let r = t[2], i = "";
|
|
if (this.options.pedantic) {
|
|
let s = this.rules.other.pedanticHrefTitle.exec(r);
|
|
s && (r = s[1], i = s[3]);
|
|
} else i = t[3] ? t[3].slice(1, -1) : "";
|
|
return r = r.trim(), this.rules.other.startAngleBracket.test(r) && (this.options.pedantic && !this.rules.other.endAngleBracket.test(n) ? r = r.slice(1) : r = r.slice(1, -1)), me(t, { href: r && r.replace(this.rules.inline.anyPunctuation, "$1"), title: i && i.replace(this.rules.inline.anyPunctuation, "$1") }, t[0], this.lexer, this.rules);
|
|
}
|
|
}
|
|
reflink(e, t) {
|
|
let n;
|
|
if ((n = this.rules.inline.reflink.exec(e)) || (n = this.rules.inline.nolink.exec(e))) {
|
|
let r = (n[2] || n[1]).replace(this.rules.other.multipleSpaceGlobal, " "), i = t[r.toLowerCase()];
|
|
if (!i) {
|
|
let s = n[0].charAt(0);
|
|
return { type: "text", raw: s, text: s };
|
|
}
|
|
return me(n, i, n[0], this.lexer, this.rules);
|
|
}
|
|
}
|
|
emStrong(e, t, n = "") {
|
|
let r = this.rules.inline.emStrongLDelim.exec(e);
|
|
if (!r || r[3] && n.match(this.rules.other.unicodeAlphaNumeric)) return;
|
|
if (!(r[1] || r[2] || "") || !n || this.rules.inline.punctuation.exec(n)) {
|
|
let s = [...r[0]].length - 1, a, o, l = s, p = 0, c = r[0][0] === "*" ? this.rules.inline.emStrongRDelimAst : this.rules.inline.emStrongRDelimUnd;
|
|
for (c.lastIndex = 0, t = t.slice(-1 * e.length + s); (r = c.exec(t)) != null; ) {
|
|
if (a = r[1] || r[2] || r[3] || r[4] || r[5] || r[6], !a) continue;
|
|
if (o = [...a].length, r[3] || r[4]) {
|
|
l += o;
|
|
continue;
|
|
} else if ((r[5] || r[6]) && s % 3 && !((s + o) % 3)) {
|
|
p += o;
|
|
continue;
|
|
}
|
|
if (l -= o, l > 0) continue;
|
|
o = Math.min(o, o + l + p);
|
|
let d = [...r[0]][0].length, h = e.slice(0, s + r.index + d + o);
|
|
if (Math.min(s, o) % 2) {
|
|
let f = h.slice(1, -1);
|
|
return { type: "em", raw: h, text: f, tokens: this.lexer.inlineTokens(f) };
|
|
}
|
|
let R = h.slice(2, -2);
|
|
return { type: "strong", raw: h, text: R, tokens: this.lexer.inlineTokens(R) };
|
|
}
|
|
}
|
|
}
|
|
codespan(e) {
|
|
let t = this.rules.inline.code.exec(e);
|
|
if (t) {
|
|
let n = t[2].replace(this.rules.other.newLineCharGlobal, " "), r = this.rules.other.nonSpaceChar.test(n), i = this.rules.other.startingSpaceChar.test(n) && this.rules.other.endingSpaceChar.test(n);
|
|
return r && i && (n = n.substring(1, n.length - 1)), { type: "codespan", raw: t[0], text: n };
|
|
}
|
|
}
|
|
br(e) {
|
|
let t = this.rules.inline.br.exec(e);
|
|
if (t) return { type: "br", raw: t[0] };
|
|
}
|
|
del(e, t, n = "") {
|
|
let r = this.rules.inline.delLDelim.exec(e);
|
|
if (!r) return;
|
|
if (!(r[1] || "") || !n || this.rules.inline.punctuation.exec(n)) {
|
|
let s = [...r[0]].length - 1, a, o, l = s, p = this.rules.inline.delRDelim;
|
|
for (p.lastIndex = 0, t = t.slice(-1 * e.length + s); (r = p.exec(t)) != null; ) {
|
|
if (a = r[1] || r[2] || r[3] || r[4] || r[5] || r[6], !a || (o = [...a].length, o !== s)) continue;
|
|
if (r[3] || r[4]) {
|
|
l += o;
|
|
continue;
|
|
}
|
|
if (l -= o, l > 0) continue;
|
|
o = Math.min(o, o + l);
|
|
let c = [...r[0]][0].length, d = e.slice(0, s + r.index + c + o), h = d.slice(s, -s);
|
|
return { type: "del", raw: d, text: h, tokens: this.lexer.inlineTokens(h) };
|
|
}
|
|
}
|
|
}
|
|
autolink(e) {
|
|
let t = this.rules.inline.autolink.exec(e);
|
|
if (t) {
|
|
let n, r;
|
|
return t[2] === "@" ? (n = t[1], r = "mailto:" + n) : (n = t[1], r = n), { type: "link", raw: t[0], text: n, href: r, tokens: [{ type: "text", raw: n, text: n }] };
|
|
}
|
|
}
|
|
url(e) {
|
|
var _a2;
|
|
let t;
|
|
if (t = this.rules.inline.url.exec(e)) {
|
|
let n, r;
|
|
if (t[2] === "@") n = t[0], r = "mailto:" + n;
|
|
else {
|
|
let i;
|
|
do
|
|
i = t[0], t[0] = ((_a2 = this.rules.inline._backpedal.exec(t[0])) == null ? void 0 : _a2[0]) ?? "";
|
|
while (i !== t[0]);
|
|
n = t[0], t[1] === "www." ? r = "http://" + t[0] : r = t[0];
|
|
}
|
|
return { type: "link", raw: t[0], text: n, href: r, tokens: [{ type: "text", raw: n, text: n }] };
|
|
}
|
|
}
|
|
inlineText(e) {
|
|
let t = this.rules.inline.text.exec(e);
|
|
if (t) {
|
|
let n = this.lexer.state.inRawBlock;
|
|
return { type: "text", raw: t[0], text: t[0], escaped: n };
|
|
}
|
|
}
|
|
};
|
|
var x = class u {
|
|
constructor(e) {
|
|
__publicField(this, "tokens");
|
|
__publicField(this, "options");
|
|
__publicField(this, "state");
|
|
__publicField(this, "inlineQueue");
|
|
__publicField(this, "tokenizer");
|
|
this.tokens = [], this.tokens.links = /* @__PURE__ */ Object.create(null), this.options = e || T, this.options.tokenizer = this.options.tokenizer || new w(), this.tokenizer = this.options.tokenizer, this.tokenizer.options = this.options, this.tokenizer.lexer = this, this.inlineQueue = [], this.state = { inLink: false, inRawBlock: false, top: true };
|
|
let t = { other: m, block: E.normal, inline: z.normal };
|
|
this.options.pedantic ? (t.block = E.pedantic, t.inline = z.pedantic) : this.options.gfm && (t.block = E.gfm, this.options.breaks ? t.inline = z.breaks : t.inline = z.gfm), this.tokenizer.rules = t;
|
|
}
|
|
static get rules() {
|
|
return { block: E, inline: z };
|
|
}
|
|
static lex(e, t) {
|
|
return new u(t).lex(e);
|
|
}
|
|
static lexInline(e, t) {
|
|
return new u(t).inlineTokens(e);
|
|
}
|
|
lex(e) {
|
|
e = e.replace(m.carriageReturn, `
|
|
`), this.blockTokens(e, this.tokens);
|
|
for (let t = 0; t < this.inlineQueue.length; t++) {
|
|
let n = this.inlineQueue[t];
|
|
this.inlineTokens(n.src, n.tokens);
|
|
}
|
|
return this.inlineQueue = [], this.tokens;
|
|
}
|
|
blockTokens(e, t = [], n = false) {
|
|
var _a2, _b, _c;
|
|
for (this.options.pedantic && (e = e.replace(m.tabCharGlobal, " ").replace(m.spaceLine, "")); e; ) {
|
|
let r;
|
|
if ((_b = (_a2 = this.options.extensions) == null ? void 0 : _a2.block) == null ? void 0 : _b.some((s) => (r = s.call({ lexer: this }, e, t)) ? (e = e.substring(r.raw.length), t.push(r), true) : false)) continue;
|
|
if (r = this.tokenizer.space(e)) {
|
|
e = e.substring(r.raw.length);
|
|
let s = t.at(-1);
|
|
r.raw.length === 1 && s !== void 0 ? s.raw += `
|
|
` : t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.code(e)) {
|
|
e = e.substring(r.raw.length);
|
|
let s = t.at(-1);
|
|
(s == null ? void 0 : s.type) === "paragraph" || (s == null ? void 0 : s.type) === "text" ? (s.raw += (s.raw.endsWith(`
|
|
`) ? "" : `
|
|
`) + r.raw, s.text += `
|
|
` + r.text, this.inlineQueue.at(-1).src = s.text) : t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.fences(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.heading(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.hr(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.blockquote(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.list(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.html(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.def(e)) {
|
|
e = e.substring(r.raw.length);
|
|
let s = t.at(-1);
|
|
(s == null ? void 0 : s.type) === "paragraph" || (s == null ? void 0 : s.type) === "text" ? (s.raw += (s.raw.endsWith(`
|
|
`) ? "" : `
|
|
`) + r.raw, s.text += `
|
|
` + r.raw, this.inlineQueue.at(-1).src = s.text) : this.tokens.links[r.tag] || (this.tokens.links[r.tag] = { href: r.href, title: r.title }, t.push(r));
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.table(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.lheading(e)) {
|
|
e = e.substring(r.raw.length), t.push(r);
|
|
continue;
|
|
}
|
|
let i = e;
|
|
if ((_c = this.options.extensions) == null ? void 0 : _c.startBlock) {
|
|
let s = 1 / 0, a = e.slice(1), o;
|
|
this.options.extensions.startBlock.forEach((l) => {
|
|
o = l.call({ lexer: this }, a), typeof o == "number" && o >= 0 && (s = Math.min(s, o));
|
|
}), s < 1 / 0 && s >= 0 && (i = e.substring(0, s + 1));
|
|
}
|
|
if (this.state.top && (r = this.tokenizer.paragraph(i))) {
|
|
let s = t.at(-1);
|
|
n && (s == null ? void 0 : s.type) === "paragraph" ? (s.raw += (s.raw.endsWith(`
|
|
`) ? "" : `
|
|
`) + r.raw, s.text += `
|
|
` + r.text, this.inlineQueue.pop(), this.inlineQueue.at(-1).src = s.text) : t.push(r), n = i.length !== e.length, e = e.substring(r.raw.length);
|
|
continue;
|
|
}
|
|
if (r = this.tokenizer.text(e)) {
|
|
e = e.substring(r.raw.length);
|
|
let s = t.at(-1);
|
|
(s == null ? void 0 : s.type) === "text" ? (s.raw += (s.raw.endsWith(`
|
|
`) ? "" : `
|
|
`) + r.raw, s.text += `
|
|
` + r.text, this.inlineQueue.pop(), this.inlineQueue.at(-1).src = s.text) : t.push(r);
|
|
continue;
|
|
}
|
|
if (e) {
|
|
let s = "Infinite loop on byte: " + e.charCodeAt(0);
|
|
if (this.options.silent) {
|
|
console.error(s);
|
|
break;
|
|
} else throw new Error(s);
|
|
}
|
|
}
|
|
return this.state.top = true, t;
|
|
}
|
|
inline(e, t = []) {
|
|
return this.inlineQueue.push({ src: e, tokens: t }), t;
|
|
}
|
|
inlineTokens(e, t = []) {
|
|
var _a2, _b, _c, _d, _e2;
|
|
let n = e, r = null;
|
|
if (this.tokens.links) {
|
|
let o = Object.keys(this.tokens.links);
|
|
if (o.length > 0) for (; (r = this.tokenizer.rules.inline.reflinkSearch.exec(n)) != null; ) o.includes(r[0].slice(r[0].lastIndexOf("[") + 1, -1)) && (n = n.slice(0, r.index) + "[" + "a".repeat(r[0].length - 2) + "]" + n.slice(this.tokenizer.rules.inline.reflinkSearch.lastIndex));
|
|
}
|
|
for (; (r = this.tokenizer.rules.inline.anyPunctuation.exec(n)) != null; ) n = n.slice(0, r.index) + "++" + n.slice(this.tokenizer.rules.inline.anyPunctuation.lastIndex);
|
|
let i;
|
|
for (; (r = this.tokenizer.rules.inline.blockSkip.exec(n)) != null; ) i = r[2] ? r[2].length : 0, n = n.slice(0, r.index + i) + "[" + "a".repeat(r[0].length - i - 2) + "]" + n.slice(this.tokenizer.rules.inline.blockSkip.lastIndex);
|
|
n = ((_b = (_a2 = this.options.hooks) == null ? void 0 : _a2.emStrongMask) == null ? void 0 : _b.call({ lexer: this }, n)) ?? n;
|
|
let s = false, a = "";
|
|
for (; e; ) {
|
|
s || (a = ""), s = false;
|
|
let o;
|
|
if ((_d = (_c = this.options.extensions) == null ? void 0 : _c.inline) == null ? void 0 : _d.some((p) => (o = p.call({ lexer: this }, e, t)) ? (e = e.substring(o.raw.length), t.push(o), true) : false)) continue;
|
|
if (o = this.tokenizer.escape(e)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.tag(e)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.link(e)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.reflink(e, this.tokens.links)) {
|
|
e = e.substring(o.raw.length);
|
|
let p = t.at(-1);
|
|
o.type === "text" && (p == null ? void 0 : p.type) === "text" ? (p.raw += o.raw, p.text += o.text) : t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.emStrong(e, n, a)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.codespan(e)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.br(e)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.del(e, n, a)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (o = this.tokenizer.autolink(e)) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
if (!this.state.inLink && (o = this.tokenizer.url(e))) {
|
|
e = e.substring(o.raw.length), t.push(o);
|
|
continue;
|
|
}
|
|
let l = e;
|
|
if ((_e2 = this.options.extensions) == null ? void 0 : _e2.startInline) {
|
|
let p = 1 / 0, c = e.slice(1), d;
|
|
this.options.extensions.startInline.forEach((h) => {
|
|
d = h.call({ lexer: this }, c), typeof d == "number" && d >= 0 && (p = Math.min(p, d));
|
|
}), p < 1 / 0 && p >= 0 && (l = e.substring(0, p + 1));
|
|
}
|
|
if (o = this.tokenizer.inlineText(l)) {
|
|
e = e.substring(o.raw.length), o.raw.slice(-1) !== "_" && (a = o.raw.slice(-1)), s = true;
|
|
let p = t.at(-1);
|
|
(p == null ? void 0 : p.type) === "text" ? (p.raw += o.raw, p.text += o.text) : t.push(o);
|
|
continue;
|
|
}
|
|
if (e) {
|
|
let p = "Infinite loop on byte: " + e.charCodeAt(0);
|
|
if (this.options.silent) {
|
|
console.error(p);
|
|
break;
|
|
} else throw new Error(p);
|
|
}
|
|
}
|
|
return t;
|
|
}
|
|
};
|
|
var y = class {
|
|
constructor(e) {
|
|
__publicField(this, "options");
|
|
__publicField(this, "parser");
|
|
this.options = e || T;
|
|
}
|
|
space(e) {
|
|
return "";
|
|
}
|
|
code({ text: e, lang: t, escaped: n }) {
|
|
var _a2;
|
|
let r = (_a2 = (t || "").match(m.notSpaceStart)) == null ? void 0 : _a2[0], i = e.replace(m.endingNewline, "") + `
|
|
`;
|
|
return r ? '<pre><code class="language-' + O(r) + '">' + (n ? i : O(i, true)) + `</code></pre>
|
|
` : "<pre><code>" + (n ? i : O(i, true)) + `</code></pre>
|
|
`;
|
|
}
|
|
blockquote({ tokens: e }) {
|
|
return `<blockquote>
|
|
${this.parser.parse(e)}</blockquote>
|
|
`;
|
|
}
|
|
html({ text: e }) {
|
|
return e;
|
|
}
|
|
def(e) {
|
|
return "";
|
|
}
|
|
heading({ tokens: e, depth: t }) {
|
|
return `<h${t}>${this.parser.parseInline(e)}</h${t}>
|
|
`;
|
|
}
|
|
hr(e) {
|
|
return `<hr>
|
|
`;
|
|
}
|
|
list(e) {
|
|
let t = e.ordered, n = e.start, r = "";
|
|
for (let a = 0; a < e.items.length; a++) {
|
|
let o = e.items[a];
|
|
r += this.listitem(o);
|
|
}
|
|
let i = t ? "ol" : "ul", s = t && n !== 1 ? ' start="' + n + '"' : "";
|
|
return "<" + i + s + `>
|
|
` + r + "</" + i + `>
|
|
`;
|
|
}
|
|
listitem(e) {
|
|
return `<li>${this.parser.parse(e.tokens)}</li>
|
|
`;
|
|
}
|
|
checkbox({ checked: e }) {
|
|
return "<input " + (e ? 'checked="" ' : "") + 'disabled="" type="checkbox"> ';
|
|
}
|
|
paragraph({ tokens: e }) {
|
|
return `<p>${this.parser.parseInline(e)}</p>
|
|
`;
|
|
}
|
|
table(e) {
|
|
let t = "", n = "";
|
|
for (let i = 0; i < e.header.length; i++) n += this.tablecell(e.header[i]);
|
|
t += this.tablerow({ text: n });
|
|
let r = "";
|
|
for (let i = 0; i < e.rows.length; i++) {
|
|
let s = e.rows[i];
|
|
n = "";
|
|
for (let a = 0; a < s.length; a++) n += this.tablecell(s[a]);
|
|
r += this.tablerow({ text: n });
|
|
}
|
|
return r && (r = `<tbody>${r}</tbody>`), `<table>
|
|
<thead>
|
|
` + t + `</thead>
|
|
` + r + `</table>
|
|
`;
|
|
}
|
|
tablerow({ text: e }) {
|
|
return `<tr>
|
|
${e}</tr>
|
|
`;
|
|
}
|
|
tablecell(e) {
|
|
let t = this.parser.parseInline(e.tokens), n = e.header ? "th" : "td";
|
|
return (e.align ? `<${n} align="${e.align}">` : `<${n}>`) + t + `</${n}>
|
|
`;
|
|
}
|
|
strong({ tokens: e }) {
|
|
return `<strong>${this.parser.parseInline(e)}</strong>`;
|
|
}
|
|
em({ tokens: e }) {
|
|
return `<em>${this.parser.parseInline(e)}</em>`;
|
|
}
|
|
codespan({ text: e }) {
|
|
return `<code>${O(e, true)}</code>`;
|
|
}
|
|
br(e) {
|
|
return "<br>";
|
|
}
|
|
del({ tokens: e }) {
|
|
return `<del>${this.parser.parseInline(e)}</del>`;
|
|
}
|
|
link({ href: e, title: t, tokens: n }) {
|
|
let r = this.parser.parseInline(n), i = X(e);
|
|
if (i === null) return r;
|
|
e = i;
|
|
let s = '<a href="' + e + '"';
|
|
return t && (s += ' title="' + O(t) + '"'), s += ">" + r + "</a>", s;
|
|
}
|
|
image({ href: e, title: t, text: n, tokens: r }) {
|
|
r && (n = this.parser.parseInline(r, this.parser.textRenderer));
|
|
let i = X(e);
|
|
if (i === null) return O(n);
|
|
e = i;
|
|
let s = `<img src="${e}" alt="${n}"`;
|
|
return t && (s += ` title="${O(t)}"`), s += ">", s;
|
|
}
|
|
text(e) {
|
|
return "tokens" in e && e.tokens ? this.parser.parseInline(e.tokens) : "escaped" in e && e.escaped ? e.text : O(e.text);
|
|
}
|
|
};
|
|
var $ = class {
|
|
strong({ text: e }) {
|
|
return e;
|
|
}
|
|
em({ text: e }) {
|
|
return e;
|
|
}
|
|
codespan({ text: e }) {
|
|
return e;
|
|
}
|
|
del({ text: e }) {
|
|
return e;
|
|
}
|
|
html({ text: e }) {
|
|
return e;
|
|
}
|
|
text({ text: e }) {
|
|
return e;
|
|
}
|
|
link({ text: e }) {
|
|
return "" + e;
|
|
}
|
|
image({ text: e }) {
|
|
return "" + e;
|
|
}
|
|
br() {
|
|
return "";
|
|
}
|
|
checkbox({ raw: e }) {
|
|
return e;
|
|
}
|
|
};
|
|
var b = class u2 {
|
|
constructor(e) {
|
|
__publicField(this, "options");
|
|
__publicField(this, "renderer");
|
|
__publicField(this, "textRenderer");
|
|
this.options = e || T, this.options.renderer = this.options.renderer || new y(), this.renderer = this.options.renderer, this.renderer.options = this.options, this.renderer.parser = this, this.textRenderer = new $();
|
|
}
|
|
static parse(e, t) {
|
|
return new u2(t).parse(e);
|
|
}
|
|
static parseInline(e, t) {
|
|
return new u2(t).parseInline(e);
|
|
}
|
|
parse(e) {
|
|
var _a2, _b;
|
|
let t = "";
|
|
for (let n = 0; n < e.length; n++) {
|
|
let r = e[n];
|
|
if ((_b = (_a2 = this.options.extensions) == null ? void 0 : _a2.renderers) == null ? void 0 : _b[r.type]) {
|
|
let s = r, a = this.options.extensions.renderers[s.type].call({ parser: this }, s);
|
|
if (a !== false || !["space", "hr", "heading", "code", "table", "blockquote", "list", "html", "def", "paragraph", "text"].includes(s.type)) {
|
|
t += a || "";
|
|
continue;
|
|
}
|
|
}
|
|
let i = r;
|
|
switch (i.type) {
|
|
case "space": {
|
|
t += this.renderer.space(i);
|
|
break;
|
|
}
|
|
case "hr": {
|
|
t += this.renderer.hr(i);
|
|
break;
|
|
}
|
|
case "heading": {
|
|
t += this.renderer.heading(i);
|
|
break;
|
|
}
|
|
case "code": {
|
|
t += this.renderer.code(i);
|
|
break;
|
|
}
|
|
case "table": {
|
|
t += this.renderer.table(i);
|
|
break;
|
|
}
|
|
case "blockquote": {
|
|
t += this.renderer.blockquote(i);
|
|
break;
|
|
}
|
|
case "list": {
|
|
t += this.renderer.list(i);
|
|
break;
|
|
}
|
|
case "checkbox": {
|
|
t += this.renderer.checkbox(i);
|
|
break;
|
|
}
|
|
case "html": {
|
|
t += this.renderer.html(i);
|
|
break;
|
|
}
|
|
case "def": {
|
|
t += this.renderer.def(i);
|
|
break;
|
|
}
|
|
case "paragraph": {
|
|
t += this.renderer.paragraph(i);
|
|
break;
|
|
}
|
|
case "text": {
|
|
t += this.renderer.text(i);
|
|
break;
|
|
}
|
|
default: {
|
|
let s = 'Token with "' + i.type + '" type was not found.';
|
|
if (this.options.silent) return console.error(s), "";
|
|
throw new Error(s);
|
|
}
|
|
}
|
|
}
|
|
return t;
|
|
}
|
|
parseInline(e, t = this.renderer) {
|
|
var _a2, _b;
|
|
let n = "";
|
|
for (let r = 0; r < e.length; r++) {
|
|
let i = e[r];
|
|
if ((_b = (_a2 = this.options.extensions) == null ? void 0 : _a2.renderers) == null ? void 0 : _b[i.type]) {
|
|
let a = this.options.extensions.renderers[i.type].call({ parser: this }, i);
|
|
if (a !== false || !["escape", "html", "link", "image", "strong", "em", "codespan", "br", "del", "text"].includes(i.type)) {
|
|
n += a || "";
|
|
continue;
|
|
}
|
|
}
|
|
let s = i;
|
|
switch (s.type) {
|
|
case "escape": {
|
|
n += t.text(s);
|
|
break;
|
|
}
|
|
case "html": {
|
|
n += t.html(s);
|
|
break;
|
|
}
|
|
case "link": {
|
|
n += t.link(s);
|
|
break;
|
|
}
|
|
case "image": {
|
|
n += t.image(s);
|
|
break;
|
|
}
|
|
case "checkbox": {
|
|
n += t.checkbox(s);
|
|
break;
|
|
}
|
|
case "strong": {
|
|
n += t.strong(s);
|
|
break;
|
|
}
|
|
case "em": {
|
|
n += t.em(s);
|
|
break;
|
|
}
|
|
case "codespan": {
|
|
n += t.codespan(s);
|
|
break;
|
|
}
|
|
case "br": {
|
|
n += t.br(s);
|
|
break;
|
|
}
|
|
case "del": {
|
|
n += t.del(s);
|
|
break;
|
|
}
|
|
case "text": {
|
|
n += t.text(s);
|
|
break;
|
|
}
|
|
default: {
|
|
let a = 'Token with "' + s.type + '" type was not found.';
|
|
if (this.options.silent) return console.error(a), "";
|
|
throw new Error(a);
|
|
}
|
|
}
|
|
}
|
|
return n;
|
|
}
|
|
};
|
|
var _a;
|
|
var P = (_a = class {
|
|
constructor(e) {
|
|
__publicField(this, "options");
|
|
__publicField(this, "block");
|
|
this.options = e || T;
|
|
}
|
|
preprocess(e) {
|
|
return e;
|
|
}
|
|
postprocess(e) {
|
|
return e;
|
|
}
|
|
processAllTokens(e) {
|
|
return e;
|
|
}
|
|
emStrongMask(e) {
|
|
return e;
|
|
}
|
|
provideLexer() {
|
|
return this.block ? x.lex : x.lexInline;
|
|
}
|
|
provideParser() {
|
|
return this.block ? b.parse : b.parseInline;
|
|
}
|
|
}, __publicField(_a, "passThroughHooks", /* @__PURE__ */ new Set(["preprocess", "postprocess", "processAllTokens", "emStrongMask"])), __publicField(_a, "passThroughHooksRespectAsync", /* @__PURE__ */ new Set(["preprocess", "postprocess", "processAllTokens"])), _a);
|
|
var B = class {
|
|
constructor(...e) {
|
|
__publicField(this, "defaults", M());
|
|
__publicField(this, "options", this.setOptions);
|
|
__publicField(this, "parse", this.parseMarkdown(true));
|
|
__publicField(this, "parseInline", this.parseMarkdown(false));
|
|
__publicField(this, "Parser", b);
|
|
__publicField(this, "Renderer", y);
|
|
__publicField(this, "TextRenderer", $);
|
|
__publicField(this, "Lexer", x);
|
|
__publicField(this, "Tokenizer", w);
|
|
__publicField(this, "Hooks", P);
|
|
this.use(...e);
|
|
}
|
|
walkTokens(e, t) {
|
|
var _a2, _b;
|
|
let n = [];
|
|
for (let r of e) switch (n = n.concat(t.call(this, r)), r.type) {
|
|
case "table": {
|
|
let i = r;
|
|
for (let s of i.header) n = n.concat(this.walkTokens(s.tokens, t));
|
|
for (let s of i.rows) for (let a of s) n = n.concat(this.walkTokens(a.tokens, t));
|
|
break;
|
|
}
|
|
case "list": {
|
|
let i = r;
|
|
n = n.concat(this.walkTokens(i.items, t));
|
|
break;
|
|
}
|
|
default: {
|
|
let i = r;
|
|
((_b = (_a2 = this.defaults.extensions) == null ? void 0 : _a2.childTokens) == null ? void 0 : _b[i.type]) ? this.defaults.extensions.childTokens[i.type].forEach((s) => {
|
|
let a = i[s].flat(1 / 0);
|
|
n = n.concat(this.walkTokens(a, t));
|
|
}) : i.tokens && (n = n.concat(this.walkTokens(i.tokens, t)));
|
|
}
|
|
}
|
|
return n;
|
|
}
|
|
use(...e) {
|
|
let t = this.defaults.extensions || { renderers: {}, childTokens: {} };
|
|
return e.forEach((n) => {
|
|
let r = { ...n };
|
|
if (r.async = this.defaults.async || r.async || false, n.extensions && (n.extensions.forEach((i) => {
|
|
if (!i.name) throw new Error("extension name required");
|
|
if ("renderer" in i) {
|
|
let s = t.renderers[i.name];
|
|
s ? t.renderers[i.name] = function(...a) {
|
|
let o = i.renderer.apply(this, a);
|
|
return o === false && (o = s.apply(this, a)), o;
|
|
} : t.renderers[i.name] = i.renderer;
|
|
}
|
|
if ("tokenizer" in i) {
|
|
if (!i.level || i.level !== "block" && i.level !== "inline") throw new Error("extension level must be 'block' or 'inline'");
|
|
let s = t[i.level];
|
|
s ? s.unshift(i.tokenizer) : t[i.level] = [i.tokenizer], i.start && (i.level === "block" ? t.startBlock ? t.startBlock.push(i.start) : t.startBlock = [i.start] : i.level === "inline" && (t.startInline ? t.startInline.push(i.start) : t.startInline = [i.start]));
|
|
}
|
|
"childTokens" in i && i.childTokens && (t.childTokens[i.name] = i.childTokens);
|
|
}), r.extensions = t), n.renderer) {
|
|
let i = this.defaults.renderer || new y(this.defaults);
|
|
for (let s in n.renderer) {
|
|
if (!(s in i)) throw new Error(`renderer '${s}' does not exist`);
|
|
if (["options", "parser"].includes(s)) continue;
|
|
let a = s, o = n.renderer[a], l = i[a];
|
|
i[a] = (...p) => {
|
|
let c = o.apply(i, p);
|
|
return c === false && (c = l.apply(i, p)), c || "";
|
|
};
|
|
}
|
|
r.renderer = i;
|
|
}
|
|
if (n.tokenizer) {
|
|
let i = this.defaults.tokenizer || new w(this.defaults);
|
|
for (let s in n.tokenizer) {
|
|
if (!(s in i)) throw new Error(`tokenizer '${s}' does not exist`);
|
|
if (["options", "rules", "lexer"].includes(s)) continue;
|
|
let a = s, o = n.tokenizer[a], l = i[a];
|
|
i[a] = (...p) => {
|
|
let c = o.apply(i, p);
|
|
return c === false && (c = l.apply(i, p)), c;
|
|
};
|
|
}
|
|
r.tokenizer = i;
|
|
}
|
|
if (n.hooks) {
|
|
let i = this.defaults.hooks || new P();
|
|
for (let s in n.hooks) {
|
|
if (!(s in i)) throw new Error(`hook '${s}' does not exist`);
|
|
if (["options", "block"].includes(s)) continue;
|
|
let a = s, o = n.hooks[a], l = i[a];
|
|
P.passThroughHooks.has(s) ? i[a] = (p) => {
|
|
if (this.defaults.async && P.passThroughHooksRespectAsync.has(s)) return (async () => {
|
|
let d = await o.call(i, p);
|
|
return l.call(i, d);
|
|
})();
|
|
let c = o.call(i, p);
|
|
return l.call(i, c);
|
|
} : i[a] = (...p) => {
|
|
if (this.defaults.async) return (async () => {
|
|
let d = await o.apply(i, p);
|
|
return d === false && (d = await l.apply(i, p)), d;
|
|
})();
|
|
let c = o.apply(i, p);
|
|
return c === false && (c = l.apply(i, p)), c;
|
|
};
|
|
}
|
|
r.hooks = i;
|
|
}
|
|
if (n.walkTokens) {
|
|
let i = this.defaults.walkTokens, s = n.walkTokens;
|
|
r.walkTokens = function(a) {
|
|
let o = [];
|
|
return o.push(s.call(this, a)), i && (o = o.concat(i.call(this, a))), o;
|
|
};
|
|
}
|
|
this.defaults = { ...this.defaults, ...r };
|
|
}), this;
|
|
}
|
|
setOptions(e) {
|
|
return this.defaults = { ...this.defaults, ...e }, this;
|
|
}
|
|
lexer(e, t) {
|
|
return x.lex(e, t ?? this.defaults);
|
|
}
|
|
parser(e, t) {
|
|
return b.parse(e, t ?? this.defaults);
|
|
}
|
|
parseMarkdown(e) {
|
|
return (n, r) => {
|
|
let i = { ...r }, s = { ...this.defaults, ...i }, a = this.onError(!!s.silent, !!s.async);
|
|
if (this.defaults.async === true && i.async === false) return a(new Error("marked(): The async option was set to true by an extension. Remove async: false from the parse options object to return a Promise."));
|
|
if (typeof n > "u" || n === null) return a(new Error("marked(): input parameter is undefined or null"));
|
|
if (typeof n != "string") return a(new Error("marked(): input parameter is of type " + Object.prototype.toString.call(n) + ", string expected"));
|
|
if (s.hooks && (s.hooks.options = s, s.hooks.block = e), s.async) return (async () => {
|
|
let o = s.hooks ? await s.hooks.preprocess(n) : n, p = await (s.hooks ? await s.hooks.provideLexer() : e ? x.lex : x.lexInline)(o, s), c = s.hooks ? await s.hooks.processAllTokens(p) : p;
|
|
s.walkTokens && await Promise.all(this.walkTokens(c, s.walkTokens));
|
|
let h = await (s.hooks ? await s.hooks.provideParser() : e ? b.parse : b.parseInline)(c, s);
|
|
return s.hooks ? await s.hooks.postprocess(h) : h;
|
|
})().catch(a);
|
|
try {
|
|
s.hooks && (n = s.hooks.preprocess(n));
|
|
let l = (s.hooks ? s.hooks.provideLexer() : e ? x.lex : x.lexInline)(n, s);
|
|
s.hooks && (l = s.hooks.processAllTokens(l)), s.walkTokens && this.walkTokens(l, s.walkTokens);
|
|
let c = (s.hooks ? s.hooks.provideParser() : e ? b.parse : b.parseInline)(l, s);
|
|
return s.hooks && (c = s.hooks.postprocess(c)), c;
|
|
} catch (o) {
|
|
return a(o);
|
|
}
|
|
};
|
|
}
|
|
onError(e, t) {
|
|
return (n) => {
|
|
if (n.message += `
|
|
Please report this to https://github.com/markedjs/marked.`, e) {
|
|
let r = "<p>An error occurred:</p><pre>" + O(n.message + "", true) + "</pre>";
|
|
return t ? Promise.resolve(r) : r;
|
|
}
|
|
if (t) return Promise.reject(n);
|
|
throw n;
|
|
};
|
|
}
|
|
};
|
|
var L = new B();
|
|
function g(u3, e) {
|
|
return L.parse(u3, e);
|
|
}
|
|
g.options = g.setOptions = function(u3) {
|
|
return L.setOptions(u3), g.defaults = L.defaults, H(g.defaults), g;
|
|
};
|
|
g.getDefaults = M;
|
|
g.defaults = T;
|
|
g.use = function(...u3) {
|
|
return L.use(...u3), g.defaults = L.defaults, H(g.defaults), g;
|
|
};
|
|
g.walkTokens = function(u3, e) {
|
|
return L.walkTokens(u3, e);
|
|
};
|
|
g.parseInline = L.parseInline;
|
|
g.Parser = b;
|
|
g.parser = b.parse;
|
|
g.Renderer = y;
|
|
g.TextRenderer = $;
|
|
g.Lexer = x;
|
|
g.lexer = x.lex;
|
|
g.Tokenizer = w;
|
|
g.Hooks = P;
|
|
g.parse = g;
|
|
var Ut = g.options;
|
|
var Kt = g.setOptions;
|
|
var Wt = g.use;
|
|
var Xt = g.walkTokens;
|
|
var Jt = g.parseInline;
|
|
var Vt = g;
|
|
var Yt = b.parse;
|
|
var en = x.lex;
|
|
export {
|
|
P as Hooks,
|
|
x as Lexer,
|
|
B as Marked,
|
|
b as Parser,
|
|
y as Renderer,
|
|
$ as TextRenderer,
|
|
w as Tokenizer,
|
|
T as defaults,
|
|
M as getDefaults,
|
|
en as lexer,
|
|
g as marked,
|
|
Ut as options,
|
|
Vt as parse,
|
|
Jt as parseInline,
|
|
Yt as parser,
|
|
Kt as setOptions,
|
|
Wt as use,
|
|
Xt as walkTokens
|
|
};
|
|
//# sourceMappingURL=marked.js.map
|