help3xsl/README.prism.js.txt |   10 
 help3xsl/prism.css           |  274 -------
 help3xsl/prism.js            | 1531 -------------------------------------------
 3 files changed, 25 insertions(+), 1790 deletions(-)

New commits:
commit 5573c118ebe4b2b5328b328170c21bf77cc9f2e8
Author:     Olivier Hallot <olivier.hal...@libreoffice.org>
AuthorDate: Fri Mar 4 13:31:51 2022 -0300
Commit:     Olivier Hallot <olivier.hal...@libreoffice.org>
CommitDate: Fri Mar 4 17:38:26 2022 +0100

    Update prism.js used in the Help
    
    version 1.2.7
    
    Change-Id: Ibec037314046a2f17a9c6c2b9c67d9353c761319
    Reviewed-on: https://gerrit.libreoffice.org/c/help/+/131028
    Tested-by: Jenkins
    Reviewed-by: Olivier Hallot <olivier.hal...@libreoffice.org>

diff --git a/help3xsl/README.prism.js.txt b/help3xsl/README.prism.js.txt
index fe0acc0d2..d23a5b658 100644
--- a/help3xsl/README.prism.js.txt
+++ b/help3xsl/README.prism.js.txt
@@ -39,6 +39,14 @@ Add class 'language-visual-basic' and 'line-numbers' to 
<code> as in
 
 <xsl:template match="bascode">
     <div class="bascode" itemscope="true" 
itemtype="http://schema.org/SoftwareSourceCode"; itemprop="codeSampleType" 
content="snippet">
-   <pre><code class="language-visual-basic line-numbers"><xsl:apply-templates 
/></code></pre></div>
+        <xsl:attribute name="data-tooltip"><xsl:value-of 
select="$ui_copyclip"/></xsl:attribute>
+        <pre><code class="language-visual-basic 
line-numbers"><xsl:apply-templates /></code></pre>
+    </div>
 </xsl:template>
 
+<xsl:template match="pycode">
+    <div class="pycode" itemscope="true" 
itemtype="http://schema.org/SoftwareSourceCode"; itemprop="codeSampleType" 
content="snippet">
+        <xsl:attribute name="data-tooltip"><xsl:value-of 
select="$ui_copyclip"/></xsl:attribute>
+        <pre><code class="language-python line-numbers"><xsl:apply-templates 
/></code></pre>
+    </div>
+</xsl:template>
diff --git a/help3xsl/prism.css b/help3xsl/prism.css
index 8bd96d9cc..e10549dfe 100644
--- a/help3xsl/prism.css
+++ b/help3xsl/prism.css
@@ -1,270 +1,4 @@
-/* PrismJS 1.20.0
-https://prismjs.com/download.html#themes=prism-coy&languages=markup+css+clike+javascript+python+visual-basic&plugins=line-numbers+normalize-whitespace
 */
-/**
- * prism.js Coy theme for JavaScript, CoffeeScript, CSS and HTML
- * Based on https://github.com/tshedor/workshop-wp-theme (Example: 
http://workshop.kansan.com/category/sessions/basics or 
http://workshop.timshedor.com/category/sessions/basics);
- * @author Tim  Shedor
- */
-
-code[class*="language-"],
-pre[class*="language-"] {
-       color: black;
-       background: none;
-       font-family: Consolas, Monaco, 'Andale Mono', 'Ubuntu Mono', monospace;
-       font-size: 1em;
-       text-align: left;
-       white-space: pre;
-       word-spacing: normal;
-       word-break: normal;
-       word-wrap: normal;
-       line-height: 1.5;
-
-       -moz-tab-size: 4;
-       -o-tab-size: 4;
-       tab-size: 4;
-
-       -webkit-hyphens: none;
-       -moz-hyphens: none;
-       -ms-hyphens: none;
-       hyphens: none;
-}
-
-/* Code blocks */
-pre[class*="language-"] {
-       position: relative;
-       margin: .5em 0;
-       overflow: visible;
-       padding: 0;
-}
-pre[class*="language-"]>code {
-       position: relative;
-       border-left: 10px solid #358ccb;
-       box-shadow: -1px 0px 0px 0px #358ccb, 0px 0px 0px 1px #dfdfdf;
-       background-color: #fdfdfd;
-       background-image: linear-gradient(transparent 50%, rgba(69, 142, 209, 
0.04) 50%);
-       background-size: 3em 3em;
-       background-origin: content-box;
-       background-attachment: local;
-}
-
-code[class*="language"] {
-       max-height: inherit;
-       height: inherit;
-       padding: 0 1em;
-       display: block;
-       overflow: auto;
-}
-
-/* Margin bottom to accommodate shadow */
-:not(pre) > code[class*="language-"],
-pre[class*="language-"] {
-       background-color: #fdfdfd;
-       -webkit-box-sizing: border-box;
-       -moz-box-sizing: border-box;
-       box-sizing: border-box;
-       margin-bottom: 1em;
-}
-
-/* Inline code */
-:not(pre) > code[class*="language-"] {
-       position: relative;
-       padding: .2em;
-       border-radius: 0.3em;
-       color: #c92c2c;
-       border: 1px solid rgba(0, 0, 0, 0.1);
-       display: inline;
-       white-space: normal;
-}
-
-pre[class*="language-"]:before,
-pre[class*="language-"]:after {
-       content: '';
-       z-index: -2;
-       display: block;
-       position: absolute;
-       bottom: 0.75em;
-       left: 0.18em;
-       width: 40%;
-       height: 20%;
-       max-height: 13em;
-       box-shadow: 0px 13px 8px #979797;
-       -webkit-transform: rotate(-2deg);
-       -moz-transform: rotate(-2deg);
-       -ms-transform: rotate(-2deg);
-       -o-transform: rotate(-2deg);
-       transform: rotate(-2deg);
-}
-
-:not(pre) > code[class*="language-"]:after,
-pre[class*="language-"]:after {
-       right: 0.75em;
-       left: auto;
-       -webkit-transform: rotate(2deg);
-       -moz-transform: rotate(2deg);
-       -ms-transform: rotate(2deg);
-       -o-transform: rotate(2deg);
-       transform: rotate(2deg);
-}
-
-.token.comment,
-.token.block-comment,
-.token.prolog,
-.token.doctype,
-.token.cdata {
-       color: #7D8B99;
-}
-
-.token.punctuation {
-       color: #5F6364;
-}
-
-.token.property,
-.token.tag,
-.token.boolean,
-.token.number,
-.token.function-name,
-.token.constant,
-.token.symbol,
-.token.deleted {
-       color: #c92c2c;
-}
-
-.token.selector,
-.token.attr-name,
-.token.string,
-.token.char,
-.token.function,
-.token.builtin,
-.token.inserted {
-       color: #2f9c0a;
-}
-
-.token.operator,
-.token.entity,
-.token.url,
-.token.variable {
-       color: #a67f59;
-       background: rgba(255, 255, 255, 0.5);
-}
-
-.token.atrule,
-.token.attr-value,
-.token.keyword,
-.token.class-name {
-       color: #1990b8;
-}
-
-.token.regex,
-.token.important {
-       color: #e90;
-}
-
-.language-css .token.string,
-.style .token.string {
-       color: #a67f59;
-       background: rgba(255, 255, 255, 0.5);
-}
-
-.token.important {
-       font-weight: normal;
-}
-
-.token.bold {
-       font-weight: bold;
-}
-.token.italic {
-       font-style: italic;
-}
-
-.token.entity {
-       cursor: help;
-}
-
-.token.namespace {
-       opacity: .7;
-}
-
-@media screen and (max-width: 767px) {
-       pre[class*="language-"]:before,
-       pre[class*="language-"]:after {
-               bottom: 14px;
-               box-shadow: none;
-       }
-
-}
-
-/* Plugin styles */
-.token.tab:not(:empty):before,
-.token.cr:before,
-.token.lf:before {
-       color: #e0d7d1;
-}
-
-/* Plugin styles: Line Numbers */
-pre[class*="language-"].line-numbers.line-numbers {
-       padding-left: 0;
-}
-
-pre[class*="language-"].line-numbers.line-numbers code {
-       padding-left: 3.8em;
-}
-
-pre[class*="language-"].line-numbers.line-numbers .line-numbers-rows {
-       left: 0;
-}
-
-/* Plugin styles: Line Highlight */
-pre[class*="language-"][data-line] {
-       padding-top: 0;
-       padding-bottom: 0;
-       padding-left: 0;
-}
-pre[data-line] code {
-       position: relative;
-       padding-left: 4em;
-}
-pre .line-highlight {
-       margin-top: 0;
-}
-
-pre[class*="language-"].line-numbers {
-       position: relative;
-       padding-left: 3.8em;
-       counter-reset: linenumber;
-}
-
-pre[class*="language-"].line-numbers > code {
-       position: relative;
-       white-space: inherit;
-}
-
-.line-numbers .line-numbers-rows {
-       position: absolute;
-       pointer-events: none;
-       top: 0;
-       font-size: 100%;
-       left: -3.8em;
-       width: 3em; /* works for line-numbers below 1000 lines */
-       letter-spacing: -1px;
-       border-right: 1px solid #999;
-
-       -webkit-user-select: none;
-       -moz-user-select: none;
-       -ms-user-select: none;
-       user-select: none;
-
-}
-
-       .line-numbers-rows > span {
-               display: block;
-               counter-increment: linenumber;
-       }
-
-               .line-numbers-rows > span:before {
-                       content: counter(linenumber);
-                       color: #999;
-                       display: block;
-                       padding-right: 0.8em;
-                       text-align: right;
-               }
-
+/* PrismJS 1.27.0
+https://prismjs.com/download.html#themes=prism-coy&languages=markup+css+clike+javascript+basic+python+visual-basic&plugins=line-numbers+normalize-whitespace
 */
+code[class*=language-],pre[class*=language-]{color:#000;background:0 
0;font-family:Consolas,Monaco,'Andale Mono','Ubuntu 
Mono',monospace;font-size:1em;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}pre[class*=language-]{position:relative;margin:.5em
 
0;overflow:visible;padding:1px}pre[class*=language-]>code{position:relative;z-index:1;border-left:10px
 solid #358ccb;box-shadow:-1px 0 0 0 #358ccb,0 0 0 1px 
#dfdfdf;background-color:#fdfdfd;background-image:linear-gradient(transparent 
50%,rgba(69,142,209,.04) 50%);background-size:3em 
3em;background-origin:content-box;background-attachment:local}code[class*=language-]{max-height:inherit;height:inherit;padding:0
 
1em;display:block;overflow:auto}:not(pre)>code[class*=language-],pre[class*=language-]{background-color:#fdfdfd;-webkit-box-sizing:border-box;-moz-box-sizing:border-bo
 
x;box-sizing:border-box;margin-bottom:1em}:not(pre)>code[class*=language-]{position:relative;padding:.2em;border-radius:.3em;color:#c92c2c;border:1px
 solid 
rgba(0,0,0,.1);display:inline;white-space:normal}pre[class*=language-]:after,pre[class*=language-]:before{content:'';display:block;position:absolute;bottom:.75em;left:.18em;width:40%;height:20%;max-height:13em;box-shadow:0
 13px 8px 
#979797;-webkit-transform:rotate(-2deg);-moz-transform:rotate(-2deg);-ms-transform:rotate(-2deg);-o-transform:rotate(-2deg);transform:rotate(-2deg)}pre[class*=language-]:after{right:.75em;left:auto;-webkit-transform:rotate(2deg);-moz-transform:rotate(2deg);-ms-transform:rotate(2deg);-o-transform:rotate(2deg);transform:rotate(2deg)}.token.block-comment,.token.cdata,.token.comment,.token.doctype,.token.prolog{color:#7d8b99}.token.punctuation{color:#5f6364}.token.boolean,.token.constant,.token.deleted,.token.function-name,.token.number,.token.property,.token.symbol,.token.tag{color:#c92c2c}.token.attr-nam
 
e,.token.builtin,.token.char,.token.function,.token.inserted,.token.selector,.token.string{color:#2f9c0a}.token.entity,.token.operator,.token.url,.token.variable{color:#a67f59;background:rgba(255,255,255,.5)}.token.atrule,.token.attr-value,.token.class-name,.token.keyword{color:#1990b8}.token.important,.token.regex{color:#e90}.language-css
 .token.string,.style 
.token.string{color:#a67f59;background:rgba(255,255,255,.5)}.token.important{font-weight:400}.token.bold{font-weight:700}.token.italic{font-style:italic}.token.entity{cursor:help}.token.namespace{opacity:.7}@media
 screen and 
(max-width:767px){pre[class*=language-]:after,pre[class*=language-]:before{bottom:14px;box-shadow:none}}pre[class*=language-].line-numbers.line-numbers{padding-left:0}pre[class*=language-].line-numbers.line-numbers
 code{padding-left:3.8em}pre[class*=language-].line-numbers.line-numbers 
.line-numbers-rows{left:0}pre[class*=language-][data-line]{padding-top:0;padding-bottom:0;padding-left:0}pre[data-line]
 co
 de{position:relative;padding-left:4em}pre .line-highlight{margin-top:0}
+pre[class*=language-].line-numbers{position:relative;padding-left:3.8em;counter-reset:linenumber}pre[class*=language-].line-numbers>code{position:relative;white-space:inherit}.line-numbers
 
.line-numbers-rows{position:absolute;pointer-events:none;top:0;font-size:100%;left:-3.8em;width:3em;letter-spacing:-1px;border-right:1px
 solid 
#999;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.line-numbers-rows>span{display:block;counter-increment:linenumber}.line-numbers-rows>span:before{content:counter(linenumber);color:#999;display:block;padding-right:.8em;text-align:right}
diff --git a/help3xsl/prism.js b/help3xsl/prism.js
index 108011888..7d2faf61f 100644
--- a/help3xsl/prism.js
+++ b/help3xsl/prism.js
@@ -1,1519 +1,12 @@
-/* PrismJS 1.20.0
-https://prismjs.com/download.html#themes=prism-coy&languages=markup+css+clike+javascript+python+visual-basic&plugins=line-numbers+normalize-whitespace
 */
-var _self = (typeof window !== 'undefined')
-       ? window   // if in browser
-       : (
-               (typeof WorkerGlobalScope !== 'undefined' && self instanceof 
WorkerGlobalScope)
-               ? self // if in worker
-               : {}   // if in node js
-       );
-
-/**
- * Prism: Lightweight, robust, elegant syntax highlighting
- * MIT license http://www.opensource.org/licenses/mit-license.php/
- * @author Lea Verou http://lea.verou.me
- */
-
-var Prism = (function (_self){
-
-// Private helper vars
-var lang = /\blang(?:uage)?-([\w-]+)\b/i;
-var uniqueId = 0;
-
-
-var _ = {
-       manual: _self.Prism && _self.Prism.manual,
-       disableWorkerMessageHandler: _self.Prism && 
_self.Prism.disableWorkerMessageHandler,
-       util: {
-               encode: function encode(tokens) {
-                       if (tokens instanceof Token) {
-                               return new Token(tokens.type, 
encode(tokens.content), tokens.alias);
-                       } else if (Array.isArray(tokens)) {
-                               return tokens.map(encode);
-                       } else {
-                               return tokens.replace(/&/g, 
'&amp;').replace(/</g, '&lt;').replace(/\u00a0/g, ' ');
-                       }
-               },
-
-               type: function (o) {
-                       return Object.prototype.toString.call(o).slice(8, -1);
-               },
-
-               objId: function (obj) {
-                       if (!obj['__id']) {
-                               Object.defineProperty(obj, '__id', { value: 
++uniqueId });
-                       }
-                       return obj['__id'];
-               },
-
-               // Deep clone a language definition (e.g. to extend it)
-               clone: function deepClone(o, visited) {
-                       var clone, id, type = _.util.type(o);
-                       visited = visited || {};
-
-                       switch (type) {
-                               case 'Object':
-                                       id = _.util.objId(o);
-                                       if (visited[id]) {
-                                               return visited[id];
-                                       }
-                                       clone = {};
-                                       visited[id] = clone;
-
-                                       for (var key in o) {
-                                               if (o.hasOwnProperty(key)) {
-                                                       clone[key] = 
deepClone(o[key], visited);
-                                               }
-                                       }
-
-                                       return clone;
-
-                               case 'Array':
-                                       id = _.util.objId(o);
-                                       if (visited[id]) {
-                                               return visited[id];
-                                       }
-                                       clone = [];
-                                       visited[id] = clone;
-
-                                       o.forEach(function (v, i) {
-                                               clone[i] = deepClone(v, 
visited);
-                                       });
-
-                                       return clone;
-
-                               default:
-                                       return o;
-                       }
-               },
-
-               /**
-                * Returns the Prism language of the given element set by a 
`language-xxxx` or `lang-xxxx` class.
-                *
-                * If no language is set for the element or the element is 
`null` or `undefined`, `none` will be returned.
-                *
-                * @param {Element} element
-                * @returns {string}
-                */
-               getLanguage: function (element) {
-                       while (element && !lang.test(element.className)) {
-                               element = element.parentElement;
-                       }
-                       if (element) {
-                               return (element.className.match(lang) || [, 
'none'])[1].toLowerCase();
-                       }
-                       return 'none';
-               },
-
-               /**
-                * Returns the script element that is currently executing.
-                *
-                * This does __not__ work for line script element.
-                *
-                * @returns {HTMLScriptElement | null}
-                */
-               currentScript: function () {
-                       if (typeof document === 'undefined') {
-                               return null;
-                       }
-                       if ('currentScript' in document) {
-                               return document.currentScript;
-                       }
-
-                       // IE11 workaround
-                       // we'll get the src of the current script by parsing 
IE11's error stack trace
-                       // this will not work for inline scripts
-
-                       try {
-                               throw new Error();
-                       } catch (err) {
-                               // Get file src url from stack. Specifically 
works with the format of stack traces in IE.
-                               // A stack will look like this:
-                               //
-                               // Error
-                               //    at _.util.currentScript 
(http://localhost/components/prism-core.js:119:5)
-                               //    at Global code 
(http://localhost/components/prism-core.js:606:1)
-
-                               var src = (/at 
[^(\r\n]*\((.*):.+:.+\)$/i.exec(err.stack) || [])[1];
-                               if (src) {
-                                       var scripts = 
document.getElementsByTagName('script');
-                                       for (var i in scripts) {
-                                               if (scripts[i].src == src) {
-                                                       return scripts[i];
-                                               }
-                                       }
-                               }
-                               return null;
-                       }
-               }
-       },
-
-       languages: {
-               extend: function (id, redef) {
-                       var lang = _.util.clone(_.languages[id]);
-
-                       for (var key in redef) {
-                               lang[key] = redef[key];
-                       }
-
-                       return lang;
-               },
-
-               /**
-                * Insert a token before another token in a language literal
-                * As this needs to recreate the object (we cannot actually 
insert before keys in object literals),
-                * we cannot just provide an object, we need an object and a 
key.
-                * @param inside The key (or language id) of the parent
-                * @param before The key to insert before.
-                * @param insert Object with the key/value pairs to insert
-                * @param root The object that contains `inside`. If equal to 
Prism.languages, it can be omitted.
-                */
-               insertBefore: function (inside, before, insert, root) {
-                       root = root || _.languages;
-                       var grammar = root[inside];
-                       var ret = {};
-
-                       for (var token in grammar) {
-                               if (grammar.hasOwnProperty(token)) {
-
-                                       if (token == before) {
-                                               for (var newToken in insert) {
-                                                       if 
(insert.hasOwnProperty(newToken)) {
-                                                               ret[newToken] = 
insert[newToken];
-                                                       }
-                                               }
-                                       }
-
-                                       // Do not insert token which also occur 
in insert. See #1525
-                                       if (!insert.hasOwnProperty(token)) {
-                                               ret[token] = grammar[token];
-                                       }
-                               }
-                       }
-
-                       var old = root[inside];
-                       root[inside] = ret;
-
-                       // Update references in other language definitions
-                       _.languages.DFS(_.languages, function(key, value) {
-                               if (value === old && key != inside) {
-                                       this[key] = ret;
-                               }
-                       });
-
-                       return ret;
-               },
-
-               // Traverse a language definition with Depth First Search
-               DFS: function DFS(o, callback, type, visited) {
-                       visited = visited || {};
-
-                       var objId = _.util.objId;
-
-                       for (var i in o) {
-                               if (o.hasOwnProperty(i)) {
-                                       callback.call(o, i, o[i], type || i);
-
-                                       var property = o[i],
-                                           propertyType = 
_.util.type(property);
-
-                                       if (propertyType === 'Object' && 
!visited[objId(property)]) {
-                                               visited[objId(property)] = true;
-                                               DFS(property, callback, null, 
visited);
-                                       }
-                                       else if (propertyType === 'Array' && 
!visited[objId(property)]) {
-                                               visited[objId(property)] = true;
-                                               DFS(property, callback, i, 
visited);
-                                       }
-                               }
-                       }
-               }
-       },
-       plugins: {},
-
-       highlightAll: function(async, callback) {
-               _.highlightAllUnder(document, async, callback);
-       },
-
-       highlightAllUnder: function(container, async, callback) {
-               var env = {
-                       callback: callback,
-                       container: container,
-                       selector: 'code[class*="language-"], 
[class*="language-"] code, code[class*="lang-"], [class*="lang-"] code'
-               };
-
-               _.hooks.run('before-highlightall', env);
-
-               env.elements = 
Array.prototype.slice.apply(env.container.querySelectorAll(env.selector));
-
-               _.hooks.run('before-all-elements-highlight', env);
-
-               for (var i = 0, element; element = env.elements[i++];) {
-                       _.highlightElement(element, async === true, 
env.callback);
-               }
-       },
-
-       highlightElement: function(element, async, callback) {
-               // Find language
-               var language = _.util.getLanguage(element);
-               var grammar = _.languages[language];
-
-               // Set language on the element, if not present
-               element.className = element.className.replace(lang, 
'').replace(/\s+/g, ' ') + ' language-' + language;
-
-               // Set language on the parent, for styling
-               var parent = element.parentNode;
-               if (parent && parent.nodeName.toLowerCase() === 'pre') {
-                       parent.className = parent.className.replace(lang, 
'').replace(/\s+/g, ' ') + ' language-' + language;
-               }
-
-               var code = element.textContent;
-
-               var env = {
-                       element: element,
-                       language: language,
-                       grammar: grammar,
-                       code: code
-               };
-
-               function insertHighlightedCode(highlightedCode) {
-                       env.highlightedCode = highlightedCode;
-
-                       _.hooks.run('before-insert', env);
-
-                       env.element.innerHTML = env.highlightedCode;
-
-                       _.hooks.run('after-highlight', env);
-                       _.hooks.run('complete', env);
-                       callback && callback.call(env.element);
-               }
-
-               _.hooks.run('before-sanity-check', env);
-
-               if (!env.code) {
-                       _.hooks.run('complete', env);
-                       callback && callback.call(env.element);
-                       return;
-               }
-
-               _.hooks.run('before-highlight', env);
-
-               if (!env.grammar) {
-                       insertHighlightedCode(_.util.encode(env.code));
-                       return;
-               }
-
-               if (async && _self.Worker) {
-                       var worker = new Worker(_.filename);
-
-                       worker.onmessage = function(evt) {
-                               insertHighlightedCode(evt.data);
-                       };
-
-                       worker.postMessage(JSON.stringify({
-                               language: env.language,
-                               code: env.code,
-                               immediateClose: true
-                       }));
-               }
-               else {
-                       insertHighlightedCode(_.highlight(env.code, 
env.grammar, env.language));
-               }
-       },
-
-       highlight: function (text, grammar, language) {
-               var env = {
-                       code: text,
-                       grammar: grammar,
-                       language: language
-               };
-               _.hooks.run('before-tokenize', env);
-               env.tokens = _.tokenize(env.code, env.grammar);
-               _.hooks.run('after-tokenize', env);
-               return Token.stringify(_.util.encode(env.tokens), env.language);
-       },
-
-       tokenize: function(text, grammar) {
-               var rest = grammar.rest;
-               if (rest) {
-                       for (var token in rest) {
-                               grammar[token] = rest[token];
-                       }
-
-                       delete grammar.rest;
-               }
-
-               var tokenList = new LinkedList();
-               addAfter(tokenList, tokenList.head, text);
-
-               matchGrammar(text, tokenList, grammar, tokenList.head, 0);
-
-               return toArray(tokenList);
-       },
-
-       hooks: {
-               all: {},
-
-               add: function (name, callback) {
-                       var hooks = _.hooks.all;
-
-                       hooks[name] = hooks[name] || [];
-
-                       hooks[name].push(callback);
-               },
-
-               run: function (name, env) {
-                       var callbacks = _.hooks.all[name];
-
-                       if (!callbacks || !callbacks.length) {
-                               return;
-                       }
-
-                       for (var i=0, callback; callback = callbacks[i++];) {
-                               callback(env);
-                       }
-               }
-       },
-
-       Token: Token
-};
-
-_self.Prism = _;
-
-function Token(type, content, alias, matchedStr, greedy) {
-       this.type = type;
-       this.content = content;
-       this.alias = alias;
-       // Copy of the full string this token was created from
-       this.length = (matchedStr || '').length|0;
-       this.greedy = !!greedy;
-}
-
-Token.stringify = function stringify(o, language) {
-       if (typeof o == 'string') {
-               return o;
-       }
-       if (Array.isArray(o)) {
-               var s = '';
-               o.forEach(function (e) {
-                       s += stringify(e, language);
-               });
-               return s;
-       }
-
-       var env = {
-               type: o.type,
-               content: stringify(o.content, language),
-               tag: 'span',
-               classes: ['token', o.type],
-               attributes: {},
-               language: language
-       };
-
-       var aliases = o.alias;
-       if (aliases) {
-               if (Array.isArray(aliases)) {
-                       Array.prototype.push.apply(env.classes, aliases);
-               } else {
-                       env.classes.push(aliases);
-               }
-       }
-
-       _.hooks.run('wrap', env);
-
-       var attributes = '';
-       for (var name in env.attributes) {
-               attributes += ' ' + name + '="' + (env.attributes[name] || 
'').replace(/"/g, '&quot;') + '"';
-       }
-
-       return '<' + env.tag + ' class="' + env.classes.join(' ') + '"' + 
attributes + '>' + env.content + '</' + env.tag + '>';
-};
-
-/**
- * @param {string} text
- * @param {LinkedList<string | Token>} tokenList
- * @param {any} grammar
- * @param {LinkedListNode<string | Token>} startNode
- * @param {number} startPos
- * @param {boolean} [oneshot=false]
- * @param {string} [target]
- */
-function matchGrammar(text, tokenList, grammar, startNode, startPos, oneshot, 
target) {
-       for (var token in grammar) {
-               if (!grammar.hasOwnProperty(token) || !grammar[token]) {
-                       continue;
-               }
-
-               var patterns = grammar[token];
-               patterns = Array.isArray(patterns) ? patterns : [patterns];
-
-               for (var j = 0; j < patterns.length; ++j) {
-                       if (target && target == token + ',' + j) {
-                               return;
-                       }
-
-                       var pattern = patterns[j],
-                               inside = pattern.inside,
-                               lookbehind = !!pattern.lookbehind,
-                               greedy = !!pattern.greedy,
-                               lookbehindLength = 0,
-                               alias = pattern.alias;
-
-                       if (greedy && !pattern.pattern.global) {
-                               // Without the global flag, lastIndex won't work
-                               var flags = 
pattern.pattern.toString().match(/[imsuy]*$/)[0];
-                               pattern.pattern = 
RegExp(pattern.pattern.source, flags + 'g');
-                       }
-
-                       pattern = pattern.pattern || pattern;
-
-                       for ( // iterate the token list and keep track of the 
current token/string position
-                               var currentNode = startNode.next, pos = 
startPos;
-                               currentNode !== tokenList.tail;
-                               pos += currentNode.value.length, currentNode = 
currentNode.next
-                       ) {
-
-                               var str = currentNode.value;
-
-                               if (tokenList.length > text.length) {
-                                       // Something went terribly wrong, 
ABORT, ABORT!
-                                       return;
-                               }
-
-                               if (str instanceof Token) {
-                                       continue;
-                               }
-
-                               var removeCount = 1; // this is the to 
parameter of removeBetween
-
-                               if (greedy && currentNode != 
tokenList.tail.prev) {
-                                       pattern.lastIndex = pos;
-                                       var match = pattern.exec(text);
-                                       if (!match) {
-                                               break;
-                                       }
-
-                                       var from = match.index + (lookbehind && 
match[1] ? match[1].length : 0);
-                                       var to = match.index + match[0].length;
-                                       var p = pos;
-
-                                       // find the node that contains the match
-                                       p += currentNode.value.length;
-                                       while (from >= p) {
-                                               currentNode = currentNode.next;
-                                               p += currentNode.value.length;
-                                       }
-                                       // adjust pos (and p)
-                                       p -= currentNode.value.length;
-                                       pos = p;
-
-                                       // the current node is a Token, then 
the match starts inside another Token, which is invalid
-                                       if (currentNode.value instanceof Token) 
{
-                                               continue;
-                                       }
-
-                                       // find the last node which is affected 
by this match
-                                       for (
-                                               var k = currentNode;
-                                               k !== tokenList.tail && (p < to 
|| (typeof k.value === 'string' && !k.prev.value.greedy));
-                                               k = k.next
-                                       ) {
-                                               removeCount++;
-                                               p += k.value.length;
-                                       }
-                                       removeCount--;
-
-                                       // replace with the new match
-                                       str = text.slice(pos, p);
-                                       match.index -= pos;
-                               } else {
-                                       pattern.lastIndex = 0;
-
-                                       var match = pattern.exec(str);
-                               }
-
-                               if (!match) {
-                                       if (oneshot) {
-                                               break;
-                                       }
-
-                                       continue;
-                               }
-
-                               if (lookbehind) {
-                                       lookbehindLength = match[1] ? 
match[1].length : 0;
-                               }
-
-                               var from = match.index + lookbehindLength,
-                                       match = 
match[0].slice(lookbehindLength),
-                                       to = from + match.length,
-                                       before = str.slice(0, from),
-                                       after = str.slice(to);
-
-                               var removeFrom = currentNode.prev;
-
-                               if (before) {
-                                       removeFrom = addAfter(tokenList, 
removeFrom, before);
-                                       pos += before.length;
-                               }
-
-                               removeRange(tokenList, removeFrom, removeCount);
-
-                               var wrapped = new Token(token, inside ? 
_.tokenize(match, inside) : match, alias, match, greedy);
-                               currentNode = addAfter(tokenList, removeFrom, 
wrapped);
-
-                               if (after) {
-                                       addAfter(tokenList, currentNode, after);
-                               }
-
-
-                               if (removeCount > 1)
-                                       matchGrammar(text, tokenList, grammar, 
currentNode.prev, pos, true, token + ',' + j);
-
-                               if (oneshot)
-                                       break;
-                       }
-               }
-       }
-}
-
-/**
- * @typedef LinkedListNode
- * @property {T} value
- * @property {LinkedListNode<T> | null} prev The previous node.
- * @property {LinkedListNode<T> | null} next The next node.
- * @template T
- */
-
-/**
- * @template T
- */
-function LinkedList() {
-       /** @type {LinkedListNode<T>} */
-       var head = { value: null, prev: null, next: null };
-       /** @type {LinkedListNode<T>} */
-       var tail = { value: null, prev: head, next: null };
-       head.next = tail;
-
-       /** @type {LinkedListNode<T>} */
-       this.head = head;
-       /** @type {LinkedListNode<T>} */
-       this.tail = tail;
-       this.length = 0;
-}
-
-/**
- * Adds a new node with the given value to the list.
- * @param {LinkedList<T>} list
- * @param {LinkedListNode<T>} node
- * @param {T} value
- * @returns {LinkedListNode<T>} The added node.
- * @template T
- */
-function addAfter(list, node, value) {
-       // assumes that node != list.tail && values.length >= 0
-       var next = node.next;
-
-       var newNode = { value: value, prev: node, next: next };
-       node.next = newNode;
-       next.prev = newNode;
-       list.length++;
-
-       return newNode;
-}
-/**
- * Removes `count` nodes after the given node. The given node will not be 
removed.
- * @param {LinkedList<T>} list
- * @param {LinkedListNode<T>} node
- * @param {number} count
- * @template T
- */
-function removeRange(list, node, count) {
-       var next = node.next;
-       for (var i = 0; i < count && next !== list.tail; i++) {
-               next = next.next;
-       }
-       node.next = next;
-       next.prev = node;
-       list.length -= i;
-}
-/**
- * @param {LinkedList<T>} list
- * @returns {T[]}
- * @template T
- */
-function toArray(list) {
-       var array = [];
-       var node = list.head.next;
-       while (node !== list.tail) {
-               array.push(node.value);
-               node = node.next;
-       }
-       return array;
-}
-
-
-if (!_self.document) {
-       if (!_self.addEventListener) {
-               // in Node.js
-               return _;
-       }
-
-       if (!_.disableWorkerMessageHandler) {
-               // In worker
-               _self.addEventListener('message', function (evt) {
-                       var message = JSON.parse(evt.data),
-                               lang = message.language,
-                               code = message.code,
-                               immediateClose = message.immediateClose;
-
-                       _self.postMessage(_.highlight(code, _.languages[lang], 
lang));
-                       if (immediateClose) {
-                               _self.close();
-                       }
-               }, false);
-       }
-
-       return _;
-}
-
-//Get current script and highlight
-var script = _.util.currentScript();
-
-if (script) {
-       _.filename = script.src;
-
-       if (script.hasAttribute('data-manual')) {
-               _.manual = true;
-       }
-}
-
-function highlightAutomaticallyCallback() {
-       if (!_.manual) {
-               _.highlightAll();
-       }
-}
-
-if (!_.manual) {
-       // If the document state is "loading", then we'll use DOMContentLoaded.
-       // If the document state is "interactive" and the prism.js script is 
deferred, then we'll also use the
-       // DOMContentLoaded event because there might be some plugins or 
languages which have also been deferred and they
-       // might take longer one animation frame to execute which can create a 
race condition where only some plugins have
-       // been loaded when Prism.highlightAll() is executed, depending on how 
fast resources are loaded.
-       // See https://github.com/PrismJS/prism/issues/2102
-       var readyState = document.readyState;
-       if (readyState === 'loading' || readyState === 'interactive' && script 
&& script.defer) {
-               document.addEventListener('DOMContentLoaded', 
highlightAutomaticallyCallback);
-       } else {
-               if (window.requestAnimationFrame) {
-                       
window.requestAnimationFrame(highlightAutomaticallyCallback);
-               } else {
-                       window.setTimeout(highlightAutomaticallyCallback, 16);
-               }
-       }
-}
-
-return _;
-
-})(_self);
-
-if (typeof module !== 'undefined' && module.exports) {
-       module.exports = Prism;
-}
-
-// hack for components to work correctly in node.js
-if (typeof global !== 'undefined') {
-       global.Prism = Prism;
-}
-;
-Prism.languages.markup = {
-       'comment': /<!--[\s\S]*?-->/,
-       'prolog': /<\?[\s\S]+?\?>/,
-       'doctype': {
-               // https://www.w3.org/TR/xml/#NT-doctypedecl
-               pattern: 
/<!DOCTYPE(?:[^>"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|<!--(?:[^-]|-(?!->))*-->)*\]\s*)?>/i,
-               greedy: true,
-               inside: {
-                       'internal-subset': {
-                               pattern: /(\[)[\s\S]+(?=\]>$)/,
-                               lookbehind: true,
-                               greedy: true,
-                               inside: null // see below
-                       },
-                       'string': {
-                               pattern: /"[^"]*"|'[^']*'/,
-                               greedy: true
-                       },
-                       'punctuation': /^<!|>$|[[\]]/,
-                       'doctype-tag': /^DOCTYPE/,
-                       'name': /[^\s<>'"]+/
-               }
-       },
-       'cdata': /<!\[CDATA\[[\s\S]*?]]>/i,
-       'tag': {
-               pattern: 
/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,
-               greedy: true,
-               inside: {
-                       'tag': {
-                               pattern: /^<\/?[^\s>\/]+/,
-                               inside: {
-                                       'punctuation': /^<\/?/,
-                                       'namespace': /^[^\s>\/:]+:/
-                               }
-                       },
-                       'attr-value': {
-                               pattern: /=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,
-                               inside: {
-                                       'punctuation': [
-                                               {
-                                                       pattern: /^=/,
-                                                       alias: 'attr-equals'
-                                               },
-                                               /"|'/
-                                       ]
-                               }
-                       },
-                       'punctuation': /\/?>/,
-                       'attr-name': {
-                               pattern: /[^\s>\/]+/,
-                               inside: {
-                                       'namespace': /^[^\s>\/:]+:/
-                               }
-                       }
-
-               }
-       },
-       'entity': [
-               {
-                       pattern: /&[\da-z]{1,8};/i,
-                       alias: 'named-entity'
-               },
-               /&#x?[\da-f]{1,8};/i
-       ]
-};
-
-Prism.languages.markup['tag'].inside['attr-value'].inside['entity'] =
-       Prism.languages.markup['entity'];
-Prism.languages.markup['doctype'].inside['internal-subset'].inside = 
Prism.languages.markup;
-
-// Plugin to make entity title show the real entity, idea by Roman Komarov
-Prism.hooks.add('wrap', function (env) {
-
-       if (env.type === 'entity') {
-               env.attributes['title'] = env.content.replace(/&amp;/, '&');
-       }
-});
-
-Object.defineProperty(Prism.languages.markup.tag, 'addInlined', {
-       /**
-        * Adds an inlined language to markup.
-        *
-        * An example of an inlined language is CSS with `<style>` tags.
-        *
-        * @param {string} tagName The name of the tag that contains the 
inlined language. This name will be treated as
-        * case insensitive.
-        * @param {string} lang The language key.
-        * @example
-        * addInlined('style', 'css');
-        */
-       value: function addInlined(tagName, lang) {
-               var includedCdataInside = {};
-               includedCdataInside['language-' + lang] = {
-                       pattern: /(^<!\[CDATA\[)[\s\S]+?(?=\]\]>$)/i,
-                       lookbehind: true,
-                       inside: Prism.languages[lang]
-               };
-               includedCdataInside['cdata'] = /^<!\[CDATA\[|\]\]>$/i;
-
-               var inside = {
-                       'included-cdata': {
-                               pattern: /<!\[CDATA\[[\s\S]*?\]\]>/i,
-                               inside: includedCdataInside
-                       }
-               };
-               inside['language-' + lang] = {
-                       pattern: /[\s\S]+/,
-                       inside: Prism.languages[lang]
-               };
-
-               var def = {};
-               def[tagName] = {
-                       pattern: 
RegExp(/(<__[\s\S]*?>)(?:<!\[CDATA\[(?:[^\]]|\](?!\]>))*\]\]>|(?!<!\[CDATA\[)[\s\S])*?(?=<\/__>)/.source.replace(/__/g,
 function () { return tagName; }), 'i'),
-                       lookbehind: true,
-                       greedy: true,
-                       inside: inside
-               };
-
-               Prism.languages.insertBefore('markup', 'cdata', def);
-       }
-});
-
-Prism.languages.html = Prism.languages.markup;
-Prism.languages.mathml = Prism.languages.markup;
-Prism.languages.svg = Prism.languages.markup;
-
-Prism.languages.xml = Prism.languages.extend('markup', {});
-Prism.languages.ssml = Prism.languages.xml;
-Prism.languages.atom = Prism.languages.xml;
-Prism.languages.rss = Prism.languages.xml;
-
-(function (Prism) {
-
-       var string = /("|')(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/;
-
-       Prism.languages.css = {
-               'comment': /\/\*[\s\S]*?\*\//,
-               'atrule': {
-                       pattern: /@[\w-]+[\s\S]*?(?:;|(?=\s*\{))/,
-                       inside: {
-                               'rule': /^@[\w-]+/,
-                               'selector-function-argument': {
-                                       pattern: 
/(\bselector\s*\((?!\s*\))\s*)(?:[^()]|\((?:[^()]|\([^()]*\))*\))+?(?=\s*\))/,
-                                       lookbehind: true,
-                                       alias: 'selector'
-                               }
-                               // See rest below
-                       }
-               },
-               'url': {
-                       pattern: RegExp('url\\((?:' + string.source + 
'|[^\n\r()]*)\\)', 'i'),
-                       greedy: true,
-                       inside: {
-                               'function': /^url/i,
-                               'punctuation': /^\(|\)$/
-                       }
-               },
-               'selector': RegExp('[^{}\\s](?:[^{};"\']|' + string.source + 
')*?(?=\\s*\\{)'),
-               'string': {
-                       pattern: string,
-                       greedy: true
-               },
-               'property': /[-_a-z\xA0-\uFFFF][-\w\xA0-\uFFFF]*(?=\s*:)/i,
-               'important': /!important\b/i,
-               'function': /[-a-z0-9]+(?=\()/i,
-               'punctuation': /[(){};:,]/
-       };
-
-       Prism.languages.css['atrule'].inside.rest = Prism.languages.css;
-
-       var markup = Prism.languages.markup;
-       if (markup) {
-               markup.tag.addInlined('style', 'css');
-
-               Prism.languages.insertBefore('inside', 'attr-value', {
-                       'style-attr': {
-                               pattern: 
/\s*style=("|')(?:\\[\s\S]|(?!\1)[^\\])*\1/i,
-                               inside: {
-                                       'attr-name': {
-                                               pattern: /^\s*style/i,
-                                               inside: markup.tag.inside
-                                       },
-                                       'punctuation': /^\s*=\s*['"]|['"]\s*$/,
-                                       'attr-value': {
-                                               pattern: /.+/i,
-                                               inside: Prism.languages.css
-                                       }
-                               },
-                               alias: 'language-css'
-                       }
-               }, markup.tag);
-       }
-
-}(Prism));
-
-Prism.languages.clike = {
-       'comment': [
-               {
-                       pattern: /(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,
-                       lookbehind: true
-               },
-               {
-                       pattern: /(^|[^\\:])\/\/.*/,
-                       lookbehind: true,
-                       greedy: true
-               }
-       ],
-       'string': {
-               pattern: /(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,
-               greedy: true
-       },
-       'class-name': {
-               pattern: 
/(\b(?:class|interface|extends|implements|trait|instanceof|new)\s+|\bcatch\s+\()[\w.\\]+/i,
-               lookbehind: true,
-               inside: {
-                       'punctuation': /[.\\]/
-               }
-       },
-       'keyword': 
/\b(?:if|else|while|do|for|return|in|instanceof|function|new|try|throw|catch|finally|null|break|continue)\b/,
-       'boolean': /\b(?:true|false)\b/,
-       'function': /\w+(?=\()/,
-       'number': /\b0x[\da-f]+\b|(?:\b\d+\.?\d*|\B\.\d+)(?:e[+-]?\d+)?/i,
-       'operator': /[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,
-       'punctuation': /[{}[\];(),.:]/
-};
-
-Prism.languages.javascript = Prism.languages.extend('clike', {
-       'class-name': [
-               Prism.languages.clike['class-name'],
-               {
-                       pattern: 
/(^|[^$\w\xA0-\uFFFF])[_$A-Z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\.(?:prototype|constructor))/,
-                       lookbehind: true
-               }
-       ],
-       'keyword': [
-               {
-                       pattern: /((?:^|})\s*)(?:catch|finally)\b/,
-                       lookbehind: true
-               },
-               {
-                       pattern: 
/(^|[^.]|\.\.\.\s*)\b(?:as|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|for|from|function|(?:get|set)(?=\s*[\[$\w\xA0-\uFFFF])|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,
-                       lookbehind: true
-               },
-       ],
-       'number': 
/\b(?:(?:0[xX](?:[\dA-Fa-f](?:_[\dA-Fa-f])?)+|0[bB](?:[01](?:_[01])?)+|0[oO](?:[0-7](?:_[0-7])?)+)n?|(?:\d(?:_\d)?)+n|NaN|Infinity)\b|(?:\b(?:\d(?:_\d)?)+\.?(?:\d(?:_\d)?)*|\B\.(?:\d(?:_\d)?)+)(?:[Ee][+-]?(?:\d(?:_\d)?)+)?/,
-       // Allow for all non-ASCII characters (See 
http://stackoverflow.com/a/2008444)
-       'function': 
/#?[_$a-zA-Z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,
-       'operator': 
/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/
-});
-
-Prism.languages.javascript['class-name'][0].pattern = 
/(\b(?:class|interface|extends|implements|instanceof|new)\s+)[\w.\\]+/;
-
-Prism.languages.insertBefore('javascript', 'keyword', {
-       'regex': {
-               pattern: 
/((?:^|[^$\w\xA0-\uFFFF."'\])\s])\s*)\/(?:\[(?:[^\]\\\r\n]|\\.)*]|\\.|[^/\\\[\r\n])+\/[gimyus]{0,6}(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/,
-               lookbehind: true,
-               greedy: true
-       },
-       // This must be declared before keyword because we use "function" 
inside the look-forward
-       'function-variable': {
-               pattern: 
/#?[_$a-zA-Z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[^()]|\([^()]*\))*\)|[_$a-zA-Z\xA0-\uFFFF][$\w\xA0-\uFFFF]*)\s*=>))/,
-               alias: 'function'
-       },
-       'parameter': [
-               {
-                       pattern: 
/(function(?:\s+[_$A-Za-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*)?\s*\(\s*)(?!\s)(?:[^()]|\([^()]*\))+?(?=\s*\))/,
-                       lookbehind: true,
-                       inside: Prism.languages.javascript
-               },
-               {
-                       pattern: 
/[_$a-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*(?=\s*=>)/i,
-                       inside: Prism.languages.javascript
-               },
-               {
-                       pattern: 
/(\(\s*)(?!\s)(?:[^()]|\([^()]*\))+?(?=\s*\)\s*=>)/,
-                       lookbehind: true,
-                       inside: Prism.languages.javascript
-               },
-               {
-                       pattern: 
/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:[_$A-Za-z\xA0-\uFFFF][$\w\xA0-\uFFFF]*\s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()]|\([^()]*\))+?(?=\s*\)\s*\{)/,
-                       lookbehind: true,
-                       inside: Prism.languages.javascript
-               }
-       ],
-       'constant': /\b[A-Z](?:[A-Z_]|\dx?)*\b/
-});
-
-Prism.languages.insertBefore('javascript', 'string', {
-       'template-string': {
-               pattern: 
/`(?:\\[\s\S]|\${(?:[^{}]|{(?:[^{}]|{[^}]*})*})+}|(?!\${)[^\\`])*`/,
-               greedy: true,
-               inside: {
-                       'template-punctuation': {
-                               pattern: /^`|`$/,
-                               alias: 'string'
-                       },
-                       'interpolation': {
-                               pattern: 
/((?:^|[^\\])(?:\\{2})*)\${(?:[^{}]|{(?:[^{}]|{[^}]*})*})+}/,
-                               lookbehind: true,
-                               inside: {
-                                       'interpolation-punctuation': {
-                                               pattern: /^\${|}$/,
-                                               alias: 'punctuation'
-                                       },
-                                       rest: Prism.languages.javascript
-                               }
-                       },
-                       'string': /[\s\S]+/
-               }
-       }
-});
-
-if (Prism.languages.markup) {
-       Prism.languages.markup.tag.addInlined('script', 'javascript');
-}
-
-Prism.languages.js = Prism.languages.javascript;
-
-Prism.languages.python = {
-       'comment': {
-               pattern: /(^|[^\\])#.*/,
-               lookbehind: true
-       },
-       'string-interpolation': {
-               pattern: 
/(?:f|rf|fr)(?:("""|''')[\s\S]*?\1|("|')(?:\\.|(?!\2)[^\\\r\n])*\2)/i,
-               greedy: true,
-               inside: {
-                       'interpolation': {
-                               // "{" <expression> <optional "!s", "!r", or 
"!a"> <optional ":" format specifier> "}"
-                               pattern: 
/((?:^|[^{])(?:{{)*){(?!{)(?:[^{}]|{(?!{)(?:[^{}]|{(?!{)(?:[^{}])+})+})+}/,
-                               lookbehind: true,
-                               inside: {
-                                       'format-spec': {
-                                               pattern: /(:)[^:(){}]+(?=}$)/,
-                                               lookbehind: true
-                                       },
-                                       'conversion-option': {
-                                               pattern: /![sra](?=[:}]$)/,
-                                               alias: 'punctuation'
-                                       },
-                                       rest: null
-                               }
-                       },
-                       'string': /[\s\S]+/
-               }
-       },
-       'triple-quoted-string': {
-               pattern: /(?:[rub]|rb|br)?("""|''')[\s\S]*?\1/i,
-               greedy: true,
-               alias: 'string'
-       },
-       'string': {
-               pattern: /(?:[rub]|rb|br)?("|')(?:\\.|(?!\1)[^\\\r\n])*\1/i,
-               greedy: true
-       },
-       'function': {
-               pattern: /((?:^|\s)def[ \t]+)[a-zA-Z_]\w*(?=\s*\()/g,
-               lookbehind: true
-       },
-       'class-name': {
-               pattern: /(\bclass\s+)\w+/i,
-               lookbehind: true
-       },
-       'decorator': {
-               pattern: /(^\s*)@\w+(?:\.\w+)*/im,
-               lookbehind: true,
-               alias: ['annotation', 'punctuation'],
-               inside: {
-                       'punctuation': /\./
-               }
-       },
-       'keyword': 
/\b(?:and|as|assert|async|await|break|class|continue|def|del|elif|else|except|exec|finally|for|from|global|if|import|in|is|lambda|nonlocal|not|or|pass|print|raise|return|try|while|with|yield)\b/,
-       'builtin': 
/\b(?:__import__|abs|all|any|apply|ascii|basestring|bin|bool|buffer|bytearray|bytes|callable|chr|classmethod|cmp|coerce|compile|complex|delattr|dict|dir|divmod|enumerate|eval|execfile|file|filter|float|format|frozenset|getattr|globals|hasattr|hash|help|hex|id|input|int|intern|isinstance|issubclass|iter|len|list|locals|long|map|max|memoryview|min|next|object|oct|open|ord|pow|property|range|raw_input|reduce|reload|repr|reversed|round|set|setattr|slice|sorted|staticmethod|str|sum|super|tuple|type|unichr|unicode|vars|xrange|zip)\b/,
-       'boolean': /\b(?:True|False|None)\b/,
-       'number': 
/(?:\b(?=\d)|\B(?=\.))(?:0[bo])?(?:(?:\d|0x[\da-f])[\da-f]*\.?\d*|\.\d+)(?:e[+-]?\d+)?j?\b/i,
-       'operator': /[-+%=]=?|!=|\*\*?=?|\/\/?=?|<[<=>]?|>[=>]?|[&|^~]/,
-       'punctuation': /[{}[\];(),.:]/
-};
-
-Prism.languages.python['string-interpolation'].inside['interpolation'].inside.rest
 = Prism.languages.python;
-
-Prism.languages.py = Prism.languages.python;
-
-Prism.languages['visual-basic'] = {
-       'comment': {
-               pattern: /(?:['‘’]|REM\b)(?:[^\r\n_]|_(?:\r\n?|\n)?)*/i,
-               inside: {
-                       'keyword': /^REM/i
-               }
-       },
-       'directive': {
-               pattern: 
/#(?:Const|Else|ElseIf|End|ExternalChecksum|ExternalSource|If|Region)(?:[^\S\r\n]_[^\S\r\n]*(?:\r\n?|\n)|.)+/i,
-               alias: 'comment',
-               greedy: true
-       },
-       'string': {
-               pattern: /\$?["“”](?:["“”]{2}|[^"“”])*["“”]C?/i,
-               greedy: true
-       },
-       'date': {
-               pattern: 
/#[^\S\r\n]*(?:\d+([/-])\d+\1\d+(?:[^\S\r\n]+(?:\d+[^\S\r\n]*(?:AM|PM)|\d+:\d+(?::\d+)?(?:[^\S\r\n]*(?:AM|PM))?))?|(?:\d+[^\S\r\n]*(?:AM|PM)|\d+:\d+(?::\d+)?(?:[^\S\r\n]*(?:AM|PM))?))[^\S\r\n]*#/i,
-               alias: 'builtin'
-       },
-       'number': 
/(?:(?:\b\d+(?:\.\d+)?|\.\d+)(?:E[+-]?\d+)?|&[HO][\dA-F]+)(?:U?[ILS]|[FRD])?/i,
-       'boolean': /\b(?:True|False|Nothing)\b/i,
-       'keyword': 
/\b(?:AddHandler|AddressOf|Alias|And(?:Also)?|As|Boolean|ByRef|Byte|ByVal|Call|Case|Catch|C(?:Bool|Byte|Char|Date|Dbl|Dec|Int|Lng|Obj|SByte|Short|Sng|Str|Type|UInt|ULng|UShort)|Char|Class|Const|Continue|Currency|Date|Decimal|Declare|Default|Delegate|Dim|DirectCast|Do|Double|Each|Else(?:If)?|End(?:If)?|Enum|Erase|Error|Event|Exit|Finally|For|Friend|Function|Get(?:Type|XMLNamespace)?|Global|GoSub|GoTo|Handles|If|Implements|Imports|In|Inherits|Integer|Interface|Is|IsNot|Let|Lib|Like|Long|Loop|Me|Mod|Module|Must(?:Inherit|Override)|My(?:Base|Class)|Namespace|Narrowing|New|Next|Not(?:Inheritable|Overridable)?|Object|Of|On|Operator|Option(?:al)?|Or(?:Else)?|Out|Overloads|Overridable|Overrides|ParamArray|Partial|Private|Property|Protected|Public|RaiseEvent|ReadOnly|ReDim|RemoveHandler|Resume|Return|SByte|Select|Set|Shadows|Shared|short|Single|Static|Step|Stop|String|Structure|Sub|SyncLock|Then|Throw|To|Try|TryCast|Type|TypeOf|U(?:Integer|Long|Short)|Using|Variant|Wend|When|Whil
 e|Widening|With(?:Events)?|WriteOnly|Xor)\b/i,
-       'operator': [
-               /[+\-*/\\^<=>&#@$%!]/,
-               {
-                       pattern: /([^\S\r\n])_(?=[^\S\r\n]*[\r\n])/,
-                       lookbehind: true
-               }
-       ],
-       'punctuation': /[{}().,:?]/
-};
-
-Prism.languages.vb = Prism.languages['visual-basic'];
-
-(function () {
-
-       if (typeof self === 'undefined' || !self.Prism || !self.document) {
-               return;
-       }
-
-       /**
-        * Plugin name which is used as a class name for <pre> which is 
activating the plugin
-        * @type {String}
-        */
-       var PLUGIN_NAME = 'line-numbers';
-
-       /**
-        * Regular expression used for determining line breaks
-        * @type {RegExp}
-        */
-       var NEW_LINE_EXP = /\n(?!$)/g;
-
-       /**
-        * Resizes line numbers spans according to height of line of code
-        * @param {Element} element <pre> element
-        */
-       var _resizeElement = function (element) {
-               var codeStyles = getStyles(element);
-               var whiteSpace = codeStyles['white-space'];
-
-               if (whiteSpace === 'pre-wrap' || whiteSpace === 'pre-line') {
-                       var codeElement = element.querySelector('code');
-                       var lineNumbersWrapper = 
element.querySelector('.line-numbers-rows');
-                       if (!codeElement || !lineNumbersWrapper) {
-                               return;
-                       }
-                       var lineNumberSizer = 
element.querySelector('.line-numbers-sizer');
-                       var codeLines = 
codeElement.textContent.split(NEW_LINE_EXP);
-
-                       if (!lineNumberSizer) {
-                               lineNumberSizer = 
document.createElement('span');
-                               lineNumberSizer.className = 
'line-numbers-sizer';
-
-                               codeElement.appendChild(lineNumberSizer);
-                       }
-
-                       lineNumberSizer.style.display = 'block';
-
-                       codeLines.forEach(function (line, lineNumber) {
-                               lineNumberSizer.textContent = line || '\n';
-                               var lineSize = 
lineNumberSizer.getBoundingClientRect().height;
-                               
lineNumbersWrapper.children[lineNumber].style.height = lineSize + 'px';
-                       });
-
-                       lineNumberSizer.textContent = '';
-                       lineNumberSizer.style.display = 'none';
-               }
-       };
-
-       /**
-        * Returns style declarations for the element
-        * @param {Element} element
-        */
-       var getStyles = function (element) {
-               if (!element) {
-                       return null;
-               }
-
-               return window.getComputedStyle ? getComputedStyle(element) : 
(element.currentStyle || null);
-       };
-
-       window.addEventListener('resize', function () {
-               Array.prototype.forEach.call(document.querySelectorAll('pre.' + 
PLUGIN_NAME), _resizeElement);
-       });
-
-       Prism.hooks.add('complete', function (env) {
-               if (!env.code) {
-                       return;
-               }
-
-               var code = env.element;
-               var pre = code.parentNode;
-
-               // works only for <code> wrapped inside <pre> (not inline)
-               if (!pre || !/pre/i.test(pre.nodeName)) {
-                       return;
-               }
-
-               // Abort if line numbers already exists
-               if (code.querySelector('.line-numbers-rows')) {
-                       return;
-               }
-
-               var addLineNumbers = false;
-               var lineNumbersRegex = /(?:^|\s)line-numbers(?:\s|$)/;
-
-               for (var element = code; element; element = element.parentNode) 
{
-                       if (lineNumbersRegex.test(element.className)) {
-                               addLineNumbers = true;
-                               break;
-                       }
-               }
-
-               // only add line numbers if <code> or one of its ancestors has 
the `line-numbers` class
-               if (!addLineNumbers) {
-                       return;
-               }
-
-               // Remove the class 'line-numbers' from the <code>
-               code.className = code.className.replace(lineNumbersRegex, ' ');
-               // Add the class 'line-numbers' to the <pre>
-               if (!lineNumbersRegex.test(pre.className)) {
-                       pre.className += ' line-numbers';
-               }
-
-               var match = env.code.match(NEW_LINE_EXP);
-               var linesNum = match ? match.length + 1 : 1;
-               var lineNumbersWrapper;
-
-               var lines = new Array(linesNum + 1).join('<span></span>');
-
-               lineNumbersWrapper = document.createElement('span');
-               lineNumbersWrapper.setAttribute('aria-hidden', 'true');
-               lineNumbersWrapper.className = 'line-numbers-rows';
-               lineNumbersWrapper.innerHTML = lines;
-
-               if (pre.hasAttribute('data-start')) {
-                       pre.style.counterReset = 'linenumber ' + 
(parseInt(pre.getAttribute('data-start'), 10) - 1);
-               }
-
-               env.element.appendChild(lineNumbersWrapper);
-
-               _resizeElement(pre);
-
-               Prism.hooks.run('line-numbers', env);
-       });
-
-       Prism.hooks.add('line-numbers', function (env) {
-               env.plugins = env.plugins || {};
-               env.plugins.lineNumbers = true;
-       });
-
-       /**
-        * Global exports
-        */
-       Prism.plugins.lineNumbers = {
-               /**
-                * Returns the node of the given line number in the given 
element.
-                * @param {Element} element A `<pre>` element with line numbers.
-                * @param {Number} number
-                * @returns {Element | undefined}
-                */
-               getLine: function (element, number) {
-                       if (element.tagName !== 'PRE' || 
!element.classList.contains(PLUGIN_NAME)) {
-                               return;
-                       }
-
-                       var lineNumberRows = 
element.querySelector('.line-numbers-rows');
-                       var lineNumberStart = 
parseInt(element.getAttribute('data-start'), 10) || 1;
-                       var lineNumberEnd = lineNumberStart + 
(lineNumberRows.children.length - 1);
-
-                       if (number < lineNumberStart) {
-                               number = lineNumberStart;
-                       }
-                       if (number > lineNumberEnd) {
-                               number = lineNumberEnd;
-                       }
-
-                       var lineIndex = number - lineNumberStart;
-
-                       return lineNumberRows.children[lineIndex];
-               },
-               /**
-                * Resizes the line numbers of the given element.
-                *
-                * This function will not add line numbers. It will only resize 
existing ones.
-                * @param {Element} element A `<pre>` element with line numbers.
-                * @returns {void}
-                */
-               resize: function (element) {
-                       _resizeElement(element);
-               }
-       };
-
-}());
-
-(function() {
-
-var assign = Object.assign || function (obj1, obj2) {
-       for (var name in obj2) {
-               if (obj2.hasOwnProperty(name))
-                       obj1[name] = obj2[name];
-       }
-       return obj1;
-}
-
-function NormalizeWhitespace(defaults) {
-       this.defaults = assign({}, defaults);
-}
-
-function toCamelCase(value) {
-       return value.replace(/-(\w)/g, function(match, firstChar) {
-               return firstChar.toUpperCase();
-       });
-}
-
-function tabLen(str) {
-       var res = 0;
-       for (var i = 0; i < str.length; ++i) {
-               if (str.charCodeAt(i) == '\t'.charCodeAt(0))
-                       res += 3;
-       }
-       return str.length + res;
-}
-
-NormalizeWhitespace.prototype = {
-       setDefaults: function (defaults) {
-               this.defaults = assign(this.defaults, defaults);
-       },
-       normalize: function (input, settings) {
-               settings = assign(this.defaults, settings);
-
-               for (var name in settings) {
-                       var methodName = toCamelCase(name);
-                       if (name !== "normalize" && methodName !== 
'setDefaults' &&
-                                       settings[name] && this[methodName]) {
-                               input = this[methodName].call(this, input, 
settings[name]);
-                       }
-               }
-
-               return input;
-       },
-
-       /*
-        * Normalization methods
-        */
-       leftTrim: function (input) {
-               return input.replace(/^\s+/, '');
-       },
-       rightTrim: function (input) {
-               return input.replace(/\s+$/, '');
-       },
-       tabsToSpaces: function (input, spaces) {
-               spaces = spaces|0 || 4;
-               return input.replace(/\t/g, new Array(++spaces).join(' '));
-       },
-       spacesToTabs: function (input, spaces) {
-               spaces = spaces|0 || 4;
-               return input.replace(RegExp(' {' + spaces + '}', 'g'), '\t');
-       },
-       removeTrailing: function (input) {
-               return input.replace(/\s*?$/gm, '');
-       },
-       // Support for deprecated plugin remove-initial-line-feed
-       removeInitialLineFeed: function (input) {
-               return input.replace(/^(?:\r?\n|\r)/, '');
-       },
-       removeIndent: function (input) {
-               var indents = input.match(/^[^\S\n\r]*(?=\S)/gm);
-
-               if (!indents || !indents[0].length)
-                       return input;
-
-               indents.sort(function(a, b){return a.length - b.length; });
-
-               if (!indents[0].length)
-                       return input;
-
-               return input.replace(RegExp('^' + indents[0], 'gm'), '');
-       },
-       indent: function (input, tabs) {
-               return input.replace(/^[^\S\n\r]*(?=\S)/gm, new 
Array(++tabs).join('\t') + '$&');
-       },
-       breakLines: function (input, characters) {
-               characters = (characters === true) ? 80 : characters|0 || 80;
-
-               var lines = input.split('\n');
-               for (var i = 0; i < lines.length; ++i) {
-                       if (tabLen(lines[i]) <= characters)
-                               continue;
-
-                       var line = lines[i].split(/(\s+)/g),
-                           len = 0;
-
-                       for (var j = 0; j < line.length; ++j) {
-                               var tl = tabLen(line[j]);
-                               len += tl;
-                               if (len > characters) {
-                                       line[j] = '\n' + line[j];
-                                       len = tl;
-                               }
-                       }
-                       lines[i] = line.join('');
-               }
-               return lines.join('\n');
-       }
-};
-
-// Support node modules
-if (typeof module !== 'undefined' && module.exports) {
-       module.exports = NormalizeWhitespace;
-}
-
-// Exit if prism is not loaded
-if (typeof Prism === 'undefined') {
-       return;
-}
-
-Prism.plugins.NormalizeWhitespace = new NormalizeWhitespace({
-       'remove-trailing': true,
-       'remove-indent': true,
-       'left-trim': true,
-       'right-trim': true,
-       /*'break-lines': 80,
-       'indent': 2,*/
-       'remove-initial-line-feed': true,
-       /*'tabs-to-spaces': 4,
-       'spaces-to-tabs': 4*/
-});
-
-Prism.hooks.add('before-sanity-check', function (env) {
-       var Normalizer = Prism.plugins.NormalizeWhitespace;
-
-       // Check settings
-       if (env.settings && env.settings['whitespace-normalization'] === false) 
{
-               return;
-       }
-
-       // Simple mode if there is no env.element
-       if ((!env.element || !env.element.parentNode) && env.code) {
-               env.code = Normalizer.normalize(env.code, env.settings);
-               return;
-       }
-
-       // Normal mode
-       var pre = env.element.parentNode;
-       var clsReg = /(?:^|\s)no-whitespace-normalization(?:\s|$)/;
-       if (!env.code || !pre || pre.nodeName.toLowerCase() !== 'pre' ||
-                       clsReg.test(pre.className) || 
clsReg.test(env.element.className))
-               return;
-
-       var children = pre.childNodes,
-           before = '',
-           after = '',
-           codeFound = false;
-
-       // Move surrounding whitespace from the <pre> tag into the <code> tag
-       for (var i = 0; i < children.length; ++i) {
-               var node = children[i];
-
-               if (node == env.element) {
-                       codeFound = true;
-               } else if (node.nodeName === "#text") {
-                       if (codeFound) {
-                               after += node.nodeValue;
-                       } else {
-                               before += node.nodeValue;
-                       }
-
-                       pre.removeChild(node);
-                       --i;
-               }
-       }
-
-       if (!env.element.children.length || !Prism.plugins.KeepMarkup) {
-               env.code = before + env.code + after;
-               env.code = Normalizer.normalize(env.code, env.settings);
-       } else {
-               // Preserve markup for keep-markup plugin
-               var html = before + env.element.innerHTML + after;
-               env.element.innerHTML = Normalizer.normalize(html, 
env.settings);
-               env.code = env.element.textContent;
-       }
-});
-
-}());
-
+/* PrismJS 1.27.0
+https://prismjs.com/download.html#themes=prism-coy&languages=markup+css+clike+javascript+basic+python+visual-basic&plugins=line-numbers+normalize-whitespace
 */
+var _self="undefined"!=typeof window?window:"undefined"!=typeof 
WorkerGlobalScope&&self instanceof 
WorkerGlobalScope?self:{},Prism=function(u){var 
t=/(?:^|\s)lang(?:uage)?-([\w-]+)(?=\s|$)/i,n=0,e={},M={manual:u.Prism&&u.Prism.manual,disableWorkerMessageHandler:u.Prism&&u.Prism.disableWorkerMessageHandler,util:{encode:function
 e(n){return n instanceof W?new 
W(n.type,e(n.content),n.alias):Array.isArray(n)?n.map(e):n.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/\u00a0/g,"
 ")},type:function(e){return 
Object.prototype.toString.call(e).slice(8,-1)},objId:function(e){return 
e.__id||Object.defineProperty(e,"__id",{value:++n}),e.__id},clone:function 
t(e,r){var 
a,n;switch(r=r||{},M.util.type(e)){case"Object":if(n=M.util.objId(e),r[n])return
 r[n];for(var i in a={},r[n]=a,e)e.hasOwnProperty(i)&&(a[i]=t(e[i],r));return 
a;case"Array":return 
n=M.util.objId(e),r[n]?r[n]:(a=[],r[n]=a,e.forEach(function(e,n){a[n]=t(e,r)}),a);default:return
 e}},getLanguage:function(e){for(;e;){var n=t.exec(e.c
 lassName);if(n)return 
n[1].toLowerCase();e=e.parentElement}return"none"},setLanguage:function(e,n){e.className=e.className.replace(RegExp(t,"gi"),""),e.classList.add("language-"+n)},currentScript:function(){if("undefined"==typeof
 document)return null;if("currentScript"in document)return 
document.currentScript;try{throw new Error}catch(e){var n=(/at 
[^(\r\n]*\((.*):[^:]+:[^:]+\)$/i.exec(e.stack)||[])[1];if(n){var 
t=document.getElementsByTagName("script");for(var r in t)if(t[r].src==n)return 
t[r]}return null}},isActive:function(e,n,t){for(var r="no-"+n;e;){var 
a=e.classList;if(a.contains(n))return!0;if(a.contains(r))return!1;e=e.parentElement}return!!t}},languages:{plain:e,plaintext:e,text:e,txt:e,extend:function(e,n){var
 t=M.util.clone(M.languages[e]);for(var r in n)t[r]=n[r];return 
t},insertBefore:function(t,e,n,r){var a=(r=r||M.languages)[t],i={};for(var l in 
a)if(a.hasOwnProperty(l)){if(l==e)for(var o in 
n)n.hasOwnProperty(o)&&(i[o]=n[o]);n.hasOwnProperty(l)||(i[l]=a[l])}var s=r[t
 ];return 
r[t]=i,M.languages.DFS(M.languages,function(e,n){n===s&&e!=t&&(this[e]=i)}),i},DFS:function
 e(n,t,r,a){a=a||{};var i=M.util.objId;for(var l in 
n)if(n.hasOwnProperty(l)){t.call(n,l,n[l],r||l);var 
o=n[l],s=M.util.type(o);"Object"!==s||a[i(o)]?"Array"!==s||a[i(o)]||(a[i(o)]=!0,e(o,t,l,a)):(a[i(o)]=!0,e(o,t,null,a))}}},plugins:{},highlightAll:function(e,n){M.highlightAllUnder(document,e,n)},highlightAllUnder:function(e,n,t){var
 r={callback:t,container:e,selector:'code[class*="language-"], 
[class*="language-"] code, code[class*="lang-"], [class*="lang-"] 
code'};M.hooks.run("before-highlightall",r),r.elements=Array.prototype.slice.apply(r.container.querySelectorAll(r.selector)),M.hooks.run("before-all-elements-highlight",r);for(var
 
a,i=0;a=r.elements[i++];)M.highlightElement(a,!0===n,r.callback)},highlightElement:function(e,n,t){var
 r=M.util.getLanguage(e),a=M.languages[r];M.util.setLanguage(e,r);var 
i=e.parentElement;i&&"pre"===i.nodeName.toLowerCase()&&M.util.setLanguage(i,r);v
 ar l={element:e,language:r,grammar:a,code:e.textContent};function 
o(e){l.highlightedCode=e,M.hooks.run("before-insert",l),l.element.innerHTML=l.highlightedCode,M.hooks.run("after-highlight",l),M.hooks.run("complete",l),t&&t.call(l.element)}if(M.hooks.run("before-sanity-check",l),(i=l.element.parentElement)&&"pre"===i.nodeName.toLowerCase()&&!i.hasAttribute("tabindex")&&i.setAttribute("tabindex","0"),!l.code)return
 
M.hooks.run("complete",l),void(t&&t.call(l.element));if(M.hooks.run("before-highlight",l),l.grammar)if(n&&u.Worker){var
 s=new 
Worker(M.filename);s.onmessage=function(e){o(e.data)},s.postMessage(JSON.stringify({language:l.language,code:l.code,immediateClose:!0}))}else
 o(M.highlight(l.code,l.grammar,l.language));else 
o(M.util.encode(l.code))},highlight:function(e,n,t){var 
r={code:e,grammar:n,language:t};if(M.hooks.run("before-tokenize",r),!r.grammar)throw
 new Error('The language "'+r.language+'" has no grammar.');return 
r.tokens=M.tokenize(r.code,r.grammar),M.hooks.run("afte
 
r-tokenize",r),W.stringify(M.util.encode(r.tokens),r.language)},tokenize:function(e,n){var
 t=n.rest;if(t){for(var r in t)n[r]=t[r];delete n.rest}var a=new i;return 
I(a,a.head,e),function e(n,t,r,a,i,l){for(var o in 
r)if(r.hasOwnProperty(o)&&r[o]){var s=r[o];s=Array.isArray(s)?s:[s];for(var 
u=0;u<s.length;++u){if(l&&l.cause==o+","+u)return;var 
c=s[u],g=c.inside,f=!!c.lookbehind,h=!!c.greedy,d=c.alias;if(h&&!c.pattern.global){var
 
v=c.pattern.toString().match(/[imsuy]*$/)[0];c.pattern=RegExp(c.pattern.source,v+"g")}for(var
 
p=c.pattern||c,m=a.next,y=i;m!==t.tail&&!(l&&y>=l.reach);y+=m.value.length,m=m.next){var
 k=m.value;if(t.length>n.length)return;if(!(k instanceof W)){var 
x,b=1;if(h){if(!(x=z(p,y,n,f))||x.index>=n.length)break;var 
w=x.index,A=x.index+x[0].length,E=y;for(E+=m.value.length;E<=w;)m=m.next,E+=m.value.length;if(E-=m.value.length,y=E,m.value
 instanceof W)continue;for(var P=m;P!==t.tail&&(E<A||"string"==typeof 
P.value);P=P.next)b++,E+=P.value.length;b--,k=n.slice(y,E),x.inde
 x-=y}else if(!(x=z(p,0,k,f)))continue;var 
w=x.index,L=x[0],S=k.slice(0,w),O=k.slice(w+L.length),j=y+k.length;l&&j>l.reach&&(l.reach=j);var
 C=m.prev;S&&(C=I(t,C,S),y+=S.length),T(t,C,b);var N=new 
W(o,g?M.tokenize(L,g):L,d,L);if(m=I(t,C,N),O&&I(t,m,O),1<b){var 
_={cause:o+","+u,reach:j};e(n,t,r,m.prev,y,_),l&&_.reach>l.reach&&(l.reach=_.reach)}}}}}}(e,a,n,a.head,0),function(e){var
 n=[],t=e.head.next;for(;t!==e.tail;)n.push(t.value),t=t.next;return 
n}(a)},hooks:{all:{},add:function(e,n){var 
t=M.hooks.all;t[e]=t[e]||[],t[e].push(n)},run:function(e,n){var 
t=M.hooks.all[e];if(t&&t.length)for(var 
r,a=0;r=t[a++];)r(n)}},Token:W};function 
W(e,n,t,r){this.type=e,this.content=n,this.alias=t,this.length=0|(r||"").length}function
 z(e,n,t,r){e.lastIndex=n;var a=e.exec(t);if(a&&r&&a[1]){var 
i=a[1].length;a.index+=i,a[0]=a[0].slice(i)}return a}function i(){var 
e={value:null,prev:null,next:null},n={value:null,prev:e,next:null};e.next=n,this.head=e,this.tail=n,this.length=0}function
 I(e,n,t){var r=n.n
 ext,a={value:t,prev:n,next:r};return n.next=a,r.prev=a,e.length++,a}function 
T(e,n,t){for(var 
r=n.next,a=0;a<t&&r!==e.tail;a++)r=r.next;(n.next=r).prev=n,e.length-=a}if(u.Prism=M,W.stringify=function
 n(e,t){if("string"==typeof e)return e;if(Array.isArray(e)){var r="";return 
e.forEach(function(e){r+=n(e,t)}),r}var 
a={type:e.type,content:n(e.content,t),tag:"span",classes:["token",e.type],attributes:{},language:t},i=e.alias;i&&(Array.isArray(i)?Array.prototype.push.apply(a.classes,i):a.classes.push(i)),M.hooks.run("wrap",a);var
 l="";for(var o in a.attributes)l+=" 
"+o+'="'+(a.attributes[o]||"").replace(/"/g,"&quot;")+'"';return"<"+a.tag+' 
class="'+a.classes.join(" 
")+'"'+l+">"+a.content+"</"+a.tag+">"},!u.document)return 
u.addEventListener&&(M.disableWorkerMessageHandler||u.addEventListener("message",function(e){var
 
n=JSON.parse(e.data),t=n.language,r=n.code,a=n.immediateClose;u.postMessage(M.highlight(r,M.languages[t],t)),a&&u.close()},!1)),M;var
 r=M.util.currentScript();function a(){M
 
.manual||M.highlightAll()}if(r&&(M.filename=r.src,r.hasAttribute("data-manual")&&(M.manual=!0)),!M.manual){var
 
l=document.readyState;"loading"===l||"interactive"===l&&r&&r.defer?document.addEventListener("DOMContentLoaded",a):window.requestAnimationFrame?window.requestAnimationFrame(a):window.setTimeout(a,16)}return
 M}(_self);"undefined"!=typeof 
module&&module.exports&&(module.exports=Prism),"undefined"!=typeof 
global&&(global.Prism=Prism);
+Prism.languages.markup={comment:{pattern:/<!--(?:(?!<!--)[\s\S])*?-->/,greedy:!0},prolog:{pattern:/<\?[\s\S]+?\?>/,greedy:!0},doctype:{pattern:/<!DOCTYPE(?:[^>"'[\]]|"[^"]*"|'[^']*')+(?:\[(?:[^<"'\]]|"[^"]*"|'[^']*'|<(?!!--)|<!--(?:[^-]|-(?!->))*-->)*\]\s*)?>/i,greedy:!0,inside:{"internal-subset":{pattern:/(^[^\[]*\[)[\s\S]+(?=\]>$)/,lookbehind:!0,greedy:!0,inside:null},string:{pattern:/"[^"]*"|'[^']*'/,greedy:!0},punctuation:/^<!|>$|[[\]]/,"doctype-tag":/^DOCTYPE/i,name:/[^\s<>'"]+/}},cdata:{pattern:/<!\[CDATA\[[\s\S]*?\]\]>/i,greedy:!0},tag:{pattern:/<\/?(?!\d)[^\s>\/=$<%]+(?:\s(?:\s*[^\s>\/=]+(?:\s*=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+(?=[\s>]))|(?=[\s/>])))+)?\s*\/?>/,greedy:!0,inside:{tag:{pattern:/^<\/?[^\s>\/]+/,inside:{punctuation:/^<\/?/,namespace:/^[^\s>\/:]+:/}},"special-attr":[],"attr-value":{pattern:/=\s*(?:"[^"]*"|'[^']*'|[^\s'">=]+)/,inside:{punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}},punctuation:/\/?>/,"attr-name":{pattern:/[^\s>\/]+/,inside:{namespace:/^[^\
 
s>\/:]+:/}}}},entity:[{pattern:/&[\da-z]{1,8};/i,alias:"named-entity"},/&#x?[\da-f]{1,8};/i]},Prism.languages.markup.tag.inside["attr-value"].inside.entity=Prism.languages.markup.entity,Prism.languages.markup.doctype.inside["internal-subset"].inside=Prism.languages.markup,Prism.hooks.add("wrap",function(a){"entity"===a.type&&(a.attributes.title=a.content.replace(/&amp;/,"&"))}),Object.defineProperty(Prism.languages.markup.tag,"addInlined",{value:function(a,e){var
 
s={};s["language-"+e]={pattern:/(^<!\[CDATA\[)[\s\S]+?(?=\]\]>$)/i,lookbehind:!0,inside:Prism.languages[e]},s.cdata=/^<!\[CDATA\[|\]\]>$/i;var
 
t={"included-cdata":{pattern:/<!\[CDATA\[[\s\S]*?\]\]>/i,inside:s}};t["language-"+e]={pattern:/[\s\S]+/,inside:Prism.languages[e]};var
 
n={};n[a]={pattern:RegExp("(<__[^>]*>)(?:<!\\[CDATA\\[(?:[^\\]]|\\](?!\\]>))*\\]\\]>|(?!<!\\[CDATA\\[)[^])*?(?=</__>)".replace(/__/g,function(){return
 
a}),"i"),lookbehind:!0,greedy:!0,inside:t},Prism.languages.insertBefore("markup","cdata",n)}}),Objec
 
t.defineProperty(Prism.languages.markup.tag,"addAttribute",{value:function(a,e){Prism.languages.markup.tag.inside["special-attr"].push({pattern:RegExp("(^|[\"'\\s])(?:"+a+")\\s*=\\s*(?:\"[^\"]*\"|'[^']*'|[^\\s'\">=]+(?=[\\s>]))","i"),lookbehind:!0,inside:{"attr-name":/^[^\s=]+/,"attr-value":{pattern:/=[\s\S]+/,inside:{value:{pattern:/(^=\s*(["']|(?!["'])))\S[\s\S]*(?=\2$)/,lookbehind:!0,alias:[e,"language-"+e],inside:Prism.languages[e]},punctuation:[{pattern:/^=/,alias:"attr-equals"},/"|'/]}}}})}}),Prism.languages.html=Prism.languages.markup,Prism.languages.mathml=Prism.languages.markup,Prism.languages.svg=Prism.languages.markup,Prism.languages.xml=Prism.languages.extend("markup",{}),Prism.languages.ssml=Prism.languages.xml,Prism.languages.atom=Prism.languages.xml,Prism.languages.rss=Prism.languages.xml;
+!function(s){var 
e=/(?:"(?:\\(?:\r\n|[\s\S])|[^"\\\r\n])*"|'(?:\\(?:\r\n|[\s\S])|[^'\\\r\n])*')/;s.languages.css={comment:/\/\*[\s\S]*?\*\//,atrule:{pattern:/@[\w-](?:[^;{\s]|\s+(?![\s{]))*(?:;|(?=\s*\{))/,inside:{rule:/^@[\w-]+/,"selector-function-argument":{pattern:/(\bselector\s*\(\s*(?![\s)]))(?:[^()\s]|\s+(?![\s)])|\((?:[^()]|\([^()]*\))*\))+(?=\s*\))/,lookbehind:!0,alias:"selector"},keyword:{pattern:/(^|[^\w-])(?:and|not|only|or)(?![\w-])/,lookbehind:!0}}},url:{pattern:RegExp("\\burl\\((?:"+e.source+"|(?:[^\\\\\r\n()\"']|\\\\[^])*)\\)","i"),greedy:!0,inside:{function:/^url/i,punctuation:/^\(|\)$/,string:{pattern:RegExp("^"+e.source+"$"),alias:"url"}}},selector:{pattern:RegExp("(^|[{}\\s])[^{}\\s](?:[^{};\"'\\s]|\\s+(?![\\s{])|"+e.source+")*(?=\\s*\\{)"),lookbehind:!0},string:{pattern:e,greedy:!0},property:{pattern:/(^|[^-\w\xA0-\uFFFF])(?!\s)[-_a-z\xA0-\uFFFF](?:(?!\s)[-\w\xA0-\uFFFF])*(?=\s*:)/i,lookbehind:!0},important:/!important\b/i,function:{pattern:/(^|[^-a-z0-9])[-a-z0-
 
9]+(?=\()/i,lookbehind:!0},punctuation:/[(){};:,]/},s.languages.css.atrule.inside.rest=s.languages.css;var
 
t=s.languages.markup;t&&(t.tag.addInlined("style","css"),t.tag.addAttribute("style","css"))}(Prism);
+Prism.languages.clike={comment:[{pattern:/(^|[^\\])\/\*[\s\S]*?(?:\*\/|$)/,lookbehind:!0,greedy:!0},{pattern:/(^|[^\\:])\/\/.*/,lookbehind:!0,greedy:!0}],string:{pattern:/(["'])(?:\\(?:\r\n|[\s\S])|(?!\1)[^\\\r\n])*\1/,greedy:!0},"class-name":{pattern:/(\b(?:class|extends|implements|instanceof|interface|new|trait)\s+|\bcatch\s+\()[\w.\\]+/i,lookbehind:!0,inside:{punctuation:/[.\\]/}},keyword:/\b(?:break|catch|continue|do|else|finally|for|function|if|in|instanceof|new|null|return|throw|try|while)\b/,boolean:/\b(?:false|true)\b/,function:/\b\w+(?=\()/,number:/\b0x[\da-f]+\b|(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:e[+-]?\d+)?/i,operator:/[<>]=?|[!=]=?=?|--?|\+\+?|&&?|\|\|?|[?*/~^%]/,punctuation:/[{}[\];(),.:]/};
+Prism.languages.javascript=Prism.languages.extend("clike",{"class-name":[Prism.languages.clike["class-name"],{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$A-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\.(?:constructor|prototype))/,lookbehind:!0}],keyword:[{pattern:/((?:^|\})\s*)catch\b/,lookbehind:!0},{pattern:/(^|[^.]|\.\.\.\s*)\b(?:as|assert(?=\s*\{)|async(?=\s*(?:function\b|\(|[$\w\xA0-\uFFFF]|$))|await|break|case|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally(?=\s*(?:\{|$))|for|from(?=\s*(?:['"]|$))|function|(?:get|set)(?=\s*(?:[#\[$\w\xA0-\uFFFF]|$))|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)\b/,lookbehind:!0}],function:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*(?:\.\s*(?:apply|bind|call)\s*)?\()/,number:{pattern:RegExp("(^|[^\\w$])(?:NaN|Infinity|0[bB][01]+(?:_[01]+)*n?|0[oO][0-7]+(?:_[0-7]+)*n?
 
|0[xX][\\dA-Fa-f]+(?:_[\\dA-Fa-f]+)*n?|\\d+(?:_\\d+)*n|(?:\\d+(?:_\\d+)*(?:\\.(?:\\d+(?:_\\d+)*)?)?|\\.\\d+(?:_\\d+)*)(?:[Ee][+-]?\\d+(?:_\\d+)*)?)(?![\\w$])"),lookbehind:!0},operator:/--|\+\+|\*\*=?|=>|&&=?|\|\|=?|[!=]==|<<=?|>>>?=?|[-+*/%&|^!=<>]=?|\.{3}|\?\?=?|\?\.?|[~:]/}),Prism.languages.javascript["class-name"][0].pattern=/(\b(?:class|extends|implements|instanceof|interface|new)\s+)[\w.\\]+/,Prism.languages.insertBefore("javascript","keyword",{regex:{pattern:/((?:^|[^$\w\xA0-\uFFFF."'\])\s]|\b(?:return|yield))\s*)\/(?:\[(?:[^\]\\\r\n]|\\.)*\]|\\.|[^/\\\[\r\n])+\/[dgimyus]{0,7}(?=(?:\s|\/\*(?:[^*]|\*(?!\/))*\*\/)*(?:$|[\r\n,.;:})\]]|\/\/))/,lookbehind:!0,greedy:!0,inside:{"regex-source":{pattern:/^(\/)[\s\S]+(?=\/[a-z]*$)/,lookbehind:!0,alias:"language-regex",inside:Prism.languages.regex},"regex-delimiter":/^\/|\/$/,"regex-flags":/^[a-z]+$/}},"function-variable":{pattern:/#?(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*[=:]\s*(?:async\s*)?(?:\bfunction\b|(?:\((?:[
 
^()]|\([^()]*\))*\)|(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)\s*=>))/,alias:"function"},parameter:[{pattern:/(function(?:\s+(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*)?\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\))/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(^|[^$\w\xA0-\uFFFF])(?!\s)[_$a-z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*=>)/i,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/(\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*=>)/,lookbehind:!0,inside:Prism.languages.javascript},{pattern:/((?:\b|\s|^)(?!(?:as|async|await|break|case|catch|class|const|continue|debugger|default|delete|do|else|enum|export|extends|finally|for|from|function|get|if|implements|import|in|instanceof|interface|let|new|null|of|package|private|protected|public|return|set|static|super|switch|this|throw|try|typeof|undefined|var|void|while|with|yield)(?![$\w\xA0-\uFFFF]))(?:(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*\
 
s*)\(\s*|\]\s*\(\s*)(?!\s)(?:[^()\s]|\s+(?![\s)])|\([^()]*\))+(?=\s*\)\s*\{)/,lookbehind:!0,inside:Prism.languages.javascript}],constant:/\b[A-Z](?:[A-Z_]|\dx?)*\b/}),Prism.languages.insertBefore("javascript","string",{hashbang:{pattern:/^#!.*/,greedy:!0,alias:"comment"},"template-string":{pattern:/`(?:\\[\s\S]|\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}|(?!\$\{)[^\\`])*`/,greedy:!0,inside:{"template-punctuation":{pattern:/^`|`$/,alias:"string"},interpolation:{pattern:/((?:^|[^\\])(?:\\{2})*)\$\{(?:[^{}]|\{(?:[^{}]|\{[^}]*\})*\})+\}/,lookbehind:!0,inside:{"interpolation-punctuation":{pattern:/^\$\{|\}$/,alias:"punctuation"},rest:Prism.languages.javascript}},string:/[\s\S]+/}},"string-property":{pattern:/((?:^|[,{])[
 
\t]*)(["'])(?:\\(?:\r\n|[\s\S])|(?!\2)[^\\\r\n])*\2(?=\s*:)/m,lookbehind:!0,greedy:!0,alias:"property"}}),Prism.languages.insertBefore("javascript","operator",{"literal-property":{pattern:/((?:^|[,{])[
 \t]*)(?!\s)[_$a-zA-Z\xA0-\uFFFF](?:(?!\s)[$\w\xA0-\uFFFF])*(?=\s*:)/m,l
 
ookbehind:!0,alias:"property"}}),Prism.languages.markup&&(Prism.languages.markup.tag.addInlined("script","javascript"),Prism.languages.markup.tag.addAttribute("on(?:abort|blur|change|click|composition(?:end|start|update)|dblclick|error|focus(?:in|out)?|key(?:down|up)|load|mouse(?:down|enter|leave|move|out|over|up)|reset|resize|scroll|select|slotchange|submit|unload|wheel)","javascript")),Prism.languages.js=Prism.languages.javascript;
+Prism.languages.basic={comment:{pattern:/(?:!|REM\b).+/i,inside:{keyword:/^REM/i}},string:{pattern:/"(?:""|[!#$%&'()*,\/:;<=>?^\w
 
+\-.])*"/,greedy:!0},number:/(?:\b\d+(?:\.\d*)?|\B\.\d+)(?:E[+-]?\d+)?/i,keyword:/\b(?:AS|BEEP|BLOAD|BSAVE|CALL(?:
 
ABSOLUTE)?|CASE|CHAIN|CHDIR|CLEAR|CLOSE|CLS|COM|COMMON|CONST|DATA|DECLARE|DEF(?:
 FN| 
SEG|DBL|INT|LNG|SNG|STR)|DIM|DO|DOUBLE|ELSE|ELSEIF|END|ENVIRON|ERASE|ERROR|EXIT|FIELD|FILES|FOR|FUNCTION|GET|GOSUB|GOTO|IF|INPUT|INTEGER|IOCTL|KEY|KILL|LINE
 INPUT|LOCATE|LOCK|LONG|LOOP|LSET|MKDIR|NAME|NEXT|OFF|ON(?: COM| ERROR| KEY| 
TIMER)?|OPEN|OPTION 
BASE|OUT|POKE|PUT|READ|REDIM|REM|RESTORE|RESUME|RETURN|RMDIR|RSET|RUN|SELECT 
CASE|SHARED|SHELL|SINGLE|SLEEP|STATIC|STEP|STOP|STRING|SUB|SWAP|SYSTEM|THEN|TIMER|TO|TROFF|TRON|TYPE|UNLOCK|UNTIL|USING|VIEW
 
PRINT|WAIT|WEND|WHILE|WRITE)(?:\$|\b)/i,function:/\b(?:ABS|ACCESS|ACOS|ANGLE|AREA|ARITHMETIC|ARRAY|ASIN|ASK|AT|ATN|BASE|BEGIN|BREAK|CAUSE|CEIL|CHR|CLIP|COLLATE|COLOR|CON|COS|COSH|COT|CSC|DATE|DATUM|DEBUG|DECIMAL|
 
DEF|DEG|DEGREES|DELETE|DET|DEVICE|DISPLAY|DOT|ELAPSED|EPS|ERASABLE|EXLINE|EXP|EXTERNAL|EXTYPE|FILETYPE|FIXED|FP|GO|GRAPH|HANDLER|IDN|IMAGE|IN|INT|INTERNAL|IP|IS|KEYED|LBOUND|LCASE|LEFT|LEN|LENGTH|LET|LINE|LINES|LOG|LOG10|LOG2|LTRIM|MARGIN|MAT|MAX|MAXNUM|MID|MIN|MISSING|MOD|NATIVE|NUL|NUMERIC|OF|OPTION|ORD|ORGANIZATION|OUTIN|OUTPUT|PI|POINT|POINTER|POINTS|POS|PRINT|PROGRAM|PROMPT|RAD|RADIANS|RANDOMIZE|RECORD|RECSIZE|RECTYPE|RELATIVE|REMAINDER|REPEAT|REST|RETRY|REWRITE|RIGHT|RND|ROUND|RTRIM|SAME|SEC|SELECT|SEQUENTIAL|SET|SETTER|SGN|SIN|SINH|SIZE|SKIP|SQR|STANDARD|STATUS|STR|STREAM|STYLE|TAB|TAN|TANH|TEMPLATE|TEXT|THERE|TIME|TIMEOUT|TRACE|TRANSFORM|TRUNCATE|UBOUND|UCASE|USE|VAL|VARIABLE|VIEWPORT|WHEN|WINDOW|WITH|ZER|ZONEWIDTH)(?:\$|\b)/i,operator:/<[=>]?|>=?|[+\-*\/^=&]|\b(?:AND|EQV|IMP|NOT|OR|XOR)\b/i,punctuation:/[,;:()]/};
+Prism.languages.python={comment:{pattern:/(^|[^\\])#.*/,lookbehind:!0,greedy:!0},"string-interpolation":{pattern:/(?:f|fr|rf)(?:("""|''')[\s\S]*?\1|("|')(?:\\.|(?!\2)[^\\\r\n])*\2)/i,greedy:!0,inside:{interpolation:{pattern:/((?:^|[^{])(?:\{\{)*)\{(?!\{)(?:[^{}]|\{(?!\{)(?:[^{}]|\{(?!\{)(?:[^{}])+\})+\})+\}/,lookbehind:!0,inside:{"format-spec":{pattern:/(:)[^:(){}]+(?=\}$)/,lookbehind:!0},"conversion-option":{pattern:/![sra](?=[:}]$)/,alias:"punctuation"},rest:null}},string:/[\s\S]+/}},"triple-quoted-string":{pattern:/(?:[rub]|br|rb)?("""|''')[\s\S]*?\1/i,greedy:!0,alias:"string"},string:{pattern:/(?:[rub]|br|rb)?("|')(?:\\.|(?!\1)[^\\\r\n])*\1/i,greedy:!0},function:{pattern:/((?:^|\s)def[
 
\t]+)[a-zA-Z_]\w*(?=\s*\()/g,lookbehind:!0},"class-name":{pattern:/(\bclass\s+)\w+/i,lookbehind:!0},decorator:{pattern:/(^[\t
 
]*)@\w+(?:\.\w+)*/m,lookbehind:!0,alias:["annotation","punctuation"],inside:{punctuation:/\./}},keyword:/\b(?:_(?=\s*:)|and|as|assert|async|await|break|case|class|continue|
 
def|del|elif|else|except|exec|finally|for|from|global|if|import|in|is|lambda|match|nonlocal|not|or|pass|print|raise|return|try|while|with|yield)\b/,builtin:/\b(?:__import__|abs|all|any|apply|ascii|basestring|bin|bool|buffer|bytearray|bytes|callable|chr|classmethod|cmp|coerce|compile|complex|delattr|dict|dir|divmod|enumerate|eval|execfile|file|filter|float|format|frozenset|getattr|globals|hasattr|hash|help|hex|id|input|int|intern|isinstance|issubclass|iter|len|list|locals|long|map|max|memoryview|min|next|object|oct|open|ord|pow|property|range|raw_input|reduce|reload|repr|reversed|round|set|setattr|slice|sorted|staticmethod|str|sum|super|tuple|type|unichr|unicode|vars|xrange|zip)\b/,boolean:/\b(?:False|None|True)\b/,number:/\b0(?:b(?:_?[01])+|o(?:_?[0-7])+|x(?:_?[a-f0-9])+)\b|(?:\b\d+(?:_\d+)*(?:\.(?:\d+(?:_\d+)*)?)?|\B\.\d+(?:_\d+)*)(?:e[+-]?\d+(?:_\d+)*)?j?(?!\w)/i,operator:/[-+%=]=?|!=|:=|\*\*?=?|\/\/?=?|<[<=>]?|>[=>]?|[&|^~]/,punctuation:/[{}[\];(),.:]/},Prism.languages.python["st
 
ring-interpolation"].inside.interpolation.inside.rest=Prism.languages.python,Prism.languages.py=Prism.languages.python;
+Prism.languages["visual-basic"]={comment:{pattern:/(?:['‘’]|REM\b)(?:[^\r\n_]|_(?:\r\n?|\n)?)*/i,inside:{keyword:/^REM/i}},directive:{pattern:/#(?:Const|Else|ElseIf|End|ExternalChecksum|ExternalSource|If|Region)(?:\b_[
 
\t]*(?:\r\n?|\n)|.)+/i,alias:"property",greedy:!0},string:{pattern:/\$?["“”](?:["“”]{2}|[^"“”])*["“”]C?/i,greedy:!0},date:{pattern:/#[
 \t]*(?:\d+([/-])\d+\1\d+(?:[ \t]+(?:\d+[ \t]*(?:AM|PM)|\d+:\d+(?::\d+)?(?:[ 
\t]*(?:AM|PM))?))?|\d+[ \t]*(?:AM|PM)|\d+:\d+(?::\d+)?(?:[ \t]*(?:AM|PM))?)[ 
\t]*#/i,alias:"number"},number:/(?:(?:\b\d+(?:\.\d+)?|\.\d+)(?:E[+-]?\d+)?|&[HO][\dA-F]+)(?:[FRD]|U?[ILS])?/i,boolean:/\b(?:False|Nothing|True)\b/i,keyword:/\b(?:AddHandler|AddressOf|Alias|And(?:Also)?|As|Boolean|ByRef|Byte|ByVal|Call|Case|Catch|C(?:Bool|Byte|Char|Date|Dbl|Dec|Int|Lng|Obj|SByte|Short|Sng|Str|Type|UInt|ULng|UShort)|Char|Class|Const|Continue|Currency|Date|Decimal|Declare|Default|Delegate|Dim|DirectCast|Do|Double|Each|Else(?:If)?|End(?:If)?|Enum|Erase|
 
Error|Event|Exit|Finally|For|Friend|Function|Get(?:Type|XMLNamespace)?|Global|GoSub|GoTo|Handles|If|Implements|Imports|In|Inherits|Integer|Interface|Is|IsNot|Let|Lib|Like|Long|Loop|Me|Mod|Module|Must(?:Inherit|Override)|My(?:Base|Class)|Namespace|Narrowing|New|Next|Not(?:Inheritable|Overridable)?|Object|Of|On|Operator|Option(?:al)?|Or(?:Else)?|Out|Overloads|Overridable|Overrides|ParamArray|Partial|Private|Property|Protected|Public|RaiseEvent|ReadOnly|ReDim|RemoveHandler|Resume|Return|SByte|Select|Set|Shadows|Shared|short|Single|Static|Step|Stop|String|Structure|Sub|SyncLock|Then|Throw|To|Try|TryCast|Type|TypeOf|U(?:Integer|Long|Short)|Until|Using|Variant|Wend|When|While|Widening|With(?:Events)?|WriteOnly|Xor)\b/i,operator:/[+\-*/\\^<=>&#@$%!]|\b_(?=[
 
\t]*[\r\n])/,punctuation:/[{}().,:?]/},Prism.languages.vb=Prism.languages["visual-basic"],Prism.languages.vba=Prism.languages["visual-basic"];
+!function(){if("undefined"!=typeof Prism&&"undefined"!=typeof document){var 
o="line-numbers",a=/\n(?!$)/g,e=Prism.plugins.lineNumbers={getLine:function(e,n){if("PRE"===e.tagName&&e.classList.contains(o)){var
 t=e.querySelector(".line-numbers-rows");if(t){var 
i=parseInt(e.getAttribute("data-start"),10)||1,r=i+(t.children.length-1);n<i&&(n=i),r<n&&(n=r);var
 s=n-i;return 
t.children[s]}}},resize:function(e){u([e])},assumeViewportIndependence:!0},n=void
 
0;window.addEventListener("resize",function(){e.assumeViewportIndependence&&n===window.innerWidth||(n=window.innerWidth,u(Array.prototype.slice.call(document.querySelectorAll("pre."+o))))}),Prism.hooks.add("complete",function(e){if(e.code){var
 
n=e.element,t=n.parentNode;if(t&&/pre/i.test(t.nodeName)&&!n.querySelector(".line-numbers-rows")&&Prism.util.isActive(n,o)){n.classList.remove(o),t.classList.add(o);var
 i,r=e.code.match(a),s=r?r.length+1:1,l=new 
Array(s+1).join("<span></span>");(i=document.createElement("span")).setAttribute("aria-hi
 
dden","true"),i.className="line-numbers-rows",i.innerHTML=l,t.hasAttribute("data-start")&&(t.style.counterReset="linenumber
 
"+(parseInt(t.getAttribute("data-start"),10)-1)),e.element.appendChild(i),u([t]),Prism.hooks.run("line-numbers",e)}}}),Prism.hooks.add("line-numbers",function(e){e.plugins=e.plugins||{},e.plugins.lineNumbers=!0})}function
 u(e){if(0!=(e=e.filter(function(e){var n=function(e){return 
e?window.getComputedStyle?getComputedStyle(e):e.currentStyle||null:null}(e)["white-space"];return"pre-wrap"===n||"pre-line"===n})).length){var
 n=e.map(function(e){var 
n=e.querySelector("code"),t=e.querySelector(".line-numbers-rows");if(n&&t){var 
i=e.querySelector(".line-numbers-sizer"),r=n.textContent.split(a);i||((i=document.createElement("span")).className="line-numbers-sizer",n.appendChild(i)),i.innerHTML="0",i.style.display="block";var
 s=i.getBoundingClientRect().height;return 
i.innerHTML="",{element:e,lines:r,lineHeights:[],oneLinerHeight:s,sizer:i}}}).filter(Boolean);n.forEach(f
 unction(e){var 
i=e.sizer,n=e.lines,r=e.lineHeights,s=e.oneLinerHeight;r[n.length-1]=void 
0,n.forEach(function(e,n){if(e&&1<e.length){var 
t=i.appendChild(document.createElement("span"));t.style.display="block",t.textContent=e}else
 r[n]=s})}),n.forEach(function(e){for(var 
n=e.sizer,t=e.lineHeights,i=0,r=0;r<t.length;r++)void 
0===t[r]&&(t[r]=n.children[i++].getBoundingClientRect().height)}),n.forEach(function(e){var
 
n=e.sizer,t=e.element.querySelector(".line-numbers-rows");n.style.display="none",n.innerHTML="",e.lineHeights.forEach(function(e,n){t.children[n].style.height=e+"px"})})}}}();
+!function(){if("undefined"!=typeof Prism){var 
i=Object.assign||function(e,n){for(var t in 
n)n.hasOwnProperty(t)&&(e[t]=n[t]);return 
e};e.prototype={setDefaults:function(e){this.defaults=i(this.defaults,e)},normalize:function(e,n){for(var
 t in n=i(this.defaults,n)){var r=t.replace(/-(\w)/g,function(e,n){return 
n.toUpperCase()});"normalize"!==t&&"setDefaults"!==r&&n[t]&&this[r]&&(e=this[r].call(this,e,n[t]))}return
 e},leftTrim:function(e){return 
e.replace(/^\s+/,"")},rightTrim:function(e){return 
e.replace(/\s+$/,"")},tabsToSpaces:function(e,n){return 
n=0|n||4,e.replace(/\t/g,new Array(++n).join(" 
"))},spacesToTabs:function(e,n){return n=0|n||4,e.replace(RegExp(" 
{"+n+"}","g"),"\t")},removeTrailing:function(e){return 
e.replace(/\s*?$/gm,"")},removeInitialLineFeed:function(e){return 
e.replace(/^(?:\r?\n|\r)/,"")},removeIndent:function(e){var 
n=e.match(/^[^\S\n\r]*(?=\S)/gm);return 
n&&n[0].length?(n.sort(function(e,n){return 
e.length-n.length}),n[0].length?e.replace(RegExp("^"+n[0],"gm")
 ,""):e):e},indent:function(e,n){return e.replace(/^[^\S\n\r]*(?=\S)/gm,new 
Array(++n).join("\t")+"$&")},breakLines:function(e,n){n=!0===n?80:0|n||80;for(var
 t=e.split("\n"),r=0;r<t.length;++r)if(!(s(t[r])<=n)){for(var 
i=t[r].split(/(\s+)/g),o=0,a=0;a<i.length;++a){var 
l=s(i[a]);n<(o+=l)&&(i[a]="\n"+i[a],o=l)}t[r]=i.join("")}return 
t.join("\n")}},"undefined"!=typeof 
module&&module.exports&&(module.exports=e),Prism.plugins.NormalizeWhitespace=new
 
e({"remove-trailing":!0,"remove-indent":!0,"left-trim":!0,"right-trim":!0}),Prism.hooks.add("before-sanity-check",function(e){var
 
n=Prism.plugins.NormalizeWhitespace;if((!e.settings||!1!==e.settings["whitespace-normalization"])&&Prism.util.isActive(e.element,"whitespace-normalization",!0))if(e.element&&e.element.parentNode||!e.code){var
 t=e.element.parentNode;if(e.code&&t&&"pre"===t.nodeName.toLowerCase()){for(var 
r=t.childNodes,i="",o="",a=!1,l=0;l<r.length;++l){var 
s=r[l];s==e.element?a=!0:"#text"===s.nodeName&&(a?o+=s.nodeValue:i+=s.nodeVa
 
lue,t.removeChild(s),--l)}if(e.element.children.length&&Prism.plugins.KeepMarkup){var
 
c=i+e.element.innerHTML+o;e.element.innerHTML=n.normalize(c,e.settings),e.code=e.element.textContent}else
 e.code=i+e.code+o,e.code=n.normalize(e.code,e.settings)}}else 
e.code=n.normalize(e.code,e.settings)})}function 
e(e){this.defaults=i({},e)}function s(e){for(var 
n=0,t=0;t<e.length;++t)e.charCodeAt(t)=="\t".charCodeAt(0)&&(n+=3);return 
e.length+n}}();

Reply via email to