Github Solidity Highlighter

synatx highlighting of ethereum languages (solidity, viper, LLL) on github

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey, Greasemonkey или Violentmonkey.

Для установки этого скрипта вам необходимо установить расширение, такое как Tampermonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Violentmonkey.

Чтобы установить этот скрипт, вы сначала должны установить расширение браузера, например Tampermonkey или Userscripts.

Чтобы установить этот скрипт, сначала вы должны установить расширение браузера, например Tampermonkey.

Чтобы установить этот скрипт, вы должны установить расширение — менеджер скриптов.

(у меня уже есть менеджер скриптов, дайте мне установить скрипт!)

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение браузера, например Stylus.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

Чтобы установить этот стиль, сначала вы должны установить расширение — менеджер стилей.

(у меня уже есть менеджер стилей, дайте мне установить скрипт!)

// ==UserScript==
// @name         Github Solidity Highlighter
// @namespace    https://github.com/ldct/github-ethereum-highlighting/
// @version      0.1
// @description  synatx highlighting of ethereum languages (solidity, viper, LLL) on github
// @author       ldct
// @match        https://*.github.com/*.sol
// @match        https://*.github.com/*.se
// @require      https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/highlight.min.js
// @require      https://cdn.jsdelivr.net/npm/[email protected]/solidity.min.js
// @require      https://code.jquery.com/jquery-3.2.1.min.js
// @resource     syntaxHighlightCSS https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/github.min.css
// @grant        GM_addStyle
// @grant        GM_getResourceText
// ==/UserScript==

(function() {
    'use strict';

    console.log("highlighting");

    // install highlightjs CSS
    var syntax_highlighter_CSS = GM_getResourceText('syntaxHighlightCSS');
    GM_addStyle(syntax_highlighter_CSS);

    // install jQuery
    const $ = jQuery;

    // get language
    var lang;
    if (window.location.href.endsWith(".se")) {
        lang = "python";
    } else if (window.location.href.endsWith(".sol")) {
        lang = "javascript";
    } else {
        return;
    }

    // get code of page
    const f = $(".file .blob-wrapper table .blob-code").map(function (i, row) {
        return $(row).text().replace(/\n/g, "");
    }).toArray();
    const code = f.join("\n");

    $(".blob-wrapper").empty().append($("<code>", {
        text: code,
        class: lang,
    }).wrap("<pre>").parent());

    hljs.initHighlighting();

})();