123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517 |
- function deepFreeze(obj) {
- if (obj instanceof Map) {
- obj.clear = obj.delete = obj.set = function () {
- throw new Error('map is read-only');
- };
- } else if (obj instanceof Set) {
- obj.add = obj.clear = obj.delete = function () {
- throw new Error('set is read-only');
- };
- }
-
- Object.freeze(obj);
- Object.getOwnPropertyNames(obj).forEach(function (name) {
- var prop = obj[name];
-
- if (typeof prop == 'object' && !Object.isFrozen(prop)) {
- deepFreeze(prop);
- }
- });
- return obj;
- }
- var deepFreezeEs6 = deepFreeze;
- var _default = deepFreeze;
- deepFreezeEs6.default = _default;
- class Response {
-
- constructor(mode) {
-
- if (mode.data === undefined) mode.data = {};
- this.data = mode.data;
- this.isMatchIgnored = false;
- }
- ignoreMatch() {
- this.isMatchIgnored = true;
- }
- }
- function escapeHTML(value) {
- return value
- .replace(/&/g, '&')
- .replace(/</g, '<')
- .replace(/>/g, '>')
- .replace(/"/g, '"')
- .replace(/'/g, ''');
- }
- function inherit(original, ...objects) {
-
- const result = Object.create(null);
- for (const key in original) {
- result[key] = original[key];
- }
- objects.forEach(function(obj) {
- for (const key in obj) {
- result[key] = obj[key];
- }
- });
- return (result);
- }
- const SPAN_CLOSE = '</span>';
- const emitsWrappingTags = (node) => {
- return !!node.kind;
- };
- class HTMLRenderer {
-
- constructor(parseTree, options) {
- this.buffer = "";
- this.classPrefix = options.classPrefix;
- parseTree.walk(this);
- }
-
- addText(text) {
- this.buffer += escapeHTML(text);
- }
-
- openNode(node) {
- if (!emitsWrappingTags(node)) return;
- let className = node.kind;
- if (!node.sublanguage) {
- className = `${this.classPrefix}${className}`;
- }
- this.span(className);
- }
-
- closeNode(node) {
- if (!emitsWrappingTags(node)) return;
- this.buffer += SPAN_CLOSE;
- }
-
- value() {
- return this.buffer;
- }
-
-
- span(className) {
- this.buffer += `<span class="${className}">`;
- }
- }
- class TokenTree {
- constructor() {
-
- this.rootNode = { children: [] };
- this.stack = [this.rootNode];
- }
- get top() {
- return this.stack[this.stack.length - 1];
- }
- get root() { return this.rootNode; }
-
- add(node) {
- this.top.children.push(node);
- }
-
- openNode(kind) {
-
- const node = { kind, children: [] };
- this.add(node);
- this.stack.push(node);
- }
- closeNode() {
- if (this.stack.length > 1) {
- return this.stack.pop();
- }
-
- return undefined;
- }
- closeAllNodes() {
- while (this.closeNode());
- }
- toJSON() {
- return JSON.stringify(this.rootNode, null, 4);
- }
-
- walk(builder) {
-
- return this.constructor._walk(builder, this.rootNode);
-
-
- }
-
- static _walk(builder, node) {
- if (typeof node === "string") {
- builder.addText(node);
- } else if (node.children) {
- builder.openNode(node);
- node.children.forEach((child) => this._walk(builder, child));
- builder.closeNode(node);
- }
- return builder;
- }
-
- static _collapse(node) {
- if (typeof node === "string") return;
- if (!node.children) return;
- if (node.children.every(el => typeof el === "string")) {
-
-
- node.children = [node.children.join("")];
- } else {
- node.children.forEach((child) => {
- TokenTree._collapse(child);
- });
- }
- }
- }
- class TokenTreeEmitter extends TokenTree {
-
- constructor(options) {
- super();
- this.options = options;
- }
-
- addKeyword(text, kind) {
- if (text === "") { return; }
- this.openNode(kind);
- this.addText(text);
- this.closeNode();
- }
-
- addText(text) {
- if (text === "") { return; }
- this.add(text);
- }
-
- addSublanguage(emitter, name) {
-
- const node = emitter.root;
- node.kind = name;
- node.sublanguage = true;
- this.add(node);
- }
- toHTML() {
- const renderer = new HTMLRenderer(this, this.options);
- return renderer.value();
- }
- finalize() {
- return true;
- }
- }
- function escape(value) {
- return new RegExp(value.replace(/[-/\\^$*+?.()|[\]{}]/g, '\\$&'), 'm');
- }
- function source(re) {
- if (!re) return null;
- if (typeof re === "string") return re;
- return re.source;
- }
- function concat(...args) {
- const joined = args.map((x) => source(x)).join("");
- return joined;
- }
- function either(...args) {
- const joined = '(' + args.map((x) => source(x)).join("|") + ")";
- return joined;
- }
- function countMatchGroups(re) {
- return (new RegExp(re.toString() + '|')).exec('').length - 1;
- }
- function startsWith(re, lexeme) {
- const match = re && re.exec(lexeme);
- return match && match.index === 0;
- }
- const BACKREF_RE = /\[(?:[^\\\]]|\\.)*\]|\(\??|\\([1-9][0-9]*)|\\./;
- function join(regexps, separator = "|") {
- let numCaptures = 0;
- return regexps.map((regex) => {
- numCaptures += 1;
- const offset = numCaptures;
- let re = source(regex);
- let out = '';
- while (re.length > 0) {
- const match = BACKREF_RE.exec(re);
- if (!match) {
- out += re;
- break;
- }
- out += re.substring(0, match.index);
- re = re.substring(match.index + match[0].length);
- if (match[0][0] === '\\' && match[1]) {
-
- out += '\\' + String(Number(match[1]) + offset);
- } else {
- out += match[0];
- if (match[0] === '(') {
- numCaptures++;
- }
- }
- }
- return out;
- }).map(re => `(${re})`).join(separator);
- }
- const MATCH_NOTHING_RE = /\b\B/;
- const IDENT_RE = '[a-zA-Z]\\w*';
- const UNDERSCORE_IDENT_RE = '[a-zA-Z_]\\w*';
- const NUMBER_RE = '\\b\\d+(\\.\\d+)?';
- const C_NUMBER_RE = '(-?)(\\b0[xX][a-fA-F0-9]+|(\\b\\d+(\\.\\d*)?|\\.\\d+)([eE][-+]?\\d+)?)';
- const BINARY_NUMBER_RE = '\\b(0b[01]+)';
- const RE_STARTERS_RE = '!|!=|!==|%|%=|&|&&|&=|\\*|\\*=|\\+|\\+=|,|-|-=|/=|/|:|;|<<|<<=|<=|<|===|==|=|>>>=|>>=|>=|>>>|>>|>|\\?|\\[|\\{|\\(|\\^|\\^=|\\||\\|=|\\|\\||~';
- const SHEBANG = (opts = {}) => {
- const beginShebang = /^#![ ]*\//;
- if (opts.binary) {
- opts.begin = concat(
- beginShebang,
- /.*\b/,
- opts.binary,
- /\b.*/);
- }
- return inherit({
- className: 'meta',
- begin: beginShebang,
- end: /$/,
- relevance: 0,
-
- "on:begin": (m, resp) => {
- if (m.index !== 0) resp.ignoreMatch();
- }
- }, opts);
- };
- const BACKSLASH_ESCAPE = {
- begin: '\\\\[\\s\\S]', relevance: 0
- };
- const APOS_STRING_MODE = {
- className: 'string',
- begin: '\'',
- end: '\'',
- illegal: '\\n',
- contains: [BACKSLASH_ESCAPE]
- };
- const QUOTE_STRING_MODE = {
- className: 'string',
- begin: '"',
- end: '"',
- illegal: '\\n',
- contains: [BACKSLASH_ESCAPE]
- };
- const 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/
- };
- const COMMENT = function(begin, end, modeOptions = {}) {
- const mode = inherit(
- {
- className: 'comment',
- begin,
- end,
- contains: []
- },
- modeOptions
- );
- mode.contains.push(PHRASAL_WORDS_MODE);
- mode.contains.push({
- className: 'doctag',
- begin: '(?:TODO|FIXME|NOTE|BUG|OPTIMIZE|HACK|XXX):',
- relevance: 0
- });
- return mode;
- };
- const C_LINE_COMMENT_MODE = COMMENT('//', '$');
- const C_BLOCK_COMMENT_MODE = COMMENT('/\\*', '\\*/');
- const HASH_COMMENT_MODE = COMMENT('#', '$');
- const NUMBER_MODE = {
- className: 'number',
- begin: NUMBER_RE,
- relevance: 0
- };
- const C_NUMBER_MODE = {
- className: 'number',
- begin: C_NUMBER_RE,
- relevance: 0
- };
- const BINARY_NUMBER_MODE = {
- className: 'number',
- begin: BINARY_NUMBER_RE,
- relevance: 0
- };
- const CSS_NUMBER_MODE = {
- className: 'number',
- begin: 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
- };
- const REGEXP_MODE = {
-
-
-
-
-
-
- begin: /(?=\/[^/\n]*\/)/,
- contains: [{
- className: 'regexp',
- begin: /\//,
- end: /\/[gimuy]*/,
- illegal: /\n/,
- contains: [
- BACKSLASH_ESCAPE,
- {
- begin: /\[/,
- end: /\]/,
- relevance: 0,
- contains: [BACKSLASH_ESCAPE]
- }
- ]
- }]
- };
- const TITLE_MODE = {
- className: 'title',
- begin: IDENT_RE,
- relevance: 0
- };
- const UNDERSCORE_TITLE_MODE = {
- className: 'title',
- begin: UNDERSCORE_IDENT_RE,
- relevance: 0
- };
- const METHOD_GUARD = {
-
- begin: '\\.\\s*' + UNDERSCORE_IDENT_RE,
- relevance: 0
- };
- const END_SAME_AS_BEGIN = function(mode) {
- return Object.assign(mode,
- {
-
- 'on:begin': (m, resp) => { resp.data._beginMatch = m[1]; },
-
- 'on:end': (m, resp) => { if (resp.data._beginMatch !== m[1]) resp.ignoreMatch(); }
- });
- };
- var MODES = Object.freeze({
- __proto__: null,
- MATCH_NOTHING_RE: MATCH_NOTHING_RE,
- IDENT_RE: IDENT_RE,
- UNDERSCORE_IDENT_RE: UNDERSCORE_IDENT_RE,
- NUMBER_RE: NUMBER_RE,
- C_NUMBER_RE: C_NUMBER_RE,
- BINARY_NUMBER_RE: BINARY_NUMBER_RE,
- RE_STARTERS_RE: RE_STARTERS_RE,
- SHEBANG: SHEBANG,
- BACKSLASH_ESCAPE: BACKSLASH_ESCAPE,
- APOS_STRING_MODE: APOS_STRING_MODE,
- QUOTE_STRING_MODE: QUOTE_STRING_MODE,
- PHRASAL_WORDS_MODE: PHRASAL_WORDS_MODE,
- COMMENT: COMMENT,
- C_LINE_COMMENT_MODE: C_LINE_COMMENT_MODE,
- C_BLOCK_COMMENT_MODE: C_BLOCK_COMMENT_MODE,
- HASH_COMMENT_MODE: HASH_COMMENT_MODE,
- NUMBER_MODE: NUMBER_MODE,
- C_NUMBER_MODE: C_NUMBER_MODE,
- BINARY_NUMBER_MODE: BINARY_NUMBER_MODE,
- CSS_NUMBER_MODE: CSS_NUMBER_MODE,
- REGEXP_MODE: REGEXP_MODE,
- TITLE_MODE: TITLE_MODE,
- UNDERSCORE_TITLE_MODE: UNDERSCORE_TITLE_MODE,
- METHOD_GUARD: METHOD_GUARD,
- END_SAME_AS_BEGIN: END_SAME_AS_BEGIN
- });
- function skipIfhasPrecedingDot(match, response) {
- const before = match.input[match.index - 1];
- if (before === ".") {
- response.ignoreMatch();
- }
- }
- function beginKeywords(mode, parent) {
- if (!parent) return;
- if (!mode.beginKeywords) return;
-
-
-
-
-
- mode.begin = '\\b(' + mode.beginKeywords.split(' ').join('|') + ')(?!\\.)(?=\\b|\\s)';
- mode.__beforeBegin = skipIfhasPrecedingDot;
- mode.keywords = mode.keywords || mode.beginKeywords;
- delete mode.beginKeywords;
-
-
-
- if (mode.relevance === undefined) mode.relevance = 0;
- }
- function compileIllegal(mode, _parent) {
- if (!Array.isArray(mode.illegal)) return;
- mode.illegal = either(...mode.illegal);
- }
- function compileMatch(mode, _parent) {
- if (!mode.match) return;
- if (mode.begin || mode.end) throw new Error("begin & end are not supported with match");
- mode.begin = mode.match;
- delete mode.match;
- }
- function compileRelevance(mode, _parent) {
-
- if (mode.relevance === undefined) mode.relevance = 1;
- }
- const COMMON_KEYWORDS = [
- 'of',
- 'and',
- 'for',
- 'in',
- 'not',
- 'or',
- 'if',
- 'then',
- 'parent',
- 'list',
- 'value'
- ];
- const DEFAULT_KEYWORD_CLASSNAME = "keyword";
- function compileKeywords(rawKeywords, caseInsensitive, className = DEFAULT_KEYWORD_CLASSNAME) {
-
- const compiledKeywords = {};
-
-
- if (typeof rawKeywords === 'string') {
- compileList(className, rawKeywords.split(" "));
- } else if (Array.isArray(rawKeywords)) {
- compileList(className, rawKeywords);
- } else {
- Object.keys(rawKeywords).forEach(function(className) {
-
- Object.assign(
- compiledKeywords,
- compileKeywords(rawKeywords[className], caseInsensitive, className)
- );
- });
- }
- return compiledKeywords;
-
-
- function compileList(className, keywordList) {
- if (caseInsensitive) {
- keywordList = keywordList.map(x => x.toLowerCase());
- }
- keywordList.forEach(function(keyword) {
- const pair = keyword.split('|');
- compiledKeywords[pair[0]] = [className, scoreForKeyword(pair[0], pair[1])];
- });
- }
- }
- function scoreForKeyword(keyword, providedScore) {
-
-
- if (providedScore) {
- return Number(providedScore);
- }
- return commonKeyword(keyword) ? 0 : 1;
- }
- function commonKeyword(keyword) {
- return COMMON_KEYWORDS.includes(keyword.toLowerCase());
- }
- function compileLanguage(language, { plugins }) {
-
- function langRe(value, global) {
- return new RegExp(
- source(value),
- 'm' + (language.case_insensitive ? 'i' : '') + (global ? 'g' : '')
- );
- }
-
- class MultiRegex {
- constructor() {
- this.matchIndexes = {};
-
- this.regexes = [];
- this.matchAt = 1;
- this.position = 0;
- }
-
- addRule(re, opts) {
- opts.position = this.position++;
-
- this.matchIndexes[this.matchAt] = opts;
- this.regexes.push([opts, re]);
- this.matchAt += countMatchGroups(re) + 1;
- }
- compile() {
- if (this.regexes.length === 0) {
-
-
- this.exec = () => null;
- }
- const terminators = this.regexes.map(el => el[1]);
- this.matcherRe = langRe(join(terminators), true);
- this.lastIndex = 0;
- }
-
- exec(s) {
- this.matcherRe.lastIndex = this.lastIndex;
- const match = this.matcherRe.exec(s);
- if (!match) { return null; }
-
- const i = match.findIndex((el, i) => i > 0 && el !== undefined);
-
- const matchData = this.matchIndexes[i];
-
-
- match.splice(0, i);
- return Object.assign(match, matchData);
- }
- }
-
- class ResumableMultiRegex {
- constructor() {
-
- this.rules = [];
-
- this.multiRegexes = [];
- this.count = 0;
- this.lastIndex = 0;
- this.regexIndex = 0;
- }
-
- getMatcher(index) {
- if (this.multiRegexes[index]) return this.multiRegexes[index];
- const matcher = new MultiRegex();
- this.rules.slice(index).forEach(([re, opts]) => matcher.addRule(re, opts));
- matcher.compile();
- this.multiRegexes[index] = matcher;
- return matcher;
- }
- resumingScanAtSamePosition() {
- return this.regexIndex !== 0;
- }
- considerAll() {
- this.regexIndex = 0;
- }
-
- addRule(re, opts) {
- this.rules.push([re, opts]);
- if (opts.type === "begin") this.count++;
- }
-
- exec(s) {
- const m = this.getMatcher(this.regexIndex);
- m.lastIndex = this.lastIndex;
- let result = m.exec(s);
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- if (this.resumingScanAtSamePosition()) {
- if (result && result.index === this.lastIndex) ; else {
- const m2 = this.getMatcher(0);
- m2.lastIndex = this.lastIndex + 1;
- result = m2.exec(s);
- }
- }
- if (result) {
- this.regexIndex += result.position + 1;
- if (this.regexIndex === this.count) {
-
- this.considerAll();
- }
- }
- return result;
- }
- }
-
- function buildModeRegex(mode) {
- const mm = new ResumableMultiRegex();
- mode.contains.forEach(term => mm.addRule(term.begin, { rule: term, type: "begin" }));
- if (mode.terminatorEnd) {
- mm.addRule(mode.terminatorEnd, { type: "end" });
- }
- if (mode.illegal) {
- mm.addRule(mode.illegal, { type: "illegal" });
- }
- return mm;
- }
-
-
- function compileMode(mode, parent) {
- const cmode = (mode);
- if (mode.isCompiled) return cmode;
- [
-
-
- compileMatch
- ].forEach(ext => ext(mode, parent));
- language.compilerExtensions.forEach(ext => ext(mode, parent));
-
- mode.__beforeBegin = null;
- [
- beginKeywords,
-
-
- compileIllegal,
-
- compileRelevance
- ].forEach(ext => ext(mode, parent));
- mode.isCompiled = true;
- let keywordPattern = null;
- if (typeof mode.keywords === "object") {
- keywordPattern = mode.keywords.$pattern;
- delete mode.keywords.$pattern;
- }
- if (mode.keywords) {
- mode.keywords = compileKeywords(mode.keywords, language.case_insensitive);
- }
-
- if (mode.lexemes && keywordPattern) {
- throw new Error("ERR: Prefer `keywords.$pattern` to `mode.lexemes`, BOTH are not allowed. (see mode reference) ");
- }
-
-
- keywordPattern = keywordPattern || mode.lexemes || /\w+/;
- cmode.keywordPatternRe = langRe(keywordPattern, true);
- if (parent) {
- if (!mode.begin) mode.begin = /\B|\b/;
- cmode.beginRe = langRe(mode.begin);
- if (mode.endSameAsBegin) mode.end = mode.begin;
- if (!mode.end && !mode.endsWithParent) mode.end = /\B|\b/;
- if (mode.end) cmode.endRe = langRe(mode.end);
- cmode.terminatorEnd = source(mode.end) || '';
- if (mode.endsWithParent && parent.terminatorEnd) {
- cmode.terminatorEnd += (mode.end ? '|' : '') + parent.terminatorEnd;
- }
- }
- if (mode.illegal) cmode.illegalRe = langRe( (mode.illegal));
- if (!mode.contains) mode.contains = [];
- mode.contains = [].concat(...mode.contains.map(function(c) {
- return expandOrCloneMode(c === 'self' ? mode : c);
- }));
- mode.contains.forEach(function(c) { compileMode( (c), cmode); });
- if (mode.starts) {
- compileMode(mode.starts, parent);
- }
- cmode.matcher = buildModeRegex(cmode);
- return cmode;
- }
- if (!language.compilerExtensions) language.compilerExtensions = [];
-
- if (language.contains && language.contains.includes('self')) {
- throw new Error("ERR: contains `self` is not supported at the top-level of a language. See documentation.");
- }
-
- language.classNameAliases = inherit(language.classNameAliases || {});
- return compileMode( (language));
- }
- function dependencyOnParent(mode) {
- if (!mode) return false;
- return mode.endsWithParent || dependencyOnParent(mode.starts);
- }
- function expandOrCloneMode(mode) {
- if (mode.variants && !mode.cachedVariants) {
- mode.cachedVariants = mode.variants.map(function(variant) {
- return inherit(mode, { variants: null }, variant);
- });
- }
-
-
-
- if (mode.cachedVariants) {
- return mode.cachedVariants;
- }
-
-
-
-
- if (dependencyOnParent(mode)) {
- return inherit(mode, { starts: mode.starts ? inherit(mode.starts) : null });
- }
- if (Object.isFrozen(mode)) {
- return inherit(mode);
- }
-
- return mode;
- }
- var version = "10.7.3";
- function hasValueOrEmptyAttribute(value) {
- return Boolean(value || value === "");
- }
- function BuildVuePlugin(hljs) {
- const Component = {
- props: ["language", "code", "autodetect"],
- data: function() {
- return {
- detectedLanguage: "",
- unknownLanguage: false
- };
- },
- computed: {
- className() {
- if (this.unknownLanguage) return "";
- return "hljs " + this.detectedLanguage;
- },
- highlighted() {
-
- if (!this.autoDetect && !hljs.getLanguage(this.language)) {
- console.warn(`The language "${this.language}" you specified could not be found.`);
- this.unknownLanguage = true;
- return escapeHTML(this.code);
- }
- let result = {};
- if (this.autoDetect) {
- result = hljs.highlightAuto(this.code);
- this.detectedLanguage = result.language;
- } else {
- result = hljs.highlight(this.language, this.code, this.ignoreIllegals);
- this.detectedLanguage = this.language;
- }
- return result.value;
- },
- autoDetect() {
- return !this.language || hasValueOrEmptyAttribute(this.autodetect);
- },
- ignoreIllegals() {
- return true;
- }
- },
-
-
- render(createElement) {
- return createElement("pre", {}, [
- createElement("code", {
- class: this.className,
- domProps: { innerHTML: this.highlighted }
- })
- ]);
- }
-
- };
- const VuePlugin = {
- install(Vue) {
- Vue.component('highlightjs', Component);
- }
- };
- return { Component, VuePlugin };
- }
- const mergeHTMLPlugin = {
- "after:highlightElement": ({ el, result, text }) => {
- const originalStream = nodeStream(el);
- if (!originalStream.length) return;
- const resultNode = document.createElement('div');
- resultNode.innerHTML = result.value;
- result.value = mergeStreams(originalStream, nodeStream(resultNode), text);
- }
- };
- function tag(node) {
- return node.nodeName.toLowerCase();
- }
- function nodeStream(node) {
-
- const result = [];
- (function _nodeStream(node, offset) {
- for (let child = node.firstChild; child; child = child.nextSibling) {
- if (child.nodeType === 3) {
- offset += child.nodeValue.length;
- } else if (child.nodeType === 1) {
- result.push({
- event: 'start',
- offset: offset,
- node: child
- });
- offset = _nodeStream(child, offset);
-
-
-
- if (!tag(child).match(/br|hr|img|input/)) {
- result.push({
- event: 'stop',
- offset: offset,
- node: child
- });
- }
- }
- }
- return offset;
- })(node, 0);
- return result;
- }
- function mergeStreams(original, highlighted, value) {
- let processed = 0;
- let result = '';
- const nodeStack = [];
- function selectStream() {
- if (!original.length || !highlighted.length) {
- return original.length ? original : highlighted;
- }
- if (original[0].offset !== highlighted[0].offset) {
- return (original[0].offset < highlighted[0].offset) ? original : highlighted;
- }
-
- return highlighted[0].event === 'start' ? original : highlighted;
- }
-
- function open(node) {
-
- function attributeString(attr) {
- return ' ' + attr.nodeName + '="' + escapeHTML(attr.value) + '"';
- }
-
- result += '<' + tag(node) + [].map.call(node.attributes, attributeString).join('') + '>';
- }
-
- function close(node) {
- result += '</' + tag(node) + '>';
- }
-
- function render(event) {
- (event.event === 'start' ? open : close)(event.node);
- }
- while (original.length || highlighted.length) {
- let stream = selectStream();
- result += escapeHTML(value.substring(processed, stream[0].offset));
- processed = stream[0].offset;
- if (stream === original) {
-
- nodeStack.reverse().forEach(close);
- do {
- render(stream.splice(0, 1)[0]);
- stream = selectStream();
- } while (stream === original && stream.length && stream[0].offset === processed);
- nodeStack.reverse().forEach(open);
- } else {
- if (stream[0].event === 'start') {
- nodeStack.push(stream[0].node);
- } else {
- nodeStack.pop();
- }
- render(stream.splice(0, 1)[0]);
- }
- }
- return result + escapeHTML(value.substr(processed));
- }
- const seenDeprecations = {};
- const error = (message) => {
- console.error(message);
- };
- const warn = (message, ...args) => {
- console.log(`WARN: ${message}`, ...args);
- };
- const deprecated = (version, message) => {
- if (seenDeprecations[`${version}/${message}`]) return;
- console.log(`Deprecated as of ${version}. ${message}`);
- seenDeprecations[`${version}/${message}`] = true;
- };
- const escape$1 = escapeHTML;
- const inherit$1 = inherit;
- const NO_MATCH = Symbol("nomatch");
- const HLJS = function(hljs) {
-
-
- const languages = Object.create(null);
-
- const aliases = Object.create(null);
-
- const plugins = [];
-
-
- let SAFE_MODE = true;
- const fixMarkupRe = /(^(<[^>]+>|\t|)+|\n)/gm;
- const LANGUAGE_NOT_FOUND = "Could not find the language '{}', did you forget to load/include a language module?";
-
- const PLAINTEXT_LANGUAGE = { disableAutodetect: true, name: 'Plain text', contains: [] };
-
-
-
- let options = {
- noHighlightRe: /^(no-?highlight)$/i,
- languageDetectRe: /\blang(?:uage)?-([\w-]+)\b/i,
- classPrefix: 'hljs-',
- tabReplace: null,
- useBR: false,
- languages: null,
-
-
- __emitter: TokenTreeEmitter
- };
-
-
- function shouldNotHighlight(languageName) {
- return options.noHighlightRe.test(languageName);
- }
-
- function blockLanguage(block) {
- let classes = block.className + ' ';
- classes += block.parentNode ? block.parentNode.className : '';
-
- const match = options.languageDetectRe.exec(classes);
- if (match) {
- const language = getLanguage(match[1]);
- if (!language) {
- warn(LANGUAGE_NOT_FOUND.replace("{}", match[1]));
- warn("Falling back to no-highlight mode for this block.", block);
- }
- return language ? match[1] : 'no-highlight';
- }
- return classes
- .split(/\s+/)
- .find((_class) => shouldNotHighlight(_class) || getLanguage(_class));
- }
-
- function highlight(codeOrlanguageName, optionsOrCode, ignoreIllegals, continuation) {
- let code = "";
- let languageName = "";
- if (typeof optionsOrCode === "object") {
- code = codeOrlanguageName;
- ignoreIllegals = optionsOrCode.ignoreIllegals;
- languageName = optionsOrCode.language;
-
-
- continuation = undefined;
- } else {
-
- deprecated("10.7.0", "highlight(lang, code, ...args) has been deprecated.");
- deprecated("10.7.0", "Please use highlight(code, options) instead.\nhttps://github.com/highlightjs/highlight.js/issues/2277");
- languageName = codeOrlanguageName;
- code = optionsOrCode;
- }
-
- const context = {
- code,
- language: languageName
- };
-
-
- fire("before:highlight", context);
-
-
- const result = context.result
- ? context.result
- : _highlight(context.language, context.code, ignoreIllegals, continuation);
- result.code = context.code;
-
- fire("after:highlight", result);
- return result;
- }
-
- function _highlight(languageName, codeToHighlight, ignoreIllegals, continuation) {
-
- function keywordData(mode, match) {
- const matchText = language.case_insensitive ? match[0].toLowerCase() : match[0];
- return Object.prototype.hasOwnProperty.call(mode.keywords, matchText) && mode.keywords[matchText];
- }
- function processKeywords() {
- if (!top.keywords) {
- emitter.addText(modeBuffer);
- return;
- }
- let lastIndex = 0;
- top.keywordPatternRe.lastIndex = 0;
- let match = top.keywordPatternRe.exec(modeBuffer);
- let buf = "";
- while (match) {
- buf += modeBuffer.substring(lastIndex, match.index);
- const data = keywordData(top, match);
- if (data) {
- const [kind, keywordRelevance] = data;
- emitter.addText(buf);
- buf = "";
- relevance += keywordRelevance;
- if (kind.startsWith("_")) {
-
-
- buf += match[0];
- } else {
- const cssClass = language.classNameAliases[kind] || kind;
- emitter.addKeyword(match[0], cssClass);
- }
- } else {
- buf += match[0];
- }
- lastIndex = top.keywordPatternRe.lastIndex;
- match = top.keywordPatternRe.exec(modeBuffer);
- }
- buf += modeBuffer.substr(lastIndex);
- emitter.addText(buf);
- }
- function processSubLanguage() {
- if (modeBuffer === "") return;
-
- let result = null;
- if (typeof top.subLanguage === 'string') {
- if (!languages[top.subLanguage]) {
- emitter.addText(modeBuffer);
- return;
- }
- result = _highlight(top.subLanguage, modeBuffer, true, continuations[top.subLanguage]);
- continuations[top.subLanguage] = (result.top);
- } else {
- result = highlightAuto(modeBuffer, top.subLanguage.length ? top.subLanguage : null);
- }
-
-
-
-
- if (top.relevance > 0) {
- relevance += result.relevance;
- }
- emitter.addSublanguage(result.emitter, result.language);
- }
- function processBuffer() {
- if (top.subLanguage != null) {
- processSubLanguage();
- } else {
- processKeywords();
- }
- modeBuffer = '';
- }
-
- function startNewMode(mode) {
- if (mode.className) {
- emitter.openNode(language.classNameAliases[mode.className] || mode.className);
- }
- top = Object.create(mode, { parent: { value: top } });
- return top;
- }
-
- function endOfMode(mode, match, matchPlusRemainder) {
- let matched = startsWith(mode.endRe, matchPlusRemainder);
- if (matched) {
- if (mode["on:end"]) {
- const resp = new Response(mode);
- mode["on:end"](match, resp);
- if (resp.isMatchIgnored) matched = false;
- }
- if (matched) {
- while (mode.endsParent && mode.parent) {
- mode = mode.parent;
- }
- return mode;
- }
- }
-
-
- if (mode.endsWithParent) {
- return endOfMode(mode.parent, match, matchPlusRemainder);
- }
- }
-
- function doIgnore(lexeme) {
- if (top.matcher.regexIndex === 0) {
-
-
- modeBuffer += lexeme[0];
- return 1;
- } else {
-
-
- resumeScanAtSamePosition = true;
- return 0;
- }
- }
-
- function doBeginMatch(match) {
- const lexeme = match[0];
- const newMode = match.rule;
- const resp = new Response(newMode);
-
- const beforeCallbacks = [newMode.__beforeBegin, newMode["on:begin"]];
- for (const cb of beforeCallbacks) {
- if (!cb) continue;
- cb(match, resp);
- if (resp.isMatchIgnored) return doIgnore(lexeme);
- }
- if (newMode && newMode.endSameAsBegin) {
- newMode.endRe = escape(lexeme);
- }
- if (newMode.skip) {
- modeBuffer += lexeme;
- } else {
- if (newMode.excludeBegin) {
- modeBuffer += lexeme;
- }
- processBuffer();
- if (!newMode.returnBegin && !newMode.excludeBegin) {
- modeBuffer = lexeme;
- }
- }
- startNewMode(newMode);
-
-
-
-
- return newMode.returnBegin ? 0 : lexeme.length;
- }
-
- function doEndMatch(match) {
- const lexeme = match[0];
- const matchPlusRemainder = codeToHighlight.substr(match.index);
- const endMode = endOfMode(top, match, matchPlusRemainder);
- if (!endMode) { return NO_MATCH; }
- const origin = top;
- if (origin.skip) {
- modeBuffer += lexeme;
- } else {
- if (!(origin.returnEnd || origin.excludeEnd)) {
- modeBuffer += lexeme;
- }
- processBuffer();
- if (origin.excludeEnd) {
- modeBuffer = lexeme;
- }
- }
- do {
- if (top.className) {
- emitter.closeNode();
- }
- if (!top.skip && !top.subLanguage) {
- relevance += top.relevance;
- }
- top = top.parent;
- } while (top !== endMode.parent);
- if (endMode.starts) {
- if (endMode.endSameAsBegin) {
- endMode.starts.endRe = endMode.endRe;
- }
- startNewMode(endMode.starts);
- }
- return origin.returnEnd ? 0 : lexeme.length;
- }
- function processContinuations() {
- const list = [];
- for (let current = top; current !== language; current = current.parent) {
- if (current.className) {
- list.unshift(current.className);
- }
- }
- list.forEach(item => emitter.openNode(item));
- }
-
- let lastMatch = {};
-
- function processLexeme(textBeforeMatch, match) {
- const lexeme = match && match[0];
-
- modeBuffer += textBeforeMatch;
- if (lexeme == null) {
- processBuffer();
- return 0;
- }
-
-
-
-
- if (lastMatch.type === "begin" && match.type === "end" && lastMatch.index === match.index && lexeme === "") {
-
- modeBuffer += codeToHighlight.slice(match.index, match.index + 1);
- if (!SAFE_MODE) {
-
- const err = new Error('0 width match regex');
- err.languageName = languageName;
- err.badRule = lastMatch.rule;
- throw err;
- }
- return 1;
- }
- lastMatch = match;
- if (match.type === "begin") {
- return doBeginMatch(match);
- } else if (match.type === "illegal" && !ignoreIllegals) {
-
-
- const err = new Error('Illegal lexeme "' + lexeme + '" for mode "' + (top.className || '<unnamed>') + '"');
- err.mode = top;
- throw err;
- } else if (match.type === "end") {
- const processed = doEndMatch(match);
- if (processed !== NO_MATCH) {
- return processed;
- }
- }
-
-
-
- if (match.type === "illegal" && lexeme === "") {
-
- return 1;
- }
-
-
-
-
- if (iterations > 100000 && iterations > match.index * 3) {
- const err = new Error('potential infinite loop, way more iterations than matches');
- throw err;
- }
-
- modeBuffer += lexeme;
- return lexeme.length;
- }
- const language = getLanguage(languageName);
- if (!language) {
- error(LANGUAGE_NOT_FOUND.replace("{}", languageName));
- throw new Error('Unknown language: "' + languageName + '"');
- }
- const md = compileLanguage(language, { plugins });
- let result = '';
-
- let top = continuation || md;
-
- const continuations = {};
- const emitter = new options.__emitter(options);
- processContinuations();
- let modeBuffer = '';
- let relevance = 0;
- let index = 0;
- let iterations = 0;
- let resumeScanAtSamePosition = false;
- try {
- top.matcher.considerAll();
- for (;;) {
- iterations++;
- if (resumeScanAtSamePosition) {
-
-
- resumeScanAtSamePosition = false;
- } else {
- top.matcher.considerAll();
- }
- top.matcher.lastIndex = index;
- const match = top.matcher.exec(codeToHighlight);
-
- if (!match) break;
- const beforeMatch = codeToHighlight.substring(index, match.index);
- const processedCount = processLexeme(beforeMatch, match);
- index = match.index + processedCount;
- }
- processLexeme(codeToHighlight.substr(index));
- emitter.closeAllNodes();
- emitter.finalize();
- result = emitter.toHTML();
- return {
-
-
- relevance: Math.floor(relevance),
- value: result,
- language: languageName,
- illegal: false,
- emitter: emitter,
- top: top
- };
- } catch (err) {
- if (err.message && err.message.includes('Illegal')) {
- return {
- illegal: true,
- illegalBy: {
- msg: err.message,
- context: codeToHighlight.slice(index - 100, index + 100),
- mode: err.mode
- },
- sofar: result,
- relevance: 0,
- value: escape$1(codeToHighlight),
- emitter: emitter
- };
- } else if (SAFE_MODE) {
- return {
- illegal: false,
- relevance: 0,
- value: escape$1(codeToHighlight),
- emitter: emitter,
- language: languageName,
- top: top,
- errorRaised: err
- };
- } else {
- throw err;
- }
- }
- }
-
- function justTextHighlightResult(code) {
- const result = {
- relevance: 0,
- emitter: new options.__emitter(options),
- value: escape$1(code),
- illegal: false,
- top: PLAINTEXT_LANGUAGE
- };
- result.emitter.addText(code);
- return result;
- }
-
- function highlightAuto(code, languageSubset) {
- languageSubset = languageSubset || options.languages || Object.keys(languages);
- const plaintext = justTextHighlightResult(code);
- const results = languageSubset.filter(getLanguage).filter(autoDetection).map(name =>
- _highlight(name, code, false)
- );
- results.unshift(plaintext);
- const sorted = results.sort((a, b) => {
-
- if (a.relevance !== b.relevance) return b.relevance - a.relevance;
-
-
- if (a.language && b.language) {
- if (getLanguage(a.language).supersetOf === b.language) {
- return 1;
- } else if (getLanguage(b.language).supersetOf === a.language) {
- return -1;
- }
- }
-
-
-
-
- return 0;
- });
- const [best, secondBest] = sorted;
-
- const result = best;
- result.second_best = secondBest;
- return result;
- }
-
- function fixMarkup(html) {
- if (!(options.tabReplace || options.useBR)) {
- return html;
- }
- return html.replace(fixMarkupRe, match => {
- if (match === '\n') {
- return options.useBR ? '<br>' : match;
- } else if (options.tabReplace) {
- return match.replace(/\t/g, options.tabReplace);
- }
- return match;
- });
- }
-
- function updateClassName(element, currentLang, resultLang) {
- const language = currentLang ? aliases[currentLang] : resultLang;
- element.classList.add("hljs");
- if (language) element.classList.add(language);
- }
-
- const brPlugin = {
- "before:highlightElement": ({ el }) => {
- if (options.useBR) {
- el.innerHTML = el.innerHTML.replace(/\n/g, '').replace(/<br[ /]*>/g, '\n');
- }
- },
- "after:highlightElement": ({ result }) => {
- if (options.useBR) {
- result.value = result.value.replace(/\n/g, "<br>");
- }
- }
- };
- const TAB_REPLACE_RE = /^(<[^>]+>|\t)+/gm;
-
- const tabReplacePlugin = {
- "after:highlightElement": ({ result }) => {
- if (options.tabReplace) {
- result.value = result.value.replace(TAB_REPLACE_RE, (m) =>
- m.replace(/\t/g, options.tabReplace)
- );
- }
- }
- };
-
- function highlightElement(element) {
-
- let node = null;
- const language = blockLanguage(element);
- if (shouldNotHighlight(language)) return;
-
- fire("before:highlightElement",
- { el: element, language: language });
- node = element;
- const text = node.textContent;
- const result = language ? highlight(text, { language, ignoreIllegals: true }) : highlightAuto(text);
-
- fire("after:highlightElement", { el: element, result, text });
- element.innerHTML = result.value;
- updateClassName(element, language, result.language);
- element.result = {
- language: result.language,
-
- re: result.relevance,
- relavance: result.relevance
- };
- if (result.second_best) {
- element.second_best = {
- language: result.second_best.language,
-
- re: result.second_best.relevance,
- relavance: result.second_best.relevance
- };
- }
- }
-
- function configure(userOptions) {
- if (userOptions.useBR) {
- deprecated("10.3.0", "'useBR' will be removed entirely in v11.0");
- deprecated("10.3.0", "Please see https://github.com/highlightjs/highlight.js/issues/2559");
- }
- options = inherit$1(options, userOptions);
- }
-
-
- const initHighlighting = () => {
- if (initHighlighting.called) return;
- initHighlighting.called = true;
- deprecated("10.6.0", "initHighlighting() is deprecated. Use highlightAll() instead.");
- const blocks = document.querySelectorAll('pre code');
- blocks.forEach(highlightElement);
- };
-
-
- function initHighlightingOnLoad() {
- deprecated("10.6.0", "initHighlightingOnLoad() is deprecated. Use highlightAll() instead.");
- wantsHighlight = true;
- }
- let wantsHighlight = false;
-
- function highlightAll() {
-
- if (document.readyState === "loading") {
- wantsHighlight = true;
- return;
- }
- const blocks = document.querySelectorAll('pre code');
- blocks.forEach(highlightElement);
- }
- function boot() {
-
- if (wantsHighlight) highlightAll();
- }
-
- if (typeof window !== 'undefined' && window.addEventListener) {
- window.addEventListener('DOMContentLoaded', boot, false);
- }
-
- function registerLanguage(languageName, languageDefinition) {
- let lang = null;
- try {
- lang = languageDefinition(hljs);
- } catch (error$1) {
- error("Language definition for '{}' could not be registered.".replace("{}", languageName));
-
- if (!SAFE_MODE) { throw error$1; } else { error(error$1); }
-
-
-
-
- lang = PLAINTEXT_LANGUAGE;
- }
-
- if (!lang.name) lang.name = languageName;
- languages[languageName] = lang;
- lang.rawDefinition = languageDefinition.bind(null, hljs);
- if (lang.aliases) {
- registerAliases(lang.aliases, { languageName });
- }
- }
-
- function unregisterLanguage(languageName) {
- delete languages[languageName];
- for (const alias of Object.keys(aliases)) {
- if (aliases[alias] === languageName) {
- delete aliases[alias];
- }
- }
- }
-
- function listLanguages() {
- return Object.keys(languages);
- }
-
- function requireLanguage(name) {
- deprecated("10.4.0", "requireLanguage will be removed entirely in v11.");
- deprecated("10.4.0", "Please see https://github.com/highlightjs/highlight.js/pull/2844");
- const lang = getLanguage(name);
- if (lang) { return lang; }
- const err = new Error('The \'{}\' language is required, but not loaded.'.replace('{}', name));
- throw err;
- }
-
- function getLanguage(name) {
- name = (name || '').toLowerCase();
- return languages[name] || languages[aliases[name]];
- }
-
- function registerAliases(aliasList, { languageName }) {
- if (typeof aliasList === 'string') {
- aliasList = [aliasList];
- }
- aliasList.forEach(alias => { aliases[alias.toLowerCase()] = languageName; });
- }
-
- function autoDetection(name) {
- const lang = getLanguage(name);
- return lang && !lang.disableAutodetect;
- }
-
- function upgradePluginAPI(plugin) {
-
- if (plugin["before:highlightBlock"] && !plugin["before:highlightElement"]) {
- plugin["before:highlightElement"] = (data) => {
- plugin["before:highlightBlock"](
- Object.assign({ block: data.el }, data)
- );
- };
- }
- if (plugin["after:highlightBlock"] && !plugin["after:highlightElement"]) {
- plugin["after:highlightElement"] = (data) => {
- plugin["after:highlightBlock"](
- Object.assign({ block: data.el }, data)
- );
- };
- }
- }
-
- function addPlugin(plugin) {
- upgradePluginAPI(plugin);
- plugins.push(plugin);
- }
-
- function fire(event, args) {
- const cb = event;
- plugins.forEach(function(plugin) {
- if (plugin[cb]) {
- plugin[cb](args);
- }
- });
- }
-
- function deprecateFixMarkup(arg) {
- deprecated("10.2.0", "fixMarkup will be removed entirely in v11.0");
- deprecated("10.2.0", "Please see https://github.com/highlightjs/highlight.js/issues/2534");
- return fixMarkup(arg);
- }
-
- function deprecateHighlightBlock(el) {
- deprecated("10.7.0", "highlightBlock will be removed entirely in v12.0");
- deprecated("10.7.0", "Please use highlightElement now.");
- return highlightElement(el);
- }
-
- Object.assign(hljs, {
- highlight,
- highlightAuto,
- highlightAll,
- fixMarkup: deprecateFixMarkup,
- highlightElement,
-
- highlightBlock: deprecateHighlightBlock,
- configure,
- initHighlighting,
- initHighlightingOnLoad,
- registerLanguage,
- unregisterLanguage,
- listLanguages,
- getLanguage,
- registerAliases,
- requireLanguage,
- autoDetection,
- inherit: inherit$1,
- addPlugin,
-
- vuePlugin: BuildVuePlugin(hljs).VuePlugin
- });
- hljs.debugMode = function() { SAFE_MODE = false; };
- hljs.safeMode = function() { SAFE_MODE = true; };
- hljs.versionString = version;
- for (const key in MODES) {
-
- if (typeof MODES[key] === "object") {
-
- deepFreezeEs6(MODES[key]);
- }
- }
-
- Object.assign(hljs, MODES);
-
- hljs.addPlugin(brPlugin);
- hljs.addPlugin(mergeHTMLPlugin);
- hljs.addPlugin(tabReplacePlugin);
- return hljs;
- };
- var highlight = HLJS({});
- module.exports = highlight;
|