├── Direct_Images ├── README.md └── direct_images.user.js ├── Direct_Links └── direct_links.user.js ├── Dirty.ru_List_of_Best ├── README.md └── dirty.ru_list_of_best.user.js ├── Dirty.ru_Title └── dirty.ru_title.user.js ├── Forum_Code_Highlighter ├── README.md ├── forum_code_highlighter.user.js └── screenshots │ ├── akelpad.sf.net.png │ ├── custombuttons.sf.net.png │ └── forum.mozilla-russia.org.png ├── GisMeteo.ru_Force_old_style ├── GisMeteo.ru_Force_old_style.user.js └── README.md ├── README.md ├── Remove_Fake_Links ├── README.md └── remove_fake_links.user.js ├── RuTor ├── README.md └── RuTor_invert_title.user.js └── VseInstrumenti.ru_Load_all_favorites ├── README.md └── VseInstrumenti.ru_Load_all_favorites.user.js /Direct_Images/README.md: -------------------------------------------------------------------------------- 1 | Redirect from preview pages to images directly. 2 |
E.g. from http://radikal.ru/fp/783f97107edc484bbdd2a04a5784f768 to http://s41.radikal.ru/i091/1306/92/1fdf5959b046.png -------------------------------------------------------------------------------- /Direct_Images/direct_images.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name Direct Images 3 | // @version 0.7.0pre21 - 2025-02-17 4 | // @description Redirect from preview pages to images directly 5 | // @author Infocatcher 6 | // @namespace dev/null 7 | // @run-at document-start 8 | // @grant GM_getValue 9 | // @grant GM_setValue 10 | // @grant GM_log 11 | 12 | // @include about:blank?UserScripts/options/Direct_Images 13 | // @include data:,UserScripts/options/Direct_Images 14 | 15 | // Get image by id: 16 | // @match *://ipicture.ru/Gallery/Viewfull/*.html 17 | // @match *://*.ipicture.ru/Gallery/Viewfull/*.html 18 | // @match *://www.picamatic.com/view/* 19 | // @match *://download.su/photo/* 20 | // @match *://imageup.ru/img*/*.html 21 | // @include *://*pixshock.net/*.html 22 | // @include *://*image-share.com/image.php?* 23 | // @include *://*image-share.com/*.html 24 | // @include *://*10pix.ru/view/* 25 | // @match *://xmages.net/show.php*.html 26 | // @match *://opicture.ru/gallery/view/*.html 27 | // @match *://picamigo.com/show.php/*.html 28 | // @match *://pikucha.ru/* 29 | // @match *://keep4u.ru/full/*.html 30 | // @match *://www.imagebanana.com/view/* 31 | // @match *://yfrog.com/* 32 | // @match *://radikal.ua/full/*.html 33 | // @match *://radikalno.ru/full/*.html 34 | // @match *://upyourpic.org/images/*.html 35 | // @include *://*postimg.com/image/* 36 | // @match *://www.bild.me/bild.php?file=* 37 | // @match *://www.pictureshack.ru/view_* 38 | // @match *://pixs.ru/showimage/* 39 | // @match *://minus.com/* 40 | // @include *://*overpic.net/viewer.php?file=* 41 | // @match *://pictube.ru/?v=* 42 | // @match *://owely.com/* 43 | // @match *://uaimage.com/image/* 44 | // @match *://vfl.ru/fotos/*.html* 45 | // @match *://geekpics.net/view/* 46 | // @match *://grab.by/* 47 | // @match *://someimage.com/* 48 | // @match *://skrinshoter.ru/* 49 | // @match *://*.imagetitan.com/img.php?image=* 50 | // @match *://www.picshare.ru/view/* 51 | // @match *://www.turboimagehost.com/*.html* 52 | 53 | // URL-based redirect: 54 | // @match *://smages.com/*.htm 55 | // @match *://anub.ru/pic/* 56 | // @include *://*onlinedisk.ru/image/* 57 | // @include *://*onlinedisk.ru/view/* 58 | // @match *://*.fotoupload.ru/viewer.php?file=* 59 | // @match *://image.vanilla.su/viewer.php?file=* 60 | // @match *://prostofotka.ru/viewer.php?file=* 61 | // @match *://foto-screen.ru/viewer.php?file=* 62 | // @match *://foto-screen.org/viewer.php?file=* 63 | // @match *://foto-boom.org/viewer.php?file=* 64 | // @match *://pixmaster.net/viewer.php?file=* 65 | // @match *://itrash.ru/idb/*.htm* 66 | // @match *://*.itrash.ru/idb/*.htm* 67 | // @match *://*.sendpic.ru/*.html 68 | // @include *://*imget.ru/show/?img=* 69 | // @match *://fastpic.msk.ru/?v=* 70 | // @match *://youpic.su/view.php?id=* 71 | // @match *://jpegshare.net/*.html 72 | // @match *://imagelike.org/?v=* 73 | // @match *://rupix.org/viewer.php?* 74 | // @match *://all-poster.ru/?v=* 75 | // @match *://picsee.net/*.html 76 | // @match *://img.bigstream.ru/viewer.php?file=* 77 | // @match *://pix.toile-libre.org/?img=* 78 | // @match *://fast-picture.ru/images/*.html 79 | // @match *://pasteboard.co/* 80 | // @match *://img-host.org.ua/?v=* 81 | // @match *://images.gameru.net/image/*.html 82 | // @match *://imgdepo.com/show/* 83 | // @match *://stick.kz/?v=* 84 | // @match *://imagestun.com/hosting/?v=* 85 | // @match *://picua.org/?v=* 86 | // @match *://*.giphy.com/media/* 87 | // @match *://scrin.org/?v=* 88 | // @match *://lostpix.com/?v=* 89 | // @match *://picplus.ru/ful/* 90 | 91 | // Get image by src: 92 | // @include *://*imagepix.org/image/*.html 93 | // @match *://saveimg.ru/show-image.php?id=* 94 | // @match *://mediapix.ru/pic.php?id=* 95 | // @match *://pixs.ru/showimage/* 96 | // @match *://postimage.org/image/* 97 | // @match *://uaimages.com/viewer.php?* 98 | // @match *://7image.ru/v.php?* 99 | // @match *://mepic.ru/view/?* 100 | // @match *://simplest-image-hosting.net/* 101 | // @match *://pics.kz/view/* 102 | // @include *://*imagepost.ru/?v=* 103 | // @match *://imgtheif.com/show-image.php?id=* 104 | // @match *://imgtheif.com/image/*.html 105 | // @match *://hostingkartinok.com/show-image.php?* 106 | // @match *://image.kz/* 107 | // @match *://imm.io/* 108 | // @match *://narodpix.net/?v=* 109 | // @match *://www.narodpix.net/?v=* 110 | // @match *://firepic.org/?v=* 111 | // @match *://www.firepic.org/?v=* 112 | // @match *://you-logo.ru/show-image.php?* 113 | // @match *://uploadimagex.com/view.php?* 114 | // @match *://toroff.net/?v=* 115 | // @match *://clip2net.com/s/* 116 | // @match *://screencast.com/*/* 117 | // @match *://img.lastusja.ru/* 118 | // @match *://gyazo.com/* 119 | // @match *://imgchilibum.ru/*.php?id=* 120 | // @match *://imglink.ru/show-image.php?id=* 121 | // @match *://www.fotolink.su/v.php?id=* 122 | // @match *://netpics.org/image/* 123 | // @include *://*ximage.ru/index.php?id=* 124 | // @include *://*ii4.ru/image-*.html* 125 | // @match *://freescreens.ru/*/ 126 | // @match *://powerlogo.ru/show-image.php?id=* 127 | // @match *://savepice.ru/full/*.html* 128 | // @match *://funkyimg.com/viewer.php?* 129 | // @match *://funkyimg.com/view/* 130 | // @match *://www.imagesnake.com/show* 131 | // @match *://*.imagevenue.com/* 132 | 133 | // Get image from thumbnail: 134 | // @match *://piccash.net/*/ 135 | // @match *://pic4you.ru/*/ 136 | // @match *://picforall.ru/* 137 | // @match *://payforpic.ru/* 138 | // @match *://pix-x.net/* 139 | // @match *://picclick.ru/* 140 | // @match *://imgclick.ru/* 141 | // @match *://imgbase.ru/* 142 | // @match *://picpays.ru/* 143 | // @match *://drlink.online/* 144 | // @match *://pronpic.org/* 145 | 146 | // Other: 147 | // @match *://*.imageshack.us/* 148 | // @match *://imageshack.us/photo/* 149 | // @match *://imageshack.us/f/*/ 150 | // @match *://imageshack.com/photo/* 151 | // @match *://savepic.ru/*.htm 152 | // @match *://savepic.org/*.htm 153 | // @match *://savepic.net/*.htm 154 | // @match *://savepic.su/*.htm 155 | // @match *://piccy.info/*view*/* 156 | // @include *://*xtupload.com/*.html 157 | // @include *://*picatom.com/*.html 158 | // @include *://*fotosik.pl/pokaz_obrazek/*.html 159 | // @match *://fotki.yandex.ru/users/*/view/* 160 | // @match *://southwc.ru/*.htm 161 | // @match *://www.pict.com/view/* 162 | // @match *://imageban.ru/show/* 163 | // @match *://habreffect.ru/* 164 | // @match *://rghost.ru/* 165 | // @match *://rghost.net/* 166 | // @match *://rgho.st/* 167 | // @match *://itmages.ru/image/* 168 | // @match *://itmages.com/image/* 169 | // @include *://*floomby.ru/*/* 170 | // @match *://www.kinopoisk.ru/picture/*/or/1/ 171 | // @match *://tenpic.ru/view.php?* 172 | // @match *://imghost.in/pt-*.html 173 | // @match *://*.binimage.org/* 174 | // @match *://forlazypeople.com/?v=* 175 | // @match *://upit.biz/?v=* 176 | // @match *://imgur.com/* 177 | // @exclude *://imgur.com/ 178 | // @exclude *://imgur.com/user/* 179 | // @match *://*.goodfon.ru/download* 180 | // @match *://*.goodfon.su/download* 181 | // @match *://*.badfon.ru/download* 182 | // @include *://*image-upload.net/*.html 183 | // @match *://imageshost.ru/links/* 184 | // @match *://imageshost.ru/photo/*.html 185 | // @match *://screenshotuploader.com/s/* 186 | // @match *://prntscr.com/* 187 | // @match *://ifotki.info/*.html 188 | // @match *://*.photobucket.com/*?action=view* 189 | // @match *://*.photobucket.com/*.html* 190 | // @match *://tinypic.com/view.php?pic=* 191 | // @include *://*fotohost.by/show/* 192 | // @match *://fastpic.ru/*view/*.html* 193 | // @match *://fastpic.org/*view/*.html* 194 | // @match *://joxi.ru/* 195 | // @match *://joxi.net/* 196 | // @match *://postimg.org/image/* 197 | // @match *://i-fotki.info/*.html 198 | // @match *://4put.ru/*.php?* 199 | // @match *://fotkidepo.ru/?id=photo:* 200 | // @match *://ixbt.photo/?id=photo:* 201 | // @match *://lostpic.net/?* 202 | // @match *://lostpic.net/image/* 203 | // @match *://*.lostpic.net/image/* 204 | // @match *://pic.lg.ua/* 205 | // @match *://cardse.net/image/* 206 | // @match *://image2you.ru/*/ 207 | // @match *://cl.ly/* 208 | // @match *://*.riotpixels.com/games/*/screenshots/* 209 | // @match *://prnt.sc/* 210 | // @match *://snag.gy/*.* 211 | // @match *://www.directupload.net/*.htm* 212 | // @match *://*.directupload.net/images/* 213 | // @match *://ibb.co/* 214 | // @match *://picturelol.com/* 215 | // @match *://imgdrive.net/img-*.html* 216 | // @match *://www.imagebam.com/image/* 217 | // @match *://postimg.cc/* 218 | // @match *://sasisa.org/foto/foto.php?* 219 | // @match *://radikal.host/i/*.* 220 | // ==/UserScript== 221 | 222 | (function di(event) { 223 | var allowBack = false; // default value 224 | // You can change greasemonkey.scriptvals.dev/null/Direct Images.allowBack in about:config 225 | if(typeof GM_getValue == "function") { 226 | var _allowBack = GM_getValue("allowBack", undefined); 227 | if(_allowBack == undefined) 228 | GM_setValue("allowBack", allowBack); 229 | else 230 | allowBack = _allowBack; 231 | } 232 | 233 | var loc = location.href; 234 | if( 235 | ( 236 | loc == "about:blank?UserScripts/options/Direct_Images" 237 | || loc == "data:,UserScripts/options/Direct_Images" 238 | ) 239 | && typeof GM_getValue == "function" 240 | ) { 241 | var t = "Direct Images Options"; 242 | var optionsUI = function() { 243 | window.removeEventListener("load", optionsUI, false); 244 | document.title = t; 245 | var body = document.body || document.documentElement; 246 | body.textContent = ""; 247 | var label = _e("label"); 248 | label.htmlFor = "allowBack"; 249 | var input = _e("input"); 250 | input.id = "allowBack"; 251 | input.type = "checkbox"; 252 | input.checked = allowBack; 253 | var handleClick = function() { 254 | GM_setValue("allowBack", input.checked); 255 | }; 256 | input.addEventListener("click", handleClick, false); 257 | label.appendChild(input); 258 | label.appendChild(document.createTextNode("Allow back (don't remove page from back/forward history)")); 259 | label.style.fontFamily = "sans-serif"; 260 | body.appendChild(label); 261 | window.addEventListener("unload", function destroy(e) { 262 | window.removeEventListener("unload", destroy, false); 263 | input.removeEventListener("click", handleClick, false); 264 | }, false); 265 | }; 266 | if(document.readyState == "loading") 267 | window.addEventListener("load", optionsUI, false); 268 | else 269 | optionsUI(); 270 | destroy(); 271 | return; 272 | } 273 | 274 | var ael = di.ael || (di.ael = window.addEventListener); 275 | var rel = di.rel || (di.rel = window.removeEventListener); 276 | var setTimeout = window.setTimeout.bind(window); 277 | 278 | var host = (function() { // a.example.com => example.com 279 | var tld = "msk.ru|org.ua"; // Only currently used TLD, for better performance 280 | var tldRe = new RegExp("[^.]+\\.(?:" + tld.replace(/\./g, "\\.") + "|[^.]+)$"); 281 | return location.hostname.match(tldRe)[0]; 282 | })(); 283 | var _iid, _img, _src, _clearDoc; 284 | var _wait; 285 | function _e(nn) { 286 | return document.createElementNS("http://www.w3.org/1999/xhtml", nn); 287 | } 288 | function $(id) { 289 | return document.getElementById(id); 290 | } 291 | function $t(tag, node) { 292 | return (node || document).getElementsByTagName(tag); 293 | } 294 | function $c(className, node) { 295 | if(!node) 296 | node = document; 297 | if(node.getElementsByClassName) 298 | return node.getElementsByClassName(className); 299 | var classNames = className.split(/\s+/); 300 | var count = classNames.length; 301 | var regs = []; 302 | for(var i = 0; i < count; ++i) 303 | regs.push(new RegExp("(^|\\s)" + classNames[i].replace(/[\\\/.^$+*?|()\[\]{}]/g, "\\$&") + "(\\s|$)")); 304 | var out = []; 305 | var nodes = node.getElementsByTagName("*"); 306 | main: 307 | for(var i = 0, l = nodes.length; i < l; ++i) { 308 | var n = nodes[i]; 309 | var c = n.className; 310 | for(var j = 0; j < count; ++j) 311 | if(!regs[j].test(c)) 312 | continue main; 313 | out.push(n); 314 | } 315 | return out; 316 | } 317 | function $i(mask, node, exclude) { 318 | var imgs = node 319 | ? node.getElementsByTagName("img") 320 | : document.images; 321 | for(var i = 0, len = imgs.length; i < len; ++i) { 322 | var src = imgs[i].src; 323 | if( 324 | src && mask.test(src) 325 | && (!exclude || !exclude.test(src)) 326 | ) 327 | return src; 328 | } 329 | return ""; 330 | } 331 | function $ie(mask, exclude, node) { 332 | return $i(mask, node, exclude); 333 | } 334 | function $inp(mask, node) { 335 | var inps = (node || document).getElementsByTagName("input"); 336 | for(var i = 0, len = inps.length; i < len; ++i) { 337 | var val = inps[i].value; 338 | if(mask.test(val)) 339 | return val; 340 | } 341 | return ""; 342 | } 343 | function $a(mask, node) { 344 | var links = (node || document).getElementsByTagName("a"); 345 | for(var i = 0, len = links.length; i < len; ++i) { 346 | var link = links[i]; 347 | if(mask.test(link.href)) 348 | return link; 349 | } 350 | return null; 351 | } 352 | function $th(imgRe, thumbRe, replacements) { 353 | var src = $i(imgRe); 354 | if(src) 355 | return src; 356 | src = $i(thumbRe); 357 | if(src) for(var find in replacements) 358 | src = src.replace(find, replacements[find]); 359 | return src; 360 | } 361 | function $u(node) { 362 | if(node && node.nodeName.toLowerCase() == "input") 363 | return $url(node.value); 364 | return ""; 365 | } 366 | function $url(s) { 367 | if(/^https?:\/\/\S+$/.test(s) && !/html?$/.test(s)) 368 | return s; 369 | return ""; 370 | } 371 | function $dec(url) { 372 | try { 373 | return decodeURIComponent(url); 374 | } 375 | catch(e) { 376 | } 377 | return url; 378 | } 379 | function ogImage() { 380 | var metaImg = document.querySelector && document.querySelector('meta[property="og:image"][content^="http"]'); 381 | return metaImg && metaImg.getAttribute("content") || ""; 382 | } 383 | function redirect(url) { 384 | if(allowBack) 385 | location.href = url; 386 | else 387 | location.replace(url); 388 | } 389 | function clearDoc(src) { 390 | window.stop(); 391 | 392 | var html = _e("html"); 393 | var head = _e("head"); 394 | var title = _e("title"); 395 | var imgName = $dec(src.match(/[^\/]*$/)[0]); 396 | title.appendChild(document.createTextNode(imgName + " - Direct Images")); 397 | head.appendChild(title); 398 | var link = _e("link"); 399 | link.rel = "shortcut icon"; 400 | link.href = src; 401 | head.appendChild(link); 402 | var style = _e("style"); 403 | style.type = "text/css"; 404 | style.appendChild(document.createTextNode("\ 405 | html, html > body {\n\ 406 | margin: 0; padding: 0;\n\ 407 | width: auto !important; height: auto !important; /* for https://userstyles.org/styles/101141/ru-adlist-css-fixes */\n\ 408 | }\n\ 409 | .zoomIn { cursor: -moz-zoom-in; cursor: -webkit-zoom-in; cursor: zoom-in; }\n\ 410 | .zoomOut { cursor: -moz-zoom-out; cursor: -webkit-zoom-out; cursor: zoom-out; }\n\ 411 | /* From resource://gre/res/TopLevelImageDocument.css */\n\ 412 | @media not print {\n\ 413 | img {\n\ 414 | text-align: center;\n\ 415 | position: absolute;\n\ 416 | margin: auto;\n\ 417 | top: 0;\n\ 418 | right: 0;\n\ 419 | bottom: 0;\n\ 420 | left: 0;\n\ 421 | }\n\ 422 | }" 423 | )); 424 | head.appendChild(style); 425 | 426 | var meta = _e("meta"); 427 | meta.name = "viewport"; 428 | meta.content = "width=device-width; height=device-height;"; 429 | head.appendChild(meta); 430 | 431 | link = _e("link"); 432 | link.rel = "stylesheet"; 433 | link.href = "resource://gre/res/TopLevelImageDocument.css"; 434 | head.appendChild(link); 435 | link = link.cloneNode(true); 436 | link.href = "chrome://global/skin/TopLevelImageDocument.css"; 437 | head.appendChild(link); 438 | link = link.cloneNode(true); 439 | link.href = "chrome://global/skin/media/TopLevelImageDocument.css"; // Firefox 19.0a1 440 | head.appendChild(link); 441 | 442 | var body = _e("body"); 443 | var img = _e("img"); 444 | var stl = img.style; 445 | stl.maxWidth = window.innerWidth + "px"; 446 | stl.maxHeight = window.innerHeight + "px"; 447 | 448 | var originalSize = false; 449 | 450 | var simpleZoom, destroySimpleZoom, preventClickUnders; 451 | ael.call(window, "click", simpleZoom = function(e) { 452 | if(e.button != 0 || e.target != img) 453 | return; 454 | originalSize = !originalSize; 455 | if(originalSize) { 456 | stl.maxWidth = stl.maxHeight = null; 457 | scrollToClicked(e, img.width, img.height); 458 | } 459 | else { 460 | stl.maxWidth = window.innerWidth + "px"; 461 | stl.maxHeight = window.innerHeight + "px"; 462 | } 463 | e.preventDefault(); 464 | e.stopPropagation(); 465 | e.stopImmediatePropagation && e.stopImmediatePropagation(); 466 | }, true); 467 | ael.call(window, "mouseup", preventClickUnders = function(e) { 468 | e.stopPropagation(); 469 | e.stopImmediatePropagation && e.stopImmediatePropagation(); 470 | }, true); 471 | ael.call(window, "unload", destroySimpleZoom = function() { 472 | rel.call(window, "unload", destroySimpleZoom, false); 473 | rel.call(window, "click", simpleZoom, true); 474 | rel.call(window, "mouseup", preventClickUnders, true); 475 | }, false); 476 | 477 | var initResizer; 478 | ael.call(img, "load", initResizer = function(e) { 479 | rel.call(img, "load", initResizer, false); 480 | destroySimpleZoom(); 481 | 482 | stl.maxWidth = stl.maxHeight = null; 483 | var iw = img.width; 484 | var ih = img.height; 485 | var size = iw + " × " + ih; 486 | function fitSize(check) { 487 | var ww = window.innerWidth; 488 | var wh = window.innerHeight; 489 | var canFit = iw > ww || ih > wh; 490 | if(check) 491 | return canFit; 492 | if(canFit) { 493 | var persent = Math.min(ww/iw, wh/ih); 494 | stl.width = iw*persent + "px"; 495 | stl.height = ih*persent + "px"; 496 | stl.marginTop = null; 497 | persent = Math.floor(persent*100); // Inherit Firefox built-in resizer behavior... 498 | document.title = imgName + " (" + size + ", " + persent + "%)" + " - Direct Images"; 499 | } 500 | else { 501 | origSize(); 502 | } 503 | setCursor(canFit); 504 | return canFit; 505 | } 506 | function origSize() { 507 | stl.width = stl.height = null; 508 | document.title = imgName + " (" + size + ")" + " - Direct Images"; 509 | if(ih > window.innerHeight) // Override styles from resource://gre/res/TopLevelImageDocument.css 510 | stl.marginTop = 0; 511 | } 512 | function setCursor(canFit) { 513 | if(canFit == undefined) 514 | canFit = fitSize(true); 515 | img.className = canFit 516 | ? originalSize 517 | ? "zoomOut" 518 | : "zoomIn" 519 | : ""; 520 | } 521 | function toggleFitSize(e) { 522 | if(e.button != 0 || e.target != img) 523 | return; 524 | if(!fitSize(true)) { // Nothing to toggle 525 | setCursor(false); 526 | return; 527 | } 528 | originalSize = !originalSize; 529 | if(originalSize) { 530 | origSize(); 531 | scrollToClicked(e, iw, ih); 532 | } 533 | else 534 | fitSize(); 535 | setCursor(true); 536 | } 537 | function onResize(e) { 538 | if(!originalSize) 539 | fitSize(); 540 | setCursor(); 541 | } 542 | ael.call(window, "click", toggleFitSize, true); 543 | ael.call(window, "resize", onResize, false); 544 | ael.call(window, "unload", function destroy(e) { 545 | rel.call(window, e.type, destroy, false); 546 | rel.call(window, "click", toggleFitSize, true); 547 | rel.call(window, "resize", onResize, false); 548 | }, false); 549 | if(originalSize) { 550 | origSize(); 551 | setCursor(); 552 | } 553 | else { 554 | fitSize(); 555 | } 556 | }, false); 557 | img.addEventListener("load", initResizer, false); // At least for Firefox 93 558 | 559 | function scrollToClicked(e, iw, ih) { 560 | if(!iw || !ih) 561 | return; 562 | var ww = window.innerWidth; 563 | var wh = window.innerHeight; 564 | var dx = e.clientX/ww; 565 | var dy = e.clientY/wh; 566 | window.scrollTo( 567 | Math.max(0, dx*iw - ww/2), 568 | Math.max(0, dy*ih - wh/2) 569 | ); 570 | } 571 | 572 | img.src = img.alt = src; 573 | body.appendChild(img); 574 | 575 | html.appendChild(head); 576 | html.appendChild(body); 577 | 578 | for(var lc; lc = document.lastChild; ) 579 | document.removeChild(lc); 580 | document.appendChild(html); 581 | 582 | // Prevent modifications, used new Function() to bypass unsafeWindow things in GreaseMonkey 583 | if(Object.defineProperty) 584 | new window.Function('var i = document.images[0]; Object.defineProperty(i, "src", { value: i.src });')(); 585 | if(window.Node && Node.prototype) { 586 | var m = [ 587 | "appendChild", 588 | "insertBefore", 589 | "removeChild", 590 | "replaceChild", 591 | //"setAttribute", 592 | "removeAttribute", 593 | "addEventListener" 594 | ]; 595 | new window.Function("var p = Node.prototype; p." + m.join(" = p.") + " = function() {};")(); 596 | } 597 | if(window.EventTarget && EventTarget.prototype) 598 | new window.Function("EventTarget.prototype.addEventListener = function() {};")(); 599 | new window.Function("window.setTimeout = window.setInterval = function() {};")(); 600 | var tmr = setTimeout(function checkCSS(_stopTime) { 601 | if(window.getComputedStyle(img, null).textAlign == "center") 602 | return; // Looks like all works fine 603 | // Let's reload styles... 604 | GM_log("Force reload styles"); 605 | var links = document.getElementsByTagName("link"); 606 | for(var i = 0, l = links.length; i < l; ++i) { 607 | var link = links[i]; 608 | if(link.rel == "stylesheet") 609 | link.href = link.href.replace(/\?.*$/, "") + "?" + new Date().getTime(); 610 | } 611 | var styles = document.getElementsByTagName("style"); 612 | for(var i = 0, l = styles.length; i < l; ++i) { 613 | var style = styles[i]; 614 | if(style.type != "text/css") 615 | continue; 616 | style.type = "text/force-reload"; 617 | style.type = "text/css"; 618 | } 619 | if(!_stopTime || _stopTime > new Date().getTime()) 620 | setTimeout(checkCSS, 100, _stopTime || new Date().getTime() + 2e3); 621 | }, 0); 622 | GM_log("Remove timers: " + (tmr - 1)); 623 | while(--tmr) 624 | clearTimeout(tmr); 625 | } 626 | hostLoop: 627 | switch(host) { 628 | // Get image by id: 629 | case "ipicture.ru": _iid = "newImg"; break; 630 | case "picamatic.com": _iid = "pic"; break; 631 | case "download.su": _iid = "thepic"; break; 632 | case "imageup.ru": _iid = "image"; break; 633 | case "pixshock.net": _iid = "mi"; break; 634 | case "image-share.com": _iid = "image"; break; 635 | case "10pix.ru": _iid = "image"; break; 636 | case "xmages.net": _iid = "img_obj"; break; 637 | case "opicture.ru": _iid = "newImg"; break; 638 | case "picamigo.com": _iid = "img_obj"; break; 639 | case "pikucha.ru": _iid = "image"; break; 640 | case "keep4u.ru": _iid = "foto"; break; 641 | case "imagebanana.com": _iid = "image"; break; 642 | case "yfrog.com": _iid = "main_image"; break; 643 | case "radikal.ua": _iid = "image"; break; 644 | case "radikalno.ru": _iid = "image"; break; 645 | case "upyourpic.org": _iid = "mainimage"; break; 646 | case "postimg.com": _iid = "image"; break; 647 | case "bild.me": _iid = "Bild"; break; 648 | case "pictureshack.ru": _iid = "image"; break; 649 | case "pixs.ru": _iid = "imgg"; break; 650 | case "minus.com": _iid = "current_image"; break; 651 | case "overpic.net": _iid = "main_img"; break; 652 | case "pictube.ru": _iid = "full_image"; break; 653 | case "owely.com": _iid = "issueImg"; break; 654 | case "uaimage.com": _iid = "im"; break; 655 | case "vfl.ru": _iid = "img_foto"; break; 656 | case "geekpics.net": _iid = "full_image"; break; 657 | case "grab.by": _iid = "thegrab"; break; 658 | case "someimage.com": _iid = "viewimage"; break; 659 | case "skrinshoter.ru": _iid = "screenshot-image"; break; 660 | case "imagetitan.com": _iid = "image"; break; 661 | case "picshare.ru": _iid = "image"; break; 662 | case "turboimagehost.com": _iid = "uImage"; break; 663 | 664 | // URL-based redirect: 665 | case "smages.com": 666 | if(/^https?:\/\/(?:www\.)?smages\.com\/(.*?)\.htm/i.test(loc)) 667 | _src = "http://smages.com/i/" + RegExp.$1; 668 | break; 669 | case "anub.ru": 670 | if(/^https?:\/\/(?:www\.)?anub\.ru\/pic\/(.+)$/i.test(loc)) 671 | _src = "http://anub.ru/uploads/" + RegExp.$1; 672 | break; 673 | case "onlinedisk.ru": 674 | if(/^https?:\/\/(?:www\.)?onlinedisk\.ru\/(?:image|view)\/(\d+)(?:\/.*)?$/i.test(loc)) 675 | _src = "http://onlinedisk.ru/get_image.php?id=" + RegExp.$1; 676 | break; 677 | case "fotoupload.ru": //~ todo: remove? 678 | case "vanilla.su": //~ todo: remove? 679 | case "prostofotka.ru": //~ todo: remove? 680 | case "foto-screen.ru": //~ todo: remove? 681 | case "foto-screen.org": 682 | case "foto-boom.org": 683 | case "pixmaster.net": 684 | _src = loc.replace("/viewer.php?file=", "/images/"); 685 | break; 686 | case "itrash.ru": 687 | case "sendpic.ru": 688 | _src = loc.replace(/\.html?$/, ""); 689 | break; 690 | case "imget.ru": 691 | _src = loc.replace("/show/?img=", ""); 692 | break; 693 | case "fastpic.msk.ru": 694 | _src = loc.replace("/?v=", "/images/"); 695 | break; 696 | case "youpic.su": 697 | _src = loc.replace(/^(https?:\/\/).*?\?id=/, "$1"); 698 | break; 699 | case "jpegshare.net": 700 | _src = loc 701 | .replace(/jpegshare\.net\//, "$&images/") 702 | .replace(/\.html$/, ""); 703 | break; 704 | case "imagelike.org": 705 | _src = loc.replace("/?v=", "/images/"); 706 | break; 707 | case "rupix.org": 708 | _src = loc.replace("/viewer.php?file=", "/images/"); 709 | break; 710 | case "all-poster.ru": 711 | _src = loc.replace("/?v=", "/images/"); 712 | break; 713 | case "picsee.net": 714 | _src = loc 715 | .replace(/^https?:\/\/(?:\w+\.)*picsee\.net\//, "$&upload/") 716 | .replace(/\.html$/, ""); 717 | break; 718 | case "bigstream.ru": 719 | _src = loc.replace("/viewer.php?file=", "/i/"); 720 | break; 721 | case "toile-libre.org": 722 | _src = loc.replace("/?img=", "/upload/original/"); 723 | break; 724 | case "fast-picture.ru": 725 | _src = loc.replace(/\.html?$/, ""); 726 | break; 727 | case "pasteboard.co": 728 | _src = loc.replace("http://pasteboard.co/", "https://cdn.pbrd.co/images/"); 729 | break; 730 | case "img-host.org.ua": 731 | _src = loc.replace("/?v=", "/images/"); 732 | break; 733 | case "gameru.net": 734 | _src = loc 735 | .replace("/image/", "/image/direct/") 736 | .replace(/\.html$/, ""); 737 | break; 738 | case "imgdepo.com": 739 | _src = loc.replace("/show/", "/id/"); 740 | break; 741 | case "stick.kz": 742 | // stick.kz/?v=2016-07-19_foo.jpg 743 | // stick.kz/img/2016-07/19/foo.jpg 744 | _src = loc.replace(/\/\?v=(\d{4}-\d\d)-(\d\d)_/, "/img/$1/$2/"); 745 | break; 746 | case "imagestun.com": 747 | _src = loc.replace("/?v=", "/kartinki/"); 748 | break; 749 | case "picua.org": 750 | // picua.org/?v=2016-08-06_foo.png 751 | // picua.org/img/2016-08/06/foo.png 752 | _src = loc.replace(/\/\?v=(\d{4}-\d\d)-(\d\d)_/, "/img/$1/$2/"); 753 | break; 754 | case "giphy.com": 755 | // http://media1.giphy.com/media/yr7n0u3qzO9nG/giphy.gif 756 | // http://i.giphy.com/yr7n0u3qzO9nG.gif 757 | _src = loc 758 | .replace(/^https?:\/\/\w+\.giphy\.com\/media\//, "https://i.giphy.com/") 759 | .replace(/\/\w+(\.\w+)$/, "$1"); 760 | break; 761 | case "scrin.org": 762 | _src = loc.replace(/\/\?v=(\w+\.\w+)/, function(s, name) { 763 | return "/i/" + name.replace(/_/g, "/"); 764 | }); 765 | break; 766 | case "lostpix.com": 767 | // lostpix.com/?v=2018-01-09_foo.png 768 | // lostpix.com/img/2018-01/09/foo.png 769 | _src = loc.replace(/\/\?v=(\d{4}-\d\d)-(\d\d)_/, "/img/$1/$2/"); 770 | break; 771 | case "picplus.ru": 772 | _src = loc.replace("/ful/", "/img/"); 773 | break; 774 | 775 | // Get image by src: 776 | case "imagepix.org": 777 | _src = $i(/^https?:\/\/(?:www\.)?imagepix\.org\/full\/\w+\.\w+$/i); 778 | break; 779 | case "saveimg.ru": 780 | _src = $i(/^https?:\/\/(?:www\.)?saveimg\.ru\/pictures\/[\w\/-]+?\/[a-f0-9]{25,}\.[a-z]+$/); 781 | break; 782 | case "mediapix.ru": 783 | _src = $i(/^https?:\/\/(?:www\.)?mediapix\.ru\/pics\/[a-f0-9]{25,}\.[a-z]+$/); 784 | break; 785 | case "pixs.ru": 786 | _src = $i(/^https?:\/\/img\.pixs\.ru\/storage\//); 787 | break; 788 | case "postimage.org": 789 | _src = $i(/^https?:\/\/\w+\.postimage.org\//); 790 | break; 791 | case "uaimages.com": 792 | _src = $i(/^https?:\/\/(?:www\.)?uaimages\.com\/images\/\w+\.\w+$/); 793 | break; 794 | case "7image.ru": 795 | _src = $i(/^https?:\/\/7image\.ru\/pics\/[^?&#]+\.\w+$/); 796 | break; 797 | case "mepic.ru": 798 | _src = $i(/^https?:\/\/mepic\.ru\/up\/[^?&#]+\.\w+$/); 799 | break; 800 | case "simplest-image-hosting.net": 801 | _src = $i(/^https?:\/\/\w+\.simplest-image-hosting\.net\/[^?&#]+\.\w+$/); 802 | break; 803 | case "pics.kz": 804 | _src = $i(/^https?:\/\/pics\.kz\/[^?&#]+\/[0-9a-f]{32,}\.\w+$/); 805 | break; 806 | case "imagepost.ru": 807 | _src = $i(/^https?:\/\/(?:www\.)?imagepost\.ru\/images\/[^?&#]+\.\w+$/); 808 | break; 809 | case "imgtheif.com": 810 | _src = $i(/^https?:\/\/(?:www\.)?imgtheif\.com\/pictures\/[^?&#]+\.\w+$/); 811 | break; 812 | case "hostingkartinok.com": 813 | _src = $i(/^https?:\/\/(?:\w+\.)?hostingkartinok\.com\/[^#]+[0-9a-f]{32,}\.\w+$/); 814 | break; 815 | case "image.kz": 816 | _src = $i(/^https?:\/\/(?:www\.)?image\.kz\/[^?&#]+\/[0-9a-f]{32,}\.\w+$/); 817 | break; 818 | case "imm.io": 819 | _src = $i(/^https?:\/\/(?:\w+\.)?imm\.io\/[^?&#]+\.\w+$/); 820 | break; 821 | case "narodpix.net": 822 | _src = $i(/^https?:\/\/(?:\w+\.)?narodpix\.net\/img\/[^?&#]+\.\w+$/); 823 | break; 824 | case "firepic.org": 825 | _src = $i(/^https?:\/\/(?:\w+\.)*firepic\.org\/[^?&#]*images\/[^?&#]+\.\w+$/); 826 | break; 827 | case "you-logo.ru": 828 | _src = $i(/^https?:\/\/(?:\w+\.)*you-logo\.ru\/[^?&#]+\/[^?&#\/]{32,}\.\w+$/); 829 | break; 830 | case "uploadimagex.com": 831 | _src = $i(/^https?:\/\/(?:\w+\.)*uploadimagex\.com\/uploads\/(?:[^?&#\/]+\/)*[^?&#\/]+\.\w+$/); 832 | break; 833 | case "toroff.net": 834 | _src = $i(/^https?:\/\/(?:\w+\.)*toroff\.net\/img\/(?:[^?&#\/]+\/)*[^?&#\/]{15,}\.\w+$/); 835 | break; 836 | case "clip2net.com": 837 | _src = $i(/^https?:\/\/(?:\w+\.)*clip2net\.com\/clip\/[^?&#]+\.\w+(?:\?nocache=\d+)?$/) 838 | .replace(/\?nocache=\d+?$/, ""); 839 | break; 840 | case "screencast.com": 841 | _src = $i(/^https?:\/\/content\.screencast\.com\/[^?&#]+\.\w+$/); 842 | break; 843 | case "lastusja.ru": 844 | _src = $i(/^https?:\/\/(?:\w+\.)*lastusja\.ru\/images\/[^?&#]+\.\w+$/); 845 | break; 846 | case "gyazo.com": 847 | _src = $i(/^https?:\/\/(?:\w+\.)*gyazo\.com\/[\da-f]{32,}\.\w+$/); 848 | break; 849 | case "imgchilibum.ru": 850 | _src = $i(/^https?:\/\/imgchilibum\.ru\/[^?&#]+\/[\da-f]{32,}\.\w+$/); 851 | break; 852 | case "imglink.ru": 853 | _src = $i(/^https?:\/\/imglink\.ru\/pictures\/[^?&#]+\/[\da-f]{32,}\.\w+$/); 854 | break; 855 | case "fotolink.su": 856 | _src = $i(/^https?:\/\/(?:\w+\.)?fotolink\.su\/pic_b\/[^?&#]*[\da-f]{32,}\.\w+$/); 857 | _clearDoc = true; 858 | break; 859 | case "netpics.org": 860 | _src = $i(/^https?:\/\/netpics\.org\/images\/[^?&#]+\/\w+\.\w+$/); 861 | break; 862 | case "ximage.ru": 863 | _src = $i(/^https?:\/\/(?:\w+\.)*ximage\.ru\/data\/imgs\/[^?&#]+\.\w+$/); 864 | break; 865 | case "ii4.ru": 866 | _src = $i(/^https?:\/\/(?:\w+\.)*ii4\.ru\/images\/[^?&#]+\.\w+$/); 867 | break; 868 | case "freescreens.ru": 869 | _src = $i(/^https?:\/\/(?:\w+\.)*freescreens\.ru\/allimage\/[^?&#]+\.\w+$/); 870 | break; 871 | case "powerlogo.ru": 872 | _src = $i(/^https?:\/\/(?:\w+\.)*powerlogo\.ru\/pictures\/[\da-f]{32,}\.\w+$/); 873 | break; 874 | case "savepice.ru": 875 | _src = $i(/^https?:\/\/(?:\w+\.)*savepice\.ru\/uploads\/[^?&#]+\/[\da-f]{32,}[^?&#\/]+\.\w+$/); 876 | break; 877 | case "funkyimg.com": 878 | _src = $i(/^https?:\/\/(?:\w+\.)*funkyimg\.com\/i\/[^?&#\/]+\.\w+$/); 879 | break; 880 | case "imagesnake.com": 881 | _src = $i(/^https?:\/\/(?:\w+\.)*imagesnake\.com\/tn\/i\d+\/[^?&#\/]+\.\w+(?:\?id=\w+)?$/); 882 | break; 883 | case "imagevenue.com": 884 | _src = $i(/^https:\/\/cdn-images\.imagevenue\.com\/[^?&#]+\.\w+$/); 885 | if(!_src) 886 | _iid = "thepic"; 887 | break; 888 | 889 | // Get image from thumbnail: 890 | case "piccash.net": 891 | _src = $th( 892 | /^https?:\/\/piccash\.net\/[^?&#]+\/img_full\/\w+\.\w+$/, 893 | /^https?:\/\/piccash\.net\/[^?&#]+\/img_thumb\/\w+-thumb\.\w+$/, 894 | { 895 | "/img_thumb/": "/img_full/", 896 | "-thumb.": "." 897 | } 898 | ); 899 | break; 900 | case "pic4you.ru": 901 | _src = $th( 902 | /^https?:\/\/(?:\w+\.)?pic4you\.ru\/[^?&#]+\/\d+\.\w+$/, 903 | /^https?:\/\/(?:\w+\.)?pic4you\.ru\/[^?&#]+\/\d+-thumb\.\w+$/, 904 | { "-thumb.": "." } 905 | ); 906 | break; 907 | case "picforall.ru": 908 | case "payforpic.ru": 909 | case "pix-x.net": 910 | case "picclick.ru": 911 | case "imgclick.ru": 912 | case "imgbase.ru": 913 | case "picpays.ru": 914 | case "drlink.online": 915 | var more = $c("more_images"); // Blocks with "similar images" (on pix-x.net) 916 | for(var i = more.length - 1; i >= 0; --i) 917 | more[i].parentNode.removeChild(more[i]); 918 | _src = $th( 919 | /^https?:\/\/[^\/]+\/allimage\/[^?&#]+\/\d+\.\w+$/, 920 | /^https?:\/\/[^\/]+\/allimage\/[^?&#]+\/\d+-thumb\.\w+$/, 921 | { 922 | "/img_thumb/": "/img_full/", 923 | "-thumb.": "." 924 | } 925 | ); 926 | break; 927 | case "pronpic.org": 928 | var img = $("full_img"); 929 | if(img) { // May be hidden in case of detected AdBlock! 930 | _src = img.src; 931 | break; 932 | } 933 | var th = $("small_img"); 934 | if(th) 935 | _src = th.src.replace("/th_", "/"); 936 | break; 937 | 938 | // Other: 939 | case "imageshack.us": 940 | case "imageshack.com": 941 | _src = $inp(/^https?:\/\/(?:\w+\.)*imageshack\.us\/(?:\w+\/)?img[^?&#]*\.\w+$/i); 942 | break; 943 | case "savepic.ru": 944 | case "savepic.org": 945 | case "savepic.net": 946 | case "savepic.su": 947 | var inp = $("http"); 948 | if(inp) { 949 | _src = inp.value; 950 | break; 951 | } 952 | var imgs = document.images; 953 | for(var i = 0, len = imgs.length; i < len; ++i) { 954 | var img = imgs[i]; 955 | var h = img.parentNode.href; 956 | var s = img.src; 957 | if( 958 | h && /^https?:\/\/(?:www\.)?savepic\.\w+\/\d+m\.htm$/.test(h) 959 | && s && /^https?:\/\/(?:www\.)?savepic\.\w+\/\d+\.[a-z0-9]{3,4}$/.test(s) 960 | ) { 961 | _src = s; 962 | break; 963 | } 964 | } 965 | break; 966 | case "piccy.info": 967 | if(/\/orig\/?$/.test(loc)) 968 | _iid = "mainim"; 969 | else 970 | _src = loc.replace(/(?:\/\d{2,4})?\/?$/, "/orig/"); 971 | break; 972 | case "xtupload.com": 973 | var src = $inp(/^\[url=[^\[\]]+\]\[img\](http:\/\/(?:www\.)?xtupload.com\/\w+\/image-[^\[\]]+)\[\/img\]\[\/url\]/); 974 | if(src) 975 | _src = RegExp.$1; 976 | break; 977 | case "picatom.com": 978 | _img = document.getElementsByName("fred")[0]; 979 | break; 980 | case "fotosik.pl": 981 | if(loc.indexOf("/pelny/") != -1) 982 | _iid = "photoDivImage"; 983 | else 984 | redirect(loc.replace(/\/pokaz_obrazek\//i, "$&pelny/")); 985 | break; 986 | case "yandex.ru": 987 | var cont = $("sizes-list"); 988 | if(!cont) 989 | break; 990 | var opts = cont.getElementsByTagName("div"), oLen = opts.length; 991 | if(!oLen) 992 | break; 993 | var a = opts[oLen - 1].getElementsByTagName("a"); 994 | if(a.length) 995 | _src = a[0].href; 996 | if(!_src) { 997 | cont = $("fotka-view"); 998 | if(!cont) 999 | break; 1000 | var imgs = cont.getElementsByTagName("img"); 1001 | if(!imgs.length) 1002 | break; 1003 | _img = imgs[0]; 1004 | } 1005 | break; 1006 | case "southwc.ru": 1007 | var links = $t("a"); 1008 | for(var i = 0, len = links.length; i < len; ++i) { 1009 | var a = links[i]; 1010 | if(a.getAttribute("rel") == "lightbox[roadtrip]") { 1011 | _src = a.href; 1012 | break; 1013 | } 1014 | } 1015 | break; 1016 | case "pict.com": 1017 | var link = $("original-link"); 1018 | if(link) 1019 | _src = link.href; 1020 | break; 1021 | case "imageban.ru": 1022 | _src = $inp(/^https?:\/\/(?:\w+\.)*imageban\.ru\/out\//); 1023 | _clearDoc = true; 1024 | break; 1025 | case "habreffect.ru": 1026 | var node = $("image"); 1027 | if(!node) 1028 | break; 1029 | var imgs = node.getElementsByTagName("img"); 1030 | if(imgs.length == 1) 1031 | _img = imgs[0]; 1032 | break; 1033 | case "rghost.ru": 1034 | case "rghost.net": 1035 | case "rgho.st": 1036 | var inp = $("direct_link"); 1037 | if(inp && inp.value) //~ old? 1038 | _src = inp.value; 1039 | else if(!$("hashes") && /^https?:\/\/rgho(?:\.st|st\.\w+)(?:\/\w+)+\.view$/.test(loc)) 1040 | _src = $i(/^https?:\/\/(?:\w+\.)*rgho(?:\.st|st\.\w+)\/[^?&#]+\/image\.\w+$/); 1041 | break; 1042 | case "itmages.ru": 1043 | case "itmages.com": 1044 | if(loc.indexOf("/preview/") != -1) 1045 | _src = loc.replace("/preview/", "/view/"); 1046 | else 1047 | _iid = "image"; 1048 | break; 1049 | case "floomby.ru": 1050 | if(!/\/full\/?$/.test(loc)) { 1051 | _src = loc.replace(/\/$/, "") + "/full/"; 1052 | break; 1053 | } 1054 | _src = $i(/^https?:\/\/(?:\w+\.)*floomby\.\w+\/files\/share\/[^?&#]+\.\w+$/); 1055 | break; 1056 | case "kinopoisk.ru": 1057 | var links = $t("a"); 1058 | for(var i = 0, len = links.length; i < len; ++i) { 1059 | var a = links[i]; 1060 | if(!/\/picture\/\d+\//.test(a.href)) 1061 | continue; 1062 | var contents = a.getElementsByTagName("*"); 1063 | if(contents.length == 1 && contents[0].nodeName.toLowerCase() == "img") { 1064 | _src = contents[0].src; 1065 | break; 1066 | } 1067 | } 1068 | break; 1069 | case "tenpic.ru": 1070 | var ta = $t("textarea"); 1071 | if(ta.length && /^https?:\/\/tenpic\.ru\//.test(ta[0].value)) 1072 | _src = ta[0].value; 1073 | break; 1074 | case "imghost.in": 1075 | var links = $t("a"); 1076 | for(var i = 0, len = links.length; i < len; ++i) { 1077 | var a = links[i]; 1078 | if(!/^https?:\/\/imghost\.in\/di-\d+\.\w+$/.test(a.href)) 1079 | continue; 1080 | var imgs = a.getElementsByTagName("img"); 1081 | if(imgs.length == 1 && /^https?:\/\/imghost\.in\/dt-\d+\.\w+$/.test(imgs[0].src)) { 1082 | _src = a.href; 1083 | break; 1084 | } 1085 | } 1086 | break; 1087 | case "binimage.org": 1088 | var frs = document.getElementsByTagName("iframe"); 1089 | if(!frs.length) 1090 | break; 1091 | var fr = frs[0]; 1092 | _src = fr.getAttribute("src").charAt(0) == "/" && fr.src; 1093 | break; 1094 | case "forlazypeople.com": 1095 | case "upit.biz": 1096 | var node = $("imagen"); 1097 | if(!node) 1098 | break; 1099 | var imgs = node.getElementsByTagName("img"); 1100 | if(imgs.length == 1) 1101 | _img = imgs[0]; 1102 | break; 1103 | case "imgur.com": 1104 | var src = ogImage() 1105 | .replace(/\?fb$/, ""); 1106 | if(/^https?:\/\/(?:\w+\.)*imgur\.com\/images\/logo-/.test(src)) // Logo is useless... 1107 | src = ""; 1108 | else if(/\?fbplay$/.test(src)) { // Video? 1109 | destroy(); 1110 | break; 1111 | } 1112 | if(src && loc.indexOf("/a/") == -1) { // Not a gallery? 1113 | _src = src; 1114 | _clearDoc = true; 1115 | break; 1116 | } 1117 | if(!di._src) // Will be changed, remember initial value... 1118 | di._src = src; 1119 | var imgCount = $c("Gallery-Content--mediaContainer").length; 1120 | if(!imgCount) { // Not yet lazy-loaded? 1121 | _wait = true; 1122 | break; 1123 | } 1124 | if(imgCount > 1) // Many images? 1125 | break; 1126 | _src = di._src || src; 1127 | break; 1128 | case "goodfon.ru": 1129 | case "goodfon.su": 1130 | case "badfon.ru": 1131 | var a = $("im"); 1132 | if(a) 1133 | _src = a.href; 1134 | break; 1135 | case "image-upload.net": 1136 | var inp = document.getElementById("codedirect"); 1137 | if(inp) 1138 | _src = inp.value; 1139 | break; 1140 | case "imageshost.ru": 1141 | //_img = $("image"); 1142 | //if(_img) 1143 | // break; 1144 | var content = $("content"); 1145 | if(!content) 1146 | break; 1147 | var ps = content.getElementsByTagName("p"); 1148 | for(var i = 0, l = ps.length; i < l; ++i) 1149 | if(ps[i].textContent == "Другие изображения из данного альбома") 1150 | break hostLoop; 1151 | _src = $i(/^https?:\/\/(?:\w+\.)?imageshost\.ru\/img\/[^?&#]+\.\w+$/, content); 1152 | break; 1153 | case "screenshotuploader.com": 1154 | var node = $("padd"); 1155 | _img = node && node.getElementsByTagName("img")[0]; 1156 | break; 1157 | case "prntscr.com": 1158 | var nodes = $c("image__pic"); 1159 | if(nodes.length == 1 && nodes[0].nodeName.toLowerCase() == "img") 1160 | _img = nodes[0]; 1161 | break; 1162 | case "ifotki.info": 1163 | _src = $i(/^https?:\/\/(?:\w+\.)?ifotki\.info\/([^?&#]+\/)?[0-9a-f]{32,}\.\w+$/); 1164 | if(!_src) { 1165 | var src = $inp(/^\[url=http:\/\/ifotki\.info\/\]\[img\](.*?)\[\/img\]\[\/url\]$/); 1166 | if(src && !/html?$/.test(RegExp.$1)) 1167 | _src = RegExp.$1; 1168 | } 1169 | break; 1170 | case "photobucket.com": 1171 | if($("flashcontent")) 1172 | break; 1173 | if(/^(http:\/\/\w+\.photobucket\.com\/[^?&#]+).*[?&]current=([^?&#]+)/.test(loc)) 1174 | _src = (RegExp.$1 + RegExp.$2).replace(/\/\/s/, "//i"); 1175 | else { 1176 | _clearDoc = true; 1177 | _src = $u($("linksModule_ccinput_1")); 1178 | if(!_src) { 1179 | var labels = document.getElementsByTagName("label"); 1180 | for(var i = 0, l = labels.length; i < l; ++i) { 1181 | var label = labels[i]; 1182 | if(/(?:^|\s)Direct(?:\s|$)/i.test(label.textContent)) { 1183 | _src = $u(label.parentNode.getElementsByTagName("input")[0]); 1184 | break; 1185 | } 1186 | } 1187 | } 1188 | } 1189 | break; 1190 | case "tinypic.com": 1191 | _clearDoc = true; 1192 | _src = $u($("direct-url")); 1193 | if(!_src) { 1194 | var block = $("flash-direct-url"); 1195 | var embed = block && $t("embed", block)[0]; 1196 | if(embed) { 1197 | var fv = embed.getAttribute("flashvars"); 1198 | if(/=(http[^\s&]+)/.test(fv)) 1199 | _src = $url($dec(RegExp.$1)); 1200 | } 1201 | } 1202 | break; 1203 | case "fotohost.by": 1204 | var imgs = $c("pic"); 1205 | if(imgs.length == 1) 1206 | _img = imgs[0]; 1207 | break; 1208 | case "fastpic.ru": 1209 | case "fastpic.org": 1210 | _img = $c("image")[0] || null; 1211 | _clearDoc = true; 1212 | break; 1213 | case "joxi.ru": 1214 | case "joxi.net": 1215 | var links = $c("js-tile-link-zoom"); 1216 | if(links.length) 1217 | _src = links[0].href; 1218 | break; 1219 | case "postimg.org": 1220 | var img = $("main-image"); 1221 | if(!img) 1222 | break; 1223 | if(img.hasAttribute("data-full")) 1224 | _src = location.protocol + img.getAttribute("data-full").replace(/^https?:/, ""); 1225 | else 1226 | _img = img; 1227 | _clearDoc = true; 1228 | break; 1229 | case "i-fotki.info": 1230 | if($inp(/^\[URL=[^\[\]]+\]\[IMG\](https?:\/\/(?:\w+\.)*ifotki\.info\/org\/[^?&#]+\.\w+)\[\/IMG\]\[\/URL\]$/i)) 1231 | _src = RegExp.$1; 1232 | break; 1233 | case "4put.ru": 1234 | _src = $inp(/^https?:\/\/(?:\w+\.)*4put\.ru\/pictures\/max\/[^?&#]+\.\w+$/); 1235 | break; 1236 | case "fotkidepo.ru": 1237 | case "ixbt.photo": 1238 | _src = $a(/^https?:\/\/(?:\w+\.)*(?:fotkidepo\.ru|ixbt\.photo)\/photo\/[^?&#]+\.\w+$/); 1239 | break; 1240 | case "lostpic.net": 1241 | _src = $a(/^https?:\/\/(?:\w+\.)*lostpic\.net\/orig_images[^?&#]*\/[0-9a-f]{32,}\.\w+$/) 1242 | || ($i(/^https?:\/\/(?:\w+\.)*lostpic\.net\/[^?&#]*\/[0-9a-f]{32,}(?:\.md)?\.\w+$/) || "") 1243 | .replace(/\.md(\.\w+)$/, "$1") 1244 | break; 1245 | case "lg.ua": 1246 | _src = $a(/^https?:\/\/pic\.lg\.ua\/[^?&#]+\.\w+$/); 1247 | break; 1248 | case "cardse.net": 1249 | _src = $inp(/^https?:\/\/cardse\.net\/[^?&#]+\.\w+$/); 1250 | break; 1251 | case "image2you.ru": 1252 | var btn = $("_confirm"); 1253 | if(btn) 1254 | btn.click(); 1255 | else 1256 | _src = $i(/^https?:\/\/image2you\.ru\/allimages\/[^?&#]+\.\w+$/); 1257 | break; 1258 | case "cl.ly": 1259 | _src = ogImage(); 1260 | if(_src && location.protocol == "https:" && /^http:\/+/i.test(_src)) 1261 | _src = "https://s3.amazonaws.com/" + RegExp.rightContext; 1262 | break; 1263 | case "riotpixels.com": 1264 | _src = $a(/^https?:\/\/(?:\w+\.)?riotpixels\.\w+\/data\/[^?&#]+\.\w+$/); 1265 | break; 1266 | case "prnt.sc": 1267 | case "snag.gy": 1268 | case "directupload.net": 1269 | case "ibb.co": 1270 | _src = ogImage(); 1271 | if(!_src) { 1272 | var img = document.querySelector && document.querySelector('img[src="' + location.pathname + '"]'); 1273 | if(img && img.src == loc && img.parentNode != document.body) { 1274 | _src = loc; 1275 | _clearDoc = true; 1276 | } 1277 | } 1278 | break; 1279 | case "picturelol.com": 1280 | _img = $c("pic")[0] || null; 1281 | _clearDoc = true; 1282 | break; 1283 | case "imgdrive.net": 1284 | _src = ogImage() 1285 | .replace("/small/", "/big/"); 1286 | break; 1287 | case "imagebam.com": 1288 | _src = ogImage(); 1289 | break; 1290 | case "postimg.cc": 1291 | var dl = $("download"); 1292 | _src = dl && dl.href && dl.href.replace(/\?dl=1$/, ""); 1293 | _clearDoc = true; 1294 | break; 1295 | case "sasisa.org": 1296 | var links = $t("a"); 1297 | for(var i = 0, l = links.length; i < l; ++i) { 1298 | var a = links[i]; 1299 | if(a.textContent == "Скачать оригинал") { 1300 | _src = a.href; 1301 | break; 1302 | } 1303 | } 1304 | break; 1305 | case "radikal.host": 1306 | _src = ogImage(); 1307 | } 1308 | if(_iid) 1309 | _img = $(_iid); 1310 | if(_img && _img.src && _img.offsetWidth && _img.offsetHeight) //~ todo: fails sometimes on DOMContentLoaded 1311 | _src = _img.src; 1312 | if(_src && _src != loc) { 1313 | GM_log("Redirect (" + (event ? event.type : "delay") + "):\n" + loc + "\n=> " + _src); 1314 | if(_clearDoc) { 1315 | if("history" in window && "pushState" in history) try { 1316 | history[allowBack ? "pushState" : "replaceState"]("", document.title, _src); 1317 | } 1318 | catch(e) { // SecurityError: The operation is insecure 1319 | setTimeout(function() { throw e; }, 0); 1320 | allowBack && history.pushState("", document.title, loc); 1321 | } 1322 | clearDoc(_src); 1323 | } 1324 | else { 1325 | redirect(_src); 1326 | } 1327 | destroy(); 1328 | } 1329 | else if(_src) { 1330 | GM_log("Clear document (" + (event ? event.type : "delay") + "):\n" + loc); 1331 | clearDoc(_src); 1332 | destroy(); 1333 | } 1334 | else if(document.readyState == "loading" || _wait) { 1335 | if(!("_count" in di)) { 1336 | di._count = 0; 1337 | // With disabled scripts setTimeout doesn't work 1338 | ael.call(window, "DOMContentLoaded", di, false); 1339 | ael.call(window, "load", di, false); 1340 | } 1341 | if(++di._count < 5*60e3/10) 1342 | di._timer = setTimeout(di, 10); 1343 | } 1344 | else if(event && event.type == "load") 1345 | destroy(); 1346 | function destroy() { 1347 | di._timer && clearTimeout(di._timer); 1348 | rel.call(window, "DOMContentLoaded", di, false); 1349 | rel.call(window, "load", di, false); 1350 | } 1351 | })(); -------------------------------------------------------------------------------- /Direct_Links/direct_links.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name Direct Links 3 | // @version 0.2.0pre4 - 2014-02-16 4 | // @description Redirect from download pages to files directly 5 | // @author Infocatcher 6 | // @namespace dev/null 7 | // @run-at document-start 8 | // @grant GM_log 9 | // @grant GM_getValue 10 | // @grant GM_setValue 11 | 12 | // @include about:blank?UserScripts/options/Direct_Links 13 | 14 | // @include http://sourceforge.net/projects/*/download 15 | // @include https://sourceforge.net/projects/*/download 16 | // @include http://sourceforge.net/projects/*/download?* 17 | // @include https://sourceforge.net/projects/*/download?* 18 | // @include http://systemexplorer.net/downloadi.php 19 | // @include http://systemexplorer.net/downloadp.php 20 | // @include http://systemexplorer.net/download-archive/*/SystemExplorer* 21 | // ==/UserScript== 22 | 23 | (function dl(event) { 24 | // You can change 25 | // greasemonkey.scriptvals.dev/null/Direct Links.* 26 | // in about:config 27 | var allowBack = getPref("allowBack", false); 28 | 29 | var loc = location.href; 30 | if( 31 | loc == "about:blank?UserScripts/options/Direct_Links" 32 | && typeof GM_setValue == "function" 33 | ) { 34 | document.title = "Direct Links Options"; 35 | var body = document.body || document.documentElement; 36 | var label = document.createElementNS("http://www.w3.org/1999/xhtml", "label"); 37 | label.htmlFor = "allowBack"; 38 | var input = document.createElementNS("http://www.w3.org/1999/xhtml", "input"); 39 | input.id = "allowBack"; 40 | input.type = "checkbox"; 41 | input.checked = allowBack; 42 | var handleClick = function() { 43 | GM_setValue("allowBack", input.checked); 44 | }; 45 | input.addEventListener("click", handleClick, false); 46 | label.appendChild(input); 47 | label.appendChild(document.createTextNode("Allow back (don't remove page from back/forward history)")); 48 | body.appendChild(label); 49 | window.addEventListener("unload", function destroy(e) { 50 | window.removeEventListener("unload", destroy, false); 51 | input.removeEventListener("click", handleClick, false); 52 | }, false); 53 | destroy(); 54 | return; 55 | } 56 | 57 | var host = location.hostname 58 | .split(".") 59 | .slice(-2) 60 | .join("."); // a.example.com => example.com 61 | var _aid, _a, _url; 62 | function $(id) { 63 | return document.getElementById(id); 64 | } 65 | function $c(className) { 66 | return document.getElementsByClassName(className); 67 | } 68 | function $t(tag) { 69 | return document.getElementsByTagName(tag); 70 | } 71 | function $a(mask) { 72 | var links = document.links; 73 | for(var i = 0, len = links.length; i < len; ++i) { 74 | var url = links[i].href; 75 | if(url && mask.test(url)) 76 | return url; 77 | } 78 | return null; 79 | } 80 | hostLoop: 81 | switch(host) { 82 | // Get link by id: 83 | // URL-based redirect: 84 | // Get link by href: 85 | case "systemexplorer.net": 86 | _url = $a(/^https?:\/\/(\w+\.)*systemexplorer\.net\/download\/[^?&#]+\/SystemExplorer[\w.-]*\.(?:exe|zip|7z)$/); 87 | break; 88 | // Other: 89 | case "sourceforge.net": 90 | _a = $c("direct-download")[0]; 91 | } 92 | 93 | if(_aid) 94 | _a = $(_aid); 95 | if(_a && _a.href && _a.offsetWidth && _a.offsetHeight) //~ todo: fails sometimes on DOMContentLoaded 96 | _url = _a.href; 97 | if(_url && _url != loc) { 98 | if(typeof GM_log == "function") { 99 | GM_log("Redirect (" + (event ? event.type : "delay") + "):\n" + loc + "\n=> " + _url); 100 | // For Close Download Tabs extension 101 | // https://github.com/Infocatcher/Close_Download_Tabs 102 | GM_log("[Close Download Tabs] Mark URI as empty:\n" + loc); 103 | } 104 | 105 | window.stop(); 106 | if(allowBack) 107 | location.href = _url; 108 | else 109 | location.replace(_url); 110 | destroy(); 111 | } 112 | else if(document.readyState == "loading") { 113 | if(!("_count" in dl)) { 114 | dl._count = 0; 115 | // With disabled scripts setTimeout doesn't works 116 | window.addEventListener("DOMContentLoaded", dl, false); 117 | window.addEventListener("load", dl, false); 118 | } 119 | if(++dl._count < 5*60*1000/10) 120 | dl._timer = setTimeout(dl, 10); 121 | } 122 | else if(event && event.type == "load") 123 | destroy(); 124 | function getPref(name, defaultVal) { 125 | if(typeof GM_getValue != "function") 126 | return defaultVal; 127 | var v = GM_getValue(name, undefined); 128 | if(v == undefined) { 129 | GM_setValue(name, defaultVal); 130 | return defaultVal; 131 | } 132 | return v; 133 | } 134 | function destroy() { 135 | dl._timer && clearTimeout(dl._timer); 136 | window.removeEventListener("DOMContentLoaded", dl, false); 137 | window.removeEventListener("load", dl, false); 138 | } 139 | })(); -------------------------------------------------------------------------------- /Dirty.ru_List_of_Best/README.md: -------------------------------------------------------------------------------- 1 | Show list with high rated comments on http://d3.ru/ (ex http://dirty.ru/) -------------------------------------------------------------------------------- /Dirty.ru_List_of_Best/dirty.ru_list_of_best.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name Dirty.ru List of Best 3 | // @version 0.1.4pre4 - 2015-07-18 4 | // @namespace dev/null 5 | // @include https://*.d3.ru/* 6 | // @include https://d3.ru/*/* 7 | // @exclude https://d3.ru/pages/* 8 | // @include https://*.dirty.ru/* 9 | // @include https://dirty.ru/*/* 10 | // @exclude https://dirty.ru/pages/* 11 | // @include about:blank?UserScripts/options/Dirty.ru_List_of_Best 12 | // @grant GM_getValue 13 | // @grant GM_setValue 14 | // @grant GM_registerMenuCommand 15 | // @grant GM_openInTab 16 | // ==/UserScript== 17 | 18 | (function() { 19 | // You can change 20 | // greasemonkey.scriptvals.dev/null/Dirty.ru List of Best.* 21 | // in about:config 22 | 23 | if( 24 | location.href == "about:blank?UserScripts/options/Dirty.ru_List_of_Best" 25 | && typeof GM_getValue == "function" 26 | ) { 27 | document.title = "Dirty.ru List of Best - Options"; 28 | var body = document.body || document.documentElement; 29 | var numPref = function(text, pref) { 30 | var row = document.createElementNS("http://www.w3.org/1999/xhtml", "div"); 31 | var input = document.createElementNS("http://www.w3.org/1999/xhtml", "input"); 32 | input.type = "number"; 33 | //input.setAttribute("size", "4"); 34 | input.style.width = "4.5em"; 35 | input.value = input._savedPref = getPref(pref, 0); 36 | input._prefName = pref; 37 | input.addEventListener("keydown", saveItem, false); 38 | input.addEventListener("click", saveItem, false); 39 | row.appendChild(document.createTextNode(text)); 40 | row.appendChild(input); 41 | body.appendChild(row); 42 | }; 43 | var saveItem = function(e) { 44 | var input = e.currentTarget; 45 | setTimeout(function() { 46 | var val = input.value; 47 | if(input._savedPref != val) { 48 | input._savedPref = val; 49 | GM_setValue(input._prefName, +val); 50 | } 51 | }, 0); 52 | }; 53 | numPref("Rating threshold: ", "limit"); 54 | numPref("Highlight threshold #1: ", "highlight"); 55 | numPref("Highlight threshold #2: ", "highlight2"); 56 | numPref("Height: ", "show"); 57 | 58 | window.addEventListener("unload", function destroy(e) { 59 | window.removeEventListener("unload", destroy, false); 60 | Array.prototype.forEach.call( 61 | document.getElementsByTagName("input"), 62 | function(input) { 63 | input.removeEventListener("keydown", saveItem, false); 64 | input.removeEventListener("click", saveItem, false); 65 | } 66 | ); 67 | }, false); 68 | return; 69 | } 70 | 71 | if( 72 | typeof GM_registerMenuCommand == "function" 73 | && typeof GM_openInTab == "function" 74 | ) { 75 | GM_registerMenuCommand("Dirty.ru List of Best - Options", function() { 76 | GM_openInTab("about:blank?UserScripts/options/Dirty.ru_List_of_Best", false); 77 | }); 78 | } 79 | 80 | var prefsVersion = 1; 81 | var v = getPref("prefsVersion", 0); 82 | var forceDefault = v == 0; 83 | var limit = getPref("limit", 20, forceDefault); 84 | var highlight = getPref("highlight", 40, forceDefault); 85 | var highlight2 = getPref("highlight2", 65, forceDefault); 86 | var show = getPref("show", 25, forceDefault); 87 | if(v != prefsVersion) 88 | setPref("prefsVersion", prefsVersion); 89 | 90 | var best = []; 91 | Array.prototype.forEach.call( 92 | document.getElementsByClassName("vote_result"), 93 | function(e, i) { 94 | if((e.parentNode.id || "").indexOf("post_id") != -1) // Post votes 95 | return; 96 | var n = e.textContent.trim(); 97 | if(n < limit) 98 | return; 99 | var id = /'(\d+)'/.test(e.getAttribute("onclick")) && RegExp.$1; 100 | var title = ""; 101 | for(var node = e.parentNode; node; node = node.parentNode) { 102 | if(/(?:^|\s)comment_inner(?:\s|$)/.test(node.className)) { 103 | var comment = node.getElementsByClassName("c_body")[0]; 104 | if(comment) { 105 | // comment.textContent doesn't contain new lines 106 | var temp = document.createElement("div"); 107 | temp.style.whiteSpace = "pre"; 108 | temp.innerHTML = comment.innerHTML 109 | .replace(/\s+/g, " ") 110 | .replace(//g, "\n"); 111 | var imgs = temp.getElementsByTagName("img"); 112 | for(var j = imgs.length - 1; j >= 0; --j) { 113 | var img = imgs[j]; 114 | img.parentNode.replaceChild(document.createTextNode(""), img); 115 | } 116 | title = ' title="' 117 | + temp.textContent.trimLeft() 118 | .replace(/&/g, "&") 119 | .replace(//g, ">") 121 | .replace(/"/g, """) 122 | + '"'; 123 | } 124 | break; 125 | } 126 | } 127 | var clss = "__userJs__bestListAnchor"; 128 | if(n >= highlight) 129 | clss += " __userJs__bestListHL"; 130 | if(n >= highlight2) 131 | clss += " __userJs__bestListHL2"; 132 | best.push( 133 | '
  • ' 134 | + '' 135 | + n + '
  • ' 136 | ); 137 | } 138 | ); 139 | var outlineColors = { 140 | target: "#c4cedb", 141 | targetHover: "#afbecf", 142 | selected: "#e0e0e0", 143 | selectedHover: "#d0d0d0" 144 | }; 145 | (function checkColors() { 146 | if(!window.getComputedStyle) 147 | return; 148 | var s = window.getComputedStyle(document.body, null); 149 | var bg = s.backgroundColor; 150 | if(!/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/.test(bg)) 151 | return; 152 | var r = +RegExp.$1; 153 | var g = +RegExp.$2; 154 | var b = +RegExp.$3; 155 | if(r > 240 && g > 240 && b > 240) 156 | return; 157 | for(var p in outlineColors) if(outlineColors.hasOwnProperty(p)) { 158 | var oldColor = outlineColors[p]; 159 | var rgb = color(oldColor); 160 | var rgb2 = { 161 | r: Math.max(0, rgb.r - (255 - r)), 162 | g: Math.max(0, rgb.g - (255 - g)), 163 | b: Math.max(0, rgb.b - (255 - b)) 164 | }; 165 | outlineColors[p] = hex(rgb2.r, rgb2.g, rgb2.b); 166 | //console.log("Old color for " + p + ": %c" + oldColor, "color: " + oldColor + "; background: " + bg); 167 | //console.log("New color for " + p + ": %c" + outlineColors[p], "color: " + outlineColors[p] + "; background: " + bg); 168 | } 169 | function color(hex) { 170 | var offset = hex.length == 4 ? 1 : 2; 171 | return { 172 | r: parseInt(hex.substr(1, offset), 16), 173 | g: parseInt(hex.substr(1 + offset, offset), 16), 174 | b: parseInt(hex.substr(1 + offset*2, offset), 16) 175 | }; 176 | } 177 | function hex(r, g, b) { 178 | return "#" + pad(r.toString(16)) + pad(g.toString(16)) + pad(b.toString(16)); 179 | } 180 | function pad(n) { 181 | return n < 10 ? "0" + n : "" + n; 182 | } 183 | })(); 184 | var div = document.createElement("div"); 185 | div.id = "__userJs__bestList"; 186 | div.innerHTML = '\ 187 | \n\ 261 | <<'; 264 | document.body.appendChild(div); 265 | 266 | var id = location.hash; 267 | if(id) { 268 | id = id.substr(1); 269 | ensurePostVisible(id); 270 | var listItem = document.getElementById("__userJs__bestListPost" + id); 271 | listItem && listItem.classList.add("__userJs__bestListTarget"); 272 | } 273 | 274 | div.addEventListener("click", clickHandler, true); 275 | window.addEventListener("unload", destroy, false); 276 | function clickHandler(e) { 277 | if(e.button != 0) 278 | return; 279 | var a = getLink(e.target); 280 | if(!a) 281 | return; 282 | if(a.id == "__userJs__bestListClose") { 283 | //var block = a.parentNode; 284 | //block.parentNode.removeChild(block); 285 | //destroy(); 286 | var block = a.previousSibling; 287 | if(block.style.display == "none") { 288 | block.style.display = ""; 289 | a.textContent = "<<"; 290 | a.title = "Свернуть"; 291 | } 292 | else { 293 | block.style.display = "none"; 294 | a.textContent = ">>"; 295 | a.title = "Развернуть"; 296 | } 297 | stopEvent(e); 298 | } 299 | else if(/^#(\d+)$/.test(a.getAttribute("href"))) { 300 | var id = RegExp.$1; 301 | var anch = getPostById(id); 302 | if(anch && "scrollIntoView" in anch) { 303 | var expanded = ensurePostVisible(anch); 304 | anch.scrollIntoView(); 305 | if(expanded) { // Dummy way to deal with expand animation 306 | var stopTime = new Date().getTime() + 400; 307 | var timer = setInterval(function() { 308 | anch.scrollIntoView(); 309 | if(new Date().getTime() > stopTime) 310 | clearInterval(timer); 311 | }, 25); 312 | } 313 | var trgClass = "__userJs__bestListTarget"; 314 | var trgs = document.getElementsByClassName(trgClass); 315 | for(var i = trgs.length - 1; i >= 0; --i) 316 | trgs[i].classList.remove(trgClass); 317 | anch.classList.add(trgClass); 318 | var listItem = document.getElementById("__userJs__bestListPost" + id); 319 | listItem && listItem.classList.add(trgClass); 320 | stopEvent(e); 321 | } 322 | } 323 | } 324 | function getPostById(id) { 325 | return document.getElementById(id) || document.getElementsByName(id)[0]; 326 | } 327 | function ensurePostVisible(id) { 328 | var expanded = false; 329 | var post = typeof id == "string" 330 | ? getPostById(id) 331 | : id; 332 | if(!post) 333 | return expanded; 334 | for(var box = post.parentNode; box; box = box.parentNode) { 335 | var cn = box.className; 336 | if( 337 | /(^|\s)b-comments_collapsed(\s|$)/.test(cn) 338 | && !/(^|\s)b-comments_collapsed_expanded(\s|$)/.test(cn) 339 | ) { 340 | var toggler = box.getElementsByClassName("b-comments_collapsed_toggle")[0]; 341 | if(toggler && toggler.click) { 342 | toggler.click(); 343 | expanded = true; 344 | } 345 | } 346 | } 347 | return expanded; 348 | } 349 | function getLink(node) { 350 | for(; node; node = node.parentNode) 351 | if(node.nodeName.toLowerCase() == "a") 352 | return node; 353 | return null; 354 | } 355 | function stopEvent(e) { 356 | e.preventDefault(); 357 | e.stopPropagation(); 358 | } 359 | function getPref(name, defaultVal, forceDefault) { 360 | if(typeof GM_getValue != "function") 361 | return defaultVal; 362 | var v = forceDefault 363 | ? undefined 364 | : GM_getValue(name, undefined); 365 | if(v == undefined) { 366 | GM_setValue(name, defaultVal); 367 | return defaultVal; 368 | } 369 | return v; 370 | } 371 | function setPref(name, val) { 372 | if(typeof GM_setValue == "function") 373 | GM_setValue(name, val); 374 | } 375 | function destroy() { 376 | div.removeEventListener("click", clickHandler, true); 377 | window.removeEventListener("unload", destroy, false); 378 | } 379 | })(); -------------------------------------------------------------------------------- /Dirty.ru_Title/dirty.ru_title.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name Dirty.ru Title 3 | // @version 0.3.3 - 2012-11-21 4 | // @author Infocatcher 5 | // @namespace dev/null 6 | // @run-at document-start 7 | // @include http://dirty.ru/comments/* 8 | // @include http://www.dirty.ru/comments/* 9 | // @include http://d3.ru/comments/* 10 | // ==/UserScript== 11 | 12 | (function reTitle(e) { 13 | var maxLength = 100; 14 | 15 | if(typeof GM_getValue == "function") { // «"GM_getValue" in this» doesn't work with setTimeout() 16 | var mm = function(n) { 17 | return Math.max(15, Math.min(500, isNaN(n) ? 100 : n)); 18 | }; 19 | maxLength = mm(GM_getValue("maxTitleLength", maxLength)); 20 | if("GM_registerMenuCommand" in this && !("_count" in reTitle)) { 21 | GM_registerMenuCommand("Максимальная длина заголовка…", function() { 22 | var ml = prompt("Максимальная длина заголовка:", mm(GM_getValue("maxTitleLength", maxLength))); 23 | if(ml) { 24 | GM_setValue("maxTitleLength", mm(ml)); 25 | reTitle(); 26 | } 27 | }, "М"); 28 | } 29 | } 30 | 31 | function tc(elt) { 32 | return elt && elt.textContent.replace(/^\s+|\s+$/g, ""); 33 | } 34 | var c = document.getElementsByTagName("h3"); 35 | c = c.length && c[0]; 36 | var text = tc(c) || tc(document.querySelector("div.post > div.dt")); 37 | //GM_log(e && typeof e == "object" ? "!!! " + e.type : "timer"); 38 | if(!text) { 39 | if(!("_count" in reTitle)) { 40 | reTitle._count = 0; 41 | if(document.readyState == "loading") { 42 | // With disabled scripts setTimeout doesn't work 43 | window.addEventListener("DOMContentLoaded", reTitle, false); 44 | window.addEventListener("load", reTitle, false); 45 | reTitle._destroy = function() { 46 | window.removeEventListener("DOMContentLoaded", reTitle, false); 47 | window.removeEventListener("load", reTitle, false); 48 | }; 49 | } 50 | } 51 | if(++reTitle._count < 5*60*1000/10) 52 | setTimeout(reTitle, 10); 53 | if(e && typeof e == "object" && e.type == "load") 54 | reTitle._destroy && reTitle._destroy(); 55 | return; 56 | } 57 | reTitle._destroy && reTitle._destroy(); 58 | if(text.length > maxLength) { 59 | var st = text.substr(0, maxLength); 60 | if(/[а-яёa-z-]$/i.test(st) && /^[а-яёa-z-]/i.test(text.substr(maxLength))) 61 | st = st.replace(/\s*[а-яёa-z-]*$/i, ""); 62 | st = st.replace(/[\s.,:;…—–-]+$/i, ""); 63 | if(!st) 64 | return; 65 | text = st + "…"; 66 | } 67 | document.title = text + " – " + location.host.replace(/^www\./, ""); 68 | })(); -------------------------------------------------------------------------------- /Forum_Code_Highlighter/README.md: -------------------------------------------------------------------------------- 1 | Adds syntax highlighting for code blocks on some forums. 2 | 3 | ##### Screenshots: 4 | [akelpad.sf.net/forum/](http://akelpad.sf.net/forum/) 5 |
    ![Screenshot for akelpad.sf.net](https://github.com/Infocatcher/UserScripts/raw/master/Forum_Code_Highlighter/screenshots/akelpad.sf.net.png) 6 | 7 | [custombuttons.sf.net/forum/](http://custombuttons.sf.net/forum/) 8 |
    ![Screenshot for custombuttons.sf.net](https://github.com/Infocatcher/UserScripts/raw/master/Forum_Code_Highlighter/screenshots/custombuttons.sf.net.png) 9 | 10 | [forum.mozilla-russia.org](https://forum.mozilla-russia.org) 11 |
    ![Screenshot for forum.mozilla-russia.org](https://github.com/Infocatcher/UserScripts/raw/master/Forum_Code_Highlighter/screenshots/forum.mozilla-russia.org.png) -------------------------------------------------------------------------------- /Forum_Code_Highlighter/forum_code_highlighter.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name Forum Code Highlighter 3 | // @version 0.2.0 - 2023-11-27 4 | // @author Infocatcher 5 | // @namespace dev/null 6 | // @match *://custombuttons.sourceforge.net/forum/viewtopic.php?* 7 | // @match *://custombuttons.sourceforge.net/forum/posting.php* 8 | // @match *://custombuttons.sourceforge.net/forum/ucp.php*mode=compose* 9 | // @match *://forum.mozilla-russia.org/viewtopic.php?* 10 | // @match *://forum.mozilla-russia.org/post.php* 11 | // @match *://forum.mozilla-russia.org/message_list.php?* 12 | // @match *://forum.mozilla-russia.org/message_send.php?* 13 | // @match *://forum.mozilla-russia.org/edit.php?* 14 | // @match *://akelpad.sourceforge.net/forum/viewtopic.php?* 15 | // @match *://akelpad.sourceforge.net/forum/posting.php* 16 | // @match *://akelpad.sourceforge.net/forum/privmsg.php* 17 | // @match *://akelpad.sourceforge.net/forum/search.php?* 18 | // ==/UserScript== 19 | 20 | // Highlighter and styles: highlight.js https://highlightjs.org/download 21 | 22 | (function() { 23 | var classPrefix = "forumCodeHighlighter"; 24 | var codeClass = classPrefix + "-code"; 25 | var switcherClass = classPrefix + "-typeSwitcher"; 26 | var cbClass = classPrefix + "-cbCodeView"; 27 | 28 | var attr = classPrefix.replace(/[A-Z]/g, function(s) { 29 | return "-" + s.toLowerCase(); 30 | }); 31 | var parsedAttr = "data-" + attr + "-parsed"; 32 | var origAttr = "data-" + attr + "-original"; 33 | 34 | 35 | /*! 36 | Highlight.js v11.9.0 (git: f47103d4f1) 37 | (c) 2006-2023 undefined and other contributors 38 | License: BSD-3-Clause 39 | */ 40 | var hljs=function(){"use strict";function e(t){return t instanceof Map?t.clear=t.delete=t.set=()=>{throw Error("map is read-only")}:t instanceof Set&&(t.add=t.clear=t.delete=()=>{throw Error("set is read-only")}),Object.freeze(t),Object.getOwnPropertyNames(t).forEach((n=>{const i=t[n],s=typeof i;"object"!==s&&"function"!==s||Object.isFrozen(i)||e(i)})),t}class t{constructor(e){void 0===e.data&&(e.data={}),this.data=e.data,this.isMatchIgnored=!1}ignoreMatch(){this.isMatchIgnored=!0}}function n(e){return e.replace(/&/g,"&").replace(//g,">").replace(/"/g,""").replace(/'/g,"'")}function i(e,...t){const n=Object.create(null);for(const t in e)n[t]=e[t];return t.forEach((e=>{for(const t in e)n[t]=e[t]})),n}const s=e=>!!e.scope;class o{constructor(e,t){this.buffer="",this.classPrefix=t.classPrefix,e.walk(this)}addText(e){this.buffer+=n(e)}openNode(e){if(!s(e))return;const t=((e,{prefix:t})=>{if(e.startsWith("language:"))return e.replace("language:","language-");if(e.includes(".")){const n=e.split(".");return[`${t}${n.shift()}`,...n.map(((e,t)=>`${e}${"_".repeat(t+1)}`))].join(" ")}return`${t}${e}`})(e.scope,{prefix:this.classPrefix});this.span(t)}closeNode(e){s(e)&&(this.buffer+="")}value(){return this.buffer}span(e){this.buffer+=``}}const r=(e={})=>{const t={children:[]};return Object.assign(t,e),t};class a{constructor(){this.rootNode=r(),this.stack=[this.rootNode]}get top(){return this.stack[this.stack.length-1]}get root(){return this.rootNode}add(e){this.top.children.push(e)}openNode(e){const t=r({scope:e});this.add(t),this.stack.push(t)}closeNode(){if(this.stack.length>1)return this.stack.pop()}closeAllNodes(){for(;this.closeNode(););}toJSON(){return JSON.stringify(this.rootNode,null,4)}walk(e){return this.constructor._walk(e,this.rootNode)}static _walk(e,t){return"string"==typeof t?e.addText(t):t.children&&(e.openNode(t),t.children.forEach((t=>this._walk(e,t))),e.closeNode(t)),e}static _collapse(e){"string"!=typeof e&&e.children&&(e.children.every((e=>"string"==typeof e))?e.children=[e.children.join("")]:e.children.forEach((e=>{a._collapse(e)})))}}class c extends a{constructor(e){super(),this.options=e}addText(e){""!==e&&this.add(e)}startScope(e){this.openNode(e)}endScope(){this.closeNode()}__addSublanguage(e,t){const n=e.root;t&&(n.scope="language:"+t),this.add(n)}toHTML(){return new o(this,this.options).value()}finalize(){return this.closeAllNodes(),!0}}function l(e){return e?"string"==typeof e?e:e.source:null}function g(e){return h("(?=",e,")")}function u(e){return h("(?:",e,")*")}function d(e){return h("(?:",e,")?")}function h(...e){return e.map((e=>l(e))).join("")}function f(...e){const t=(e=>{const t=e[e.length-1];return"object"==typeof t&&t.constructor===Object?(e.splice(e.length-1,1),t):{}})(e);return"("+(t.capture?"":"?:")+e.map((e=>l(e))).join("|")+")"}function p(e){return RegExp(e.toString()+"|").exec("").length-1}const b=/\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./;function m(e,{joinWith:t}){let n=0;return e.map((e=>{n+=1;const t=n;let i=l(e),s="";for(;i.length>0;){const e=b.exec(i);if(!e){s+=i;break}s+=i.substring(0,e.index),i=i.substring(e.index+e[0].length),"\\"===e[0][0]&&e[1]?s+="\\"+(Number(e[1])+t):(s+=e[0],"("===e[0]&&n++)}return s})).map((e=>`(${e})`)).join(t)}const E="[a-zA-Z]\\w*",x="[a-zA-Z_]\\w*",w="\\b\\d+(\\.\\d+)?",y="(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)",_="\\b(0b[01]+)",O={begin:"\\\\[\\s\\S]",relevance:0},v={scope:"string",begin:"'",end:"'",illegal:"\\n",contains:[O]},k={scope:"string",begin:'"',end:'"',illegal:"\\n",contains:[O]},N=(e,t,n={})=>{const s=i({scope:"comment",begin:e,end:t,contains:[]},n);s.contains.push({scope:"doctag",begin:"[ ]*(?=(TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):)",end:/(TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):/,excludeBegin:!0,relevance:0});const o=f("I","a","is","so","us","to","at","if","in","it","on",/[A-Za-z]+['](d|ve|re|ll|t|s|n)/,/[A-Za-z]+[-][a-z]+/,/[A-Za-z][a-z]{2,}/);return s.contains.push({begin:h(/[ ]+/,"(",o,/[.]?[:]?([.][ ]|[ ])/,"){3}")}),s},S=N("//","$"),M=N("/\\*","\\*/"),R=N("#","$");var j=Object.freeze({__proto__:null,APOS_STRING_MODE:v,BACKSLASH_ESCAPE:O,BINARY_NUMBER_MODE:{scope:"number",begin:_,relevance:0},BINARY_NUMBER_RE:_,COMMENT:N,C_BLOCK_COMMENT_MODE:M,C_LINE_COMMENT_MODE:S,C_NUMBER_MODE:{scope:"number",begin:y,relevance:0},C_NUMBER_RE:y,END_SAME_AS_BEGIN:e=>Object.assign(e,{"on:begin":(e,t)=>{t.data._beginMatch=e[1]},"on:end":(e,t)=>{t.data._beginMatch!==e[1]&&t.ignoreMatch()}}),HASH_COMMENT_MODE:R,IDENT_RE:E,MATCH_NOTHING_RE:/\b\B/,METHOD_GUARD:{begin:"\\.\\s*"+x,relevance:0},NUMBER_MODE:{scope:"number",begin:w,relevance:0},NUMBER_RE:w,PHRASAL_WORDS_MODE:{begin:/\b(a|an|the|are|I'm|isn't|don't|doesn't|won't|but|just|should|pretty|simply|enough|gonna|going|wtf|so|such|will|you|your|they|like|more)\b/},QUOTE_STRING_MODE:k,REGEXP_MODE:{scope:"regexp",begin:/\/(?=[^/\n]*\/)/,end:/\/[gimuy]*/,contains:[O,{begin:/\[/,end:/\]/,relevance:0,contains:[O]}]},RE_STARTERS_RE:"!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~",SHEBANG:(e={})=>{const t=/^#![ ]*\//;return e.binary&&(e.begin=h(t,/.*\b/,e.binary,/\b.*/)),i({scope:"meta",begin:t,end:/$/,relevance:0,"on:begin":(e,t)=>{0!==e.index&&t.ignoreMatch()}},e)},TITLE_MODE:{scope:"title",begin:E,relevance:0},UNDERSCORE_IDENT_RE:x,UNDERSCORE_TITLE_MODE:{scope:"title",begin:x,relevance:0}});function A(e,t){"."===e.input[e.index-1]&&t.ignoreMatch()}function I(e,t){void 0!==e.className&&(e.scope=e.className,delete e.className)}function T(e,t){t&&e.beginKeywords&&(e.begin="\\b("+e.beginKeywords.split(" ").join("|")+")(?!\\.)(?=\\b|\\s)",e.__beforeBegin=A,e.keywords=e.keywords||e.beginKeywords,delete e.beginKeywords,void 0===e.relevance&&(e.relevance=0))}function L(e,t){Array.isArray(e.illegal)&&(e.illegal=f(...e.illegal))}function B(e,t){if(e.match){if(e.begin||e.end)throw Error("begin & end are not supported with match");e.begin=e.match,delete e.match}}function P(e,t){void 0===e.relevance&&(e.relevance=1)}const D=(e,t)=>{if(!e.beforeMatch)return;if(e.starts)throw Error("beforeMatch cannot be used with starts");const n=Object.assign({},e);Object.keys(e).forEach((t=>{delete e[t]})),e.keywords=n.keywords,e.begin=h(n.beforeMatch,g(n.begin)),e.starts={relevance:0,contains:[Object.assign(n,{endsParent:!0})]},e.relevance=0,delete n.beforeMatch},H=["of","and","for","in","not","or","if","then","parent","list","value"],C="keyword";function $(e,t,n=C){const i=Object.create(null);return"string"==typeof e?s(n,e.split(" ")):Array.isArray(e)?s(n,e):Object.keys(e).forEach((n=>{Object.assign(i,$(e[n],t,n))})),i;function s(e,n){t&&(n=n.map((e=>e.toLowerCase()))),n.forEach((t=>{const n=t.split("|");i[n[0]]=[e,U(n[0],n[1])]}))}}function U(e,t){return t?Number(t):(e=>H.includes(e.toLowerCase()))(e)?0:1}const z={},W=e=>{console.error(e)},X=(e,...t)=>{console.log("WARN: "+e,...t)},G=(e,t)=>{z[`${e}/${t}`]||(console.log(`Deprecated as of ${e}. ${t}`),z[`${e}/${t}`]=!0)},K=Error();function F(e,t,{key:n}){let i=0;const s=e[n],o={},r={};for(let e=1;e<=t.length;e++)r[e+i]=s[e],o[e+i]=!0,i+=p(t[e-1]);e[n]=r,e[n]._emit=o,e[n]._multi=!0}function Z(e){(e=>{e.scope&&"object"==typeof e.scope&&null!==e.scope&&(e.beginScope=e.scope,delete e.scope)})(e),"string"==typeof e.beginScope&&(e.beginScope={_wrap:e.beginScope}),"string"==typeof e.endScope&&(e.endScope={_wrap:e.endScope}),(e=>{if(Array.isArray(e.begin)){if(e.skip||e.excludeBegin||e.returnBegin)throw W("skip, excludeBegin, returnBegin not compatible with beginScope: {}"),K;if("object"!=typeof e.beginScope||null===e.beginScope)throw W("beginScope must be object"),K;F(e,e.begin,{key:"beginScope"}),e.begin=m(e.begin,{joinWith:""})}})(e),(e=>{if(Array.isArray(e.end)){if(e.skip||e.excludeEnd||e.returnEnd)throw W("skip, excludeEnd, returnEnd not compatible with endScope: {}"),K;if("object"!=typeof e.endScope||null===e.endScope)throw W("endScope must be object"),K;F(e,e.end,{key:"endScope"}),e.end=m(e.end,{joinWith:""})}})(e)}function V(e){function t(t,n){return RegExp(l(t),"m"+(e.case_insensitive?"i":"")+(e.unicodeRegex?"u":"")+(n?"g":""))}class n{constructor(){this.matchIndexes={},this.regexes=[],this.matchAt=1,this.position=0}addRule(e,t){t.position=this.position++,this.matchIndexes[this.matchAt]=t,this.regexes.push([t,e]),this.matchAt+=p(e)+1}compile(){0===this.regexes.length&&(this.exec=()=>null);const e=this.regexes.map((e=>e[1]));this.matcherRe=t(m(e,{joinWith:"|"}),!0),this.lastIndex=0}exec(e){this.matcherRe.lastIndex=this.lastIndex;const t=this.matcherRe.exec(e);if(!t)return null;const n=t.findIndex(((e,t)=>t>0&&void 0!==e)),i=this.matchIndexes[n];return t.splice(0,n),Object.assign(t,i)}}class s{constructor(){this.rules=[],this.multiRegexes=[],this.count=0,this.lastIndex=0,this.regexIndex=0}getMatcher(e){if(this.multiRegexes[e])return this.multiRegexes[e];const t=new n;return this.rules.slice(e).forEach((([e,n])=>t.addRule(e,n))),t.compile(),this.multiRegexes[e]=t,t}resumingScanAtSamePosition(){return 0!==this.regexIndex}considerAll(){this.regexIndex=0}addRule(e,t){this.rules.push([e,t]),"begin"===t.type&&this.count++}exec(e){const t=this.getMatcher(this.regexIndex);t.lastIndex=this.lastIndex;let n=t.exec(e);if(this.resumingScanAtSamePosition())if(n&&n.index===this.lastIndex);else{const t=this.getMatcher(0);t.lastIndex=this.lastIndex+1,n=t.exec(e)}return n&&(this.regexIndex+=n.position+1,this.regexIndex===this.count&&this.considerAll()),n}}if(e.compilerExtensions||(e.compilerExtensions=[]),e.contains&&e.contains.includes("self"))throw Error("ERR: contains `self` is not supported at the top-level of a language. See documentation.");return e.classNameAliases=i(e.classNameAliases||{}),function n(o,r){const a=o;if(o.isCompiled)return a;[I,B,Z,D].forEach((e=>e(o,r))),e.compilerExtensions.forEach((e=>e(o,r))),o.__beforeBegin=null,[T,L,P].forEach((e=>e(o,r))),o.isCompiled=!0;let c=null;return"object"==typeof o.keywords&&o.keywords.$pattern&&(o.keywords=Object.assign({},o.keywords),c=o.keywords.$pattern,delete o.keywords.$pattern),c=c||/\w+/,o.keywords&&(o.keywords=$(o.keywords,e.case_insensitive)),a.keywordPatternRe=t(c,!0),r&&(o.begin||(o.begin=/\B|\b/),a.beginRe=t(a.begin),o.end||o.endsWithParent||(o.end=/\B|\b/),o.end&&(a.endRe=t(a.end)),a.terminatorEnd=l(a.end)||"",o.endsWithParent&&r.terminatorEnd&&(a.terminatorEnd+=(o.end?"|":"")+r.terminatorEnd)),o.illegal&&(a.illegalRe=t(o.illegal)),o.contains||(o.contains=[]),o.contains=[].concat(...o.contains.map((e=>(e=>(e.variants&&!e.cachedVariants&&(e.cachedVariants=e.variants.map((t=>i(e,{variants:null},t)))),e.cachedVariants?e.cachedVariants:q(e)?i(e,{starts:e.starts?i(e.starts):null}):Object.isFrozen(e)?i(e):e))("self"===e?o:e)))),o.contains.forEach((e=>{n(e,a)})),o.starts&&n(o.starts,r),a.matcher=(e=>{const t=new s;return e.contains.forEach((e=>t.addRule(e.begin,{rule:e,type:"begin"}))),e.terminatorEnd&&t.addRule(e.terminatorEnd,{type:"end"}),e.illegal&&t.addRule(e.illegal,{type:"illegal"}),t})(a),a}(e)}function q(e){return!!e&&(e.endsWithParent||q(e.starts))}class J extends Error{constructor(e,t){super(e),this.name="HTMLInjectionError",this.html=t}}const Y=n,Q=i,ee=Symbol("nomatch"),te=n=>{const i=Object.create(null),s=Object.create(null),o=[];let r=!0;const a="Could not find the language '{}', did you forget to load/include a language module?",l={disableAutodetect:!0,name:"Plain text",contains:[]};let p={ignoreUnescapedHTML:!1,throwUnescapedHTML:!1,noHighlightRe:/^(no-?highlight)$/i,languageDetectRe:/\blang(?:uage)?-([\w-]+)\b/i,classPrefix:"hljs-",cssSelector:"pre code",languages:null,__emitter:c};function b(e){return p.noHighlightRe.test(e)}function m(e,t,n){let i="",s="";"object"==typeof t?(i=e,n=t.ignoreIllegals,s=t.language):(G("10.7.0","highlight(lang, code, ...args) has been deprecated."),G("10.7.0","Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277"),s=e,i=t),void 0===n&&(n=!0);const o={code:i,language:s};N("before:highlight",o);const r=o.result?o.result:E(o.language,o.code,n);return r.code=o.code,N("after:highlight",r),r}function E(e,n,s,o){const c=Object.create(null);function l(){if(!N.keywords)return void M.addText(R);let e=0;N.keywordPatternRe.lastIndex=0;let t=N.keywordPatternRe.exec(R),n="";for(;t;){n+=R.substring(e,t.index);const s=_.case_insensitive?t[0].toLowerCase():t[0],o=(i=s,N.keywords[i]);if(o){const[e,i]=o;if(M.addText(n),n="",c[s]=(c[s]||0)+1,c[s]<=7&&(j+=i),e.startsWith("_"))n+=t[0];else{const n=_.classNameAliases[e]||e;u(t[0],n)}}else n+=t[0];e=N.keywordPatternRe.lastIndex,t=N.keywordPatternRe.exec(R)}var i;n+=R.substring(e),M.addText(n)}function g(){null!=N.subLanguage?(()=>{if(""===R)return;let e=null;if("string"==typeof N.subLanguage){if(!i[N.subLanguage])return void M.addText(R);e=E(N.subLanguage,R,!0,S[N.subLanguage]),S[N.subLanguage]=e._top}else e=x(R,N.subLanguage.length?N.subLanguage:null);N.relevance>0&&(j+=e.relevance),M.__addSublanguage(e._emitter,e.language)})():l(),R=""}function u(e,t){""!==e&&(M.startScope(t),M.addText(e),M.endScope())}function d(e,t){let n=1;const i=t.length-1;for(;n<=i;){if(!e._emit[n]){n++;continue}const i=_.classNameAliases[e[n]]||e[n],s=t[n];i?u(s,i):(R=s,l(),R=""),n++}}function h(e,t){return e.scope&&"string"==typeof e.scope&&M.openNode(_.classNameAliases[e.scope]||e.scope),e.beginScope&&(e.beginScope._wrap?(u(R,_.classNameAliases[e.beginScope._wrap]||e.beginScope._wrap),R=""):e.beginScope._multi&&(d(e.beginScope,t),R="")),N=Object.create(e,{parent:{value:N}}),N}function f(e,n,i){let s=((e,t)=>{const n=e&&e.exec(t);return n&&0===n.index})(e.endRe,i);if(s){if(e["on:end"]){const i=new t(e);e["on:end"](n,i),i.isMatchIgnored&&(s=!1)}if(s){for(;e.endsParent&&e.parent;)e=e.parent;return e}}if(e.endsWithParent)return f(e.parent,n,i)}function b(e){return 0===N.matcher.regexIndex?(R+=e[0],1):(T=!0,0)}function m(e){const t=e[0],i=n.substring(e.index),s=f(N,e,i);if(!s)return ee;const o=N;N.endScope&&N.endScope._wrap?(g(),u(t,N.endScope._wrap)):N.endScope&&N.endScope._multi?(g(),d(N.endScope,e)):o.skip?R+=t:(o.returnEnd||o.excludeEnd||(R+=t),g(),o.excludeEnd&&(R=t));do{N.scope&&M.closeNode(),N.skip||N.subLanguage||(j+=N.relevance),N=N.parent}while(N!==s.parent);return s.starts&&h(s.starts,e),o.returnEnd?0:t.length}let w={};function y(i,o){const a=o&&o[0];if(R+=i,null==a)return g(),0;if("begin"===w.type&&"end"===o.type&&w.index===o.index&&""===a){if(R+=n.slice(o.index,o.index+1),!r){const t=Error(`0 width match regex (${e})`);throw t.languageName=e,t.badRule=w.rule,t}return 1}if(w=o,"begin"===o.type)return(e=>{const n=e[0],i=e.rule,s=new t(i),o=[i.__beforeBegin,i["on:begin"]];for(const t of o)if(t&&(t(e,s),s.isMatchIgnored))return b(n);return i.skip?R+=n:(i.excludeBegin&&(R+=n),g(),i.returnBegin||i.excludeBegin||(R=n)),h(i,e),i.returnBegin?0:n.length})(o);if("illegal"===o.type&&!s){const e=Error('Illegal lexeme "'+a+'" for mode "'+(N.scope||"")+'"');throw e.mode=N,e}if("end"===o.type){const e=m(o);if(e!==ee)return e}if("illegal"===o.type&&""===a)return 1;if(I>1e5&&I>3*o.index)throw Error("potential infinite loop, way more iterations than matches");return R+=a,a.length}const _=O(e);if(!_)throw W(a.replace("{}",e)),Error('Unknown language: "'+e+'"');const v=V(_);let k="",N=o||v;const S={},M=new p.__emitter(p);(()=>{const e=[];for(let t=N;t!==_;t=t.parent)t.scope&&e.unshift(t.scope);e.forEach((e=>M.openNode(e)))})();let R="",j=0,A=0,I=0,T=!1;try{if(_.__emitTokens)_.__emitTokens(n,M);else{for(N.matcher.considerAll();;){I++,T?T=!1:N.matcher.considerAll(),N.matcher.lastIndex=A;const e=N.matcher.exec(n);if(!e)break;const t=y(n.substring(A,e.index),e);A=e.index+t}y(n.substring(A))}return M.finalize(),k=M.toHTML(),{language:e,value:k,relevance:j,illegal:!1,_emitter:M,_top:N}}catch(t){if(t.message&&t.message.includes("Illegal"))return{language:e,value:Y(n),illegal:!0,relevance:0,_illegalBy:{message:t.message,index:A,context:n.slice(A-100,A+100),mode:t.mode,resultSoFar:k},_emitter:M};if(r)return{language:e,value:Y(n),illegal:!1,relevance:0,errorRaised:t,_emitter:M,_top:N};throw t}}function x(e,t){t=t||p.languages||Object.keys(i);const n=(e=>{const t={value:Y(e),illegal:!1,relevance:0,_top:l,_emitter:new p.__emitter(p)};return t._emitter.addText(e),t})(e),s=t.filter(O).filter(k).map((t=>E(t,e,!1)));s.unshift(n);const o=s.sort(((e,t)=>{if(e.relevance!==t.relevance)return t.relevance-e.relevance;if(e.language&&t.language){if(O(e.language).supersetOf===t.language)return 1;if(O(t.language).supersetOf===e.language)return-1}return 0})),[r,a]=o,c=r;return c.secondBest=a,c}function w(e){let t=null;const n=(e=>{let t=e.className+" ";t+=e.parentNode?e.parentNode.className:"";const n=p.languageDetectRe.exec(t);if(n){const t=O(n[1]);return t||(X(a.replace("{}",n[1])),X("Falling back to no-highlight mode for this block.",e)),t?n[1]:"no-highlight"}return t.split(/\s+/).find((e=>b(e)||O(e)))})(e);if(b(n))return;if(N("before:highlightElement",{el:e,language:n}),e.dataset.highlighted)return void console.log("Element previously highlighted. To highlight again, first unset `dataset.highlighted`.",e);if(e.children.length>0&&(p.ignoreUnescapedHTML||(console.warn("One of your code blocks includes unescaped HTML. This is a potentially serious security risk."),console.warn("https://github.com/highlightjs/highlight.js/wiki/security"),console.warn("The element with unescaped HTML:"),console.warn(e)),p.throwUnescapedHTML))throw new J("One of your code blocks includes unescaped HTML.",e.innerHTML);t=e;const i=t.textContent,o=n?m(i,{language:n,ignoreIllegals:!0}):x(i);e.innerHTML=o.value,e.dataset.highlighted="yes",((e,t,n)=>{const i=t&&s[t]||n;e.classList.add("hljs"),e.classList.add("language-"+i)})(e,n,o.language),e.result={language:o.language,re:o.relevance,relevance:o.relevance},o.secondBest&&(e.secondBest={language:o.secondBest.language,relevance:o.secondBest.relevance}),N("after:highlightElement",{el:e,result:o,text:i})}let y=!1;function _(){"loading"!==document.readyState?document.querySelectorAll(p.cssSelector).forEach(w):y=!0}function O(e){return e=(e||"").toLowerCase(),i[e]||i[s[e]]}function v(e,{languageName:t}){"string"==typeof e&&(e=[e]),e.forEach((e=>{s[e.toLowerCase()]=t}))}function k(e){const t=O(e);return t&&!t.disableAutodetect}function N(e,t){const n=e;o.forEach((e=>{e[n]&&e[n](t)}))}"undefined"!=typeof window&&window.addEventListener&&window.addEventListener("DOMContentLoaded",(()=>{y&&_()}),!1),Object.assign(n,{highlight:m,highlightAuto:x,highlightAll:_,highlightElement:w,highlightBlock:e=>(G("10.7.0","highlightBlock will be removed entirely in v12.0"),G("10.7.0","Please use highlightElement now."),w(e)),configure:e=>{p=Q(p,e)},initHighlighting:()=>{_(),G("10.6.0","initHighlighting() deprecated. Use highlightAll() now.")},initHighlightingOnLoad:()=>{_(),G("10.6.0","initHighlightingOnLoad() deprecated. Use highlightAll() now.")},registerLanguage:(e,t)=>{let s=null;try{s=t(n)}catch(t){if(W("Language definition for '{}' could not be registered.".replace("{}",e)),!r)throw t;W(t),s=l}s.name||(s.name=e),i[e]=s,s.rawDefinition=t.bind(null,n),s.aliases&&v(s.aliases,{languageName:e})},unregisterLanguage:e=>{delete i[e];for(const t of Object.keys(s))s[t]===e&&delete s[t]},listLanguages:()=>Object.keys(i),getLanguage:O,registerAliases:v,autoDetection:k,inherit:Q,addPlugin:e=>{(e=>{e["before:highlightBlock"]&&!e["before:highlightElement"]&&(e["before:highlightElement"]=t=>{e["before:highlightBlock"](Object.assign({block:t.el},t))}),e["after:highlightBlock"]&&!e["after:highlightElement"]&&(e["after:highlightElement"]=t=>{e["after:highlightBlock"](Object.assign({block:t.el},t))})})(e),o.push(e)},removePlugin:e=>{const t=o.indexOf(e);-1!==t&&o.splice(t,1)}}),n.debugMode=()=>{r=!1},n.safeMode=()=>{r=!0},n.versionString="11.9.0",n.regex={concat:h,lookahead:g,either:f,optional:d,anyNumberOfTimes:u};for(const t in j)"object"==typeof j[t]&&e(j[t]);return Object.assign(n,j),n},ne=te({});return ne.newInstance=()=>te({}),ne}();"object"==typeof exports&&"undefined"!=typeof module&&(module.exports=hljs);/*! `cpp` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const t=e.regex,a=e.COMMENT("//","$",{contains:[{begin:/\\\n/}]}),n="decltype\\(auto\\)",r="[a-zA-Z_]\\w*::",i="(?!struct)("+n+"|"+t.optional(r)+"[a-zA-Z_]\\w*"+t.optional("<[^<>]+>")+")",s={className:"type",begin:"\\b[a-z\\d_]*_t\\b"},c={className:"string",variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n",contains:[e.BACKSLASH_ESCAPE]},{begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)",end:"'",illegal:"."},e.END_SAME_AS_BEGIN({begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},o={className:"number",variants:[{begin:"\\b(0b[01']+)"},{begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)((ll|LL|l|L)(u|U)?|(u|U)(ll|LL|l|L)?|f|F|b|B)"},{begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"}],relevance:0},l={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{keyword:"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include"},contains:[{begin:/\\\n/,relevance:0},e.inherit(c,{className:"string"}),{className:"string",begin:/<.*?>/},a,e.C_BLOCK_COMMENT_MODE]},d={className:"title",begin:t.optional(r)+e.IDENT_RE,relevance:0},u=t.optional(r)+e.IDENT_RE+"\\s*\\(",p={type:["bool","char","char16_t","char32_t","char8_t","double","float","int","long","short","void","wchar_t","unsigned","signed","const","static"],keyword:["alignas","alignof","and","and_eq","asm","atomic_cancel","atomic_commit","atomic_noexcept","auto","bitand","bitor","break","case","catch","class","co_await","co_return","co_yield","compl","concept","const_cast|10","consteval","constexpr","constinit","continue","decltype","default","delete","do","dynamic_cast|10","else","enum","explicit","export","extern","false","final","for","friend","goto","if","import","inline","module","mutable","namespace","new","noexcept","not","not_eq","nullptr","operator","or","or_eq","override","private","protected","public","reflexpr","register","reinterpret_cast|10","requires","return","sizeof","static_assert","static_cast|10","struct","switch","synchronized","template","this","thread_local","throw","transaction_safe","transaction_safe_dynamic","true","try","typedef","typeid","typename","union","using","virtual","volatile","while","xor","xor_eq"],literal:["NULL","false","nullopt","nullptr","true"],built_in:["_Pragma"],_type_hints:["any","auto_ptr","barrier","binary_semaphore","bitset","complex","condition_variable","condition_variable_any","counting_semaphore","deque","false_type","future","imaginary","initializer_list","istringstream","jthread","latch","lock_guard","multimap","multiset","mutex","optional","ostringstream","packaged_task","pair","promise","priority_queue","queue","recursive_mutex","recursive_timed_mutex","scoped_lock","set","shared_future","shared_lock","shared_mutex","shared_timed_mutex","shared_ptr","stack","string_view","stringstream","timed_mutex","thread","true_type","tuple","unique_lock","unique_ptr","unordered_map","unordered_multimap","unordered_multiset","unordered_set","variant","vector","weak_ptr","wstring","wstring_view"]},_={className:"function.dispatch",relevance:0,keywords:{_hint:["abort","abs","acos","apply","as_const","asin","atan","atan2","calloc","ceil","cerr","cin","clog","cos","cosh","cout","declval","endl","exchange","exit","exp","fabs","floor","fmod","forward","fprintf","fputs","free","frexp","fscanf","future","invoke","isalnum","isalpha","iscntrl","isdigit","isgraph","islower","isprint","ispunct","isspace","isupper","isxdigit","labs","launder","ldexp","log","log10","make_pair","make_shared","make_shared_for_overwrite","make_tuple","make_unique","malloc","memchr","memcmp","memcpy","memset","modf","move","pow","printf","putchar","puts","realloc","scanf","sin","sinh","snprintf","sprintf","sqrt","sscanf","std","stderr","stdin","stdout","strcat","strchr","strcmp","strcpy","strcspn","strlen","strncat","strncmp","strncpy","strpbrk","strrchr","strspn","strstr","swap","tan","tanh","terminate","to_underlying","tolower","toupper","vfprintf","visit","vprintf","vsprintf"]},begin:t.concat(/\b/,/(?!decltype)/,/(?!if)/,/(?!for)/,/(?!switch)/,/(?!while)/,e.IDENT_RE,t.lookahead(/(<[^<>]+>|)\s*\(/))},m=[_,l,s,a,e.C_BLOCK_COMMENT_MODE,o,c],g={variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{beginKeywords:"new throw return else",end:/;/}],keywords:p,contains:m.concat([{begin:/\(/,end:/\)/,keywords:p,contains:m.concat(["self"]),relevance:0}]),relevance:0},f={className:"function",begin:"("+i+"[\\*&\\s]+)+"+u,returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:p,illegal:/[^\w\s\*&:<>.]/,contains:[{begin:n,keywords:p,relevance:0},{begin:u,returnBegin:!0,contains:[d],relevance:0},{begin:/::/,relevance:0},{begin:/:/,endsWithParent:!0,contains:[c,o]},{relevance:0,match:/,/},{className:"params",begin:/\(/,end:/\)/,keywords:p,relevance:0,contains:[a,e.C_BLOCK_COMMENT_MODE,c,o,s,{begin:/\(/,end:/\)/,keywords:p,relevance:0,contains:["self",a,e.C_BLOCK_COMMENT_MODE,c,o,s]}]},s,a,e.C_BLOCK_COMMENT_MODE,l]};return{name:"C++",aliases:["cc","c++","h++","hpp","hh","hxx","cxx"],keywords:p,illegal:"",keywords:p,contains:["self",s]},{begin:e.IDENT_RE+"::",keywords:p},{match:[/\b(?:enum(?:\s+(?:class|struct))?|class|struct|union)/,/\s+/,/\w+/],className:{1:"keyword",3:"title.class"}}])}}})();hljs.registerLanguage("cpp",e)})();/*! `css` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";const e=["a","abbr","address","article","aside","audio","b","blockquote","body","button","canvas","caption","cite","code","dd","del","details","dfn","div","dl","dt","em","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","html","i","iframe","img","input","ins","kbd","label","legend","li","main","mark","menu","nav","object","ol","p","q","quote","samp","section","span","strong","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","ul","var","video"],i=["any-hover","any-pointer","aspect-ratio","color","color-gamut","color-index","device-aspect-ratio","device-height","device-width","display-mode","forced-colors","grid","height","hover","inverted-colors","monochrome","orientation","overflow-block","overflow-inline","pointer","prefers-color-scheme","prefers-contrast","prefers-reduced-motion","prefers-reduced-transparency","resolution","scan","scripting","update","width","min-width","max-width","min-height","max-height"],r=["active","any-link","blank","checked","current","default","defined","dir","disabled","drop","empty","enabled","first","first-child","first-of-type","fullscreen","future","focus","focus-visible","focus-within","has","host","host-context","hover","indeterminate","in-range","invalid","is","lang","last-child","last-of-type","left","link","local-link","not","nth-child","nth-col","nth-last-child","nth-last-col","nth-last-of-type","nth-of-type","only-child","only-of-type","optional","out-of-range","past","placeholder-shown","read-only","read-write","required","right","root","scope","target","target-within","user-invalid","valid","visited","where"],t=["after","backdrop","before","cue","cue-region","first-letter","first-line","grammar-error","marker","part","placeholder","selection","slotted","spelling-error"],o=["align-content","align-items","align-self","all","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","backface-visibility","background","background-attachment","background-blend-mode","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","block-size","border","border-block","border-block-color","border-block-end","border-block-end-color","border-block-end-style","border-block-end-width","border-block-start","border-block-start-color","border-block-start-style","border-block-start-width","border-block-style","border-block-width","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-inline","border-inline-color","border-inline-end","border-inline-end-color","border-inline-end-style","border-inline-end-width","border-inline-start","border-inline-start-color","border-inline-start-style","border-inline-start-width","border-inline-style","border-inline-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","caret-color","clear","clip","clip-path","clip-rule","color","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","contain","content","content-visibility","counter-increment","counter-reset","cue","cue-after","cue-before","cursor","direction","display","empty-cells","filter","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","flow","font","font-display","font-family","font-feature-settings","font-kerning","font-language-override","font-size","font-size-adjust","font-smoothing","font-stretch","font-style","font-synthesis","font-variant","font-variant-caps","font-variant-east-asian","font-variant-ligatures","font-variant-numeric","font-variant-position","font-variation-settings","font-weight","gap","glyph-orientation-vertical","grid","grid-area","grid-auto-columns","grid-auto-flow","grid-auto-rows","grid-column","grid-column-end","grid-column-start","grid-gap","grid-row","grid-row-end","grid-row-start","grid-template","grid-template-areas","grid-template-columns","grid-template-rows","hanging-punctuation","height","hyphens","icon","image-orientation","image-rendering","image-resolution","ime-mode","inline-size","isolation","justify-content","left","letter-spacing","line-break","line-height","list-style","list-style-image","list-style-position","list-style-type","margin","margin-block","margin-block-end","margin-block-start","margin-bottom","margin-inline","margin-inline-end","margin-inline-start","margin-left","margin-right","margin-top","marks","mask","mask-border","mask-border-mode","mask-border-outset","mask-border-repeat","mask-border-slice","mask-border-source","mask-border-width","mask-clip","mask-composite","mask-image","mask-mode","mask-origin","mask-position","mask-repeat","mask-size","mask-type","max-block-size","max-height","max-inline-size","max-width","min-block-size","min-height","min-inline-size","min-width","mix-blend-mode","nav-down","nav-index","nav-left","nav-right","nav-up","none","normal","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-wrap","overflow-x","overflow-y","padding","padding-block","padding-block-end","padding-block-start","padding-bottom","padding-inline","padding-inline-end","padding-inline-start","padding-left","padding-right","padding-top","page-break-after","page-break-before","page-break-inside","pause","pause-after","pause-before","perspective","perspective-origin","pointer-events","position","quotes","resize","rest","rest-after","rest-before","right","row-gap","scroll-margin","scroll-margin-block","scroll-margin-block-end","scroll-margin-block-start","scroll-margin-bottom","scroll-margin-inline","scroll-margin-inline-end","scroll-margin-inline-start","scroll-margin-left","scroll-margin-right","scroll-margin-top","scroll-padding","scroll-padding-block","scroll-padding-block-end","scroll-padding-block-start","scroll-padding-bottom","scroll-padding-inline","scroll-padding-inline-end","scroll-padding-inline-start","scroll-padding-left","scroll-padding-right","scroll-padding-top","scroll-snap-align","scroll-snap-stop","scroll-snap-type","scrollbar-color","scrollbar-gutter","scrollbar-width","shape-image-threshold","shape-margin","shape-outside","speak","speak-as","src","tab-size","table-layout","text-align","text-align-all","text-align-last","text-combine-upright","text-decoration","text-decoration-color","text-decoration-line","text-decoration-style","text-emphasis","text-emphasis-color","text-emphasis-position","text-emphasis-style","text-indent","text-justify","text-orientation","text-overflow","text-rendering","text-shadow","text-transform","text-underline-position","top","transform","transform-box","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","vertical-align","visibility","voice-balance","voice-duration","voice-family","voice-pitch","voice-range","voice-rate","voice-stress","voice-volume","white-space","widows","width","will-change","word-break","word-spacing","word-wrap","writing-mode","z-index"].reverse();return n=>{const a=n.regex,l=(e=>({IMPORTANT:{scope:"meta",begin:"!important"},BLOCK_COMMENT:e.C_BLOCK_COMMENT_MODE,HEXCOLOR:{scope:"number",begin:/#(([0-9a-fA-F]{3,4})|(([0-9a-fA-F]{2}){3,4}))\b/},FUNCTION_DISPATCH:{className:"built_in",begin:/[\w-]+(?=\()/},ATTRIBUTE_SELECTOR_MODE:{scope:"selector-attr",begin:/\[/,end:/\]/,illegal:"$",contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]},CSS_NUMBER_MODE:{scope:"number",begin:e.NUMBER_RE+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",relevance:0},CSS_VARIABLE:{className:"attr",begin:/--[A-Za-z_][A-Za-z0-9_-]*/}}))(n),s=[n.APOS_STRING_MODE,n.QUOTE_STRING_MODE];return{name:"CSS",case_insensitive:!0,illegal:/[=|'\$]/,keywords:{keyframePosition:"from to"},classNameAliases:{keyframePosition:"selector-tag"},contains:[l.BLOCK_COMMENT,{begin:/-(webkit|moz|ms|o)-(?=[a-z])/},l.CSS_NUMBER_MODE,{className:"selector-id",begin:/#[A-Za-z0-9_-]+/,relevance:0},{className:"selector-class",begin:"\\.[a-zA-Z-][a-zA-Z0-9_-]*",relevance:0},l.ATTRIBUTE_SELECTOR_MODE,{className:"selector-pseudo",variants:[{begin:":("+r.join("|")+")"},{begin:":(:)?("+t.join("|")+")"}]},l.CSS_VARIABLE,{className:"attribute",begin:"\\b("+o.join("|")+")\\b"},{begin:/:/,end:/[;}{]/,contains:[l.BLOCK_COMMENT,l.HEXCOLOR,l.IMPORTANT,l.CSS_NUMBER_MODE,...s,{begin:/(url|data-uri)\(/,end:/\)/,relevance:0,keywords:{built_in:"url data-uri"},contains:[...s,{className:"string",begin:/[^)]/,endsWithParent:!0,excludeEnd:!0}]},l.FUNCTION_DISPATCH]},{begin:a.lookahead(/@/),end:"[{;]",relevance:0,illegal:/:/,contains:[{className:"keyword",begin:/@-?\w[\w]*(-\w+)*/},{begin:/\s/,endsWithParent:!0,excludeEnd:!0,relevance:0,keywords:{$pattern:/[a-z-]+/,keyword:"and or not only",attribute:i.join(" ")},contains:[{begin:/[a-z-]+(?=:)/,className:"attribute"},...s,l.CSS_NUMBER_MODE]}]},{className:"selector-tag",begin:"\\b("+e.join("|")+")\\b"}]}}})();hljs.registerLanguage("css",e)})();/*! `diff` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const a=e.regex;return{name:"Diff",aliases:["patch"],contains:[{className:"meta",relevance:10,match:a.either(/^@@ +-\d+,\d+ +\+\d+,\d+ +@@/,/^\*\*\* +\d+,\d+ +\*\*\*\*$/,/^--- +\d+,\d+ +----$/)},{className:"comment",variants:[{begin:a.either(/Index: /,/^index/,/={3,}/,/^-{3}/,/^\*{3} /,/^\+{3}/,/^diff --git/),end:/$/},{match:/^\*{15}$/}]},{className:"addition",begin:/^\+/,end:/$/},{className:"deletion",begin:/^-/,end:/$/},{className:"addition",begin:/^!/,end:/$/}]}}})();hljs.registerLanguage("diff",e)})();/*! `dos` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const r=e.COMMENT(/^\s*@?rem\b/,/$/,{relevance:10});return{name:"Batch file (DOS)",aliases:["bat","cmd"],case_insensitive:!0,illegal:/\/\*/,keywords:{keyword:["if","else","goto","for","in","do","call","exit","not","exist","errorlevel","defined","equ","neq","lss","leq","gtr","geq"],built_in:["prn","nul","lpt3","lpt2","lpt1","con","com4","com3","com2","com1","aux","shift","cd","dir","echo","setlocal","endlocal","set","pause","copy","append","assoc","at","attrib","break","cacls","cd","chcp","chdir","chkdsk","chkntfs","cls","cmd","color","comp","compact","convert","date","dir","diskcomp","diskcopy","doskey","erase","fs","find","findstr","format","ftype","graftabl","help","keyb","label","md","mkdir","mode","more","move","path","pause","print","popd","pushd","promt","rd","recover","rem","rename","replace","restore","rmdir","shift","sort","start","subst","time","title","tree","type","ver","verify","vol","ping","net","ipconfig","taskkill","xcopy","ren","del"]},contains:[{className:"variable",begin:/%%[^ ]|%[^ ]+?%|![^ ]+?!/},{className:"function",begin:"^\\s*[A-Za-z._?][A-Za-z0-9_$#@~.?]*(:|\\s+label)",end:"goto:eof",contains:[e.inherit(e.TITLE_MODE,{begin:"([_a-zA-Z]\\w*\\.)*([_a-zA-Z]\\w*:)?[_a-zA-Z]\\w*"}),r]},{className:"number",begin:"\\b\\d+",relevance:0},r]}}})();hljs.registerLanguage("dos",e)})();/*! `ini` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const n=e.regex,a={className:"number",relevance:0,variants:[{begin:/([+-]+)?[\d]+_[\d_]+/},{begin:e.NUMBER_RE}]},s=e.COMMENT();s.variants=[{begin:/;/,end:/$/},{begin:/#/,end:/$/}];const i={className:"variable",variants:[{begin:/\$[\w\d"][\w\d_]*/},{begin:/\$\{(.*?)\}/}]},t={className:"literal",begin:/\bon|off|true|false|yes|no\b/},r={className:"string",contains:[e.BACKSLASH_ESCAPE],variants:[{begin:"'''",end:"'''",relevance:10},{begin:'"""',end:'"""',relevance:10},{begin:'"',end:'"'},{begin:"'",end:"'"}]},l={begin:/\[/,end:/\]/,contains:[s,t,i,r,a,"self"],relevance:0},c=n.either(/[A-Za-z0-9_-]+/,/"(\\"|[^"])*"/,/'[^']*'/);return{name:"TOML, also INI",aliases:["toml"],case_insensitive:!0,illegal:/\S/,contains:[s,{className:"section",begin:/\[+/,end:/\]+/},{begin:n.concat(c,"(\\s*\\.\\s*",c,")*",n.lookahead(/\s*=\s*[^#\s]/)),className:"attr",starts:{end:/$/,contains:[s,l,t,i,r,a]}}]}}})();hljs.registerLanguage("ini",e)})();/*! `javascript` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";const e="[A-Za-z$_][0-9A-Za-z$_]*",n=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],a=["true","false","null","undefined","NaN","Infinity"],t=["Object","Function","Boolean","Symbol","Math","Date","Number","BigInt","String","RegExp","Array","Float32Array","Float64Array","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Int32Array","Uint16Array","Uint32Array","BigInt64Array","BigUint64Array","Set","Map","WeakSet","WeakMap","ArrayBuffer","SharedArrayBuffer","Atomics","DataView","JSON","Promise","Generator","GeneratorFunction","AsyncFunction","Reflect","Proxy","Intl","WebAssembly"],s=["Error","EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"],r=["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],c=["arguments","this","super","console","window","document","localStorage","sessionStorage","module","global"],i=[].concat(r,t,s);return o=>{const l=o.regex,b=e,d={begin:/<[A-Za-z0-9\\._:-]+/,end:/\/[A-Za-z0-9\\._:-]+>|\/>/,isTrulyOpeningTag:(e,n)=>{const a=e[0].length+e.index,t=e.input[a];if("<"===t||","===t)return void n.ignoreMatch();let s;">"===t&&(((e,{after:n})=>{const a="",$={match:[/const|var|let/,/\s+/,b,/\s*/,/=\s*/,/(async\s*)?/,l.lookahead(B)],keywords:"async",className:{1:"keyword",3:"title.function"},contains:[R]};return{name:"JavaScript",aliases:["js","jsx","mjs","cjs"],keywords:g,exports:{PARAMS_CONTAINS:w,CLASS_REFERENCE:k},illegal:/#(?![$_A-z])/,contains:[o.SHEBANG({label:"shebang",binary:"node",relevance:5}),{label:"use_strict",className:"meta",relevance:10,begin:/^\s*['"]use (strict|asm)['"]/},o.APOS_STRING_MODE,o.QUOTE_STRING_MODE,h,N,_,f,v,{match:/\$\d+/},A,k,{className:"attr",begin:b+l.lookahead(":"),relevance:0},$,{begin:"("+o.RE_STARTERS_RE+"|\\b(case|return|throw)\\b)\\s*",keywords:"return throw case",relevance:0,contains:[v,o.REGEXP_MODE,{className:"function",begin:B,returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{begin:o.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:g,contains:w}]}]},{begin:/,/,relevance:0},{match:/\s+/,relevance:0},{variants:[{begin:"<>",end:""},{match:/<[A-Za-z0-9\\._:-]+\s*\/>/},{begin:d.begin,"on:begin":d.isTrulyOpeningTag,end:d.end}],subLanguage:"xml",contains:[{begin:d.begin,end:d.end,skip:!0,contains:["self"]}]}]},I,{beginKeywords:"while if switch catch for"},{begin:"\\b(?!function)"+o.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)\\s*\\{",returnBegin:!0,label:"func.def",contains:[R,o.inherit(o.TITLE_MODE,{begin:b,className:"title.function"})]},{match:/\.\.\./,relevance:0},C,{match:"\\$"+b,relevance:0},{match:[/\bconstructor(?=\s*\()/],className:{1:"title.function"},contains:[R]},x,{relevance:0,match:/\b[A-Z][A-Z_0-9]+\b/,className:"variable.constant"},O,M,{match:/\$[(.]/}]}}})();hljs.registerLanguage("javascript",e)})();/*! `json` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const a=["true","false","null"],n={scope:"literal",beginKeywords:a.join(" ")};return{name:"JSON",keywords:{literal:a},contains:[{className:"attr",begin:/"(\\.|[^\\"\r\n])*"(?=\s*:)/,relevance:1.01},{match:/[{}[\],:]/,className:"punctuation",relevance:0},e.QUOTE_STRING_MODE,n,e.C_NUMBER_MODE,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE],illegal:"\\S"}}})();hljs.registerLanguage("json",e)})();/*! `vbscript` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const t=e.regex,r=["lcase","month","vartype","instrrev","ubound","setlocale","getobject","rgb","getref","string","weekdayname","rnd","dateadd","monthname","now","day","minute","isarray","cbool","round","formatcurrency","conversions","csng","timevalue","second","year","space","abs","clng","timeserial","fixs","len","asc","isempty","maths","dateserial","atn","timer","isobject","filter","weekday","datevalue","ccur","isdate","instr","datediff","formatdatetime","replace","isnull","right","sgn","array","snumeric","log","cdbl","hex","chr","lbound","msgbox","ucase","getlocale","cos","cdate","cbyte","rtrim","join","hour","oct","typename","trim","strcomp","int","createobject","loadpicture","tan","formatnumber","mid","split","cint","sin","datepart","ltrim","sqr","time","derived","eval","date","formatpercent","exp","inputbox","left","ascw","chrw","regexp","cstr","err"];return{name:"VBScript",aliases:["vbs"],case_insensitive:!0,keywords:{keyword:["call","class","const","dim","do","loop","erase","execute","executeglobal","exit","for","each","next","function","if","then","else","on","error","option","explicit","new","private","property","let","get","public","randomize","redim","rem","select","case","set","stop","sub","while","wend","with","end","to","elseif","is","or","xor","and","not","class_initialize","class_terminate","default","preserve","in","me","byval","byref","step","resume","goto"],built_in:["server","response","request","scriptengine","scriptenginebuildversion","scriptengineminorversion","scriptenginemajorversion"],literal:["true","false","null","nothing","empty"]},illegal:"//",contains:[{begin:t.concat(t.either(...r),"\\s*\\("),relevance:0,keywords:{built_in:r}},e.inherit(e.QUOTE_STRING_MODE,{contains:[{begin:'""'}]}),e.COMMENT(/'/,/$/,{relevance:0}),e.C_NUMBER_MODE]}}})();hljs.registerLanguage("vbscript",e)})();/*! `xml` grammar compiled for Highlight.js 11.9.0 */(()=>{var e=(()=>{"use strict";return e=>{const a=e.regex,n=a.concat(/[\p{L}_]/u,a.optional(/[\p{L}0-9_.-]*:/u),/[\p{L}0-9_.-]*/u),s={className:"symbol",begin:/&[a-z]+;|&#[0-9]+;|&#x[a-f0-9]+;/},t={begin:/\s/,contains:[{className:"keyword",begin:/#?[a-z_][a-z1-9_-]+/,illegal:/\n/}]},i=e.inherit(t,{begin:/\(/,end:/\)/}),c=e.inherit(e.APOS_STRING_MODE,{className:"string"}),l=e.inherit(e.QUOTE_STRING_MODE,{className:"string"}),r={endsWithParent:!0,illegal:/`]+/}]}]}]};return{name:"HTML, XML",aliases:["html","xhtml","rss","atom","xjb","xsd","xsl","plist","wsf","svg"],case_insensitive:!0,unicodeRegex:!0,contains:[{className:"meta",begin://,relevance:10,contains:[t,l,c,i,{begin:/\[/,end:/\]/,contains:[{className:"meta",begin://,contains:[t,i,l,c]}]}]},e.COMMENT(//,{relevance:10}),{begin://,relevance:10},s,{className:"meta",end:/\?>/,variants:[{begin:/<\?xml/,relevance:10,contains:[l]},{begin:/<\?[a-z][a-z0-9]+/}]},{className:"tag",begin:/)/,end:/>/,keywords:{name:"style"},contains:[r],starts:{end:/<\/style>/,returnEnd:!0,subLanguage:["css","xml"]}},{className:"tag",begin:/)/,end:/>/,keywords:{name:"script"},contains:[r],starts:{end:/<\/script>/,returnEnd:!0,subLanguage:["javascript","handlebars","xml"]}},{className:"tag",begin:/<>|<\/>/},{className:"tag",begin:a.concat(//,/>/,/\s/)))),end:/\/?>/,contains:[{className:"name",begin:n,relevance:0,starts:r}]},{className:"tag",begin:a.concat(/<\//,a.lookahead(a.concat(n,/>/))),contains:[{className:"name",begin:n,relevance:0},{begin:/>/,relevance:0,endsParent:!0}]}]}}})();hljs.registerLanguage("xml",e)})(); 41 | /*! `diff` grammar compiled for Highlight.js 11.9.0 */ 42 | (()=>{var e=(()=>{"use strict";return e=>{const a=e.regex;return{name:"Diff",aliases:["patch"],contains:[{className:"meta",relevance:10,match:a.either(/^@@ +-\d+,\d+ +\+\d+,\d+ +@@/,/^\*\*\* +\d+,\d+ +\*\*\*\*$/,/^--- +\d+,\d+ +----$/)},{className:"comment",variants:[{begin:a.either(/Index: /,/^index/,/={3,}/,/^-{3}/,/^\*{3} /,/^\+{3}/,/^diff --git/),end:/$/},{match:/^\*{15}$/}]},{className:"addition",begin:/^\+/,end:/$/},{className:"deletion",begin:/^-/,end:/$/},{className:"addition",begin:/^!/,end:/$/}]}}})();hljs.registerLanguage("diff",e)})(); 43 | /*! `json` grammar compiled for Highlight.js 11.9.0 */ 44 | (()=>{var e=(()=>{"use strict";return e=>{const a=["true","false","null"],n={scope:"literal",beginKeywords:a.join(" ")};return{name:"JSON",keywords:{literal:a},contains:[{className:"attr",begin:/"(\\.|[^\\"\r\n])*"(?=\s*:)/,relevance:1.01},{match:/[{}[\],:]/,className:"punctuation",relevance:0},e.QUOTE_STRING_MODE,n,e.C_NUMBER_MODE,e.C_LINE_COMMENT_MODE,e.C_BLOCK_COMMENT_MODE],illegal:"\\S"}}})();hljs.registerLanguage("json",e)})(); 45 | /*! `xml` grammar compiled for Highlight.js 11.9.0 */ 46 | (()=>{var e=(()=>{"use strict";return e=>{const a=e.regex,n=a.concat(/[\p{L}_]/u,a.optional(/[\p{L}0-9_.-]*:/u),/[\p{L}0-9_.-]*/u),s={className:"symbol",begin:/&[a-z]+;|&#[0-9]+;|&#x[a-f0-9]+;/},t={begin:/\s/,contains:[{className:"keyword",begin:/#?[a-z_][a-z1-9_-]+/,illegal:/\n/}]},i=e.inherit(t,{begin:/\(/,end:/\)/}),c=e.inherit(e.APOS_STRING_MODE,{className:"string"}),l=e.inherit(e.QUOTE_STRING_MODE,{className:"string"}),r={endsWithParent:!0,illegal:/`]+/}]}]}]};return{name:"HTML, XML",aliases:["html","xhtml","rss","atom","xjb","xsd","xsl","plist","wsf","svg"],case_insensitive:!0,unicodeRegex:!0,contains:[{className:"meta",begin://,relevance:10,contains:[t,l,c,i,{begin:/\[/,end:/\]/,contains:[{className:"meta",begin://,contains:[t,i,l,c]}]}]},e.COMMENT(//,{relevance:10}),{begin://,relevance:10},s,{className:"meta",end:/\?>/,variants:[{begin:/<\?xml/,relevance:10,contains:[l]},{begin:/<\?[a-z][a-z0-9]+/}]},{className:"tag",begin:/)/,end:/>/,keywords:{name:"style"},contains:[r],starts:{end:/<\/style>/,returnEnd:!0,subLanguage:["css","xml"]}},{className:"tag",begin:/)/,end:/>/,keywords:{name:"script"},contains:[r],starts:{end:/<\/script>/,returnEnd:!0,subLanguage:["javascript","handlebars","xml"]}},{className:"tag",begin:/<>|<\/>/},{className:"tag",begin:a.concat(//,/>/,/\s/)))),end:/\/?>/,contains:[{className:"name",begin:n,relevance:0,starts:r}]},{className:"tag",begin:a.concat(/<\//,a.lookahead(a.concat(n,/>/))),contains:[{className:"name",begin:n,relevance:0},{begin:/>/,relevance:0,endsParent:!0}]}]}}})();hljs.registerLanguage("xml",e)})(); 47 | /*! `javascript` grammar compiled for Highlight.js 11.9.0 */ 48 | (()=>{var e=(()=>{"use strict";const e="[A-Za-z$_][0-9A-Za-z$_]*",n=["as","in","of","if","for","while","finally","var","new","function","do","return","void","else","break","catch","instanceof","with","throw","case","default","try","switch","continue","typeof","delete","let","yield","const","class","debugger","async","await","static","import","from","export","extends"],a=["true","false","null","undefined","NaN","Infinity"],t=["Object","Function","Boolean","Symbol","Math","Date","Number","BigInt","String","RegExp","Array","Float32Array","Float64Array","Int8Array","Uint8Array","Uint8ClampedArray","Int16Array","Int32Array","Uint16Array","Uint32Array","BigInt64Array","BigUint64Array","Set","Map","WeakSet","WeakMap","ArrayBuffer","SharedArrayBuffer","Atomics","DataView","JSON","Promise","Generator","GeneratorFunction","AsyncFunction","Reflect","Proxy","Intl","WebAssembly"],s=["Error","EvalError","InternalError","RangeError","ReferenceError","SyntaxError","TypeError","URIError"],r=["setInterval","setTimeout","clearInterval","clearTimeout","require","exports","eval","isFinite","isNaN","parseFloat","parseInt","decodeURI","decodeURIComponent","encodeURI","encodeURIComponent","escape","unescape"],c=["arguments","this","super","console","window","document","localStorage","sessionStorage","module","global"],i=[].concat(r,t,s);return o=>{const l=o.regex,b=e,d={begin:/<[A-Za-z0-9\\._:-]+/,end:/\/[A-Za-z0-9\\._:-]+>|\/>/,isTrulyOpeningTag:(e,n)=>{const a=e[0].length+e.index,t=e.input[a];if("<"===t||","===t)return void n.ignoreMatch();let s;">"===t&&(((e,{after:n})=>{const a="",$={match:[/const|var|let/,/\s+/,b,/\s*/,/=\s*/,/(async\s*)?/,l.lookahead(B)],keywords:"async",className:{1:"keyword",3:"title.function"},contains:[R]};return{name:"JavaScript",aliases:["js","jsx","mjs","cjs"],keywords:g,exports:{PARAMS_CONTAINS:w,CLASS_REFERENCE:k},illegal:/#(?![$_A-z])/,contains:[o.SHEBANG({label:"shebang",binary:"node",relevance:5}),{label:"use_strict",className:"meta",relevance:10,begin:/^\s*['"]use (strict|asm)['"]/},o.APOS_STRING_MODE,o.QUOTE_STRING_MODE,h,N,_,f,v,{match:/\$\d+/},A,k,{className:"attr",begin:b+l.lookahead(":"),relevance:0},$,{begin:"("+o.RE_STARTERS_RE+"|\\b(case|return|throw)\\b)\\s*",keywords:"return throw case",relevance:0,contains:[v,o.REGEXP_MODE,{className:"function",begin:B,returnBegin:!0,end:"\\s*=>",contains:[{className:"params",variants:[{begin:o.UNDERSCORE_IDENT_RE,relevance:0},{className:null,begin:/\(\s*\)/,skip:!0},{begin:/\(/,end:/\)/,excludeBegin:!0,excludeEnd:!0,keywords:g,contains:w}]}]},{begin:/,/,relevance:0},{match:/\s+/,relevance:0},{variants:[{begin:"<>",end:""},{match:/<[A-Za-z0-9\\._:-]+\s*\/>/},{begin:d.begin,"on:begin":d.isTrulyOpeningTag,end:d.end}],subLanguage:"xml",contains:[{begin:d.begin,end:d.end,skip:!0,contains:["self"]}]}]},I,{beginKeywords:"while if switch catch for"},{begin:"\\b(?!function)"+o.UNDERSCORE_IDENT_RE+"\\([^()]*(\\([^()]*(\\([^()]*\\)[^()]*)*\\)[^()]*)*\\)\\s*\\{",returnBegin:!0,label:"func.def",contains:[R,o.inherit(o.TITLE_MODE,{begin:b,className:"title.function"})]},{match:/\.\.\./,relevance:0},C,{match:"\\$"+b,relevance:0},{match:[/\bconstructor(?=\s*\()/],className:{1:"title.function"},contains:[R]},x,{relevance:0,match:/\b[A-Z][A-Z_0-9]+\b/,className:"variable.constant"},O,M,{match:/\$[(.]/}]}}})();hljs.registerLanguage("javascript",e)})(); 49 | /*! `css` grammar compiled for Highlight.js 11.9.0 */ 50 | (()=>{var e=(()=>{"use strict";const e=["a","abbr","address","article","aside","audio","b","blockquote","body","button","canvas","caption","cite","code","dd","del","details","dfn","div","dl","dt","em","fieldset","figcaption","figure","footer","form","h1","h2","h3","h4","h5","h6","header","hgroup","html","i","iframe","img","input","ins","kbd","label","legend","li","main","mark","menu","nav","object","ol","p","q","quote","samp","section","span","strong","summary","sup","table","tbody","td","textarea","tfoot","th","thead","time","tr","ul","var","video"],i=["any-hover","any-pointer","aspect-ratio","color","color-gamut","color-index","device-aspect-ratio","device-height","device-width","display-mode","forced-colors","grid","height","hover","inverted-colors","monochrome","orientation","overflow-block","overflow-inline","pointer","prefers-color-scheme","prefers-contrast","prefers-reduced-motion","prefers-reduced-transparency","resolution","scan","scripting","update","width","min-width","max-width","min-height","max-height"],r=["active","any-link","blank","checked","current","default","defined","dir","disabled","drop","empty","enabled","first","first-child","first-of-type","fullscreen","future","focus","focus-visible","focus-within","has","host","host-context","hover","indeterminate","in-range","invalid","is","lang","last-child","last-of-type","left","link","local-link","not","nth-child","nth-col","nth-last-child","nth-last-col","nth-last-of-type","nth-of-type","only-child","only-of-type","optional","out-of-range","past","placeholder-shown","read-only","read-write","required","right","root","scope","target","target-within","user-invalid","valid","visited","where"],t=["after","backdrop","before","cue","cue-region","first-letter","first-line","grammar-error","marker","part","placeholder","selection","slotted","spelling-error"],o=["align-content","align-items","align-self","all","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","backface-visibility","background","background-attachment","background-blend-mode","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","block-size","border","border-block","border-block-color","border-block-end","border-block-end-color","border-block-end-style","border-block-end-width","border-block-start","border-block-start-color","border-block-start-style","border-block-start-width","border-block-style","border-block-width","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-inline","border-inline-color","border-inline-end","border-inline-end-color","border-inline-end-style","border-inline-end-width","border-inline-start","border-inline-start-color","border-inline-start-style","border-inline-start-width","border-inline-style","border-inline-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","caret-color","clear","clip","clip-path","clip-rule","color","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","contain","content","content-visibility","counter-increment","counter-reset","cue","cue-after","cue-before","cursor","direction","display","empty-cells","filter","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","flow","font","font-display","font-family","font-feature-settings","font-kerning","font-language-override","font-size","font-size-adjust","font-smoothing","font-stretch","font-style","font-synthesis","font-variant","font-variant-caps","font-variant-east-asian","font-variant-ligatures","font-variant-numeric","font-variant-position","font-variation-settings","font-weight","gap","glyph-orientation-vertical","grid","grid-area","grid-auto-columns","grid-auto-flow","grid-auto-rows","grid-column","grid-column-end","grid-column-start","grid-gap","grid-row","grid-row-end","grid-row-start","grid-template","grid-template-areas","grid-template-columns","grid-template-rows","hanging-punctuation","height","hyphens","icon","image-orientation","image-rendering","image-resolution","ime-mode","inline-size","isolation","justify-content","left","letter-spacing","line-break","line-height","list-style","list-style-image","list-style-position","list-style-type","margin","margin-block","margin-block-end","margin-block-start","margin-bottom","margin-inline","margin-inline-end","margin-inline-start","margin-left","margin-right","margin-top","marks","mask","mask-border","mask-border-mode","mask-border-outset","mask-border-repeat","mask-border-slice","mask-border-source","mask-border-width","mask-clip","mask-composite","mask-image","mask-mode","mask-origin","mask-position","mask-repeat","mask-size","mask-type","max-block-size","max-height","max-inline-size","max-width","min-block-size","min-height","min-inline-size","min-width","mix-blend-mode","nav-down","nav-index","nav-left","nav-right","nav-up","none","normal","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-wrap","overflow-x","overflow-y","padding","padding-block","padding-block-end","padding-block-start","padding-bottom","padding-inline","padding-inline-end","padding-inline-start","padding-left","padding-right","padding-top","page-break-after","page-break-before","page-break-inside","pause","pause-after","pause-before","perspective","perspective-origin","pointer-events","position","quotes","resize","rest","rest-after","rest-before","right","row-gap","scroll-margin","scroll-margin-block","scroll-margin-block-end","scroll-margin-block-start","scroll-margin-bottom","scroll-margin-inline","scroll-margin-inline-end","scroll-margin-inline-start","scroll-margin-left","scroll-margin-right","scroll-margin-top","scroll-padding","scroll-padding-block","scroll-padding-block-end","scroll-padding-block-start","scroll-padding-bottom","scroll-padding-inline","scroll-padding-inline-end","scroll-padding-inline-start","scroll-padding-left","scroll-padding-right","scroll-padding-top","scroll-snap-align","scroll-snap-stop","scroll-snap-type","scrollbar-color","scrollbar-gutter","scrollbar-width","shape-image-threshold","shape-margin","shape-outside","speak","speak-as","src","tab-size","table-layout","text-align","text-align-all","text-align-last","text-combine-upright","text-decoration","text-decoration-color","text-decoration-line","text-decoration-style","text-emphasis","text-emphasis-color","text-emphasis-position","text-emphasis-style","text-indent","text-justify","text-orientation","text-overflow","text-rendering","text-shadow","text-transform","text-underline-position","top","transform","transform-box","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","vertical-align","visibility","voice-balance","voice-duration","voice-family","voice-pitch","voice-range","voice-rate","voice-stress","voice-volume","white-space","widows","width","will-change","word-break","word-spacing","word-wrap","writing-mode","z-index"].reverse();return n=>{const a=n.regex,l=(e=>({IMPORTANT:{scope:"meta",begin:"!important"},BLOCK_COMMENT:e.C_BLOCK_COMMENT_MODE,HEXCOLOR:{scope:"number",begin:/#(([0-9a-fA-F]{3,4})|(([0-9a-fA-F]{2}){3,4}))\b/},FUNCTION_DISPATCH:{className:"built_in",begin:/[\w-]+(?=\()/},ATTRIBUTE_SELECTOR_MODE:{scope:"selector-attr",begin:/\[/,end:/\]/,illegal:"$",contains:[e.APOS_STRING_MODE,e.QUOTE_STRING_MODE]},CSS_NUMBER_MODE:{scope:"number",begin:e.NUMBER_RE+"(%|em|ex|ch|rem|vw|vh|vmin|vmax|cm|mm|in|pt|pc|px|deg|grad|rad|turn|s|ms|Hz|kHz|dpi|dpcm|dppx)?",relevance:0},CSS_VARIABLE:{className:"attr",begin:/--[A-Za-z_][A-Za-z0-9_-]*/}}))(n),s=[n.APOS_STRING_MODE,n.QUOTE_STRING_MODE];return{name:"CSS",case_insensitive:!0,illegal:/[=|'\$]/,keywords:{keyframePosition:"from to"},classNameAliases:{keyframePosition:"selector-tag"},contains:[l.BLOCK_COMMENT,{begin:/-(webkit|moz|ms|o)-(?=[a-z])/},l.CSS_NUMBER_MODE,{className:"selector-id",begin:/#[A-Za-z0-9_-]+/,relevance:0},{className:"selector-class",begin:"\\.[a-zA-Z-][a-zA-Z0-9_-]*",relevance:0},l.ATTRIBUTE_SELECTOR_MODE,{className:"selector-pseudo",variants:[{begin:":("+r.join("|")+")"},{begin:":(:)?("+t.join("|")+")"}]},l.CSS_VARIABLE,{className:"attribute",begin:"\\b("+o.join("|")+")\\b"},{begin:/:/,end:/[;}{]/,contains:[l.BLOCK_COMMENT,l.HEXCOLOR,l.IMPORTANT,l.CSS_NUMBER_MODE,...s,{begin:/(url|data-uri)\(/,end:/\)/,relevance:0,keywords:{built_in:"url data-uri"},contains:[...s,{className:"string",begin:/[^)]/,endsWithParent:!0,excludeEnd:!0}]},l.FUNCTION_DISPATCH]},{begin:a.lookahead(/@/),end:"[{;]",relevance:0,illegal:/:/,contains:[{className:"keyword",begin:/@-?\w[\w]*(-\w+)*/},{begin:/\s/,endsWithParent:!0,excludeEnd:!0,relevance:0,keywords:{$pattern:/[a-z-]+/,keyword:"and or not only",attribute:i.join(" ")},contains:[{begin:/[a-z-]+(?=:)/,className:"attribute"},...s,l.CSS_NUMBER_MODE]}]},{className:"selector-tag",begin:"\\b("+e.join("|")+")\\b"}]}}})();hljs.registerLanguage("css",e)})(); 51 | /*! `cpp` grammar compiled for Highlight.js 11.9.0 */ 52 | (()=>{var e=(()=>{"use strict";return e=>{const t=e.regex,a=e.COMMENT("//","$",{contains:[{begin:/\\\n/}]}),n="decltype\\(auto\\)",r="[a-zA-Z_]\\w*::",i="(?!struct)("+n+"|"+t.optional(r)+"[a-zA-Z_]\\w*"+t.optional("<[^<>]+>")+")",s={className:"type",begin:"\\b[a-z\\d_]*_t\\b"},c={className:"string",variants:[{begin:'(u8?|U|L)?"',end:'"',illegal:"\\n",contains:[e.BACKSLASH_ESCAPE]},{begin:"(u8?|U|L)?'(\\\\(x[0-9A-Fa-f]{2}|u[0-9A-Fa-f]{4,8}|[0-7]{3}|\\S)|.)",end:"'",illegal:"."},e.END_SAME_AS_BEGIN({begin:/(?:u8?|U|L)?R"([^()\\ ]{0,16})\(/,end:/\)([^()\\ ]{0,16})"/})]},o={className:"number",variants:[{begin:"\\b(0b[01']+)"},{begin:"(-?)\\b([\\d']+(\\.[\\d']*)?|\\.[\\d']+)((ll|LL|l|L)(u|U)?|(u|U)(ll|LL|l|L)?|f|F|b|B)"},{begin:"(-?)(\\b0[xX][a-fA-F0-9']+|(\\b[\\d']+(\\.[\\d']*)?|\\.[\\d']+)([eE][-+]?[\\d']+)?)"}],relevance:0},l={className:"meta",begin:/#\s*[a-z]+\b/,end:/$/,keywords:{keyword:"if else elif endif define undef warning error line pragma _Pragma ifdef ifndef include"},contains:[{begin:/\\\n/,relevance:0},e.inherit(c,{className:"string"}),{className:"string",begin:/<.*?>/},a,e.C_BLOCK_COMMENT_MODE]},d={className:"title",begin:t.optional(r)+e.IDENT_RE,relevance:0},u=t.optional(r)+e.IDENT_RE+"\\s*\\(",p={type:["bool","char","char16_t","char32_t","char8_t","double","float","int","long","short","void","wchar_t","unsigned","signed","const","static"],keyword:["alignas","alignof","and","and_eq","asm","atomic_cancel","atomic_commit","atomic_noexcept","auto","bitand","bitor","break","case","catch","class","co_await","co_return","co_yield","compl","concept","const_cast|10","consteval","constexpr","constinit","continue","decltype","default","delete","do","dynamic_cast|10","else","enum","explicit","export","extern","false","final","for","friend","goto","if","import","inline","module","mutable","namespace","new","noexcept","not","not_eq","nullptr","operator","or","or_eq","override","private","protected","public","reflexpr","register","reinterpret_cast|10","requires","return","sizeof","static_assert","static_cast|10","struct","switch","synchronized","template","this","thread_local","throw","transaction_safe","transaction_safe_dynamic","true","try","typedef","typeid","typename","union","using","virtual","volatile","while","xor","xor_eq"],literal:["NULL","false","nullopt","nullptr","true"],built_in:["_Pragma"],_type_hints:["any","auto_ptr","barrier","binary_semaphore","bitset","complex","condition_variable","condition_variable_any","counting_semaphore","deque","false_type","future","imaginary","initializer_list","istringstream","jthread","latch","lock_guard","multimap","multiset","mutex","optional","ostringstream","packaged_task","pair","promise","priority_queue","queue","recursive_mutex","recursive_timed_mutex","scoped_lock","set","shared_future","shared_lock","shared_mutex","shared_timed_mutex","shared_ptr","stack","string_view","stringstream","timed_mutex","thread","true_type","tuple","unique_lock","unique_ptr","unordered_map","unordered_multimap","unordered_multiset","unordered_set","variant","vector","weak_ptr","wstring","wstring_view"]},_={className:"function.dispatch",relevance:0,keywords:{_hint:["abort","abs","acos","apply","as_const","asin","atan","atan2","calloc","ceil","cerr","cin","clog","cos","cosh","cout","declval","endl","exchange","exit","exp","fabs","floor","fmod","forward","fprintf","fputs","free","frexp","fscanf","future","invoke","isalnum","isalpha","iscntrl","isdigit","isgraph","islower","isprint","ispunct","isspace","isupper","isxdigit","labs","launder","ldexp","log","log10","make_pair","make_shared","make_shared_for_overwrite","make_tuple","make_unique","malloc","memchr","memcmp","memcpy","memset","modf","move","pow","printf","putchar","puts","realloc","scanf","sin","sinh","snprintf","sprintf","sqrt","sscanf","std","stderr","stdin","stdout","strcat","strchr","strcmp","strcpy","strcspn","strlen","strncat","strncmp","strncpy","strpbrk","strrchr","strspn","strstr","swap","tan","tanh","terminate","to_underlying","tolower","toupper","vfprintf","visit","vprintf","vsprintf"]},begin:t.concat(/\b/,/(?!decltype)/,/(?!if)/,/(?!for)/,/(?!switch)/,/(?!while)/,e.IDENT_RE,t.lookahead(/(<[^<>]+>|)\s*\(/))},m=[_,l,s,a,e.C_BLOCK_COMMENT_MODE,o,c],g={variants:[{begin:/=/,end:/;/},{begin:/\(/,end:/\)/},{beginKeywords:"new throw return else",end:/;/}],keywords:p,contains:m.concat([{begin:/\(/,end:/\)/,keywords:p,contains:m.concat(["self"]),relevance:0}]),relevance:0},f={className:"function",begin:"("+i+"[\\*&\\s]+)+"+u,returnBegin:!0,end:/[{;=]/,excludeEnd:!0,keywords:p,illegal:/[^\w\s\*&:<>.]/,contains:[{begin:n,keywords:p,relevance:0},{begin:u,returnBegin:!0,contains:[d],relevance:0},{begin:/::/,relevance:0},{begin:/:/,endsWithParent:!0,contains:[c,o]},{relevance:0,match:/,/},{className:"params",begin:/\(/,end:/\)/,keywords:p,relevance:0,contains:[a,e.C_BLOCK_COMMENT_MODE,c,o,s,{begin:/\(/,end:/\)/,keywords:p,relevance:0,contains:["self",a,e.C_BLOCK_COMMENT_MODE,c,o,s]}]},s,a,e.C_BLOCK_COMMENT_MODE,l]};return{name:"C++",aliases:["cc","c++","h++","hpp","hh","hxx","cxx"],keywords:p,illegal:"",keywords:p,contains:["self",s]},{begin:e.IDENT_RE+"::",keywords:p},{match:[/\b(?:enum(?:\s+(?:class|struct))?|class|struct|union)/,/\s+/,/\w+/],className:{1:"keyword",3:"title.class"}}])}}})();hljs.registerLanguage("cpp",e)})(); 53 | /*! `ini` grammar compiled for Highlight.js 11.9.0 */ 54 | (()=>{var e=(()=>{"use strict";return e=>{const n=e.regex,a={className:"number",relevance:0,variants:[{begin:/([+-]+)?[\d]+_[\d_]+/},{begin:e.NUMBER_RE}]},s=e.COMMENT();s.variants=[{begin:/;/,end:/$/},{begin:/#/,end:/$/}];const i={className:"variable",variants:[{begin:/\$[\w\d"][\w\d_]*/},{begin:/\$\{(.*?)\}/}]},t={className:"literal",begin:/\bon|off|true|false|yes|no\b/},r={className:"string",contains:[e.BACKSLASH_ESCAPE],variants:[{begin:"'''",end:"'''",relevance:10},{begin:'"""',end:'"""',relevance:10},{begin:'"',end:'"'},{begin:"'",end:"'"}]},l={begin:/\[/,end:/\]/,contains:[s,t,i,r,a,"self"],relevance:0},c=n.either(/[A-Za-z0-9_-]+/,/"(\\"|[^"])*"/,/'[^']*'/);return{name:"TOML, also INI",aliases:["toml"],case_insensitive:!0,illegal:/\S/,contains:[s,{className:"section",begin:/\[+/,end:/\]+/},{begin:n.concat(c,"(\\s*\\.\\s*",c,")*",n.lookahead(/\s*=\s*[^#\s]/)),className:"attr",starts:{end:/$/,contains:[s,l,t,i,r,a]}}]}}})();hljs.registerLanguage("ini",e)})(); 55 | /*! `dos` grammar compiled for Highlight.js 11.9.0 */ 56 | (()=>{var e=(()=>{"use strict";return e=>{const r=e.COMMENT(/^\s*@?rem\b/,/$/,{relevance:10});return{name:"Batch file (DOS)",aliases:["bat","cmd"],case_insensitive:!0,illegal:/\/\*/,keywords:{keyword:["if","else","goto","for","in","do","call","exit","not","exist","errorlevel","defined","equ","neq","lss","leq","gtr","geq"],built_in:["prn","nul","lpt3","lpt2","lpt1","con","com4","com3","com2","com1","aux","shift","cd","dir","echo","setlocal","endlocal","set","pause","copy","append","assoc","at","attrib","break","cacls","cd","chcp","chdir","chkdsk","chkntfs","cls","cmd","color","comp","compact","convert","date","dir","diskcomp","diskcopy","doskey","erase","fs","find","findstr","format","ftype","graftabl","help","keyb","label","md","mkdir","mode","more","move","path","pause","print","popd","pushd","promt","rd","recover","rem","rename","replace","restore","rmdir","shift","sort","start","subst","time","title","tree","type","ver","verify","vol","ping","net","ipconfig","taskkill","xcopy","ren","del"]},contains:[{className:"variable",begin:/%%[^ ]|%[^ ]+?%|![^ ]+?!/},{className:"function",begin:"^\\s*[A-Za-z._?][A-Za-z0-9_$#@~.?]*(:|\\s+label)",end:"goto:eof",contains:[e.inherit(e.TITLE_MODE,{begin:"([_a-zA-Z]\\w*\\.)*([_a-zA-Z]\\w*:)?[_a-zA-Z]\\w*"}),r]},{className:"number",begin:"\\b\\d+",relevance:0},r]}}})();hljs.registerLanguage("dos",e)})(); 57 | /*! `vbscript` grammar compiled for Highlight.js 11.9.0 */ 58 | (()=>{var e=(()=>{"use strict";return e=>{const t=e.regex,r=["lcase","month","vartype","instrrev","ubound","setlocale","getobject","rgb","getref","string","weekdayname","rnd","dateadd","monthname","now","day","minute","isarray","cbool","round","formatcurrency","conversions","csng","timevalue","second","year","space","abs","clng","timeserial","fixs","len","asc","isempty","maths","dateserial","atn","timer","isobject","filter","weekday","datevalue","ccur","isdate","instr","datediff","formatdatetime","replace","isnull","right","sgn","array","snumeric","log","cdbl","hex","chr","lbound","msgbox","ucase","getlocale","cos","cdate","cbyte","rtrim","join","hour","oct","typename","trim","strcomp","int","createobject","loadpicture","tan","formatnumber","mid","split","cint","sin","datepart","ltrim","sqr","time","derived","eval","date","formatpercent","exp","inputbox","left","ascw","chrw","regexp","cstr","err"];return{name:"VBScript",aliases:["vbs"],case_insensitive:!0,keywords:{keyword:["call","class","const","dim","do","loop","erase","execute","executeglobal","exit","for","each","next","function","if","then","else","on","error","option","explicit","new","private","property","let","get","public","randomize","redim","rem","select","case","set","stop","sub","while","wend","with","end","to","elseif","is","or","xor","and","not","class_initialize","class_terminate","default","preserve","in","me","byval","byref","step","resume","goto"],built_in:["server","response","request","scriptengine","scriptenginebuildversion","scriptengineminorversion","scriptenginemajorversion"],literal:["true","false","null","nothing","empty"]},illegal:"//",contains:[{begin:t.concat(t.either(...r),"\\s*\\("),relevance:0,keywords:{built_in:r}},e.inherit(e.QUOTE_STRING_MODE,{contains:[{begin:'""'}]}),e.COMMENT(/'/,/$/,{relevance:0}),e.C_NUMBER_MODE]}}})();hljs.registerLanguage("vbscript",e)})(); 59 | 60 | 61 | /*** Site-specific variables ***/ 62 | var codeSelector; 63 | var defaultType = "javascript"; // If autodetection fails 64 | var getBoxes; 65 | var getHeader; 66 | var styleSelect; 67 | var types = { 68 | javascript: "JavaScript", 69 | cpp: "C++", 70 | vbscript: "VBScript", 71 | dos: "Batch", 72 | ini: "INI", 73 | xml: "HTML, XML", 74 | css: "CSS", 75 | json: "JSON", 76 | diff: "Diff", 77 | "+diff": "+Diff" 78 | }; 79 | 80 | function getCodeHeader(box) { 81 | if(box.classList.contains(cbClass + "-section-value")) 82 | return box.parentNode.firstChild; 83 | return getHeader(box); 84 | } 85 | 86 | var host = location.hostname; 87 | if(host == "akelpad.sourceforge.net") { 88 | codeSelector = "code." + codeClass; 89 | 90 | getBoxes = function() { 91 | return document.getElementsByTagName("code"); 92 | }; 93 | getHeader = function(box) { 94 | return box.parentNode.parentNode.getElementsByTagName("p")[0]; 95 | }; 96 | styleSelect = function(s) { 97 | s.marginTop = "-2px"; 98 | }; 99 | } 100 | else { 101 | hljs.unregisterLanguage("cpp"); 102 | hljs.unregisterLanguage("ini"); 103 | hljs.unregisterLanguage("dos"); 104 | hljs.unregisterLanguage("vbscript"); 105 | delete types.cpp; 106 | delete types.ini; 107 | delete types.dos; 108 | delete types.vbscript; 109 | 110 | if(host == "custombuttons.sourceforge.net") { 111 | codeSelector = "dl.codebox code." + codeClass; 112 | getBoxes = function() { 113 | return document.getElementsByTagName("code"); 114 | }; 115 | getHeader = function(box) { 116 | return box.parentNode.previousSibling; 117 | }; 118 | styleSelect = function(s) { 119 | s.marginTop = "-3px"; 120 | }; 121 | } 122 | else if(host == "forum.mozilla-russia.org") { 123 | codeSelector = ".pun pre." + codeClass; 124 | getBoxes = function() { 125 | return document.querySelectorAll(".codebox > * > * > pre"); 126 | }; 127 | getHeader = function(box) { 128 | return box.parentNode.parentNode; 129 | }; 130 | styleSelect = function(s) { 131 | }; 132 | } 133 | } 134 | 135 | 136 | /*** Add styles ***/ 137 | var isDarkTheme = false; 138 | if(window.getComputedStyle) { // No autodetection in IE, sorry 139 | var bg = window.getComputedStyle(document.body).backgroundColor; 140 | var r, g, b; 141 | if(/^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/i.test(bg)) 142 | r = +RegExp.$1, g = +RegExp.$2, b = +RegExp.$3; 143 | else if(/^#([\da-f]{6})$/i.test(bg) || /^#([\da-f]{3})$/i.test(bg)) { 144 | var hex = RegExp.$1; 145 | var part = hex.length/3; 146 | r = parseInt(hex.substr(0, part), 16); 147 | g = parseInt(hex.substr(part, part), 16); 148 | b = parseInt(hex.slice(-part), 16); 149 | } 150 | if(r != undefined) { 151 | var brightness = Math.max(r/255, g/255, b/255); // HSV, 0..1 152 | if(brightness < 0.5) 153 | isDarkTheme = true; 154 | } 155 | } 156 | 157 | var style = (isDarkTheme 158 | ? ` 159 | /* Tomorrow Night Bright Theme */ 160 | /* Original theme - https://github.com/chriskempson/tomorrow-theme */ 161 | /* http://jmblog.github.com/color-themes-for-google-code-highlightjs */ 162 | /* Modified by Infocatcher */ 163 | _PRE .hljs-keyword, 164 | _PRE .hljs-literal { 165 | font-weight: bold; 166 | } 167 | _PRE .hljs-comment, 168 | _PRE .hljs-string { 169 | font-style: italic; 170 | } 171 | _PRE code.hljs { 172 | display: block; 173 | overflow-x: auto; 174 | padding: 3px 5px 175 | } 176 | _PRE .hljs-comment, 177 | _PRE .hljs-quote { 178 | color: #969896 179 | } 180 | _PRE .hljs-deletion, 181 | _PRE .hljs-name, 182 | _PRE .hljs-regexp, 183 | _PRE .hljs-selector-class, 184 | _PRE .hljs-selector-id, 185 | _PRE .hljs-tag, 186 | _PRE .hljs-template-variable, 187 | _PRE .hljs-variable { 188 | color: #d54e53 189 | } 190 | _PRE .hljs-built_in, 191 | _PRE .hljs-link, 192 | _PRE .hljs-literal, 193 | _PRE .hljs-meta, 194 | _PRE .hljs-number, 195 | _PRE .hljs-params, 196 | _PRE .hljs-type { 197 | color: #e78c45 198 | } 199 | _PRE .hljs-attribute { 200 | color: #e7c547 201 | } 202 | _PRE .hljs-addition, 203 | _PRE .hljs-bullet, 204 | _PRE .hljs-string, 205 | _PRE .hljs-symbol { 206 | color: #b9ca4a 207 | } 208 | _PRE .hljs-section, 209 | _PRE .hljs-title { 210 | color: #7aa6da 211 | } 212 | _PRE .hljs-keyword, 213 | _PRE .hljs-selector-tag { 214 | color: #c397d8 215 | } 216 | _PRE.hljs, 217 | ._FCH-forceBG { 218 | background: #000; 219 | color: #eaeaea; 220 | tab-size: 4; 221 | } 222 | _PRE .hljs-emphasis { 223 | font-style: italic 224 | } 225 | _PRE .hljs-strong { 226 | font-weight: 700 227 | } 228 | /* Tweaks for parsed custombutton://… */ 229 | ._CB ._CB-section-value._CODE { 230 | border: 1px solid #555 !important; 231 | max-height: 35em !important; 232 | overflow: auto !important; 233 | }` 234 | : ` 235 | /*! 236 | Theme: GitHub 237 | Description: Light theme as seen on github.com 238 | Author: github.com 239 | Maintainer: @Hirse 240 | Updated: 2021-05-15 241 | 242 | Outdated base version: https://github.com/primer/github-syntax-light 243 | Current colors taken from GitHub's CSS 244 | Modified by Infocatcher 245 | */ 246 | _PRE .hljs-keyword, 247 | _PRE .hljs-literal { 248 | font-weight: bold; 249 | } 250 | _PRE .hljs-comment, 251 | _PRE .hljs-string { 252 | font-style: italic; 253 | } 254 | _PRE.hljs { 255 | display: block; 256 | overflow-x: auto; 257 | padding: 3px 5px; 258 | } 259 | _PRE.hljs, 260 | ._FCH-forceBG { 261 | color: #000; 262 | background: #f8f8ff; 263 | tab-size: 4; 264 | } 265 | _PRE .hljs-doctag, 266 | _PRE .hljs-keyword, 267 | _PRE .hljs-meta .hljs-keyword, 268 | _PRE .hljs-template-tag, 269 | _PRE .hljs-template-variable, 270 | _PRE .hljs-type, 271 | _PRE .hljs-variable.language_ { 272 | color: #d73a49 273 | } 274 | _PRE .hljs-title, 275 | _PRE .hljs-title.class_, 276 | _PRE .hljs-title.class_.inherited__, 277 | _PRE .hljs-title.function_ { 278 | color: #6f42c1 279 | } 280 | _PRE .hljs-attr, 281 | _PRE .hljs-attribute, 282 | _PRE .hljs-literal, 283 | _PRE .hljs-meta, 284 | _PRE .hljs-number, 285 | _PRE .hljs-operator, 286 | _PRE .hljs-selector-attr, 287 | _PRE .hljs-selector-class, 288 | _PRE .hljs-selector-id, 289 | _PRE .hljs-variable { 290 | color: #005cc5 291 | } 292 | _PRE .hljs-meta .hljs-string, 293 | _PRE .hljs-regexp, 294 | _PRE .hljs-string { 295 | color: #032f62 296 | } 297 | _PRE .hljs-built_in, 298 | _PRE .hljs-symbol { 299 | color: #e36209 300 | } 301 | _PRE .hljs-code, 302 | _PRE .hljs-comment, 303 | _PRE .hljs-formula { 304 | color: #6a737d 305 | } 306 | _PRE .hljs-name, 307 | _PRE .hljs-quote, 308 | _PRE .hljs-selector-pseudo, 309 | _PRE .hljs-selector-tag { 310 | color: #22863a 311 | } 312 | _PRE .hljs-subst { 313 | color: #24292e 314 | } 315 | _PRE .hljs-section { 316 | color: #005cc5; 317 | font-weight: 700 318 | } 319 | _PRE .hljs-bullet { 320 | color: #735c0f 321 | } 322 | _PRE .hljs-emphasis { 323 | color: #24292e; 324 | font-style: italic 325 | } 326 | _PRE .hljs-strong { 327 | color: #24292e; 328 | font-weight: 700 329 | } 330 | _PRE .hljs-addition { 331 | color: #22863a; 332 | background-color: #f0fff4 333 | } 334 | _PRE .hljs-deletion { 335 | color: #b31d28; 336 | background-color: #ffeef0 337 | } 338 | /* Tweaks for parsed custombutton://… */ 339 | ._CB ._CB-section-value._CODE { 340 | border: 1px solid #ccc !important; 341 | max-height: 35em !important; 342 | overflow: auto !important; 343 | }` 344 | ) + ` 345 | ._CB-wrapper { 346 | overflow: hidden !important; 347 | text-overflow: ellipsis !important; 348 | } 349 | ._CB ._CB-section-header { 350 | margin: 1.6em 0 0.2em !important; 351 | } 352 | ._CB ._CB-section-header > ._FCH-typeSwitcher { 353 | margin-top: -0.5em !important; 354 | } 355 | /* Type switcher */ 356 | ._SWITCHER { 357 | float: right !important; 358 | text-transform: none !important; 359 | margin-left: 6px !important; 360 | cursor: auto !important; 361 | } 362 | `; 363 | 364 | function loadStylesOnce() { 365 | loadStylesOnce = function() {}; 366 | 367 | style = style 368 | .replace(/_PRE/g, codeSelector) 369 | .replace(/\._CODE/g, "." + codeClass) 370 | .replace(/\._FCH/g, "." + classPrefix) 371 | .replace(/\._CB/g, "." + cbClass) 372 | .replace(/\._SWITCHER/g, "." + switcherClass); 373 | 374 | var s = document.createElement("style"); 375 | s.id = classPrefix + "-styles"; 376 | s.type = "text/css"; 377 | s.appendChild(document.createTextNode(style)); 378 | document.getElementsByTagName("head")[0].appendChild(s); 379 | } 380 | 381 | /*** Main functions ***/ 382 | function highlight(box, newType, append) { 383 | if(!append) { 384 | delete box.dataset.highlighted; 385 | hljs.highlightElement(box); 386 | return; 387 | } 388 | box.innerHTML = hljs.highlight( 389 | box.innerHTML, 390 | { language: newType } 391 | ).value 392 | .replace(/</g, "<") // Is there some better way? 393 | .replace(/>/g, ">") 394 | .replace(/"/g, '"') 395 | .replace(/&/g, "&"); 396 | } 397 | function higlightAll() { 398 | var boxes = getBoxes(); 399 | for(var i = 0, l = boxes.length; i < l; ++i) { 400 | var box = boxes[i]; 401 | initBoxDelayed(box); 402 | } 403 | } 404 | function initBoxDelayed(box) { 405 | setTimeout(function() { 406 | _updLock = true; 407 | initBox(box); 408 | _updLock = false; 409 | }, 0); 410 | } 411 | function initBox(box) { 412 | if(box.hasAttribute(parsedAttr)) 413 | return; 414 | box.setAttribute(parsedAttr, "true"); 415 | loadStylesOnce(); 416 | 417 | // Special "codes" 418 | var tc = box.textContent; 419 | var isCB = /^custombutton:\/\/\S+%3C\/custombutton%3E\s*$/.test(tc) 420 | if( 421 | isCB 422 | || /^data:[\w-]+\/[\w-]+;base64,\S+\s*$/.test(tc) 423 | ) { 424 | tc = tc.replace(/\s+$/, ""); 425 | var wrapper = document.createElement("div"); 426 | wrapper.className = cbClass + "-wrapper"; 427 | var a = wrapper.appendChild(document.createElement("a")); 428 | a.href = tc; 429 | 430 | var icon, maxSize; 431 | if(/^data:image\//.test(tc)) 432 | icon = tc; 433 | else if(isCB && /%3Cimage%3E%3C%21%5BCDATA%5B(data%3A\S+)%5D%5D%3E%3C\/image%3E/.test(tc)) { 434 | try { 435 | icon = decodeURIComponent(RegExp.$1); 436 | maxSize = "32px"; 437 | } 438 | catch(e) { 439 | } 440 | } 441 | if(icon) { 442 | var img = document.createElement("img"); 443 | img.src = icon; 444 | img.alt = ""; 445 | var s = img.style; 446 | s.marginRight = "4px"; 447 | s.verticalAlign = "middle"; 448 | if(maxSize) 449 | s.maxWidth = s.maxHeight = maxSize; 450 | a.appendChild(img); 451 | } 452 | 453 | a.appendChild(document.createTextNode(tc)); 454 | var s = a.style; 455 | s.background = "none"; 456 | s.margin = s.padding = 0; 457 | 458 | box.innerHTML = ""; 459 | box.appendChild(wrapper); 460 | 461 | isCB && setTimeout(function() { 462 | var pn = box.parentNode; 463 | if(pn.style.height) 464 | pn.style.height = ""; 465 | viewCustomButtonCode(tc, box); 466 | }, 0); 467 | 468 | return; 469 | } 470 | 471 | box.classList.add(codeClass); 472 | if(box.parentNode.className == "scrollbox") // For forum.mozilla-russia.org 473 | box.parentNode.classList.add(classPrefix + "-forceBG"); 474 | 475 | if(box.getElementsByTagName("span").length) // Already highlighted 476 | box.setAttribute(origAttr, ""); 477 | else 478 | highlight(box); 479 | addTypeSwitcher(box); 480 | } 481 | var _updLast = 0; 482 | var _updInitialDelay = 100; // Wait for all DOM mutations 483 | var _updMinDelay = 500; // Limit update frequency 484 | var _updScheduled = false; 485 | var _updLock = false; 486 | function updProxy() { 487 | if(_updScheduled || _updLock) 488 | return; 489 | var dt = Math.max(_updInitialDelay, _updLast + _updMinDelay - new Date().getTime()); 490 | _updScheduled = true; 491 | setTimeout(function() { 492 | _updScheduled = false; 493 | higlightAll(); 494 | _updLast = new Date().getTime(); 495 | }, dt); 496 | } 497 | function addTypeSwitcher(box) { 498 | var header = getCodeHeader(box); 499 | var select = document.createElement("select"); 500 | select.className = switcherClass; 501 | styleSelect(select.style); 502 | 503 | var selectedType; 504 | if(box.hasAttribute(origAttr)) { 505 | var option = document.createElement("option"); 506 | option.value = "__original__"; 507 | option.appendChild(document.createTextNode("Original")); 508 | option.selected = true; 509 | select.appendChild(option); 510 | } 511 | else { 512 | var cl = box.classList; 513 | for(var type in types) { 514 | if(cl.contains("language-" + type)) { 515 | selectedType = type; 516 | break; 517 | } 518 | } 519 | if(!selectedType) { 520 | selectedType = defaultType; 521 | backup(box); 522 | cl.remove("language-undefined"); 523 | cl.add("language-" + defaultType); 524 | highlight(box); 525 | } 526 | } 527 | 528 | for(var type in types) { 529 | var name = types[type]; 530 | var option = document.createElement("option"); 531 | option.value = type; 532 | option.appendChild(document.createTextNode(name)); 533 | if(type == selectedType) 534 | option.selected = true; 535 | select.appendChild(option); 536 | } 537 | header.insertBefore(select, header.firstChild); 538 | } 539 | function switchTypeHandler(e) { 540 | var select = e.target; 541 | if(select.className != switcherClass) 542 | return; 543 | var container = select.parentNode; 544 | var nn = container.nodeName.toLowerCase(); 545 | if(nn == "td") // td -> tr -> tbody 546 | container = container.parentNode.parentNode; 547 | else if(nn == "dt" || nn == "p" || nn == "h5") // dt -> dl, p -> div, h5 -> div 548 | container = container.parentNode; 549 | var box = container.querySelector("[" + parsedAttr + "]"); 550 | box && switchType(select, box); 551 | } 552 | function switchType(select, box) { 553 | _updLock = true; 554 | var newType = select.value; 555 | var cl = box.classList; 556 | for(var type in types) 557 | if(type != newType) 558 | cl.remove("language-" + type); 559 | cl.remove("language-undefined"); 560 | if(newType == "__original__") 561 | box.innerHTML = box.getAttribute(origAttr); 562 | else { 563 | backup(box); 564 | var append = newType.charAt(0) == "+"; 565 | if(append) 566 | newType = newType.substr(1); 567 | cl.add("language-" + newType); 568 | highlight(box, newType, append); 569 | } 570 | _updLock = false; 571 | } 572 | function backup(node) { 573 | if( 574 | node.hasAttribute(origAttr) 575 | && !node.getAttribute(origAttr) 576 | ) 577 | node.setAttribute(origAttr, node.innerHTML); 578 | } 579 | function unhl(node) { 580 | node.innerHTML = node.innerHTML.replace(/<\/?span[^<>]*>/ig, ""); 581 | } 582 | 583 | //=== Custom Buttons parser: begin 584 | // https://github.com/Infocatcher/Custom_Buttons/blob/gh-pages/viewCustomButton.js 585 | // Parser for custombutton:// URIs https://addons.mozilla.org/addon/custom-buttons/ 586 | // (c) Infocatcher 2013 587 | // version 0.1.0 - 2013-10-16 (modified) 588 | function viewCustomButtonCode(cbURI, outBlock) { 589 | var data = parseCustomButtonURI(cbURI); 590 | var res = document.createElement("div"); 591 | res.className = cbClass; 592 | function appendSection(name, code, hl) { 593 | var section = document.createElement("div"); 594 | section.className = cbClass + "-section"; 595 | var header = document.createElement("h5"); 596 | header.className = cbClass + "-section-header"; 597 | var a = document.createElement("a"); 598 | a.className = cbClass + "-section-toggler"; 599 | a.href = "javascript://Select code"; 600 | a.appendChild(document.createTextNode(name)); 601 | header.appendChild(a); 602 | section.appendChild(header); 603 | var value = document.createElement("pre"); 604 | value.style.fontSize = "1em"; // Force fix size 605 | value.appendChild(document.createTextNode(code)); 606 | value.className = cbClass + "-section-value"; 607 | section.appendChild(value); 608 | res.appendChild(section); 609 | if(hl) setTimeout(function() { 610 | value.className += " " + codeClass; 611 | highlight(value); 612 | value.setAttribute(parsedAttr, "true"); 613 | if(name != "Name") 614 | addTypeSwitcher(value); 615 | }, 0); 616 | } 617 | appendSection("Name", data.name); 618 | if(data.accelkey) { 619 | var disableDefault = data.mode & 2 /*CB_MODE_DISABLE_DEFAULT_KEY_BEHAVIOR*/; 620 | appendSection("Hotkey", data.accelkey + (disableDefault ? " (disable default action)" : "")); 621 | } 622 | appendSection("Code", data.code, true); 623 | appendSection("Initialization Code", data.initCode, true); 624 | if(data.help) 625 | appendSection("Help", data.help, true); 626 | //~ loadHihglighterStyles(); 627 | if(!outBlock) 628 | outBlock = document.body || document.documentElement; 629 | outBlock.appendChild(res); 630 | } 631 | function parseCustomButtonURI(cbURI) { 632 | var out = {}; 633 | if(cbURI.substr(0, 15) != "custombutton://") 634 | throw new Error("Not a custombutton:// URI"); 635 | var data = unescape(cbURI.substr(15)); 636 | if(data.substr(0, 6) != " " + nh); 238 | a.href = nh; 239 | fixHref(a, nh, h); 240 | 241 | // Force update link in status bar 242 | if(e.type == "focus") { 243 | a.ownerDocument.documentElement.focus(); 244 | setTimeout(function() { 245 | a.focus(); 246 | }, 0); 247 | } 248 | else if(e.type == "mouseover") { 249 | var orig = a.hasAttribute("style") && a.getAttribute("style"); 250 | a.style.visibility = "hidden"; 251 | setTimeout(function() { 252 | if(orig !== false) 253 | a.setAttribute("style", orig); 254 | else 255 | a.removeAttribute("style"); 256 | }, 0); 257 | } 258 | } 259 | function handleKeyDown(e) { 260 | if(e.keyCode == (e.DOM_VK_RETURN || 13)) 261 | clearLink(e); 262 | } 263 | function getLink(e) { 264 | for(var a = e.target, ln; a && (ln = a.localName); a = a.parentNode) 265 | if(ln.toLowerCase() == "a") 266 | return a.href && a; 267 | return null; 268 | } 269 | function decode(s) { 270 | try { 271 | return decodeURIComponent(s); 272 | } 273 | catch(e) { 274 | setTimeout(function() { throw e; }, 0); 275 | } 276 | return s; 277 | } 278 | function renameAttr(node, attr, check) { 279 | if(!node.hasAttribute(attr)) 280 | return false; 281 | var orig = node.getAttribute(attr); 282 | var skip = false; 283 | switch(typeof check) { 284 | case "string": skip = orig.indexOf(check) == -1; break; 285 | case "object": skip = !check.test(orig); 286 | } 287 | if(skip) 288 | return false; 289 | node.setAttribute(deleted + attr, orig); 290 | node.removeAttribute(attr); 291 | return true; 292 | } 293 | function fixHref(a, newHref, origHref) { 294 | Object.defineProperty && Object.defineProperty(a, "href", { 295 | get: function() { 296 | return newHref; 297 | }, 298 | set: function(h) { 299 | if(h == origHref) // Attempt to restore 300 | return; 301 | newHref = h; 302 | a.setAttribute("href", h); 303 | } 304 | }); 305 | } 306 | 307 | function _log(s) { 308 | _log = _debug && "console" in window && "log" in console 309 | ? function(s) { 310 | console.log("[Remove fake links] " + s); 311 | } 312 | : function(s) { 313 | }; 314 | return _log.apply(this, arguments); 315 | } 316 | 317 | })(); 318 | -------------------------------------------------------------------------------- /RuTor/README.md: -------------------------------------------------------------------------------- 1 | Invert tab/window title on RuTor (& mirrors): 2 |
    зеркало … :: полезный заголовок 3 |
    => полезный заголовок – зеркало … -------------------------------------------------------------------------------- /RuTor/RuTor_invert_title.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name RuTor: invert title 3 | // @namespace dev/null 4 | // @include http://rus-tor.com/* 5 | // @include http://freedom-tor.org/* 6 | // @include http://tor-bit.net/* 7 | // @include http://new-tor.net/* 8 | // @include http://rutor.info/* 9 | // @version 0.2.0.2 - 2022-09-28 10 | // @run-at document-start 11 | // @grant none 12 | // ==/UserScript== 13 | 14 | var stopTime = new Date().getTime() + 5e3; 15 | var observer = new MutationObserver(function() { 16 | if(/^((?:зеркало )?rutor\.info) :: /i.test(document.title)) { 17 | observer.disconnect(); 18 | document.title = RegExp.rightContext + " – " + RegExp.$1; 19 | } 20 | else if(new Date().getTime() > stopTime) 21 | observer.disconnect(); 22 | }); 23 | observer.observe(document.documentElement, { childList: true }); -------------------------------------------------------------------------------- /VseInstrumenti.ru_Load_all_favorites/README.md: -------------------------------------------------------------------------------- 1 | Load all favorites on VseInstrumenti.ru -------------------------------------------------------------------------------- /VseInstrumenti.ru_Load_all_favorites/VseInstrumenti.ru_Load_all_favorites.user.js: -------------------------------------------------------------------------------- 1 | // ==UserScript== 2 | // @name VseInstrumenti.ru: Load all favorites 3 | // @author Infocatcher 4 | // @namespace dev/null 5 | // @include https://www.vseinstrumenti.ru/user/favorites 6 | // @include https://www.vseinstrumenti.ru/user/favorites/ 7 | // @version 0.1.0.3 - 2023-12-03 8 | // @grant none 9 | // ==/UserScript== 10 | 11 | (function iteration() { 12 | var btnLoad = /Показать ещ[её]/i; 13 | var btnLoading = /Загружается/i; 14 | var ttls = ["⏳ ", "⌛️ "]; // Clock/hourglass emoji 15 | var ttlsScroll = ["🔽 ", "⏬ "]; // Down arrows 16 | var useScroller = true; 17 | var msg = "[VSI loader]: "; 18 | iteration.__titles = ttls; 19 | var btnNext = iteration.__btnNext || (iteration.__btnNext = (function() { 20 | var btns = document.getElementsByTagName("button"); 21 | btnLoop: for(var i = 0, l = btns.length; i < l; ++i) { 22 | var btn = btns[i]; 23 | //console.log(msg + btn.textContent); 24 | if(btnLoad.test(btn.textContent)) { 25 | for(var pn = btn; (pn = pn.parentNode); ) 26 | if(pn.nodeName == "ASIDE") 27 | continue btnLoop; 28 | return btn; 29 | } 30 | } 31 | return null; 32 | })()); 33 | if(!btnNext) { 34 | console.log(msg + "wait for button…"); 35 | setTimeout(iteration, 200); 36 | return; 37 | } 38 | if(!btnNext.parentNode) { 39 | document.title = unprefix(); 40 | iteration.__done = true; 41 | console.log(msg + "done!"); 42 | if(useScroller) { 43 | iteration.__index = 0; 44 | iteration.__titles = ttlsScroll; 45 | if(iteration.__scroller) 46 | document.title = prefix(); 47 | } 48 | return; 49 | } 50 | if(btnLoading.test(btnNext.textContent) || btnNext.disabled) { 51 | console.log(msg + "loading, wait…"); 52 | setTimeout(iteration, 200); 53 | return; 54 | } 55 | 56 | document.title = prefix(); 57 | 58 | console.log(msg + "load next"); 59 | btnNext.click(); 60 | setTimeout(iteration, 300); 61 | if(useScroller && !iteration.__scroller) { 62 | var step = Math.round(window.innerHeight/2); 63 | scrollTo(0, 0); 64 | iteration.__scrollUpdate = 0; 65 | iteration.__scroller = setInterval(function() { 66 | var y = window.scrollY; 67 | scrollBy(0, step); 68 | if(window.scrollY - y <= 20) { 69 | clearInterval(iteration.__scroller); 70 | delete iteration.__scroller; 71 | scrollTo(0, 0); 72 | console.log(msg + "scroll loading done!"); 73 | if(iteration.__done || false) 74 | document.title = unprefix(); 75 | } 76 | else if(iteration.__done || false) { 77 | var t = new Date().getTime(); 78 | if(t - iteration.__scrollUpdate > 650) { 79 | iteration.__scrollUpdate = t; 80 | document.title = prefix(); 81 | } 82 | } 83 | }, 100); 84 | } 85 | 86 | function prefix() { 87 | var ttls = iteration.__titles; 88 | var indx = "__index" in iteration ? ++iteration.__index : (iteration.__index = 0); 89 | if(indx >= ttls.length) 90 | indx = iteration.__index = 0; 91 | return ttls[indx] + unprefix(); 92 | } 93 | function unprefix() { 94 | var t = document.title; 95 | var ttls = iteration.__titles; 96 | for(var i = 0, l = ttls.length; i < l; ++i) { 97 | var p = ttls[i]; 98 | if(t.startsWith(p)) 99 | return t.substr(p.length); 100 | } 101 | return t; 102 | } 103 | })(); --------------------------------------------------------------------------------