/** * marked v15.0.2 - a markdown parser * Copyright (c) 2011-2024, Christopher Jeffrey. (MIT Licensed) * https://github.com/markedjs/marked */ !function (e, t) { "object" == typeof exports && "undefined" != typeof module ? t(exports) : "function" == typeof define && define.amd ? define(["exports"], t) : t((e = "undefined" != typeof globalThis ? globalThis : e || self).marked = {}) }(this, (function (e) { "use strict"; function t() { return { async: !1, breaks: !1, extensions: null, gfm: !0, hooks: null, pedantic: !1, renderer: null, silent: !1, tokenizer: null, walkTokens: null } } function n(t) { e.defaults = t } e.defaults = { async: !1, breaks: !1, extensions: null, gfm: !0, hooks: null, pedantic: !1, renderer: null, silent: !1, tokenizer: null, walkTokens: null }; const s = {exec: () => null}; function r(e, t = "") { let n = "string" == typeof e ? e : e.source; const s = { replace: (e, t) => { let r = "string" == typeof t ? t : t.source; return r = r.replace(i.caret, "$1"), n = n.replace(e, r), s }, getRegex: () => new RegExp(n, t) }; return s } const i = { 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, listReplaceTabs: /^\t+/, listReplaceNesting: /^ {1,4}(?=( {4})*[^ ])/g, listIsTask: /^\[[ xX]\] /, listReplaceTask: /^\[[ xX]\] +/, anyLine: /\n.*\n/, hrefBrackets: /^<(.*)>$/, tableDelimiter: /[:|]/, tableAlignChars: /^\||\| *$/g, tableRowBlankLine: /\n[ \t]*$/, tableAlignRight: /^ *-+: *$/, tableAlignCenter: /^ *:-+: *$/, tableAlignLeft: /^ *:-+ *$/, startATag: /^/i, startPreScriptTag: /^<(pre|code|kbd|script)(\s|>)/i, endPreScriptTag: /^<\/(pre|code|kbd|script)(\s|>)/i, startAngleBracket: /^$/, 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+));?/gi, caret: /(^|[^\[])\^/g, percentDecode: /%25/g, findPipe: /\|/g, splitPipe: / \|/, slashPipe: /\\\|/g, carriageReturn: /\r\n|\r/g, spaceLine: /^ +$/gm, notSpaceStart: /^\S*/, endingNewline: /\n$/, listItemRegex: e => new RegExp(`^( {0,3}${e})((?:[\t ][^\\n]*)?(?:\\n|$))`), nextBulletRegex: e => new RegExp(`^ {0,${Math.min(3,e-1)}}(?:[*+-]|\\d{1,9}[.)])((?:[ \t][^\\n]*)?(?:\\n|$))`), hrRegex: e => new RegExp(`^ {0,${Math.min(3,e-1)}}((?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\\n+|$)`), fencesBeginRegex: e => new RegExp(`^ {0,${Math.min(3,e-1)}}(?:\`\`\`|~~~)`), headingBeginRegex: e => new RegExp(`^ {0,${Math.min(3,e-1)}}#`), htmlBeginRegex: e => new RegExp(`^ {0,${Math.min(3,e-1)}}<(?:[a-z].*>|!--)`, "i") }, l = /^ {0,3}((?:-[\t ]*){3,}|(?:_[ \t]*){3,}|(?:\*[ \t]*){3,})(?:\n+|$)/, o = /(?:[*+-]|\d{1,9}[.)])/, a = r(/^(?!bull |blockCode|fences|blockquote|heading|html)((?:.|\n(?!\s*?\n|bull |blockCode|fences|blockquote|heading|html))+?)\n {0,3}(=+|-+) *(?:\n+|$)/).replace(/bull/g, o).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/).getRegex(), c = /^([^\n]+(?:\n(?!hr|heading|lheading|blockquote|fences|list|html|table| +\n)[^\n]+)*)/, h = /(?!\s*\])(?:\\.|[^\[\]\\])+/, p = r(/^ {0,3}\[(label)\]: *(?:\n[ \t]*)?([^<\s][^\s]*|<.*?>)(?:(?: +(?:\n[ \t]*)?| *\n[ \t]*)(title))? *(?:\n+|$)/).replace("label", h).replace("title", /(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/).getRegex(), u = r(/^( {0,3}bull)([ \t][^\n]+?)?(?:\n|$)/).replace(/bull/g, o).getRegex(), k = "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", g = /|$))/, d = r("^ {0,3}(?:<(script|pre|style|textarea)[\\s>][\\s\\S]*?(?:[^\\n]*\\n+|$)|comment[^\\n]*(\\n+|$)|<\\?[\\s\\S]*?(?:\\?>\\n*|$)|\\n*|$)|\\n*|$)|)[\\s\\S]*?(?:(?:\\n[ \t]*)+\\n|$)|<(?!script|pre|style|textarea)([a-z][\\w-]*)(?:attribute)*? */?>(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ \t]*)+\\n|$)|(?=[ \\t]*(?:\\n|$))[\\s\\S]*?(?:(?:\\n[ \t]*)+\\n|$))", "i").replace("comment", g).replace("tag", k).replace("attribute", / +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex(), f = r(c).replace("hr", l).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[.)]) ").replace("html", ")|<(?:script|pre|style|textarea|!--)").replace("tag", k).getRegex(), x = { blockquote: r(/^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/).replace("paragraph", f).getRegex(), code: /^((?: {4}| {0,3}\t)[^\n]+(?:\n(?:[ \t]*(?:\n|$))*)?)+/, def: p, fences: /^ {0,3}(`{3,}(?=[^`\n]*(?:\n|$))|~{3,})([^\n]*)(?:\n|$)(?:|([\s\S]*?)(?:\n|$))(?: {0,3}\1[~`]* *(?=\n|$)|$)/, heading: /^ {0,3}(#{1,6})(?=\s|$)(.*)(?:\n+|$)/, hr: l, html: d, lheading: a, list: u, newline: /^(?:[ \t]*(?:\n|$))+/, paragraph: f, table: s, text: /^[^\n]+/ }, b = r("^ *([^\\n ].*)\\n {0,3}((?:\\| *)?:?-+:? *(?:\\| *:?-+:? *)*(?:\\| *)?)(?:\\n((?:(?! *\\n|hr|heading|blockquote|code|fences|list|html).*(?:\\n|$))*)\\n*|$)").replace("hr", l).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("blockquote", " {0,3}>").replace("code", "(?: {4}| {0,3}\t)[^\\n]").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", ")|<(?:script|pre|style|textarea|!--)").replace("tag", k).getRegex(), w = { ...x, table: b, paragraph: r(c).replace("hr", l).replace("heading", " {0,3}#{1,6}(?:\\s|$)").replace("|lheading", "").replace("table", b).replace("blockquote", " {0,3}>").replace("fences", " {0,3}(?:`{3,}(?=[^`\\n]*\\n)|~{3,})[^\\n]*\\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", ")|<(?:script|pre|style|textarea|!--)").replace("tag", k).getRegex() }, m = { ...x, html: r("^ *(?:comment *(?:\\n|\\s*$)|<(tag)[\\s\\S]+? *(?:\\n{2,}|\\s*$)|\\s]*)*?/?> *(?:\\n{2,}|\\s*$))").replace("comment", g).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: /^ *\[([^\]]+)\]: *]+)>?(?: +(["(][^\n]+[")]))? *(?:\n+|$)/, heading: /^(#{1,6})(.*)(?:\n+|$)/, fences: s, lheading: /^(.+?)\n {0,3}(=+|-+) *(?:\n+|$)/, paragraph: r(c).replace("hr", l).replace("heading", " *#{1,6} *[^\n]").replace("lheading", a).replace("|table", "").replace("blockquote", " {0,3}>").replace("|fences", "").replace("|list", "").replace("|html", "").replace("|tag", "").getRegex() }, y = /^\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/, $ = /^( {2,}|\\)\n(?!\s*$)/, R = /\p{P}\p{S}/u, T = r(/^((?![*_])[\spunctuation])/, "u").replace(/punctuation/g, R).getRegex(), z = r(/^(?:\*+(?:((?!\*)[punct])|[^\s*]))|^_+(?:((?!_)[punct])|([^\s_]))/, "u").replace(/punct/g, R).getRegex(), A = r("^[^_*]*?__[^_*]*?\\*[^_*]*?(?=__)|[^*]+(?=[^*])|(?!\\*)[punct](\\*+)(?=[\\s]|$)|[^punct\\s](\\*+)(?!\\*)(?=[punct\\s]|$)|(?!\\*)[punct\\s](\\*+)(?=[^punct\\s])|[\\s](\\*+)(?!\\*)(?=[punct])|(?!\\*)[punct](\\*+)(?!\\*)(?=[punct])|[^punct\\s](\\*+)(?=[^punct\\s])", "gu").replace(/punct/g, R).getRegex(), S = r("^[^_*]*?\\*\\*[^_*]*?_[^_*]*?(?=\\*\\*)|[^_]+(?=[^_])|(?!_)[punct](_+)(?=[\\s]|$)|[^punct\\s](_+)(?!_)(?=[punct\\s]|$)|(?!_)[punct\\s](_+)(?=[^punct\\s])|[\\s](_+)(?!_)(?=[punct])|(?!_)[punct](_+)(?!_)(?=[punct])", "gu").replace(/punct/g, R).getRegex(), _ = r(/\\([punct])/, "gu").replace(/punct/g, R).getRegex(), I = r(/^<(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(), L = r(g).replace("(?:--\x3e|$)", "--\x3e").getRegex(), B = r("^comment|^|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^|^").replace("comment", L).replace("attribute", /\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/).getRegex(), C = /(?:\[(?:\\.|[^\[\]\\])*\]|\\.|`[^`]*`|[^\[\]\\`])*?/, E = r(/^!?\[(label)\]\(\s*(href)(?:\s+(title))?\s*\)/).replace("label", C).replace("href", /<(?:\\.|[^\n<>\\])+>|[^\s\x00-\x1f]*/).replace("title", /"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/).getRegex(), q = r(/^!?\[(label)\]\[(ref)\]/).replace("label", C).replace("ref", h).getRegex(), P = r(/^!?\[(ref)\](?:\[\])?/).replace("ref", h).getRegex(), Z = { _backpedal: s, anyPunctuation: _, autolink: I, blockSkip: /\[[^[\]]*?\]\((?:\\.|[^\\\(\)]|\((?:\\.|[^\\\(\)])*\))*\)|`[^`]*?`|<[^<>]*?>/g, br: $, code: /^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/, del: s, emStrongLDelim: z, emStrongRDelimAst: A, emStrongRDelimUnd: S, escape: y, link: E, nolink: P, punctuation: T, reflink: q, reflinkSearch: r("reflink|nolink(?!\\()", "g").replace("reflink", q).replace("nolink", P).getRegex(), tag: B, text: /^(`+|[^`])(?:(?= {2,}\n)|[\s\S]*?(?:(?=[\\": ">", '"': """, "'": "'"}, N = e => j[e]; function G(e, t) { if (t) { if (i.escapeTest.test(e)) return e.replace(i.escapeReplace, N) } else if (i.escapeTestNoEncode.test(e)) return e.replace(i.escapeReplaceNoEncode, N); return e } function H(e) { try { e = encodeURI(e).replace(i.percentDecode, "%") } catch { return null } return e } function X(e, t) { const n = e.replace(i.findPipe, ((e, t, n) => { let s = !1, r = t; for (; --r >= 0 && "\\" === n[r];) s = !s; return s ? "|" : " |" })).split(i.splitPipe); let s = 0; if (n[0].trim() || n.shift(), n.length > 0 && !n.at(-1)?.trim() && n.pop(), t) if (n.length > t) n.splice(t); else for (; n.length < t;) n.push(""); for (; s < n.length; s++) n[s] = n[s].trim().replace(i.slashPipe, "|"); return n } function F(e, t, n) { const s = e.length; if (0 === s) return ""; let r = 0; for (; r < s;) { const i = e.charAt(s - r - 1); if (i !== t || n) { if (i === t || !n) break; r++ } else r++ } return e.slice(0, s - r) } function U(e, t, n, s, r) { const i = t.href, l = t.title || null, o = e[1].replace(r.other.outputLinkReplace, "$1"); if ("!" !== e[0].charAt(0)) { s.state.inLink = !0; const e = {type: "link", raw: n, href: i, title: l, text: o, tokens: s.inlineTokens(o)}; return s.state.inLink = !1, e } return {type: "image", raw: n, href: i, title: l, text: o} } class J { options; rules; lexer; constructor(t) { this.options = t || e.defaults } space(e) { const t = this.rules.block.newline.exec(e); if (t && t[0].length > 0) return {type: "space", raw: t[0]} } code(e) { const t = this.rules.block.code.exec(e); if (t) { const e = t[0].replace(this.rules.other.codeRemoveIndent, ""); return { type: "code", raw: t[0], codeBlockStyle: "indented", text: this.options.pedantic ? e : F(e, "\n") } } } fences(e) { const t = this.rules.block.fences.exec(e); if (t) { const e = t[0], n = function (e, t, n) { const s = e.match(n.other.indentCodeCompensation); if (null === s) return t; const r = s[1]; return t.split("\n").map((e => { const t = e.match(n.other.beginningSpace); if (null === t) return e; const [s] = t; return s.length >= r.length ? e.slice(r.length) : e })).join("\n") }(e, t[3] || "", this.rules); return { type: "code", raw: e, lang: t[2] ? t[2].trim().replace(this.rules.inline.anyPunctuation, "$1") : t[2], text: n } } } heading(e) { const t = this.rules.block.heading.exec(e); if (t) { let e = t[2].trim(); if (this.rules.other.endingHash.test(e)) { const t = F(e, "#"); this.options.pedantic ? e = t.trim() : t && !this.rules.other.endingSpaceChar.test(t) || (e = t.trim()) } return {type: "heading", raw: t[0], depth: t[1].length, text: e, tokens: this.lexer.inline(e)} } } hr(e) { const t = this.rules.block.hr.exec(e); if (t) return {type: "hr", raw: F(t[0], "\n")} } blockquote(e) { const t = this.rules.block.blockquote.exec(e); if (t) { let e = F(t[0], "\n").split("\n"), n = "", s = ""; const r = []; for (; e.length > 0;) { let t = !1; const i = []; let l; for (l = 0; l < e.length; l++) if (this.rules.other.blockquoteStart.test(e[l])) i.push(e[l]), t = !0; else { if (t) break; i.push(e[l]) } e = e.slice(l); const o = i.join("\n"), a = o.replace(this.rules.other.blockquoteSetextReplace, "\n $1").replace(this.rules.other.blockquoteSetextReplace2, ""); n = n ? `${n}\n${o}` : o, s = s ? `${s}\n${a}` : a; const c = this.lexer.state.top; if (this.lexer.state.top = !0, this.lexer.blockTokens(a, r, !0), this.lexer.state.top = c, 0 === e.length) break; const h = r.at(-1); if ("code" === h?.type) break; if ("blockquote" === h?.type) { const t = h, i = t.raw + "\n" + e.join("\n"), l = this.blockquote(i); r[r.length - 1] = l, n = n.substring(0, n.length - t.raw.length) + l.raw, s = s.substring(0, s.length - t.text.length) + l.text; break } if ("list" !== h?.type) ; else { const t = h, i = t.raw + "\n" + e.join("\n"), l = this.list(i); r[r.length - 1] = l, n = n.substring(0, n.length - h.raw.length) + l.raw, s = s.substring(0, s.length - t.raw.length) + l.raw, e = i.substring(r.at(-1).raw.length).split("\n") } } return {type: "blockquote", raw: n, tokens: r, text: s} } } list(e) { let t = this.rules.block.list.exec(e); if (t) { let n = t[1].trim(); const s = n.length > 1, r = {type: "list", raw: "", ordered: s, start: s ? +n.slice(0, -1) : "", loose: !1, items: []}; n = s ? `\\d{1,9}\\${n.slice(-1)}` : `\\${n}`, this.options.pedantic && (n = s ? n : "[*+-]"); const i = this.rules.other.listItemRegex(n); let l = !1; for (; e;) { let n = !1, s = "", o = ""; if (!(t = i.exec(e))) break; if (this.rules.block.hr.test(e)) break; s = t[0], e = e.substring(s.length); let a = t[2].split("\n", 1)[0].replace(this.rules.other.listReplaceTabs, (e => " ".repeat(3 * e.length))), c = e.split("\n", 1)[0], h = !a.trim(), p = 0; if (this.options.pedantic ? (p = 2, o = a.trimStart()) : h ? p = t[1].length + 1 : (p = t[2].search(this.rules.other.nonSpaceChar), p = p > 4 ? 1 : p, o = a.slice(p), p += t[1].length), h && this.rules.other.blankLine.test(c) && (s += c + "\n", e = e.substring(c.length + 1), n = !0), !n) { const t = this.rules.other.nextBulletRegex(p), n = this.rules.other.hrRegex(p), r = this.rules.other.fencesBeginRegex(p), i = this.rules.other.headingBeginRegex(p), l = this.rules.other.htmlBeginRegex(p); for (; e;) { const u = e.split("\n", 1)[0]; let k; if (c = u, this.options.pedantic ? (c = c.replace(this.rules.other.listReplaceNesting, " "), k = c) : k = c.replace(this.rules.other.tabCharGlobal, " "), r.test(c)) break; if (i.test(c)) break; if (l.test(c)) break; if (t.test(c)) break; if (n.test(c)) break; if (k.search(this.rules.other.nonSpaceChar) >= p || !c.trim()) o += "\n" + k.slice(p); else { if (h) break; if (a.replace(this.rules.other.tabCharGlobal, " ").search(this.rules.other.nonSpaceChar) >= 4) break; if (r.test(a)) break; if (i.test(a)) break; if (n.test(a)) break; o += "\n" + c } h || c.trim() || (h = !0), s += u + "\n", e = e.substring(u.length + 1), a = k.slice(p) } } r.loose || (l ? r.loose = !0 : this.rules.other.doubleBlankLine.test(s) && (l = !0)); let u, k = null; this.options.gfm && (k = this.rules.other.listIsTask.exec(o), k && (u = "[ ] " !== k[0], o = o.replace(this.rules.other.listReplaceTask, ""))), r.items.push({ type: "list_item", raw: s, task: !!k, checked: u, loose: !1, text: o, tokens: [] }), r.raw += s } const o = r.items.at(-1); o && (o.raw = o.raw.trimEnd(), o.text = o.text.trimEnd()), r.raw = r.raw.trimEnd(); for (let e = 0; e < r.items.length; e++) if (this.lexer.state.top = !1, r.items[e].tokens = this.lexer.blockTokens(r.items[e].text, []), !r.loose) { const t = r.items[e].tokens.filter((e => "space" === e.type)), n = t.length > 0 && t.some((e => this.rules.other.anyLine.test(e.raw))); r.loose = n } if (r.loose) for (let e = 0; e < r.items.length; e++) r.items[e].loose = !0; return r } } html(e) { const t = this.rules.block.html.exec(e); if (t) { return { type: "html", block: !0, raw: t[0], pre: "pre" === t[1] || "script" === t[1] || "style" === t[1], text: t[0] } } } def(e) { const t = this.rules.block.def.exec(e); if (t) { const e = t[1].toLowerCase().replace(this.rules.other.multipleSpaceGlobal, " "), n = t[2] ? t[2].replace(this.rules.other.hrefBrackets, "$1").replace(this.rules.inline.anyPunctuation, "$1") : "", s = t[3] ? t[3].substring(1, t[3].length - 1).replace(this.rules.inline.anyPunctuation, "$1") : t[3]; return {type: "def", tag: e, raw: t[0], href: n, title: s} } } table(e) { const t = this.rules.block.table.exec(e); if (!t) return; if (!this.rules.other.tableDelimiter.test(t[2])) return; const n = X(t[1]), s = t[2].replace(this.rules.other.tableAlignChars, "").split("|"), r = t[3]?.trim() ? t[3].replace(this.rules.other.tableRowBlankLine, "").split("\n") : [], i = {type: "table", raw: t[0], header: [], align: [], rows: []}; if (n.length === s.length) { for (const e of s) this.rules.other.tableAlignRight.test(e) ? i.align.push("right") : this.rules.other.tableAlignCenter.test(e) ? i.align.push("center") : this.rules.other.tableAlignLeft.test(e) ? i.align.push("left") : i.align.push(null); for (let e = 0; e < n.length; e++) i.header.push({ text: n[e], tokens: this.lexer.inline(n[e]), header: !0, align: i.align[e] }); for (const e of r) i.rows.push(X(e, i.header.length).map(((e, t) => ({ text: e, tokens: this.lexer.inline(e), header: !1, align: i.align[t] })))); return i } } lheading(e) { const 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) { const t = this.rules.block.paragraph.exec(e); if (t) { const e = "\n" === t[1].charAt(t[1].length - 1) ? t[1].slice(0, -1) : t[1]; return {type: "paragraph", raw: t[0], text: e, tokens: this.lexer.inline(e)} } } text(e) { const 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) { const t = this.rules.inline.escape.exec(e); if (t) return {type: "escape", raw: t[0], text: t[1]} } tag(e) { const 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 = !0 : this.lexer.state.inLink && this.rules.other.endATag.test(t[0]) && (this.lexer.state.inLink = !1), !this.lexer.state.inRawBlock && this.rules.other.startPreScriptTag.test(t[0]) ? this.lexer.state.inRawBlock = !0 : this.lexer.state.inRawBlock && this.rules.other.endPreScriptTag.test(t[0]) && (this.lexer.state.inRawBlock = !1), { type: "html", raw: t[0], inLink: this.lexer.state.inLink, inRawBlock: this.lexer.state.inRawBlock, block: !1, text: t[0] } } link(e) { const t = this.rules.inline.link.exec(e); if (t) { const e = t[2].trim(); if (!this.options.pedantic && this.rules.other.startAngleBracket.test(e)) { if (!this.rules.other.endAngleBracket.test(e)) return; const t = F(e.slice(0, -1), "\\"); if ((e.length - t.length) % 2 == 0) return } else { const e = function (e, t) { if (-1 === e.indexOf(t[1])) return -1; let n = 0; for (let s = 0; s < e.length; s++) if ("\\" === e[s]) s++; else if (e[s] === t[0]) n++; else if (e[s] === t[1] && (n--, n < 0)) return s; return -1 }(t[2], "()"); if (e > -1) { const n = (0 === t[0].indexOf("!") ? 5 : 4) + t[1].length + e; t[2] = t[2].substring(0, e), t[0] = t[0].substring(0, n).trim(), t[3] = "" } } let n = t[2], s = ""; if (this.options.pedantic) { const e = this.rules.other.pedanticHrefTitle.exec(n); e && (n = e[1], s = e[3]) } else s = t[3] ? t[3].slice(1, -1) : ""; return n = n.trim(), this.rules.other.startAngleBracket.test(n) && (n = this.options.pedantic && !this.rules.other.endAngleBracket.test(e) ? n.slice(1) : n.slice(1, -1)), U(t, { href: n ? n.replace(this.rules.inline.anyPunctuation, "$1") : n, title: s ? s.replace(this.rules.inline.anyPunctuation, "$1") : s }, 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))) { const e = t[(n[2] || n[1]).replace(this.rules.other.multipleSpaceGlobal, " ").toLowerCase()]; if (!e) { const e = n[0].charAt(0); return {type: "text", raw: e, text: e} } return U(n, e, n[0], this.lexer, this.rules) } } emStrong(e, t, n = "") { let s = this.rules.inline.emStrongLDelim.exec(e); if (!s) return; if (s[3] && n.match(this.rules.other.unicodeAlphaNumeric)) return; if (!(s[1] || s[2] || "") || !n || this.rules.inline.punctuation.exec(n)) { const n = [...s[0]].length - 1; let r, i, l = n, o = 0; const a = "*" === s[0][0] ? this.rules.inline.emStrongRDelimAst : this.rules.inline.emStrongRDelimUnd; for (a.lastIndex = 0, t = t.slice(-1 * e.length + n); null != (s = a.exec(t));) { if (r = s[1] || s[2] || s[3] || s[4] || s[5] || s[6], !r) continue; if (i = [...r].length, s[3] || s[4]) { l += i; continue } if ((s[5] || s[6]) && n % 3 && !((n + i) % 3)) { o += i; continue } if (l -= i, l > 0) continue; i = Math.min(i, i + l + o); const t = [...s[0]][0].length, a = e.slice(0, n + s.index + t + i); if (Math.min(n, i) % 2) { const e = a.slice(1, -1); return {type: "em", raw: a, text: e, tokens: this.lexer.inlineTokens(e)} } const c = a.slice(2, -2); return {type: "strong", raw: a, text: c, tokens: this.lexer.inlineTokens(c)} } } } codespan(e) { const t = this.rules.inline.code.exec(e); if (t) { let e = t[2].replace(this.rules.other.newLineCharGlobal, " "); const n = this.rules.other.nonSpaceChar.test(e), s = this.rules.other.startingSpaceChar.test(e) && this.rules.other.endingSpaceChar.test(e); return n && s && (e = e.substring(1, e.length - 1)), {type: "codespan", raw: t[0], text: e} } } br(e) { const t = this.rules.inline.br.exec(e); if (t) return {type: "br", raw: t[0]} } del(e) { const t = this.rules.inline.del.exec(e); if (t) return {type: "del", raw: t[0], text: t[2], tokens: this.lexer.inlineTokens(t[2])} } autolink(e) { const t = this.rules.inline.autolink.exec(e); if (t) { let e, n; return "@" === t[2] ? (e = t[1], n = "mailto:" + e) : (e = t[1], n = e), { type: "link", raw: t[0], text: e, href: n, tokens: [{type: "text", raw: e, text: e}] } } } url(e) { let t; if (t = this.rules.inline.url.exec(e)) { let e, n; if ("@" === t[2]) e = t[0], n = "mailto:" + e; else { let s; do { s = t[0], t[0] = this.rules.inline._backpedal.exec(t[0])?.[0] ?? "" } while (s !== t[0]); e = t[0], n = "www." === t[1] ? "http://" + t[0] : t[0] } return {type: "link", raw: t[0], text: e, href: n, tokens: [{type: "text", raw: e, text: e}]} } } inlineText(e) { const t = this.rules.inline.text.exec(e); if (t) { const e = this.lexer.state.inRawBlock; return {type: "text", raw: t[0], text: t[0], escaped: e} } } } class K { tokens; options; state; tokenizer; inlineQueue; constructor(t) { this.tokens = [], this.tokens.links = Object.create(null), this.options = t || e.defaults, this.options.tokenizer = this.options.tokenizer || new J, this.tokenizer = this.options.tokenizer, this.tokenizer.options = this.options, this.tokenizer.lexer = this, this.inlineQueue = [], this.state = { inLink: !1, inRawBlock: !1, top: !0 }; const n = {other: i, block: O.normal, inline: Q.normal}; this.options.pedantic ? (n.block = O.pedantic, n.inline = Q.pedantic) : this.options.gfm && (n.block = O.gfm, this.options.breaks ? n.inline = Q.breaks : n.inline = Q.gfm), this.tokenizer.rules = n } static get rules() { return {block: O, inline: Q} } static lex(e, t) { return new K(t).lex(e) } static lexInline(e, t) { return new K(t).inlineTokens(e) } lex(e) { e = e.replace(i.carriageReturn, "\n"), this.blockTokens(e, this.tokens); for (let e = 0; e < this.inlineQueue.length; e++) { const t = this.inlineQueue[e]; this.inlineTokens(t.src, t.tokens) } return this.inlineQueue = [], this.tokens } blockTokens(e, t = [], n = !1) { for (this.options.pedantic && (e = e.replace(i.tabCharGlobal, " ").replace(i.spaceLine, "")); e;) { let s; if (this.options.extensions?.block?.some((n => !!(s = n.call({lexer: this}, e, t)) && (e = e.substring(s.raw.length), t.push(s), !0)))) continue; if (s = this.tokenizer.space(e)) { e = e.substring(s.raw.length); const n = t.at(-1); 1 === s.raw.length && void 0 !== n ? n.raw += "\n" : t.push(s); continue } if (s = this.tokenizer.code(e)) { e = e.substring(s.raw.length); const n = t.at(-1); "paragraph" === n?.type || "text" === n?.type ? (n.raw += "\n" + s.raw, n.text += "\n" + s.text, this.inlineQueue.at(-1).src = n.text) : t.push(s); continue } if (s = this.tokenizer.fences(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.heading(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.hr(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.blockquote(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.list(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.html(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.def(e)) { e = e.substring(s.raw.length); const n = t.at(-1); "paragraph" === n?.type || "text" === n?.type ? (n.raw += "\n" + s.raw, n.text += "\n" + s.raw, this.inlineQueue.at(-1).src = n.text) : this.tokens.links[s.tag] || (this.tokens.links[s.tag] = { href: s.href, title: s.title }); continue } if (s = this.tokenizer.table(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.lheading(e)) { e = e.substring(s.raw.length), t.push(s); continue } let r = e; if (this.options.extensions?.startBlock) { let t = 1 / 0; const n = e.slice(1); let s; this.options.extensions.startBlock.forEach((e => { s = e.call({lexer: this}, n), "number" == typeof s && s >= 0 && (t = Math.min(t, s)) })), t < 1 / 0 && t >= 0 && (r = e.substring(0, t + 1)) } if (this.state.top && (s = this.tokenizer.paragraph(r))) { const i = t.at(-1); n && "paragraph" === i?.type ? (i.raw += "\n" + s.raw, i.text += "\n" + s.text, this.inlineQueue.pop(), this.inlineQueue.at(-1).src = i.text) : t.push(s), n = r.length !== e.length, e = e.substring(s.raw.length) } else if (s = this.tokenizer.text(e)) { e = e.substring(s.raw.length); const n = t.at(-1); "text" === n?.type ? (n.raw += "\n" + s.raw, n.text += "\n" + s.text, this.inlineQueue.pop(), this.inlineQueue.at(-1).src = n.text) : t.push(s) } else if (e) { const t = "Infinite loop on byte: " + e.charCodeAt(0); if (this.options.silent) { console.error(t); break } throw new Error(t) } } return this.state.top = !0, t } inline(e, t = []) { return this.inlineQueue.push({src: e, tokens: t}), t } inlineTokens(e, t = []) { let n = e, s = null; if (this.tokens.links) { const e = Object.keys(this.tokens.links); if (e.length > 0) for (; null != (s = this.tokenizer.rules.inline.reflinkSearch.exec(n));) e.includes(s[0].slice(s[0].lastIndexOf("[") + 1, -1)) && (n = n.slice(0, s.index) + "[" + "a".repeat(s[0].length - 2) + "]" + n.slice(this.tokenizer.rules.inline.reflinkSearch.lastIndex)) } for (; null != (s = this.tokenizer.rules.inline.blockSkip.exec(n));) n = n.slice(0, s.index) + "[" + "a".repeat(s[0].length - 2) + "]" + n.slice(this.tokenizer.rules.inline.blockSkip.lastIndex); for (; null != (s = this.tokenizer.rules.inline.anyPunctuation.exec(n));) n = n.slice(0, s.index) + "++" + n.slice(this.tokenizer.rules.inline.anyPunctuation.lastIndex); let r = !1, i = ""; for (; e;) { let s; if (r || (i = ""), r = !1, this.options.extensions?.inline?.some((n => !!(s = n.call({lexer: this}, e, t)) && (e = e.substring(s.raw.length), t.push(s), !0)))) continue; if (s = this.tokenizer.escape(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.tag(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.link(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.reflink(e, this.tokens.links)) { e = e.substring(s.raw.length); const n = t.at(-1); "text" === s.type && "text" === n?.type ? (n.raw += s.raw, n.text += s.text) : t.push(s); continue } if (s = this.tokenizer.emStrong(e, n, i)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.codespan(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.br(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.del(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (s = this.tokenizer.autolink(e)) { e = e.substring(s.raw.length), t.push(s); continue } if (!this.state.inLink && (s = this.tokenizer.url(e))) { e = e.substring(s.raw.length), t.push(s); continue } let l = e; if (this.options.extensions?.startInline) { let t = 1 / 0; const n = e.slice(1); let s; this.options.extensions.startInline.forEach((e => { s = e.call({lexer: this}, n), "number" == typeof s && s >= 0 && (t = Math.min(t, s)) })), t < 1 / 0 && t >= 0 && (l = e.substring(0, t + 1)) } if (s = this.tokenizer.inlineText(l)) { e = e.substring(s.raw.length), "_" !== s.raw.slice(-1) && (i = s.raw.slice(-1)), r = !0; const n = t.at(-1); "text" === n?.type ? (n.raw += s.raw, n.text += s.text) : t.push(s) } else if (e) { const t = "Infinite loop on byte: " + e.charCodeAt(0); if (this.options.silent) { console.error(t); break } throw new Error(t) } } return t } } class V { options; parser; constructor(t) { this.options = t || e.defaults } space(e) { return "" } code({text: e, lang: t, escaped: n}) { const s = (t || "").match(i.notSpaceStart)?.[0], r = e.replace(i.endingNewline, "") + "\n"; return s ? '
' + (n ? r : G(r, !0)) + "
\n" : "
" + (n ? r : G(r, !0)) + "
\n" } blockquote({tokens: e}) { return `
\n${this.parser.parse(e)}
\n` } html({text: e}) { return e } heading({tokens: e, depth: t}) { return `${this.parser.parseInline(e)}\n` } hr(e) { return "
\n" } list(e) { const t = e.ordered, n = e.start; let s = ""; for (let t = 0; t < e.items.length; t++) { const n = e.items[t]; s += this.listitem(n) } const r = t ? "ol" : "ul"; return "<" + r + (t && 1 !== n ? ' start="' + n + '"' : "") + ">\n" + s + "\n" } listitem(e) { let t = ""; if (e.task) { const n = this.checkbox({checked: !!e.checked}); e.loose ? "paragraph" === e.tokens[0]?.type ? (e.tokens[0].text = n + " " + e.tokens[0].text, e.tokens[0].tokens && e.tokens[0].tokens.length > 0 && "text" === e.tokens[0].tokens[0].type && (e.tokens[0].tokens[0].text = n + " " + G(e.tokens[0].tokens[0].text), e.tokens[0].tokens[0].escaped = !0)) : e.tokens.unshift({ type: "text", raw: n + " ", text: n + " ", escaped: !0 }) : t += n + " " } return t += this.parser.parse(e.tokens, !!e.loose), `
  • ${t}
  • \n` } checkbox({checked: e}) { return "' } paragraph({tokens: e}) { return `

    ${this.parser.parseInline(e)}

    \n` } table(e) { let t = "", n = ""; for (let t = 0; t < e.header.length; t++) n += this.tablecell(e.header[t]); t += this.tablerow({text: n}); let s = ""; for (let t = 0; t < e.rows.length; t++) { const r = e.rows[t]; n = ""; for (let e = 0; e < r.length; e++) n += this.tablecell(r[e]); s += this.tablerow({text: n}) } return s && (s = `${s}`), "\n\n" + t + "\n" + s + "
    \n" } tablerow({text: e}) { return `\n${e}\n` } tablecell(e) { const 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 `${this.parser.parseInline(e)}` } em({tokens: e}) { return `${this.parser.parseInline(e)}` } codespan({text: e}) { return `${G(e, !0)}` } br(e) { return "
    " } del({tokens: e}) { return `${this.parser.parseInline(e)}` } link({href: e, title: t, tokens: n}) { const s = this.parser.parseInline(n), r = H(e); if (null === r) return s; let i = '
    ", i } image({href: e, title: t, text: n}) { const s = H(e); if (null === s) return G(n); let r = `${n} { const r = e[s].flat(1 / 0); n = n.concat(this.walkTokens(r, t)) })) : e.tokens && (n = n.concat(this.walkTokens(e.tokens, t))) } } return n } use(...e) { const t = this.defaults.extensions || {renderers: {}, childTokens: {}}; return e.forEach((e => { const n = {...e}; if (n.async = this.defaults.async || n.async || !1, e.extensions && (e.extensions.forEach((e => { if (!e.name) throw new Error("extension name required"); if ("renderer" in e) { const n = t.renderers[e.name]; t.renderers[e.name] = n ? function (...t) { let s = e.renderer.apply(this, t); return !1 === s && (s = n.apply(this, t)), s } : e.renderer } if ("tokenizer" in e) { if (!e.level || "block" !== e.level && "inline" !== e.level) throw new Error("extension level must be 'block' or 'inline'"); const n = t[e.level]; n ? n.unshift(e.tokenizer) : t[e.level] = [e.tokenizer], e.start && ("block" === e.level ? t.startBlock ? t.startBlock.push(e.start) : t.startBlock = [e.start] : "inline" === e.level && (t.startInline ? t.startInline.push(e.start) : t.startInline = [e.start])) } "childTokens" in e && e.childTokens && (t.childTokens[e.name] = e.childTokens) })), n.extensions = t), e.renderer) { const t = this.defaults.renderer || new V(this.defaults); for (const n in e.renderer) { if (!(n in t)) throw new Error(`renderer '${n}' does not exist`); if (["options", "parser"].includes(n)) continue; const s = n, r = e.renderer[s], i = t[s]; t[s] = (...e) => { let n = r.apply(t, e); return !1 === n && (n = i.apply(t, e)), n || "" } } n.renderer = t } if (e.tokenizer) { const t = this.defaults.tokenizer || new J(this.defaults); for (const n in e.tokenizer) { if (!(n in t)) throw new Error(`tokenizer '${n}' does not exist`); if (["options", "rules", "lexer"].includes(n)) continue; const s = n, r = e.tokenizer[s], i = t[s]; t[s] = (...e) => { let n = r.apply(t, e); return !1 === n && (n = i.apply(t, e)), n } } n.tokenizer = t } if (e.hooks) { const t = this.defaults.hooks || new ee; for (const n in e.hooks) { if (!(n in t)) throw new Error(`hook '${n}' does not exist`); if (["options", "block"].includes(n)) continue; const s = n, r = e.hooks[s], i = t[s]; ee.passThroughHooks.has(n) ? t[s] = e => { if (this.defaults.async) return Promise.resolve(r.call(t, e)).then((e => i.call(t, e))); const n = r.call(t, e); return i.call(t, n) } : t[s] = (...e) => { let n = r.apply(t, e); return !1 === n && (n = i.apply(t, e)), n } } n.hooks = t } if (e.walkTokens) { const t = this.defaults.walkTokens, s = e.walkTokens; n.walkTokens = function (e) { let n = []; return n.push(s.call(this, e)), t && (n = n.concat(t.call(this, e))), n } } this.defaults = {...this.defaults, ...n} })), this } setOptions(e) { return this.defaults = {...this.defaults, ...e}, this } lexer(e, t) { return K.lex(e, t ?? this.defaults) } parser(e, t) { return Y.parse(e, t ?? this.defaults) } parseMarkdown(e) { return (t, n) => { const s = {...n}, r = {...this.defaults, ...s}, i = this.onError(!!r.silent, !!r.async); if (!0 === this.defaults.async && !1 === s.async) return i(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 (null == t) return i(new Error("marked(): input parameter is undefined or null")); if ("string" != typeof t) return i(new Error("marked(): input parameter is of type " + Object.prototype.toString.call(t) + ", string expected")); r.hooks && (r.hooks.options = r, r.hooks.block = e); const l = r.hooks ? r.hooks.provideLexer() : e ? K.lex : K.lexInline, o = r.hooks ? r.hooks.provideParser() : e ? Y.parse : Y.parseInline; if (r.async) return Promise.resolve(r.hooks ? r.hooks.preprocess(t) : t).then((e => l(e, r))).then((e => r.hooks ? r.hooks.processAllTokens(e) : e)).then((e => r.walkTokens ? Promise.all(this.walkTokens(e, r.walkTokens)).then((() => e)) : e)).then((e => o(e, r))).then((e => r.hooks ? r.hooks.postprocess(e) : e)).catch(i); try { r.hooks && (t = r.hooks.preprocess(t)); let e = l(t, r); r.hooks && (e = r.hooks.processAllTokens(e)), r.walkTokens && this.walkTokens(e, r.walkTokens); let n = o(e, r); return r.hooks && (n = r.hooks.postprocess(n)), n } catch (e) { return i(e) } } } onError(e, t) { return n => { if (n.message += "\nPlease report this to https://github.com/markedjs/marked.", e) { const e = "

    An error occurred:

    " + G(n.message + "", !0) + "
    "; return t ? Promise.resolve(e) : e } if (t) return Promise.reject(n); throw n } } } const ne = new te; function se(e, t) { return ne.parse(e, t) } se.options = se.setOptions = function (e) { return ne.setOptions(e), se.defaults = ne.defaults, n(se.defaults), se }, se.getDefaults = t, se.defaults = e.defaults, se.use = function (...e) { return ne.use(...e), se.defaults = ne.defaults, n(se.defaults), se }, se.walkTokens = function (e, t) { return ne.walkTokens(e, t) }, se.parseInline = ne.parseInline, se.Parser = Y, se.parser = Y.parse, se.Renderer = V, se.TextRenderer = W, se.Lexer = K, se.lexer = K.lex, se.Tokenizer = J, se.Hooks = ee, se.parse = se; const re = se.options, ie = se.setOptions, le = se.use, oe = se.walkTokens, ae = se.parseInline, ce = se, he = Y.parse, pe = K.lex; e.Hooks = ee, e.Lexer = K, e.Marked = te, e.Parser = Y, e.Renderer = V, e.TextRenderer = W, e.Tokenizer = J, e.getDefaults = t, e.lexer = pe, e.marked = se, e.options = re, e.parse = ce, e.parseInline = ae, e.parser = he, e.setOptions = ie, e.use = le, e.walkTokens = oe }));