TV-BOX/hikerviewrules/public/markdown.html
yuanwangokk-1 fd88dfa315 main
2025-08-11 12:28:16 +08:00

1900 lines
98 KiB
HTML
Raw Permalink Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta
content="width=device-width,
height=device-height, initial-scale=1,
maximum-scale=1, minimum-scale=1, user-scalable=no"
name="viewport"/>
<title>Markdown</title>
<style>
@media (prefers-color-scheme: dark) {
.markdown-body {
color-scheme: dark;
--color-prettylights-syntax-comment: #8b949e;
--color-prettylights-syntax-constant: #79c0ff;
--color-prettylights-syntax-entity: #d2a8ff;
--color-prettylights-syntax-storage-modifier-import: #c9d1d9;
--color-prettylights-syntax-entity-tag: #7ee787;
--color-prettylights-syntax-keyword: #ff7b72;
--color-prettylights-syntax-string: #a5d6ff;
--color-prettylights-syntax-variable: #ffa657;
--color-prettylights-syntax-brackethighlighter-unmatched: #f85149;
--color-prettylights-syntax-invalid-illegal-text: #f0f6fc;
--color-prettylights-syntax-invalid-illegal-bg: #8e1519;
--color-prettylights-syntax-carriage-return-text: #f0f6fc;
--color-prettylights-syntax-carriage-return-bg: #b62324;
--color-prettylights-syntax-string-regexp: #7ee787;
--color-prettylights-syntax-markup-list: #f2cc60;
--color-prettylights-syntax-markup-heading: #1f6feb;
--color-prettylights-syntax-markup-italic: #c9d1d9;
--color-prettylights-syntax-markup-bold: #c9d1d9;
--color-prettylights-syntax-markup-deleted-text: #ffdcd7;
--color-prettylights-syntax-markup-deleted-bg: #67060c;
--color-prettylights-syntax-markup-inserted-text: #aff5b4;
--color-prettylights-syntax-markup-inserted-bg: #033a16;
--color-prettylights-syntax-markup-changed-text: #ffdfb6;
--color-prettylights-syntax-markup-changed-bg: #5a1e02;
--color-prettylights-syntax-markup-ignored-text: #c9d1d9;
--color-prettylights-syntax-markup-ignored-bg: #1158c7;
--color-prettylights-syntax-meta-diff-range: #d2a8ff;
--color-prettylights-syntax-brackethighlighter-angle: #8b949e;
--color-prettylights-syntax-sublimelinter-gutter-mark: #484f58;
--color-prettylights-syntax-constant-other-reference-link: #a5d6ff;
--color-fg-default: #c9d1d9;
--color-fg-muted: #8b949e;
--color-fg-subtle: #484f58;
--color-canvas-default: #0d1117;
--color-canvas-subtle: #161b22;
--color-border-default: #30363d;
--color-border-muted: #21262d;
--color-neutral-muted: rgba(110, 118, 129, 0.4);
--color-accent-fg: #58a6ff;
--color-accent-emphasis: #1f6feb;
--color-attention-subtle: rgba(187, 128, 9, 0.15);
--color-danger-fg: #f85149
}
}
@media (prefers-color-scheme: light) {
.markdown-body {
color-scheme: light;
--color-prettylights-syntax-comment: #6e7781;
--color-prettylights-syntax-constant: #0550ae;
--color-prettylights-syntax-entity: #8250df;
--color-prettylights-syntax-storage-modifier-import: #24292f;
--color-prettylights-syntax-entity-tag: #116329;
--color-prettylights-syntax-keyword: #cf222e;
--color-prettylights-syntax-string: #0a3069;
--color-prettylights-syntax-variable: #953800;
--color-prettylights-syntax-brackethighlighter-unmatched: #82071e;
--color-prettylights-syntax-invalid-illegal-text: #f6f8fa;
--color-prettylights-syntax-invalid-illegal-bg: #82071e;
--color-prettylights-syntax-carriage-return-text: #f6f8fa;
--color-prettylights-syntax-carriage-return-bg: #cf222e;
--color-prettylights-syntax-string-regexp: #116329;
--color-prettylights-syntax-markup-list: #3b2300;
--color-prettylights-syntax-markup-heading: #0550ae;
--color-prettylights-syntax-markup-italic: #24292f;
--color-prettylights-syntax-markup-bold: #24292f;
--color-prettylights-syntax-markup-deleted-text: #82071e;
--color-prettylights-syntax-markup-deleted-bg: #ffebe9;
--color-prettylights-syntax-markup-inserted-text: #116329;
--color-prettylights-syntax-markup-inserted-bg: #dafbe1;
--color-prettylights-syntax-markup-changed-text: #953800;
--color-prettylights-syntax-markup-changed-bg: #ffd8b5;
--color-prettylights-syntax-markup-ignored-text: #eaeef2;
--color-prettylights-syntax-markup-ignored-bg: #0550ae;
--color-prettylights-syntax-meta-diff-range: #8250df;
--color-prettylights-syntax-brackethighlighter-angle: #57606a;
--color-prettylights-syntax-sublimelinter-gutter-mark: #8c959f;
--color-prettylights-syntax-constant-other-reference-link: #0a3069;
--color-fg-default: #24292f;
--color-fg-muted: #57606a;
--color-fg-subtle: #6e7781;
--color-canvas-default: #fff;
--color-canvas-subtle: #f6f8fa;
--color-border-default: #d0d7de;
--color-border-muted: hsla(210, 18%, 87%, 1);
--color-neutral-muted: rgba(175, 184, 193, 0.2);
--color-accent-fg: #0969da;
--color-accent-emphasis: #0969da;
--color-attention-subtle: #fff8c5;
--color-danger-fg: #cf222e
}
}
.markdown-body {
-ms-text-size-adjust: 100%;
-webkit-text-size-adjust: 100%;
margin: 0;
color: var(--color-fg-default);
background-color: var(--color-canvas-default);
font-family: -apple-system, BlinkMacSystemFont, segoe ui, Helvetica, Arial, sans-serif, apple color emoji, segoe ui emoji;
font-size: 16px;
line-height: 1.5;
word-wrap: break-word
}
.markdown-body .octicon {
display: inline-block;
fill: currentColor;
vertical-align: text-bottom
}
.markdown-body h1:hover .anchor .octicon-link:before, .markdown-body h2:hover .anchor .octicon-link:before, .markdown-body h3:hover .anchor .octicon-link:before, .markdown-body h4:hover .anchor .octicon-link:before, .markdown-body h5:hover .anchor .octicon-link:before, .markdown-body h6:hover .anchor .octicon-link:before {
width: 16px;
height: 16px;
content: ' ';
display: inline-block;
background-color: currentColor;
-webkit-mask-image: url();
mask-image: url()
}
.markdown-body details, .markdown-body figcaption, .markdown-body figure {
display: block
}
.markdown-body summary {
display: list-item
}
.markdown-body [hidden] {
display: none !important
}
.markdown-body a {
background-color: transparent;
color: var(--color-accent-fg);
text-decoration: none
}
.markdown-body a:active, .markdown-body a:hover {
outline-width: 0
}
.markdown-body abbr[title] {
border-bottom: 0;
text-decoration: underline dotted
}
.markdown-body b, .markdown-body strong {
font-weight: 600
}
.markdown-body dfn {
font-style: italic
}
.markdown-body h1 {
margin: .67em 0;
font-weight: 600;
padding-bottom: .3em;
font-size: 2em;
border-bottom: 1px solid var(--color-border-muted)
}
.markdown-body mark {
background-color: var(--color-attention-subtle);
color: var(--color-text-primary)
}
.markdown-body small {
font-size: 90%
}
.markdown-body sub, .markdown-body sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline
}
.markdown-body sub {
bottom: -.25em
}
.markdown-body sup {
top: -.5em
}
.markdown-body img {
border-style: none;
max-width: 100%;
box-sizing: content-box;
background-color: var(--color-canvas-default)
}
.markdown-body code, .markdown-body kbd, .markdown-body pre, .markdown-body samp {
font-family: monospace, monospace;
font-size: 1em
}
.markdown-body figure {
margin: 1em 40px
}
.markdown-body hr {
box-sizing: content-box;
overflow: hidden;
background: 0;
border-bottom: 1px solid var(--color-border-muted);
height: .25em;
padding: 0;
margin: 24px 0;
background-color: var(--color-border-default);
border: 0
}
.markdown-body input {
font: inherit;
margin: 0;
overflow: visible;
font-family: inherit;
font-size: inherit;
line-height: inherit
}
.markdown-body [type=button], .markdown-body [type=reset], .markdown-body [type=submit] {
-webkit-appearance: button
}
.markdown-body [type=button]::-moz-focus-inner, .markdown-body [type=reset]::-moz-focus-inner, .markdown-body [type=submit]::-moz-focus-inner {
border-style: none;
padding: 0
}
.markdown-body [type=button]:-moz-focusring, .markdown-body [type=reset]:-moz-focusring, .markdown-body [type=submit]:-moz-focusring {
outline: 1px dotted ButtonText
}
.markdown-body [type=checkbox], .markdown-body [type=radio] {
box-sizing: border-box;
padding: 0
}
.markdown-body [type=number]::-webkit-inner-spin-button, .markdown-body [type=number]::-webkit-outer-spin-button {
height: auto
}
.markdown-body [type=search] {
-webkit-appearance: textfield;
outline-offset: -2px
}
.markdown-body [type=search]::-webkit-search-cancel-button, .markdown-body [type=search]::-webkit-search-decoration {
-webkit-appearance: none
}
.markdown-body ::-webkit-input-placeholder {
color: inherit;
opacity: .54
}
.markdown-body ::-webkit-file-upload-button {
-webkit-appearance: button;
font: inherit
}
.markdown-body a:hover {
text-decoration: underline
}
.markdown-body hr::before {
display: table;
content: ""
}
.markdown-body hr::after {
display: table;
clear: both;
content: ""
}
.markdown-body table {
border-spacing: 0;
border-collapse: collapse;
display: block;
width: max-content;
max-width: 100%;
overflow: auto
}
.markdown-body td, .markdown-body th {
padding: 0
}
.markdown-body details summary {
cursor: pointer
}
.markdown-body details:not([open]) > *:not(summary) {
display: none !important
}
.markdown-body kbd {
display: inline-block;
padding: 3px 5px;
font: 11px ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace;
line-height: 10px;
color: var(--color-fg-default);
vertical-align: middle;
background-color: var(--color-canvas-subtle);
border: solid 1px var(--color-neutral-muted);
border-bottom-color: var(--color-neutral-muted);
border-radius: 6px;
box-shadow: inset 0 -1px 0 var(--color-neutral-muted)
}
.markdown-body h1, .markdown-body h2, .markdown-body h3, .markdown-body h4, .markdown-body h5, .markdown-body h6 {
margin-top: 24px;
margin-bottom: 16px;
font-weight: 600;
line-height: 1.25
}
.markdown-body h2 {
font-weight: 600;
padding-bottom: .3em;
font-size: 1.5em;
border-bottom: 1px solid var(--color-border-muted)
}
.markdown-body h3 {
font-weight: 600;
font-size: 1.25em
}
.markdown-body h4 {
font-weight: 600;
font-size: 1em
}
.markdown-body h5 {
font-weight: 600;
font-size: .875em
}
.markdown-body h6 {
font-weight: 600;
font-size: .85em;
color: var(--color-fg-muted)
}
.markdown-body p {
margin-top: 0;
margin-bottom: 10px
}
.markdown-body blockquote {
margin: 0;
padding: 0 1em;
color: var(--color-fg-muted);
border-left: .25em solid var(--color-border-default)
}
.markdown-body ul, .markdown-body ol {
margin-top: 0;
margin-bottom: 0;
padding-left: 2em
}
.markdown-body ol ol, .markdown-body ul ol {
list-style-type: lower-roman
}
.markdown-body ul ul ol, .markdown-body ul ol ol, .markdown-body ol ul ol, .markdown-body ol ol ol {
list-style-type: lower-alpha
}
.markdown-body dd {
margin-left: 0
}
.markdown-body tt, .markdown-body code {
font-family: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace;
font-size: 12px
}
.markdown-body pre {
margin-top: 0;
margin-bottom: 0;
font-family: ui-monospace, SFMono-Regular, SF Mono, Menlo, Consolas, Liberation Mono, monospace;
font-size: 12px;
word-wrap: normal
}
.markdown-body .octicon {
display: inline-block;
overflow: visible !important;
vertical-align: text-bottom;
fill: currentColor
}
.markdown-body ::placeholder {
color: var(--color-fg-subtle);
opacity: 1
}
.markdown-body input::-webkit-outer-spin-button, .markdown-body input::-webkit-inner-spin-button {
margin: 0;
-webkit-appearance: none;
appearance: none
}
.markdown-body .pl-c {
color: var(--color-prettylights-syntax-comment)
}
.markdown-body .pl-c1, .markdown-body .pl-s .pl-v {
color: var(--color-prettylights-syntax-constant)
}
.markdown-body .pl-e, .markdown-body .pl-en {
color: var(--color-prettylights-syntax-entity)
}
.markdown-body .pl-smi, .markdown-body .pl-s .pl-s1 {
color: var(--color-prettylights-syntax-storage-modifier-import)
}
.markdown-body .pl-ent {
color: var(--color-prettylights-syntax-entity-tag)
}
.markdown-body .pl-k {
color: var(--color-prettylights-syntax-keyword)
}
.markdown-body .pl-s, .markdown-body .pl-pds, .markdown-body .pl-s .pl-pse .pl-s1, .markdown-body .pl-sr, .markdown-body .pl-sr .pl-cce, .markdown-body .pl-sr .pl-sre, .markdown-body .pl-sr .pl-sra {
color: var(--color-prettylights-syntax-string)
}
.markdown-body .pl-v, .markdown-body .pl-smw {
color: var(--color-prettylights-syntax-variable)
}
.markdown-body .pl-bu {
color: var(--color-prettylights-syntax-brackethighlighter-unmatched)
}
.markdown-body .pl-ii {
color: var(--color-prettylights-syntax-invalid-illegal-text);
background-color: var(--color-prettylights-syntax-invalid-illegal-bg)
}
.markdown-body .pl-c2 {
color: var(--color-prettylights-syntax-carriage-return-text);
background-color: var(--color-prettylights-syntax-carriage-return-bg)
}
.markdown-body .pl-sr .pl-cce {
font-weight: 700;
color: var(--color-prettylights-syntax-string-regexp)
}
.markdown-body .pl-ml {
color: var(--color-prettylights-syntax-markup-list)
}
.markdown-body .pl-mh, .markdown-body .pl-mh .pl-en, .markdown-body .pl-ms {
font-weight: 700;
color: var(--color-prettylights-syntax-markup-heading)
}
.markdown-body .pl-mi {
font-style: italic;
color: var(--color-prettylights-syntax-markup-italic)
}
.markdown-body .pl-mb {
font-weight: 700;
color: var(--color-prettylights-syntax-markup-bold)
}
.markdown-body .pl-md {
color: var(--color-prettylights-syntax-markup-deleted-text);
background-color: var(--color-prettylights-syntax-markup-deleted-bg)
}
.markdown-body .pl-mi1 {
color: var(--color-prettylights-syntax-markup-inserted-text);
background-color: var(--color-prettylights-syntax-markup-inserted-bg)
}
.markdown-body .pl-mc {
color: var(--color-prettylights-syntax-markup-changed-text);
background-color: var(--color-prettylights-syntax-markup-changed-bg)
}
.markdown-body .pl-mi2 {
color: var(--color-prettylights-syntax-markup-ignored-text);
background-color: var(--color-prettylights-syntax-markup-ignored-bg)
}
.markdown-body .pl-mdr {
font-weight: 700;
color: var(--color-prettylights-syntax-meta-diff-range)
}
.markdown-body .pl-ba {
color: var(--color-prettylights-syntax-brackethighlighter-angle)
}
.markdown-body .pl-sg {
color: var(--color-prettylights-syntax-sublimelinter-gutter-mark)
}
.markdown-body .pl-corl {
text-decoration: underline;
color: var(--color-prettylights-syntax-constant-other-reference-link)
}
.markdown-body [data-catalyst] {
display: block
}
.markdown-body g-emoji {
font-family: apple color emoji, segoe ui emoji, segoe ui symbol;
font-size: 1em;
font-style: normal !important;
font-weight: 400;
line-height: 1;
vertical-align: -.075em
}
.markdown-body g-emoji img {
width: 1em;
height: 1em
}
.markdown-body::before {
display: table;
content: ""
}
.markdown-body::after {
display: table;
clear: both;
content: ""
}
.markdown-body > *:first-child {
margin-top: 0 !important
}
.markdown-body > *:last-child {
margin-bottom: 0 !important
}
.markdown-body a:not([href]) {
color: inherit;
text-decoration: none
}
.markdown-body .absent {
color: var(--color-danger-fg)
}
.markdown-body .anchor {
float: left;
padding-right: 4px;
margin-left: -20px;
line-height: 1
}
.markdown-body .anchor:focus {
outline: 0
}
.markdown-body p, .markdown-body blockquote, .markdown-body ul, .markdown-body ol, .markdown-body dl, .markdown-body table, .markdown-body pre, .markdown-body details {
margin-top: 0;
margin-bottom: 16px
}
.markdown-body blockquote > :first-child {
margin-top: 0
}
.markdown-body blockquote > :last-child {
margin-bottom: 0
}
.markdown-body sup > a::before {
content: "["
}
.markdown-body sup > a::after {
content: "]"
}
.markdown-body h1 .octicon-link, .markdown-body h2 .octicon-link, .markdown-body h3 .octicon-link, .markdown-body h4 .octicon-link, .markdown-body h5 .octicon-link, .markdown-body h6 .octicon-link {
color: var(--color-fg-default);
vertical-align: middle;
visibility: hidden
}
.markdown-body h1:hover .anchor, .markdown-body h2:hover .anchor, .markdown-body h3:hover .anchor, .markdown-body h4:hover .anchor, .markdown-body h5:hover .anchor, .markdown-body h6:hover .anchor {
text-decoration: none
}
.markdown-body h1:hover .anchor .octicon-link, .markdown-body h2:hover .anchor .octicon-link, .markdown-body h3:hover .anchor .octicon-link, .markdown-body h4:hover .anchor .octicon-link, .markdown-body h5:hover .anchor .octicon-link, .markdown-body h6:hover .anchor .octicon-link {
visibility: visible
}
.markdown-body h1 tt, .markdown-body h1 code, .markdown-body h2 tt, .markdown-body h2 code, .markdown-body h3 tt, .markdown-body h3 code, .markdown-body h4 tt, .markdown-body h4 code, .markdown-body h5 tt, .markdown-body h5 code, .markdown-body h6 tt, .markdown-body h6 code {
padding: 0 .2em;
font-size: inherit
}
.markdown-body ul.no-list, .markdown-body ol.no-list {
padding: 0;
list-style-type: none
}
.markdown-body ol[type="1"] {
list-style-type: decimal
}
.markdown-body ol[type=a] {
list-style-type: lower-alpha
}
.markdown-body ol[type=i] {
list-style-type: lower-roman
}
.markdown-body div > ol:not([type]) {
list-style-type: decimal
}
.markdown-body ul ul, .markdown-body ul ol, .markdown-body ol ol, .markdown-body ol ul {
margin-top: 0;
margin-bottom: 0
}
.markdown-body li > p {
margin-top: 16px
}
.markdown-body li + li {
margin-top: .25em
}
.markdown-body dl {
padding: 0
}
.markdown-body dl dt {
padding: 0;
margin-top: 16px;
font-size: 1em;
font-style: italic;
font-weight: 600
}
.markdown-body dl dd {
padding: 0 16px;
margin-bottom: 16px
}
.markdown-body table th {
font-weight: 600
}
.markdown-body table th, .markdown-body table td {
padding: 6px 13px;
border: 1px solid var(--color-border-default)
}
.markdown-body table tr {
background-color: var(--color-canvas-default);
border-top: 1px solid var(--color-border-muted)
}
.markdown-body table tr:nth-child(2n) {
background-color: var(--color-canvas-subtle)
}
.markdown-body table img {
background-color: transparent
}
.markdown-body img[align=right] {
padding-left: 20px
}
.markdown-body img[align=left] {
padding-right: 20px
}
.markdown-body .emoji {
max-width: none;
vertical-align: text-top;
background-color: transparent
}
.markdown-body span.frame {
display: block;
overflow: hidden
}
.markdown-body span.frame > span {
display: block;
float: left;
width: auto;
padding: 7px;
margin: 13px 0 0;
overflow: hidden;
border: 1px solid var(--color-border-default)
}
.markdown-body span.frame span img {
display: block;
float: left
}
.markdown-body span.frame span span {
display: block;
padding: 5px 0 0;
clear: both;
color: var(--color-fg-default)
}
.markdown-body span.align-center {
display: block;
overflow: hidden;
clear: both
}
.markdown-body span.align-center > span {
display: block;
margin: 13px auto 0;
overflow: hidden;
text-align: center
}
.markdown-body span.align-center span img {
margin: 0 auto;
text-align: center
}
.markdown-body span.align-right {
display: block;
overflow: hidden;
clear: both
}
.markdown-body span.align-right > span {
display: block;
margin: 13px 0 0;
overflow: hidden;
text-align: right
}
.markdown-body span.align-right span img {
margin: 0;
text-align: right
}
.markdown-body span.float-left {
display: block;
float: left;
margin-right: 13px;
overflow: hidden
}
.markdown-body span.float-left span {
margin: 13px 0 0
}
.markdown-body span.float-right {
display: block;
float: right;
margin-left: 13px;
overflow: hidden
}
.markdown-body span.float-right > span {
display: block;
margin: 13px auto 0;
overflow: hidden;
text-align: right
}
.markdown-body code, .markdown-body tt {
padding: .2em .4em;
margin: 0;
font-size: 85%;
background-color: var(--color-neutral-muted);
border-radius: 6px
}
.markdown-body code br, .markdown-body tt br {
display: none
}
.markdown-body del code {
text-decoration: inherit
}
.markdown-body pre code {
font-size: 100%
}
.markdown-body pre > code {
padding: 0;
margin: 0;
word-break: normal;
white-space: pre;
background: 0;
border: 0
}
.markdown-body .highlight {
margin-bottom: 16px
}
.markdown-body .highlight pre {
margin-bottom: 0;
word-break: normal
}
.markdown-body .highlight pre, .markdown-body pre {
padding: 16px;
overflow: auto;
font-size: 85%;
line-height: 1.45;
background-color: var(--color-canvas-subtle);
border-radius: 6px
}
.markdown-body pre code, .markdown-body pre tt {
display: inline;
max-width: auto;
padding: 0;
margin: 0;
overflow: visible;
line-height: inherit;
word-wrap: normal;
background-color: transparent;
border: 0
}
.markdown-body .csv-data td, .markdown-body .csv-data th {
padding: 5px;
overflow: hidden;
font-size: 12px;
line-height: 1;
text-align: left;
white-space: nowrap
}
.markdown-body .csv-data .blob-num {
padding: 10px 8px 9px;
text-align: right;
background: var(--color-canvas-default);
border: 0
}
.markdown-body .csv-data tr {
border-top: 0
}
.markdown-body .csv-data th {
font-weight: 600;
background: var(--color-canvas-subtle);
border-top: 0
}
.markdown-body .footnotes {
font-size: 12px;
color: var(--color-fg-muted);
border-top: 1px solid var(--color-border-default)
}
.markdown-body .footnotes ol {
padding-left: 16px
}
.markdown-body .footnotes li {
position: relative
}
.markdown-body .footnotes li:target::before {
position: absolute;
top: -8px;
right: -8px;
bottom: -8px;
left: -24px;
pointer-events: none;
content: "";
border: 2px solid var(--color-accent-emphasis);
border-radius: 6px
}
.markdown-body .footnotes li:target {
color: var(--color-fg-default)
}
.markdown-body .footnotes .data-footnote-backref g-emoji {
font-family: monospace
}
.markdown-body .task-list-item {
list-style-type: none
}
.markdown-body .task-list-item label {
font-weight: 400
}
.markdown-body .task-list-item.enabled label {
cursor: pointer
}
.markdown-body .task-list-item + .task-list-item {
margin-top: 3px
}
.markdown-body .task-list-item .handle {
display: none
}
.markdown-body .task-list-item-checkbox {
margin: 0 .2em .25em -1.6em;
vertical-align: middle
}
.markdown-body .contains-task-list:dir(rtl) .task-list-item-checkbox {
margin: 0 -1.6em .25em .2em
}
.markdown-body ::-webkit-calendar-picker-indicator {
filter: invert(50%)
}
</style>
</head>
<body>
<script>
/**
* marked - a markdown parser
* Copyright (c) 2011-2021, 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 (r) {
"use strict";
function i(e, t) {
for (var u = 0; u < t.length; u++) {
var n = t[u];
n.enumerable = n.enumerable || !1, n.configurable = !0, "value" in n && (n.writable = !0), Object.defineProperty(e, n.key, n)
}
}
function s(e, t) {
(null == t || t > e.length) && (t = e.length);
for (var u = 0, n = new Array(t); u < t; u++) n[u] = e[u];
return n
}
function D(e, t) {
var u = "undefined" != typeof Symbol && e[Symbol.iterator] || e["@@iterator"];
if (u) return (u = u.call(e)).next.bind(u);
if (Array.isArray(e) || (u = function (e, t) {
if (e) {
if ("string" == typeof e) return s(e, t);
var u = Object.prototype.toString.call(e).slice(8, -1);
return "Map" === (u = "Object" === u && e.constructor ? e.constructor.name : u) || "Set" === u ? Array.from(e) : "Arguments" === u || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(u) ? s(e, t) : void 0
}
}(e)) || t && e && "number" == typeof e.length) {
u && (e = u);
var n = 0;
return function () {
return n >= e.length ? {done: !0} : {done: !1, value: e[n++]}
}
}
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")
}
function e() {
return {
baseUrl: null,
breaks: !1,
extensions: null,
gfm: !0,
headerIds: !0,
headerPrefix: "",
highlight: null,
langPrefix: "language-",
mangle: !0,
pedantic: !1,
renderer: null,
sanitize: !1,
sanitizer: null,
silent: !1,
smartLists: !1,
smartypants: !1,
tokenizer: null,
walkTokens: null,
xhtml: !1
}
}
r.defaults = e();
function u(e) {
return t[e]
}
var n = /[&<>"']/, l = /[&<>"']/g, a = /[<>"']|&(?!#?\w+;)/, o = /[<>"']|&(?!#?\w+;)/g,
t = {"&": "&amp;", "<": "&lt;", ">": "&gt;", '"': "&quot;", "'": "&#39;"};
function c(e, t) {
if (t) {
if (n.test(e)) return e.replace(l, u)
} else if (a.test(e)) return e.replace(o, u);
return e
}
var h = /&(#(?:\d+)|(?:#x[0-9A-Fa-f]+)|(?:\w+));?/gi;
function x(e) {
return e.replace(h, function (e, t) {
return "colon" === (t = t.toLowerCase()) ? ":" : "#" === t.charAt(0) ? "x" === t.charAt(1) ? String.fromCharCode(parseInt(t.substring(2), 16)) : String.fromCharCode(+t.substring(1)) : ""
})
}
var p = /(^|[^\[])\^/g;
function f(u, e) {
u = u.source || u, e = e || "";
var n = {
replace: function (e, t) {
return t = (t = t.source || t).replace(p, "$1"), u = u.replace(e, t), n
}, getRegex: function () {
return new RegExp(u, e)
}
};
return n
}
var g = /[^\w:]/g, F = /^$|^[a-z][a-z0-9+.-]*:|^[?#]/i;
function A(e, t, u) {
if (e) {
var n;
try {
n = decodeURIComponent(x(u)).replace(g, "").toLowerCase()
} catch (e) {
return null
}
if (0 === n.indexOf("javascript:") || 0 === n.indexOf("vbscript:") || 0 === n.indexOf("data:")) return null
}
t && !F.test(u) && (u = function (e, t) {
d[" " + e] || (C.test(e) ? d[" " + e] = e + "/" : d[" " + e] = w(e, "/", !0));
var u = -1 === (e = d[" " + e]).indexOf(":");
return "//" === t.substring(0, 2) ? u ? t : e.replace(k, "$1") + t : "/" === t.charAt(0) ? u ? t : e.replace(E, "$1") + t : e + t
}(t, u));
try {
u = encodeURI(u).replace(/%25/g, "%")
} catch (e) {
return null
}
return u
}
var d = {}, C = /^[^:]+:\/*[^/]*$/, k = /^([^:]+:)[\s\S]*$/, E = /^([^:]+:\/*[^/]*)[\s\S]*$/;
var m = {
exec: function () {
}
};
function b(e) {
for (var t, u, n = 1; n < arguments.length; n++) for (u in t = arguments[n]) Object.prototype.hasOwnProperty.call(t, u) && (e[u] = t[u]);
return e
}
function B(e, t) {
var u = e.replace(/\|/g, function (e, t, u) {
for (var n = !1, r = t; 0 <= --r && "\\" === u[r];) n = !n;
return n ? "|" : " |"
}).split(/ \|/), n = 0;
if (u[0].trim() || u.shift(), u[u.length - 1].trim() || u.pop(), u.length > t) u.splice(t); else for (; u.length < t;) u.push("");
for (; n < u.length; n++) u[n] = u[n].trim().replace(/\\\|/g, "|");
return u
}
function w(e, t, u) {
var n = e.length;
if (0 === n) return "";
for (var r = 0; r < n;) {
var i = e.charAt(n - r - 1);
if (i !== t || u) {
if (i === t || !u) break;
r++
} else r++
}
return e.substr(0, n - r)
}
function v(e) {
e && e.sanitize && !e.silent && console.warn("marked(): sanitize and sanitizer parameters are deprecated since version 0.7.0, should not be used and will be removed in the future. Read more here: https://marked.js.org/#/USING_ADVANCED.md#options")
}
function y(e, t) {
if (t < 1) return "";
for (var u = ""; 1 < t;) 1 & t && (u += e), t >>= 1, e += e;
return u + e
}
function _(e, t, u, n) {
var r = t.href, i = t.title ? c(t.title) : null, t = e[1].replace(/\\([\[\]])/g, "$1");
if ("!" === e[0].charAt(0)) return {type: "image", raw: u, href: r, title: i, text: c(t)};
n.state.inLink = !0;
t = {type: "link", raw: u, href: r, title: i, text: t, tokens: n.inlineTokens(t, [])};
return n.state.inLink = !1, t
}
var z = function () {
function e(e) {
this.options = e || r.defaults
}
var t = e.prototype;
return t.space = function (e) {
e = this.rules.block.newline.exec(e);
if (e) return 1 < e[0].length ? {type: "space", raw: e[0]} : {raw: "\n"}
}, t.code = function (e) {
var t = this.rules.block.code.exec(e);
if (t) {
e = t[0].replace(/^ {1,4}/gm, "");
return {
type: "code",
raw: t[0],
codeBlockStyle: "indented",
text: this.options.pedantic ? e : w(e, "\n")
}
}
}, t.fences = function (e) {
var t = this.rules.block.fences.exec(e);
if (t) {
var u = t[0], e = function (e, t) {
if (null === (e = e.match(/^(\s+)(?:```)/))) return t;
var u = e[1];
return t.split("\n").map(function (e) {
var t = e.match(/^\s+/);
return null !== t && t[0].length >= u.length ? e.slice(u.length) : e
}).join("\n")
}(u, t[3] || "");
return {type: "code", raw: u, lang: t[2] && t[2].trim(), text: e}
}
}, t.heading = function (e) {
var t = this.rules.block.heading.exec(e);
if (t) {
var u = t[2].trim();
/#$/.test(u) && (e = w(u, "#"), !this.options.pedantic && e && !/ $/.test(e) || (u = e.trim()));
u = {type: "heading", raw: t[0], depth: t[1].length, text: u, tokens: []};
return this.lexer.inline(u.text, u.tokens), u
}
}, t.hr = function (e) {
e = this.rules.block.hr.exec(e);
if (e) return {type: "hr", raw: e[0]}
}, t.blockquote = function (e) {
var t = this.rules.block.blockquote.exec(e);
if (t) {
e = t[0].replace(/^ *> ?/gm, "");
return {type: "blockquote", raw: t[0], tokens: this.lexer.blockTokens(e, []), text: e}
}
}, t.list = function (e) {
var t = this.rules.block.list.exec(e);
if (t) {
var u, n, r, i, s, l, a, D, o, c, h, p = 1 < (g = t[1].trim()).length,
f = {type: "list", raw: "", ordered: p, start: p ? +g.slice(0, -1) : "", loose: !1, items: []},
g = p ? "\\d{1,9}\\" + g.slice(-1) : "\\" + g;
this.options.pedantic && (g = p ? g : "[*+-]");
for (var F = new RegExp("^( {0,3}" + g + ")((?: [^\n]*)?(?:\n|$))"); e && (h = !1, t = F.exec(e)) && !this.rules.block.hr.test(e);) {
if (u = t[0], e = e.substring(u.length), a = t[2].split("\n", 1)[0], D = e.split("\n", 1)[0], this.options.pedantic ? (i = 2, c = a.trimLeft()) : (i = t[2].search(/[^ ]/), c = a.slice(i = 4 < i ? 1 : i), i += t[1].length), s = !1, !a && /^ *$/.test(D) && (u += D + "\n", e = e.substring(D.length + 1), h = !0), !h) for (var A = new RegExp("^ {0," + Math.min(3, i - 1) + "}(?:[*+-]|\\d{1,9}[.)])"); e && (a = o = e.split("\n", 1)[0], this.options.pedantic && (a = a.replace(/^ {1,4}(?=( {4})*[^ ])/g, " ")), !A.test(a));) {
if (a.search(/[^ ]/) >= i || !a.trim()) c += "\n" + a.slice(i); else {
if (s) break;
c += "\n" + a
}
s || a.trim() || (s = !0), u += o + "\n", e = e.substring(o.length + 1)
}
f.loose || (l ? f.loose = !0 : /\n *\n *$/.test(u) && (l = !0)), this.options.gfm && (n = /^\[[ xX]\] /.exec(c)) && (r = "[ ] " !== n[0], c = c.replace(/^\[[ xX]\] +/, "")), f.items.push({
type: "list_item",
raw: u,
task: !!n,
checked: r,
loose: !1,
text: c
}), f.raw += u
}
f.items[f.items.length - 1].raw = u.trimRight(), f.items[f.items.length - 1].text = c.trimRight(), f.raw = f.raw.trimRight();
for (var d = f.items.length, C = 0; C < d; C++) this.lexer.state.top = !1, f.items[C].tokens = this.lexer.blockTokens(f.items[C].text, []), !f.loose && f.items[C].tokens.some(function (e) {
return "space" === e.type
}) && (f.loose = !0, f.items[C].loose = !0);
return f
}
}, t.html = function (e) {
var t = this.rules.block.html.exec(e);
if (t) {
e = {
type: "html",
raw: t[0],
pre: !this.options.sanitizer && ("pre" === t[1] || "script" === t[1] || "style" === t[1]),
text: t[0]
};
return this.options.sanitize && (e.type = "paragraph", e.text = this.options.sanitizer ? this.options.sanitizer(t[0]) : c(t[0]), e.tokens = [], this.lexer.inline(e.text, e.tokens)), e
}
}, t.def = function (e) {
e = this.rules.block.def.exec(e);
if (e) return e[3] && (e[3] = e[3].substring(1, e[3].length - 1)), {
type: "def",
tag: e[1].toLowerCase().replace(/\s+/g, " "),
raw: e[0],
href: e[2],
title: e[3]
}
}, t.table = function (e) {
e = this.rules.block.table.exec(e);
if (e) {
var t = {
type: "table",
header: B(e[1]).map(function (e) {
return {text: e}
}),
align: e[2].replace(/^ *|\| *$/g, "").split(/ *\| */),
rows: e[3] ? e[3].replace(/\n[ \t]*$/, "").split("\n") : []
};
if (t.header.length === t.align.length) {
t.raw = e[0];
for (var u, n, r, i = t.align.length, s = 0; s < i; s++) /^ *-+: *$/.test(t.align[s]) ? t.align[s] = "right" : /^ *:-+: *$/.test(t.align[s]) ? t.align[s] = "center" : /^ *:-+ *$/.test(t.align[s]) ? t.align[s] = "left" : t.align[s] = null;
for (i = t.rows.length, s = 0; s < i; s++) t.rows[s] = B(t.rows[s], t.header.length).map(function (e) {
return {text: e}
});
for (i = t.header.length, u = 0; u < i; u++) t.header[u].tokens = [], this.lexer.inlineTokens(t.header[u].text, t.header[u].tokens);
for (i = t.rows.length, u = 0; u < i; u++) for (r = t.rows[u], n = 0; n < r.length; n++) r[n].tokens = [], this.lexer.inlineTokens(r[n].text, r[n].tokens);
return t
}
}
}, t.lheading = function (e) {
e = this.rules.block.lheading.exec(e);
if (e) {
e = {type: "heading", raw: e[0], depth: "=" === e[2].charAt(0) ? 1 : 2, text: e[1], tokens: []};
return this.lexer.inline(e.text, e.tokens), e
}
}, t.paragraph = function (e) {
e = this.rules.block.paragraph.exec(e);
if (e) {
e = {
type: "paragraph",
raw: e[0],
text: "\n" === e[1].charAt(e[1].length - 1) ? e[1].slice(0, -1) : e[1],
tokens: []
};
return this.lexer.inline(e.text, e.tokens), e
}
}, t.text = function (e) {
e = this.rules.block.text.exec(e);
if (e) {
e = {type: "text", raw: e[0], text: e[0], tokens: []};
return this.lexer.inline(e.text, e.tokens), e
}
}, t.escape = function (e) {
e = this.rules.inline.escape.exec(e);
if (e) return {type: "escape", raw: e[0], text: c(e[1])}
}, t.tag = function (e) {
e = this.rules.inline.tag.exec(e);
if (e) return !this.lexer.state.inLink && /^<a /i.test(e[0]) ? this.lexer.state.inLink = !0 : this.lexer.state.inLink && /^<\/a>/i.test(e[0]) && (this.lexer.state.inLink = !1), !this.lexer.state.inRawBlock && /^<(pre|code|kbd|script)(\s|>)/i.test(e[0]) ? this.lexer.state.inRawBlock = !0 : this.lexer.state.inRawBlock && /^<\/(pre|code|kbd|script)(\s|>)/i.test(e[0]) && (this.lexer.state.inRawBlock = !1), {
type: this.options.sanitize ? "text" : "html",
raw: e[0],
inLink: this.lexer.state.inLink,
inRawBlock: this.lexer.state.inRawBlock,
text: this.options.sanitize ? this.options.sanitizer ? this.options.sanitizer(e[0]) : c(e[0]) : e[0]
}
}, t.link = function (e) {
var t = this.rules.inline.link.exec(e);
if (t) {
e = t[2].trim();
if (!this.options.pedantic && /^</.test(e)) {
if (!/>$/.test(e)) return;
var u = w(e.slice(0, -1), "\\");
if ((e.length - u.length) % 2 == 0) return
} else {
var n = function (e, t) {
if (-1 === e.indexOf(t[1])) return -1;
for (var u = e.length, n = 0, r = 0; r < u; r++) if ("\\" === e[r]) r++; else if (e[r] === t[0]) n++; else if (e[r] === t[1] && --n < 0) return r;
return -1
}(t[2], "()");
-1 < n && (r = (0 === t[0].indexOf("!") ? 5 : 4) + t[1].length + n, t[2] = t[2].substring(0, n), t[0] = t[0].substring(0, r).trim(), t[3] = "")
}
var r, u = t[2], n = "";
return this.options.pedantic ? (r = /^([^'"]*[^\s])\s+(['"])(.*)\2/.exec(u)) && (u = r[1], n = r[3]) : n = t[3] ? t[3].slice(1, -1) : "", u = u.trim(), _(t, {
href: (u = /^</.test(u) ? this.options.pedantic && !/>$/.test(e) ? u.slice(1) : u.slice(1, -1) : u) && u.replace(this.rules.inline._escapes, "$1"),
title: n && n.replace(this.rules.inline._escapes, "$1")
}, t[0], this.lexer)
}
}, t.reflink = function (e, t) {
if ((u = this.rules.inline.reflink.exec(e)) || (u = this.rules.inline.nolink.exec(e))) {
var e = (u[2] || u[1]).replace(/\s+/g, " ");
if ((e = t[e.toLowerCase()]) && e.href) return _(u, e, u[0], this.lexer);
var u = u[0].charAt(0);
return {type: "text", raw: u, text: u}
}
}, t.emStrong = function (e, t, u) {
void 0 === u && (u = "");
var n = this.rules.inline.emStrong.lDelim.exec(e);
if (n && (!n[3] || !u.match(/(?:[0-9A-Za-z\xAA\xB2\xB3\xB5\xB9\xBA\xBC-\xBE\xC0-\xD6\xD8-\xF6\xF8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377\u037A-\u037D\u037F\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5\u03F7-\u0481\u048A-\u052F\u0531-\u0556\u0559\u0560-\u0588\u05D0-\u05EA\u05EF-\u05F2\u0620-\u064A\u0660-\u0669\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07C0-\u07EA\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u0860-\u086A\u0870-\u0887\u0889-\u088E\u08A0-\u08C9\u0904-\u0939\u093D\u0950\u0958-\u0961\u0966-\u096F\u0971-\u0980\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09E6-\u09F1\u09F4-\u09F9\u09FC\u0A05-\u0A0A\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39\u0A59-\u0A5C\u0A5E\u0A66-\u0A6F\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0AE6-\u0AEF\u0AF9\u0B05-\u0B0C\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C\u0B5D\u0B5F-\u0B61\u0B66-\u0B6F\u0B71-\u0B77\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0\u0BE6-\u0BF2\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C39\u0C3D\u0C58-\u0C5A\u0C5D\u0C60\u0C61\u0C66-\u0C6F\u0C78-\u0C7E\u0C80\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3\u0CB5-\u0CB9\u0CBD\u0CDD\u0CDE\u0CE0\u0CE1\u0CE6-\u0CEF\u0CF1\u0CF2\u0D04-\u0D0C\u0D0E-\u0D10\u0D12-\u0D3A\u0D3D\u0D4E\u0D54-\u0D56\u0D58-\u0D61\u0D66-\u0D78\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0DE6-\u0DEF\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E50-\u0E59\u0E81\u0E82\u0E84\u0E86-\u0E8A\u0E8C-\u0EA3\u0EA5\u0EA7-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6\u0ED0-\u0ED9\u0EDC-\u0EDF\u0F00\u0F20-\u0F33\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A\u103F-\u1049\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081\u108E\u1090-\u1099\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310\u1312-\u1315\u1318-\u135A\u1369-\u137C\u1380-\u138F\u13A0-\u13F5\u13F8-\u13FD\u1401-\u166C\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u16EE-\u16F8\u1700-\u1711\u171F-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7\u17DC\u17E0-\u17E9\u17F0-\u17F9\u1810-\u1819\u1820-\u1878\u1880-\u1884\u1887-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191E\u1946-\u196D\u1970-\u1974\u1980-\u19AB\u19B0-\u19C9\u19D0-\u19DA\u1A00-\u1A16\u1A20-\u1A54\u1A80-\u1A89\u1A90-\u1A99\u1AA7\u1B05-\u1B33\u1B45-\u1B4C\u1B50-\u1B59\u1B83-\u1BA0\u1BAE-\u1BE5\u1C00-\u1C23\u1C40-\u1C49\u1C4D-\u1C7D\u1C80-\u1C88\u1C90-\u1CBA\u1CBD-\u1CBF\u1CE9-\u1CEC\u1CEE-\u1CF3\u1CF5\u1CF6\u1CFA\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2070\u2071\u2074-\u2079\u207F-\u2089\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2150-\u2189\u2460-\u249B\u24EA-\u24FF\u2776-\u2793\u2C00-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3\u2CFD\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005-\u3007\u3021-\u3029\u3031-\u3035\u3038-\u303C\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312F\u3131-\u318E\u3192-\u3195\u31A0-\u31BF\u31F0-\u31FF\u3220-\u3229\u3248-\u324F\u3251-\u325F\u3280-\u3289\u32B1-\u32BF\u3400-\u4DBF\u4E00-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA62B\uA640-\uA66E\uA67F-\uA69D\uA6A0-\uA6EF\uA717-\uA71F\uA722-\uA788\uA78B-\uA7CA\uA7D0\uA7D1\uA7D3\uA7D5-\uA7D9\uA7F2-\uA801\uA803-\uA805\uA807-\uA80A\uA80C-\uA822\uA830-\uA835\uA840-\uA873\uA882-\uA8B3\uA8D0-\uA8D9\uA8F2-\uA8F7\uA8FB\uA8FD\uA8FE\uA900-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF-\uA9D9\uA9E0-\uA9E4\uA9E6-\uA9FE\uAA00-\uAA28\uAA40-\uAA42\uAA44-\uAA4B\uAA50-\uAA59\uAA60-\uAA76\uAA7A\uAA7E-\uAAAF\uAAB1\uAAB5\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E\uAB30-\uAB5A\uAB5C-\uAB69\uAB70-\uABE2\uABF0-\uABF9\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC\uFF10-\uFF19\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF\uFFD2-\uFFD7\uFFDA-\uFFDC]|\uD800[\uDC00-\uDC0B\uDC0D-\uDC26\uDC28-\uDC3A\uDC3C\uDC3D\uDC3F-\uDC4D\uDC50-\uDC5D\uDC80-\uDCFA\uDD07-\uDD33\uDD40-\uDD78\uDD8A\uDD8B\uDE80-\uDE9C\uDEA0-\uDED0\uDEE1-\uDEFB\uDF00-\uDF23\uDF2D-\uDF4A\uDF50-\uDF75\uDF80-\uDF9D\uDFA0-\uDFC3\uDFC8-\uDFCF\uDFD1-\uDFD5]|\uD801[\uDC00-\uDC9D\uDCA0-\uDCA9\uDCB0-\uDCD3\uDCD8-\uDCFB\uDD00-\uDD27\uDD30-\uDD63\uDD70-\uDD7A\uDD7C-\uDD8A\uDD8C-\uDD92\uDD94\uDD95\uDD97-\uDDA1\uDDA3-\uDDB1\uDDB3-\uDDB9\uDDBB\uDDBC\uDE00-\uDF36\uDF40-\uDF55\uDF60-\uDF67\uDF80-\uDF85\uDF87-\uDFB0\uDFB2-\uDFBA]|\uD802[\uDC00-\uDC05\uDC08\uDC0A-\uDC35\uDC37\uDC38\uDC3C\uDC3F-\uDC55\uDC58-\uDC76\uDC79-\uDC9E\uDCA7-\uDCAF\uDCE0-\uDCF2\uDCF4\uDCF5\uDCFB-\uDD1B\uDD20-\uDD39\uDD80-\uDDB7\uDDBC-\uDDCF\uDDD2-\uDE00\uDE10-\uDE13\uDE15-\uDE17\uDE19-\uDE35\uDE40-\uDE48\uDE60-\uDE7E\uDE80-\uDE9F\uDEC0-\uDEC7\uDEC9-\uDEE4\uDEEB-\uDEEF\uDF00-\uDF35\uDF40-\uDF55\uDF58-\uDF72\uDF78-\uDF91\uDFA9-\uDFAF]|\uD803[\uDC00-\uDC48\uDC80-\uDCB2\uDCC0-\uDCF2\uDCFA-\uDD23\uDD30-\uDD39\uDE60-\uDE7E\uDE80-\uDEA9\uDEB0\uDEB1\uDF00-\uDF27\uDF30-\uDF45\uDF51-\uDF54\uDF70-\uDF81\uDFB0-\uDFCB\uDFE0-\uDFF6]|\uD804[\uDC03-\uDC37\uDC52-\uDC6F\uDC71\uDC72\uDC75\uDC83-\uDCAF\uDCD0-\uDCE8\uDCF0-\uDCF9\uDD03-\uDD26\uDD36-\uDD3F\uDD44\uDD47\uDD50-\uDD72\uDD76\uDD83-\uDDB2\uDDC1-\uDDC4\uDDD0-\uDDDA\uDDDC\uDDE1-\uDDF4\uDE00-\uDE11\uDE13-\uDE2B\uDE80-\uDE86\uDE88\uDE8A-\uDE8D\uDE8F-\uDE9D\uDE9F-\uDEA8\uDEB0-\uDEDE\uDEF0-\uDEF9\uDF05-\uDF0C\uDF0F\uDF10\uDF13-\uDF28\uDF2A-\uDF30\uDF32\uDF33\uDF35-\uDF39\uDF3D\uDF50\uDF5D-\uDF61]|\uD805[\uDC00-\uDC34\uDC47-\uDC4A\uDC50-\uDC59\uDC5F-\uDC61\uDC80-\uDCAF\uDCC4\uDCC5\uDCC7\uDCD0-\uDCD9\uDD80-\uDDAE\uDDD8-\uDDDB\uDE00-\uDE2F\uDE44\uDE50-\uDE59\uDE80-\uDEAA\uDEB8\uDEC0-\uDEC9\uDF00-\uDF1A\uDF30-\uDF3B\uDF40-\uDF46]|\uD806[\uDC00-\uDC2B\uDCA0-\uDCF2\uDCFF-\uDD06\uDD09\uDD0C-\uDD13\uDD15\uDD16\uDD18-\uDD2F\uDD3F\uDD41\uDD50-\uDD59\uDDA0-\uDDA7\uDDAA-\uDDD0\uDDE1\uDDE3\uDE00\uDE0B-\uDE32\uDE3A\uDE50\uDE5C-\uDE89\uDE9D\uDEB0-\uDEF8]|\uD807[\uDC00-\uDC08\uDC0A-\uDC2E\uDC40\uDC50-\uDC6C\uDC72-\uDC8F\uDD00-\uDD06\uDD08\uDD09\uDD0B-\uDD30\uDD46\uDD50-\uDD59\uDD60-\uDD65\uDD67\uDD68\uDD6A-\uDD89\uDD98\uDDA0-\uDDA9\uDEE0-\uDEF2\uDFB0\uDFC0-\uDFD4]|\uD808[\uDC00-\uDF99]|\uD809[\uDC00-\uDC6E\uDC80-\uDD43]|\uD80B[\uDF90-\uDFF0]|[\uD80C\uD81C-\uD820\uD822\uD840-\uD868\uD86A-\uD86C\uD86F-\uD872\uD874-\uD879\uD880-\uD883][\uDC00-\uDFFF]|\uD80D[\uDC00-\uDC2E]|\uD811[\uDC00-\uDE46]|\uD81A[\uDC00-\uDE38\uDE40-\uDE5E\uDE60-\uDE69\uDE70-\uDEBE\uDEC0-\uDEC9\uDED0-\uDEED\uDF00-\uDF2F\uDF40-\uDF43\uDF50-\uDF59\uDF5B-\uDF61\uDF63-\uDF77\uDF7D-\uDF8F]|\uD81B[\uDE40-\uDE96\uDF00-\uDF4A\uDF50\uDF93-\uDF9F\uDFE0\uDFE1\uDFE3]|\uD821[\uDC00-\uDFF7]|\uD823[\uDC00-\uDCD5\uDD00-\uDD08]|\uD82B[\uDFF0-\uDFF3\uDFF5-\uDFFB\uDFFD\uDFFE]|\uD82C[\uDC00-\uDD22\uDD50-\uDD52\uDD64-\uDD67\uDD70-\uDEFB]|\uD82F[\uDC00-\uDC6A\uDC70-\uDC7C\uDC80-\uDC88\uDC90-\uDC99]|\uD834[\uDEE0-\uDEF3\uDF60-\uDF78]|\uD835[\uDC00-\uDC54\uDC56-\uDC9C\uDC9E\uDC9F\uDCA2\uDCA5\uDCA6\uDCA9-\uDCAC\uDCAE-\uDCB9\uDCBB\uDCBD-\uDCC3\uDCC5-\uDD05\uDD07-\uDD0A\uDD0D-\uDD14\uDD16-\uDD1C\uDD1E-\uDD39\uDD3B-\uDD3E\uDD40-\uDD44\uDD46\uDD4A-\uDD50\uDD52-\uDEA5\uDEA8-\uDEC0\uDEC2-\uDEDA\uDEDC-\uDEFA\uDEFC-\uDF14\uDF16-\uDF34\uDF36-\uDF4E\uDF50-\uDF6E\uDF70-\uDF88\uDF8A-\uDFA8\uDFAA-\uDFC2\uDFC4-\uDFCB\uDFCE-\uDFFF]|\uD837[\uDF00-\uDF1E]|\uD838[\uDD00-\uDD2C\uDD37-\uDD3D\uDD40-\uDD49\uDD4E\uDE90-\uDEAD\uDEC0-\uDEEB\uDEF0-\uDEF9]|\uD839[\uDFE0-\uDFE6\uDFE8-\uDFEB\uDFED\uDFEE\uDFF0-\uDFFE]|\uD83A[\uDC00-\uDCC4\uDCC7-\uDCCF\uDD00-\uDD43\uDD4B\uDD50-\uDD59]|\uD83B[\uDC71-\uDCAB\uDCAD-\uDCAF\uDCB1-\uDCB4\uDD01-\uDD2D\uDD2F-\uDD3D\uDE00-\uDE03\uDE05-\uDE1F\uDE21\uDE22\uDE24\uDE27\uDE29-\uDE32\uDE34-\uDE37\uDE39\uDE3B\uDE42\uDE47\uDE49\uDE4B\uDE4D-\uDE4F\uDE51\uDE52\uDE54\uDE57\uDE59\uDE5B\uDE5D\uDE5F\uDE61\uDE62\uDE64\uDE67-\uDE6A\uDE6C-\uDE72\uDE74-\uDE77\uDE79-\uDE7C\uDE7E\uDE80-\uDE89\uDE8B-\uDE9B\uDEA1-\uDEA3\uDEA5-\uDEA9\uDEAB-\uDEBB]|\uD83C[\uDD00-\uDD0C]|\uD83E[\uDFF0-\uDFF9]|\uD869[\uDC00-\uDEDF\uDF00-\uDFFF]|\uD86D[\uDC00-\uDF38\uDF40-\uDFFF]|\uD86E[\uDC00-\uDC1D\uDC20-\uDFFF]|\uD873[\uDC00-\uDEA1\uDEB0-\uDFFF]|\uD87A[\uDC00-\uDFE0]|\uD87E[\uDC00-\uDE1D]|\uD884[\uDC00-\uDF4A])/))) {
var r = n[1] || n[2] || "";
if (!r || "" === u || this.rules.inline.punctuation.exec(u)) {
var i, s = n[0].length - 1, l = s, a = 0,
D = "*" === n[0][0] ? this.rules.inline.emStrong.rDelimAst : this.rules.inline.emStrong.rDelimUnd;
for (D.lastIndex = 0, t = t.slice(-1 * e.length + s); null != (n = D.exec(t));) if (i = n[1] || n[2] || n[3] || n[4] || n[5] || n[6]) if (i = i.length, n[3] || n[4]) l += i; else if (!((n[5] || n[6]) && s % 3) || (s + i) % 3) {
if (!(0 < (l -= i))) {
if (i = Math.min(i, i + l + a), Math.min(s, i) % 2) {
var o = e.slice(1, s + n.index + i);
return {
type: "em",
raw: e.slice(0, s + n.index + i + 1),
text: o,
tokens: this.lexer.inlineTokens(o, [])
}
}
o = e.slice(2, s + n.index + i - 1);
return {
type: "strong",
raw: e.slice(0, s + n.index + i + 1),
text: o,
tokens: this.lexer.inlineTokens(o, [])
}
}
} else a += i
}
}
}, t.codespan = function (e) {
var t = this.rules.inline.code.exec(e);
if (t) {
var u = t[2].replace(/\n/g, " "), n = /[^ ]/.test(u), e = /^ /.test(u) && / $/.test(u),
u = c(u = n && e ? u.substring(1, u.length - 1) : u, !0);
return {type: "codespan", raw: t[0], text: u}
}
}, t.br = function (e) {
e = this.rules.inline.br.exec(e);
if (e) return {type: "br", raw: e[0]}
}, t.del = function (e) {
e = this.rules.inline.del.exec(e);
if (e) return {type: "del", raw: e[0], text: e[2], tokens: this.lexer.inlineTokens(e[2], [])}
}, t.autolink = function (e, t) {
e = this.rules.inline.autolink.exec(e);
if (e) {
var u, t = "@" === e[2] ? "mailto:" + (u = c(this.options.mangle ? t(e[1]) : e[1])) : u = c(e[1]);
return {type: "link", raw: e[0], text: u, href: t, tokens: [{type: "text", raw: u, text: u}]}
}
}, t.url = function (e, t) {
var u, n, r, i;
if (u = this.rules.inline.url.exec(e)) {
if ("@" === u[2]) r = "mailto:" + (n = c(this.options.mangle ? t(u[0]) : u[0])); else {
for (; i = u[0], u[0] = this.rules.inline._backpedal.exec(u[0])[0], i !== u[0];) ;
n = c(u[0]), r = "www." === u[1] ? "http://" + n : n
}
return {type: "link", raw: u[0], text: n, href: r, tokens: [{type: "text", raw: n, text: n}]}
}
}, t.inlineText = function (e, t) {
e = this.rules.inline.text.exec(e);
if (e) {
t = this.lexer.state.inRawBlock ? this.options.sanitize ? this.options.sanitizer ? this.options.sanitizer(e[0]) : c(e[0]) : e[0] : c(this.options.smartypants ? t(e[0]) : e[0]);
return {type: "text", raw: e[0], text: t}
}
}, e
}(), $ = {
newline: /^(?: *(?:\n|$))+/,
code: /^( {4}[^\n]+(?:\n(?: *(?:\n|$))*)?)+/,
fences: /^ {0,3}(`{3,}(?=[^`\n]*\n)|~{3,})([^\n]*)\n(?:|([\s\S]*?)\n)(?: {0,3}\1[~`]* *(?=\n|$)|$)/,
hr: /^ {0,3}((?:- *){3,}|(?:_ *){3,}|(?:\* *){3,})(?:\n+|$)/,
heading: /^ {0,3}(#{1,6})(?=\s|$)(.*)(?:\n+|$)/,
blockquote: /^( {0,3}> ?(paragraph|[^\n]*)(?:\n|$))+/,
list: /^( {0,3}bull)( [^\n]+?)?(?:\n|$)/,
html: "^ {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|$))",
def: /^ {0,3}\[(label)\]: *\n? *<?([^\s>]+)>?(?:(?: +\n? *| *\n *)(title))? *(?:\n+|$)/,
table: m,
lheading: /^([^\n]+)\n {0,3}(=+|-+) *(?:\n+|$)/,
_paragraph: /^([^\n]+(?:\n(?!hr|heading|lheading|blockquote|fences|list|html|table| +\n)[^\n]+)*)/,
text: /^[^\n]+/,
_label: /(?!\s*\])(?:\\[\[\]]|[^\[\]])+/,
_title: /(?:"(?:\\"?|[^"\\])*"|'[^'\n]*(?:\n[^'\n]+)*\n?'|\([^()]*\))/
};
$.def = f($.def).replace("label", $._label).replace("title", $._title).getRegex(), $.bullet = /(?:[*+-]|\d{1,9}[.)])/, $.listItemStart = f(/^( *)(bull) */).replace("bull", $.bullet).getRegex(), $.list = f($.list).replace(/bull/g, $.bullet).replace("hr", "\n+(?=\\1?(?:(?:- *){3,}|(?:_ *){3,}|(?:\\* *){3,})(?:\n+|$))").replace("def", "\n+(?=" + $.def.source + ")").getRegex(), $._tag = "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|section|source|summary|table|tbody|td|tfoot|th|thead|title|tr|track|ul", $._comment =
/<!--(?!-?>)[\s\S]*?(?:-->
|
$
)/,
$.html = f($.html, "i").replace("comment", $._comment).replace("tag", $._tag).replace("attribute", / +[a-zA-Z:_][\w.:-]*(?: *= *"[^"\n]*"| *= *'[^'\n]*'| *= *[^\s"'=<>`]+)?/).getRegex(), $.paragraph = f($._paragraph).replace("hr", $.hr).replace("heading", " {0,3}#{1,6} ").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", "</?(?:tag)(?: +|\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag", $._tag).getRegex(), $.blockquote = f($.blockquote).replace("paragraph", $.paragraph).getRegex(), $.normal = b({}, $), $.gfm = b({}, $.normal, {table: "^ *([^\n ].*\\|.*)\n {0,3}(?:\\| *)?(:?-+:? *(?:\\| *:?-+:? *)*)(?:\\| *)?(?:\n((?:(?! *\n|hr|heading|blockquote|code|fences|list|html).*(?:\n|$))*)\n*|$)"}), $.gfm.table = f($.gfm.table).replace("hr", $.hr).replace("heading", " {0,3}#{1,6} ").replace("blockquote", " {0,3}>").replace("code", " {4}[^\n]").replace("fences", " {0,3}(?:`{3,}(?=[^`\n]*\n)|~{3,})[^\n]*\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", "</?(?:tag)(?: +|\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag", $._tag).getRegex(), $.gfm.paragraph = f($._paragraph).replace("hr", $.hr).replace("heading", " {0,3}#{1,6} ").replace("|lheading", "").replace("table", $.gfm.table).replace("blockquote", " {0,3}>").replace("fences", " {0,3}(?:`{3,}(?=[^`\n]*\n)|~{3,})[^\n]*\n").replace("list", " {0,3}(?:[*+-]|1[.)]) ").replace("html", "</?(?:tag)(?: +|\n|/?>)|<(?:script|pre|style|textarea|!--)").replace("tag", $._tag).getRegex(), $.pedantic = b({}, $.normal, {
html: f("^ *(?:comment *(?:\n|\\s*$)|<(tag)[\\s\\S]+?</\\1> *(?:\n{2,}|\\s*$)|<tag(?:\"[^\"]*\"|'[^']*'|\\s[^'\"/>\\s]*)*?/?> *(?:\n{2,}|\\s*$))").replace("comment", $._comment).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: m,
paragraph: f($.normal._paragraph).replace("hr", $.hr).replace("heading", " *#{1,6} *[^\n]").replace("lheading", $.lheading).replace("blockquote", " {0,3}>").replace("|fences", "").replace("|list", "").replace("|html", "").getRegex()
});
var S = {
escape: /^\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/,
autolink: /^<(scheme:[^\s\x00-\x1f<>]*|email)>/,
url: m,
tag: "^comment|^</[a-zA-Z][\\w:-]*\\s*>|^<[a-zA-Z][\\w-]*(?:attribute)*?\\s*/?>|^<\\?[\\s\\S]*?\\?>|^<![a-zA-Z]+\\s[\\s\\S]*?>|^<!\\[CDATA\\[[\\s\\S]*?\\]\\]>",
link: /^!?\[(label)\]\(\s*(href)(?:\s+(title))?\s*\)/,
reflink: /^!?\[(label)\]\[(?!\s*\])((?:\\[\[\]]?|[^\[\]\\])+)\]/,
nolink: /^!?\[(?!\s*\])((?:\[[^\[\]]*\]|\\[\[\]]|[^\[\]])*)\](?:\[\])?/,
reflinkSearch: "reflink|nolink(?!\\()",
emStrong: {
lDelim: /^(?:\*+(?:([punct_])|[^\s*]))|^_+(?:([punct*])|([^\s_]))/,
rDelimAst: /^[^_*]*?\_\_[^_*]*?\*[^_*]*?(?=\_\_)|[punct_](\*+)(?=[\s]|$)|[^punct*_\s](\*+)(?=[punct_\s]|$)|[punct_\s](\*+)(?=[^punct*_\s])|[\s](\*+)(?=[punct_])|[punct_](\*+)(?=[punct_])|[^punct*_\s](\*+)(?=[^punct*_\s])/,
rDelimUnd: /^[^_*]*?\*\*[^_*]*?\_[^_*]*?(?=\*\*)|[punct*](\_+)(?=[\s]|$)|[^punct*_\s](\_+)(?=[punct*\s]|$)|[punct*\s](\_+)(?=[^punct*_\s])|[\s](\_+)(?=[punct*])|[punct*](\_+)(?=[punct*])/
},
code: /^(`+)([^`]|[^`][\s\S]*?[^`])\1(?!`)/,
br: /^( {2,}|\\)\n(?!\s*$)/,
del: m,
text: /^(`+|[^`])(?:(?= {2,}\n)|[\s\S]*?(?:(?=[\\<!\[`*_]|\b_|$)|[^ ](?= {2,}\n)))/,
punctuation: /^([\spunctuation])/
};
function T(e) {
return e.replace(/---/g, "—").replace(/--/g, "").replace(/(^|[-\u2014/(\[{"\s])'/g, "$1").replace(/'/g, "").replace(/(^|[-\u2014/(\[{\u2018\s])"/g, "$1“").replace(/"/g, "”").replace(/\.{3}/g, "…")
}
function R(e) {
for (var t, u = "", n = e.length, r = 0; r < n; r++) t = e.charCodeAt(r), u += "&#" + (t = .5 < Math.random() ? "x" + t.toString(16) : t) + ";";
return u
}
S._punctuation = "!\"#$%&'()+\\-.,/:;<=>?@\\[\\]`^{|}~", S.punctuation = f(S.punctuation).replace(/punctuation/g, S._punctuation).getRegex(), S.blockSkip = /\[[^\]]*?\]\([^\)]*?\)|`[^`]*?`|<[^>]*?>/g, S.escapedEmSt = /\\\*|\\_/g, S._comment = f($._comment).replace("(?:--\x3e|$)", "--\x3e").getRegex(), S.emStrong.lDelim = f(S.emStrong.lDelim).replace(/punct/g, S._punctuation).getRegex(), S.emStrong.rDelimAst = f(S.emStrong.rDelimAst, "g").replace(/punct/g, S._punctuation).getRegex(), S.emStrong.rDelimUnd = f(S.emStrong.rDelimUnd, "g").replace(/punct/g, S._punctuation).getRegex(), S._escapes = /\\([!"#$%&'()*+,\-./:;<=>?@\[\]\\^_`{|}~])/g, S._scheme = /[a-zA-Z][a-zA-Z0-9+.-]{1,31}/, S._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])?)+(?![-_])/, S.autolink = f(S.autolink).replace("scheme", S._scheme).replace("email", S._email).getRegex(), S._attribute = /\s+[a-zA-Z:_][\w.:-]*(?:\s*=\s*"[^"]*"|\s*=\s*'[^']*'|\s*=\s*[^\s"'=<>`]+)?/, S.tag = f(S.tag).replace("comment", S._comment).replace("attribute", S._attribute).getRegex(), S._label = /(?:\[(?:\\.|[^\[\]\\])*\]|\\.|`[^`]*`|[^\[\]\\`])*?/, S._href = /<(?:\\.|[^\n<>\\])+>|[^\s\x00-\x1f]*/, S._title = /"(?:\\"?|[^"\\])*"|'(?:\\'?|[^'\\])*'|\((?:\\\)?|[^)\\])*\)/, S.link = f(S.link).replace("label", S._label).replace("href", S._href).replace("title", S._title).getRegex(), S.reflink = f(S.reflink).replace("label", S._label).getRegex(), S.reflinkSearch = f(S.reflinkSearch, "g").replace("reflink", S.reflink).replace("nolink", S.nolink).getRegex(), S.normal = b({}, S), S.pedantic = b({}, S.normal, {
strong: {
start: /^__|\*\*/,
middle: /^__(?=\S)([\s\S]*?\S)__(?!_)|^\*\*(?=\S)([\s\S]*?\S)\*\*(?!\*)/,
endAst: /\*\*(?!\*)/g,
endUnd: /__(?!_)/g
},
em: {
start: /^_|\*/,
middle: /^()\*(?=\S)([\s\S]*?\S)\*(?!\*)|^_(?=\S)([\s\S]*?\S)_(?!_)/,
endAst: /\*(?!\*)/g,
endUnd: /_(?!_)/g
},
link: f(/^!?\[(label)\]\((.*?)\)/).replace("label", S._label).getRegex(),
reflink: f(/^!?\[(label)\]\s*\[([^\]]*)\]/).replace("label", S._label).getRegex()
}), S.gfm = b({}, S.normal, {
escape: f(S.escape).replace("])", "~|])").getRegex(),
_extended_email: /[A-Za-z0-9._+-]+(@)[a-zA-Z0-9-_]+(?:\.[a-zA-Z0-9-_]*[a-zA-Z0-9])+(?![-_])/,
url: /^((?:ftp|https?):\/\/|www\.)(?:[a-zA-Z0-9\-]+\.?)+[^\s<]*|^email/,
_backpedal: /(?:[^?!.,:;*_~()&]+|\([^)]*\)|&(?![a-zA-Z0-9]+;$)|[?!.,:;*_~)]+(?!$))+/,
del: /^(~~?)(?=[^\s~])([\s\S]*?[^\s~])\1(?=[^~]|$)/,
text: /^([`~]+|[^`~])(?:(?= {2,}\n)|(?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)|[\s\S]*?(?:(?=[\\<!\[`*~_]|\b_|https?:\/\/|ftp:\/\/|www\.|$)|[^ ](?= {2,}\n)|[^a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-](?=[a-zA-Z0-9.!#$%&'*+\/=?_`{\|}~-]+@)))/
}), S.gfm.url = f(S.gfm.url, "i").replace("email", S.gfm._extended_email).getRegex(), S.breaks = b({}, S.gfm, {
br: f(S.br).replace("{2,}", "*").getRegex(),
text: f(S.gfm.text).replace("\\b_", "\\b_| {2,}\n").replace(/\{2,\}/g, "*").getRegex()
});
var I = function () {
function u(e) {
this.tokens = [], this.tokens.links = Object.create(null), this.options = e || r.defaults, this.options.tokenizer = this.options.tokenizer || new z, this.tokenizer = this.options.tokenizer, this.tokenizer.options = this.options, (this.tokenizer.lexer = this).inlineQueue = [], this.state = {
inLink: !1,
inRawBlock: !1,
top: !0
};
e = {block: $.normal, inline: S.normal};
this.options.pedantic ? (e.block = $.pedantic, e.inline = S.pedantic) : this.options.gfm && (e.block = $.gfm, this.options.breaks ? e.inline = S.breaks : e.inline = S.gfm), this.tokenizer.rules = e
}
u.lex = function (e, t) {
return new u(t).lex(e)
}, u.lexInline = function (e, t) {
return new u(t).inlineTokens(e)
};
var e, t, n = u.prototype;
return n.lex = function (e) {
var t;
for (e = e.replace(/\r\n|\r/g, "\n").replace(/\t/g, " "), this.blockTokens(e, this.tokens); t = this.inlineQueue.shift();) this.inlineTokens(t.src, t.tokens);
return this.tokens
}, n.blockTokens = function (r, t) {
var u, e, i, n, s = this;
for (void 0 === t && (t = []), this.options.pedantic && (r = r.replace(/^ +$/gm, "")); r;) if (!(this.options.extensions && this.options.extensions.block && this.options.extensions.block.some(function (e) {
return !!(u = e.call({lexer: s}, r, t)) && (r = r.substring(u.raw.length), t.push(u), !0)
}))) if (u = this.tokenizer.space(r)) r = r.substring(u.raw.length), u.type && t.push(u); else if (u = this.tokenizer.code(r)) r = r.substring(u.raw.length), !(e = t[t.length - 1]) || "paragraph" !== e.type && "text" !== e.type ? t.push(u) : (e.raw += "\n" + u.raw, e.text += "\n" + u.text, this.inlineQueue[this.inlineQueue.length - 1].src = e.text); else if (u = this.tokenizer.fences(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.heading(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.hr(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.blockquote(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.list(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.html(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.def(r)) r = r.substring(u.raw.length), !(e = t[t.length - 1]) || "paragraph" !== e.type && "text" !== e.type ? this.tokens.links[u.tag] || (this.tokens.links[u.tag] = {
href: u.href,
title: u.title
}) : (e.raw += "\n" + u.raw, e.text += "\n" + u.raw, this.inlineQueue[this.inlineQueue.length - 1].src = e.text); else if (u = this.tokenizer.table(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.lheading(r)) r = r.substring(u.raw.length), t.push(u); else if (i = r, this.options.extensions && this.options.extensions.startBlock && function () {
var t, u = 1 / 0, n = r.slice(1);
s.options.extensions.startBlock.forEach(function (e) {
"number" == typeof (t = e.call({lexer: this}, n)) && 0 <= t && (u = Math.min(u, t))
}), u < 1 / 0 && 0 <= u && (i = r.substring(0, u + 1))
}(), this.state.top && (u = this.tokenizer.paragraph(i))) e = t[t.length - 1], n && "paragraph" === e.type ? (e.raw += "\n" + u.raw, e.text += "\n" + u.text, this.inlineQueue.pop(), this.inlineQueue[this.inlineQueue.length - 1].src = e.text) : t.push(u), n = i.length !== r.length, r = r.substring(u.raw.length); else if (u = this.tokenizer.text(r)) r = r.substring(u.raw.length), (e = t[t.length - 1]) && "text" === e.type ? (e.raw += "\n" + u.raw, e.text += "\n" + u.text, this.inlineQueue.pop(), this.inlineQueue[this.inlineQueue.length - 1].src = e.text) : t.push(u); else if (r) {
var l = "Infinite loop on byte: " + r.charCodeAt(0);
if (this.options.silent) {
console.error(l);
break
}
throw new Error(l)
}
return this.state.top = !0, t
}, n.inline = function (e, t) {
this.inlineQueue.push({src: e, tokens: t})
}, n.inlineTokens = function (r, t) {
var u, e, i, s = this;
void 0 === t && (t = []);
var n, l, a, D = r;
if (this.tokens.links) {
var o = Object.keys(this.tokens.links);
if (0 < o.length) for (; null != (n = this.tokenizer.rules.inline.reflinkSearch.exec(D));) o.includes(n[0].slice(n[0].lastIndexOf("[") + 1, -1)) && (D = D.slice(0, n.index) + "[" + y("a", n[0].length - 2) + "]" + D.slice(this.tokenizer.rules.inline.reflinkSearch.lastIndex))
}
for (; null != (n = this.tokenizer.rules.inline.blockSkip.exec(D));) D = D.slice(0, n.index) + "[" + y("a", n[0].length - 2) + "]" + D.slice(this.tokenizer.rules.inline.blockSkip.lastIndex);
for (; null != (n = this.tokenizer.rules.inline.escapedEmSt.exec(D));) D = D.slice(0, n.index) + "++" + D.slice(this.tokenizer.rules.inline.escapedEmSt.lastIndex);
for (; r;) if (l || (a = ""), l = !1, !(this.options.extensions && this.options.extensions.inline && this.options.extensions.inline.some(function (e) {
return !!(u = e.call({lexer: s}, r, t)) && (r = r.substring(u.raw.length), t.push(u), !0)
}))) if (u = this.tokenizer.escape(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.tag(r)) r = r.substring(u.raw.length), (e = t[t.length - 1]) && "text" === u.type && "text" === e.type ? (e.raw += u.raw, e.text += u.text) : t.push(u); else if (u = this.tokenizer.link(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.reflink(r, this.tokens.links)) r = r.substring(u.raw.length), (e = t[t.length - 1]) && "text" === u.type && "text" === e.type ? (e.raw += u.raw, e.text += u.text) : t.push(u); else if (u = this.tokenizer.emStrong(r, D, a)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.codespan(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.br(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.del(r)) r = r.substring(u.raw.length), t.push(u); else if (u = this.tokenizer.autolink(r, R)) r = r.substring(u.raw.length), t.push(u); else if (this.state.inLink || !(u = this.tokenizer.url(r, R))) {
if (i = r, this.options.extensions && this.options.extensions.startInline && function () {
var t, u = 1 / 0, n = r.slice(1);
s.options.extensions.startInline.forEach(function (e) {
"number" == typeof (t = e.call({lexer: this}, n)) && 0 <= t && (u = Math.min(u, t))
}), u < 1 / 0 && 0 <= u && (i = r.substring(0, u + 1))
}(), u = this.tokenizer.inlineText(i, T)) r = r.substring(u.raw.length), "_" !== u.raw.slice(-1) && (a = u.raw.slice(-1)), l = !0, (e = t[t.length - 1]) && "text" === e.type ? (e.raw += u.raw, e.text += u.text) : t.push(u); else if (r) {
var c = "Infinite loop on byte: " + r.charCodeAt(0);
if (this.options.silent) {
console.error(c);
break
}
throw new Error(c)
}
} else r = r.substring(u.raw.length), t.push(u);
return t
}, e = u, t = [{
key: "rules", get: function () {
return {block: $, inline: S}
}
}], (n = null) && i(e.prototype, n), t && i(e, t), u
}(), Z = function () {
function e(e) {
this.options = e || r.defaults
}
var t = e.prototype;
return t.code = function (e, t, u) {
var n = (t || "").match(/\S*/)[0];
return !this.options.highlight || null != (t = this.options.highlight(e, n)) && t !== e && (u = !0, e = t), e = e.replace(/\n$/, "") + "\n", n ? '<pre><code class="' + this.options.langPrefix + c(n, !0) + '">' + (u ? e : c(e, !0)) + "</code></pre>\n" : "<pre><code>" + (u ? e : c(e, !0)) + "</code></pre>\n"
}, t.blockquote = function (e) {
return "<blockquote>\n" + e + "</blockquote>\n"
}, t.html = function (e) {
return e
}, t.heading = function (e, t, u, n) {
return this.options.headerIds ? "<h" + t + ' id="' + this.options.headerPrefix + n.slug(u) + '">' + e + "</h" + t + ">\n" : "<h" + t + ">" + e + "</h" + t + ">\n"
}, t.hr = function () {
return this.options.xhtml ? "<hr/>\n" : "<hr>\n"
}, t.list = function (e, t, u) {
var n = t ? "ol" : "ul";
return "<" + n + (t && 1 !== u ? ' start="' + u + '"' : "") + ">\n" + e + "</" + n + ">\n"
}, t.listitem = function (e) {
return "<li>" + e + "</li>\n"
}, t.checkbox = function (e) {
return "<input " + (e ? 'checked="" ' : "") + 'disabled="" type="checkbox"' + (this.options.xhtml ? " /" : "") + "> "
}, t.paragraph = function (e) {
return "<p>" + e + "</p>\n"
}, t.table = function (e, t) {
return "<table>\n<thead>\n" + e + "</thead>\n" + (t = t && "<tbody>" + t + "</tbody>") + "</table>\n"
}, t.tablerow = function (e) {
return "<tr>\n" + e + "</tr>\n"
}, t.tablecell = function (e, t) {
var u = t.header ? "th" : "td";
return (t.align ? "<" + u + ' align="' + t.align + '">' : "<" + u + ">") + e + "</" + u + ">\n"
}, t.strong = function (e) {
return "<strong>" + e + "</strong>"
}, t.em = function (e) {
return "<em>" + e + "</em>"
}, t.codespan = function (e) {
return "<code>" + e + "</code>"
}, t.br = function () {
return this.options.xhtml ? "<br/>" : "<br>"
}, t.del = function (e) {
return "<del>" + e + "</del>"
}, t.link = function (e, t, u) {
if (null === (e = A(this.options.sanitize, this.options.baseUrl, e))) return u;
e = '<a href="' + c(e) + '"';
return t && (e += ' title="' + t + '"'), e += ">" + u + "</a>"
}, t.image = function (e, t, u) {
if (null === (e = A(this.options.sanitize, this.options.baseUrl, e))) return u;
u = '<img src="' + e + '" alt="' + u + '"';
return t && (u += ' title="' + t + '"'), u += this.options.xhtml ? "/>" : ">"
}, t.text = function (e) {
return e
}, e
}(), q = function () {
function e() {
}
var t = e.prototype;
return t.strong = function (e) {
return e
}, t.em = function (e) {
return e
}, t.codespan = function (e) {
return e
}, t.del = function (e) {
return e
}, t.html = function (e) {
return e
}, t.text = function (e) {
return e
}, t.link = function (e, t, u) {
return "" + u
}, t.image = function (e, t, u) {
return "" + u
}, t.br = function () {
return ""
}, e
}(), O = function () {
function e() {
this.seen = {}
}
var t = e.prototype;
return t.serialize = function (e) {
return e.toLowerCase().trim().replace(/<[!\/a-z].*?>/gi, "").replace(/[\u2000-\u206F\u2E00-\u2E7F\\'!"#$%&()*+,./:;<=>?@[\]^`{|}~]/g, "").replace(/\s/g, "-")
}, t.getNextSafeSlug = function (e, t) {
var u = e, n = 0;
if (this.seen.hasOwnProperty(u)) for (n = this.seen[e]; u = e + "-" + ++n, this.seen.hasOwnProperty(u);) ;
return t || (this.seen[e] = n, this.seen[u] = 0), u
}, t.slug = function (e, t) {
void 0 === t && (t = {});
e = this.serialize(e);
return this.getNextSafeSlug(e, t.dryrun)
}, e
}(), L = function () {
function u(e) {
this.options = e || r.defaults, this.options.renderer = this.options.renderer || new Z, this.renderer = this.options.renderer, this.renderer.options = this.options, this.textRenderer = new q, this.slugger = new O
}
u.parse = function (e, t) {
return new u(t).parse(e)
}, u.parseInline = function (e, t) {
return new u(t).parseInline(e)
};
var e = u.prototype;
return e.parse = function (e, t) {
void 0 === t && (t = !0);
for (var u, n, r, i, s, l, a, D, o, c, h, p, f, g, F, A, d = "", C = e.length, k = 0; k < C; k++) if (D = e[k], !(this.options.extensions && this.options.extensions.renderers && this.options.extensions.renderers[D.type]) || !1 === (A = this.options.extensions.renderers[D.type].call({parser: this}, D)) && ["space", "hr", "heading", "code", "table", "blockquote", "list", "html", "paragraph", "text"].includes(D.type)) switch (D.type) {
case"space":
continue;
case"hr":
d += this.renderer.hr();
continue;
case"heading":
d += this.renderer.heading(this.parseInline(D.tokens), D.depth, x(this.parseInline(D.tokens, this.textRenderer)), this.slugger);
continue;
case"code":
d += this.renderer.code(D.text, D.lang, D.escaped);
continue;
case"table":
for (l = o = "", r = D.header.length, u = 0; u < r; u++) l += this.renderer.tablecell(this.parseInline(D.header[u].tokens), {
header: !0,
align: D.align[u]
});
for (o += this.renderer.tablerow(l), a = "", r = D.rows.length, u = 0; u < r; u++) {
for (l = "", i = (s = D.rows[u]).length, n = 0; n < i; n++) l += this.renderer.tablecell(this.parseInline(s[n].tokens), {
header: !1,
align: D.align[n]
});
a += this.renderer.tablerow(l)
}
d += this.renderer.table(o, a);
continue;
case"blockquote":
a = this.parse(D.tokens), d += this.renderer.blockquote(a);
continue;
case"list":
for (o = D.ordered, E = D.start, c = D.loose, r = D.items.length, a = "", u = 0; u < r; u++) f = (p = D.items[u]).checked, g = p.task, h = "", p.task && (F = this.renderer.checkbox(f), c ? 0 < p.tokens.length && "paragraph" === p.tokens[0].type ? (p.tokens[0].text = F + " " + p.tokens[0].text, p.tokens[0].tokens && 0 < p.tokens[0].tokens.length && "text" === p.tokens[0].tokens[0].type && (p.tokens[0].tokens[0].text = F + " " + p.tokens[0].tokens[0].text)) : p.tokens.unshift({
type: "text",
text: F
}) : h += F), h += this.parse(p.tokens, c), a += this.renderer.listitem(h, g, f);
d += this.renderer.list(a, o, E);
continue;
case"html":
d += this.renderer.html(D.text);
continue;
case"paragraph":
d += this.renderer.paragraph(this.parseInline(D.tokens));
continue;
case"text":
for (a = D.tokens ? this.parseInline(D.tokens) : D.text; k + 1 < C && "text" === e[k + 1].type;) a += "\n" + ((D = e[++k]).tokens ? this.parseInline(D.tokens) : D.text);
d += t ? this.renderer.paragraph(a) : a;
continue;
default:
var E = 'Token with "' + D.type + '" type was not found.';
if (this.options.silent) return void console.error(E);
throw new Error(E)
} else d += A || "";
return d
}, e.parseInline = function (e, t) {
t = t || this.renderer;
for (var u, n, r = "", i = e.length, s = 0; s < i; s++) if (u = e[s], !(this.options.extensions && this.options.extensions.renderers && this.options.extensions.renderers[u.type]) || !1 === (n = this.options.extensions.renderers[u.type].call({parser: this}, u)) && ["escape", "html", "link", "image", "strong", "em", "codespan", "br", "del", "text"].includes(u.type)) switch (u.type) {
case"escape":
r += t.text(u.text);
break;
case"html":
r += t.html(u.text);
break;
case"link":
r += t.link(u.href, u.title, this.parseInline(u.tokens, t));
break;
case"image":
r += t.image(u.href, u.title, u.text);
break;
case"strong":
r += t.strong(this.parseInline(u.tokens, t));
break;
case"em":
r += t.em(this.parseInline(u.tokens, t));
break;
case"codespan":
r += t.codespan(u.text);
break;
case"br":
r += t.br();
break;
case"del":
r += t.del(this.parseInline(u.tokens, t));
break;
case"text":
r += t.text(u.text);
break;
default:
var l = 'Token with "' + u.type + '" type was not found.';
if (this.options.silent) return void console.error(l);
throw new Error(l)
} else r += n || "";
return r
}, u
}();
function j(e, u, n) {
if (null == e) throw new Error("marked(): input parameter is undefined or null");
if ("string" != typeof e) throw new Error("marked(): input parameter is of type " + Object.prototype.toString.call(e) + ", string expected");
if ("function" == typeof u && (n = u, u = null), v(u = b({}, j.defaults, u || {})), n) {
var r, i = u.highlight;
try {
r = I.lex(e, u)
} catch (e) {
return n(e)
}
var s = function (t) {
var e;
if (!t) try {
u.walkTokens && j.walkTokens(r, u.walkTokens), e = L.parse(r, u)
} catch (e) {
t = e
}
return u.highlight = i, t ? n(t) : n(null, e)
};
if (!i || i.length < 3) return s();
if (delete u.highlight, !r.length) return s();
var l = 0;
return j.walkTokens(r, function (u) {
"code" === u.type && (l++, setTimeout(function () {
i(u.text, u.lang, function (e, t) {
return e ? s(e) : (null != t && t !== u.text && (u.text = t, u.escaped = !0), void (0 === --l && s()))
})
}, 0))
}), void (0 === l && s())
}
try {
var t = I.lex(e, u);
return u.walkTokens && j.walkTokens(t, u.walkTokens), L.parse(t, u)
} catch (e) {
if (e.message += "\nPlease report this to https://github.com/markedjs/marked.", u.silent) return "<p>An error occurred:</p><pre>" + c(e.message + "", !0) + "</pre>";
throw e
}
}
j.options = j.setOptions = function (e) {
return b(j.defaults, e), e = j.defaults, r.defaults = e, j
}, j.getDefaults = e, j.defaults = r.defaults, j.use = function () {
for (var e = arguments.length, t = new Array(e), u = 0; u < e; u++) t[u] = arguments[u];
var n, r = b.apply(void 0, [{}].concat(t)), s = j.defaults.extensions || {renderers: {}, childTokens: {}};
t.forEach(function (l) {
var t;
l.extensions && (n = !0, l.extensions.forEach(function (r) {
if (!r.name) throw new Error("extension name required");
var i;
if (r.renderer && (i = s.renderers ? s.renderers[r.name] : null, s.renderers[r.name] = i ? function () {
for (var e = arguments.length, t = new Array(e), u = 0; u < e; u++) t[u] = arguments[u];
var n = r.renderer.apply(this, t);
return n = !1 === n ? i.apply(this, t) : n
} : r.renderer), r.tokenizer) {
if (!r.level || "block" !== r.level && "inline" !== r.level) throw new Error("extension level must be 'block' or 'inline'");
s[r.level] ? s[r.level].unshift(r.tokenizer) : s[r.level] = [r.tokenizer], r.start && ("block" === r.level ? s.startBlock ? s.startBlock.push(r.start) : s.startBlock = [r.start] : "inline" === r.level && (s.startInline ? s.startInline.push(r.start) : s.startInline = [r.start]))
}
r.childTokens && (s.childTokens[r.name] = r.childTokens)
})), l.renderer && function () {
var e, s = j.defaults.renderer || new Z;
for (e in l.renderer) !function (r) {
var i = s[r];
s[r] = function () {
for (var e = arguments.length, t = new Array(e), u = 0; u < e; u++) t[u] = arguments[u];
var n = l.renderer[r].apply(s, t);
return n = !1 === n ? i.apply(s, t) : n
}
}(e);
r.renderer = s
}(), l.tokenizer && function () {
var e, s = j.defaults.tokenizer || new z;
for (e in l.tokenizer) !function (r) {
var i = s[r];
s[r] = function () {
for (var e = arguments.length, t = new Array(e), u = 0; u < e; u++) t[u] = arguments[u];
var n = l.tokenizer[r].apply(s, t);
return n = !1 === n ? i.apply(s, t) : n
}
}(e);
r.tokenizer = s
}(), l.walkTokens && (t = j.defaults.walkTokens, r.walkTokens = function (e) {
l.walkTokens.call(this, e), t && t.call(this, e)
}), n && (r.extensions = s), j.setOptions(r)
})
}, j.walkTokens = function (e, l) {
for (var a, t = D(e); !(a = t()).done;) !function () {
var t = a.value;
switch (l.call(j, t), t.type) {
case"table":
for (var e = D(t.header); !(u = e()).done;) {
var u = u.value;
j.walkTokens(u.tokens, l)
}
for (var n, r = D(t.rows); !(n = r()).done;) for (var i = D(n.value); !(s = i()).done;) {
var s = s.value;
j.walkTokens(s.tokens, l)
}
break;
case"list":
j.walkTokens(t.items, l);
break;
default:
j.defaults.extensions && j.defaults.extensions.childTokens && j.defaults.extensions.childTokens[t.type] ? j.defaults.extensions.childTokens[t.type].forEach(function (e) {
j.walkTokens(t[e], l)
}) : t.tokens && j.walkTokens(t.tokens, l)
}
}()
}, j.parseInline = function (e, t) {
if (null == e) throw new Error("marked.parseInline(): input parameter is undefined or null");
if ("string" != typeof e) throw new Error("marked.parseInline(): input parameter is of type " + Object.prototype.toString.call(e) + ", string expected");
v(t = b({}, j.defaults, t || {}));
try {
var u = I.lexInline(e, t);
return t.walkTokens && j.walkTokens(u, t.walkTokens), L.parseInline(u, t)
} catch (e) {
if (e.message += "\nPlease report this to https://github.com/markedjs/marked.", t.silent) return "<p>An error occurred:</p><pre>" + c(e.message + "", !0) + "</pre>";
throw e
}
}, j.Parser = L, j.parser = L.parse, j.Renderer = Z, j.TextRenderer = q, j.Lexer = I, j.lexer = I.lex, j.Tokenizer = z, j.Slugger = O;
var P = (j.parse = j).options, Q = j.setOptions, U = j.use, M = j.walkTokens, N = j.parseInline, X = j,
G = L.parse, m = I.lex;
r.Lexer = I, r.Parser = L, r.Renderer = Z, r.Slugger = O, r.TextRenderer = q, r.Tokenizer = z, r.getDefaults = e, r.lexer = m, r.marked = j, r.options = P, r.parse = X, r.parseInline = N, r.parser = G, r.setOptions = Q, r.use = U, r.walkTokens = M, Object.defineProperty(r, "__esModule", {value: !0})
});
</script>
<article class="markdown-body" id="md"></article>
<script>
let timeout = setTimeout(() => {
const reg = /\\u([\d\w]{4})/gi;
let md_content = fba.getVar('md_content')
fba.log(md_content)
let res
/*md_content = md_content.replace(reg, function (match, grp) {
return String.fromCharCode(parseInt(grp, 16));
})*//*.replace(/\\n/gi, '\n').replace(/\\t/gi, '\t').replace(/\\r/gi, '\r')*/
eval(`res = md_content`)
fba.log(res)
document.getElementById('md').innerHTML = marked.parse(res);
clearTimeout(timeout)
}, 100)
</script>
</body>
</html>