UNPKG

@21epub/epub-thirdparty

Version:
400 lines (398 loc) 14.6 kB
/*--------------------------------------------------------------------------------------------- * Copyright (c) Microsoft Corporation. All rights reserved. * Licensed under the MIT License. See License.txt in the project root for license information. *--------------------------------------------------------------------------------------------*/ define('vs/basic-languages/handlebars/handlebars',["require", "exports", "../fillers/monaco-editor-core"], function (require, exports, monaco_editor_core_1) { "use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.language = exports.conf = void 0; var EMPTY_ELEMENTS = [ 'area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'menuitem', 'meta', 'param', 'source', 'track', 'wbr' ]; exports.conf = { wordPattern: /(-?\d*\.\d\w*)|([^\`\~\!\@\$\^\&\*\(\)\=\+\[\{\]\}\\\|\;\:\'\"\,\.\<\>\/\s]+)/g, comments: { blockComment: ['{{!--', '--}}'] }, brackets: [ ['<!--', '-->'], ['<', '>'], ['{{', '}}'], ['{', '}'], ['(', ')'] ], autoClosingPairs: [ { open: '{', close: '}' }, { open: '[', close: ']' }, { open: '(', close: ')' }, { open: '"', close: '"' }, { open: "'", close: "'" } ], surroundingPairs: [ { open: '<', close: '>' }, { open: '"', close: '"' }, { open: "'", close: "'" } ], onEnterRules: [ { beforeText: new RegExp("<(?!(?:" + EMPTY_ELEMENTS.join('|') + "))(\\w[\\w\\d]*)([^/>]*(?!/)>)[^<]*$", 'i'), afterText: /^<\/(\w[\w\d]*)\s*>$/i, action: { indentAction: monaco_editor_core_1.languages.IndentAction.IndentOutdent } }, { beforeText: new RegExp("<(?!(?:" + EMPTY_ELEMENTS.join('|') + "))(\\w[\\w\\d]*)([^/>]*(?!/)>)[^<]*$", 'i'), action: { indentAction: monaco_editor_core_1.languages.IndentAction.Indent } } ] }; exports.language = { defaultToken: '', tokenPostfix: '', // ignoreCase: true, // The main tokenizer for our languages tokenizer: { root: [ [/\{\{!--/, 'comment.block.start.handlebars', '@commentBlock'], [/\{\{!/, 'comment.start.handlebars', '@comment'], [/\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.root' }], [/<!DOCTYPE/, 'metatag.html', '@doctype'], [/<!--/, 'comment.html', '@commentHtml'], [/(<)(\w+)(\/>)/, ['delimiter.html', 'tag.html', 'delimiter.html']], [/(<)(script)/, ['delimiter.html', { token: 'tag.html', next: '@script' }]], [/(<)(style)/, ['delimiter.html', { token: 'tag.html', next: '@style' }]], [/(<)([:\w]+)/, ['delimiter.html', { token: 'tag.html', next: '@otherTag' }]], [/(<\/)(\w+)/, ['delimiter.html', { token: 'tag.html', next: '@otherTag' }]], [/</, 'delimiter.html'], [/\{/, 'delimiter.html'], [/[^<{]+/] // text ], doctype: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.comment' } ], [/[^>]+/, 'metatag.content.html'], [/>/, 'metatag.html', '@pop'] ], comment: [ [/\}\}/, 'comment.end.handlebars', '@pop'], [/./, 'comment.content.handlebars'] ], commentBlock: [ [/--\}\}/, 'comment.block.end.handlebars', '@pop'], [/./, 'comment.content.handlebars'] ], commentHtml: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.comment' } ], [/-->/, 'comment.html', '@pop'], [/[^-]+/, 'comment.content.html'], [/./, 'comment.content.html'] ], otherTag: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.otherTag' } ], [/\/?>/, 'delimiter.html', '@pop'], [/"([^"]*)"/, 'attribute.value'], [/'([^']*)'/, 'attribute.value'], [/[\w\-]+/, 'attribute.name'], [/=/, 'delimiter'], [/[ \t\r\n]+/] // whitespace ], // -- BEGIN <script> tags handling // After <script script: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.script' } ], [/type/, 'attribute.name', '@scriptAfterType'], [/"([^"]*)"/, 'attribute.value'], [/'([^']*)'/, 'attribute.value'], [/[\w\-]+/, 'attribute.name'], [/=/, 'delimiter'], [ />/, { token: 'delimiter.html', next: '@scriptEmbedded.text/javascript', nextEmbedded: 'text/javascript' } ], [/[ \t\r\n]+/], [ /(<\/)(script\s*)(>)/, ['delimiter.html', 'tag.html', { token: 'delimiter.html', next: '@pop' }] ] ], // After <script ... type scriptAfterType: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.scriptAfterType' } ], [/=/, 'delimiter', '@scriptAfterTypeEquals'], [ />/, { token: 'delimiter.html', next: '@scriptEmbedded.text/javascript', nextEmbedded: 'text/javascript' } ], [/[ \t\r\n]+/], [/<\/script\s*>/, { token: '@rematch', next: '@pop' }] ], // After <script ... type = scriptAfterTypeEquals: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.scriptAfterTypeEquals' } ], [ /"([^"]*)"/, { token: 'attribute.value', switchTo: '@scriptWithCustomType.$1' } ], [ /'([^']*)'/, { token: 'attribute.value', switchTo: '@scriptWithCustomType.$1' } ], [ />/, { token: 'delimiter.html', next: '@scriptEmbedded.text/javascript', nextEmbedded: 'text/javascript' } ], [/[ \t\r\n]+/], [/<\/script\s*>/, { token: '@rematch', next: '@pop' }] ], // After <script ... type = $S2 scriptWithCustomType: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.scriptWithCustomType.$S2' } ], [ />/, { token: 'delimiter.html', next: '@scriptEmbedded.$S2', nextEmbedded: '$S2' } ], [/"([^"]*)"/, 'attribute.value'], [/'([^']*)'/, 'attribute.value'], [/[\w\-]+/, 'attribute.name'], [/=/, 'delimiter'], [/[ \t\r\n]+/], [/<\/script\s*>/, { token: '@rematch', next: '@pop' }] ], scriptEmbedded: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInEmbeddedState.scriptEmbedded.$S2', nextEmbedded: '@pop' } ], [/<\/script/, { token: '@rematch', next: '@pop', nextEmbedded: '@pop' }] ], // -- END <script> tags handling // -- BEGIN <style> tags handling // After <style style: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.style' } ], [/type/, 'attribute.name', '@styleAfterType'], [/"([^"]*)"/, 'attribute.value'], [/'([^']*)'/, 'attribute.value'], [/[\w\-]+/, 'attribute.name'], [/=/, 'delimiter'], [ />/, { token: 'delimiter.html', next: '@styleEmbedded.text/css', nextEmbedded: 'text/css' } ], [/[ \t\r\n]+/], [ /(<\/)(style\s*)(>)/, ['delimiter.html', 'tag.html', { token: 'delimiter.html', next: '@pop' }] ] ], // After <style ... type styleAfterType: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.styleAfterType' } ], [/=/, 'delimiter', '@styleAfterTypeEquals'], [ />/, { token: 'delimiter.html', next: '@styleEmbedded.text/css', nextEmbedded: 'text/css' } ], [/[ \t\r\n]+/], [/<\/style\s*>/, { token: '@rematch', next: '@pop' }] ], // After <style ... type = styleAfterTypeEquals: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.styleAfterTypeEquals' } ], [ /"([^"]*)"/, { token: 'attribute.value', switchTo: '@styleWithCustomType.$1' } ], [ /'([^']*)'/, { token: 'attribute.value', switchTo: '@styleWithCustomType.$1' } ], [ />/, { token: 'delimiter.html', next: '@styleEmbedded.text/css', nextEmbedded: 'text/css' } ], [/[ \t\r\n]+/], [/<\/style\s*>/, { token: '@rematch', next: '@pop' }] ], // After <style ... type = $S2 styleWithCustomType: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInSimpleState.styleWithCustomType.$S2' } ], [ />/, { token: 'delimiter.html', next: '@styleEmbedded.$S2', nextEmbedded: '$S2' } ], [/"([^"]*)"/, 'attribute.value'], [/'([^']*)'/, 'attribute.value'], [/[\w\-]+/, 'attribute.name'], [/=/, 'delimiter'], [/[ \t\r\n]+/], [/<\/style\s*>/, { token: '@rematch', next: '@pop' }] ], styleEmbedded: [ [ /\{\{/, { token: '@rematch', switchTo: '@handlebarsInEmbeddedState.styleEmbedded.$S2', nextEmbedded: '@pop' } ], [/<\/style/, { token: '@rematch', next: '@pop', nextEmbedded: '@pop' }] ], // -- END <style> tags handling handlebarsInSimpleState: [ [/\{\{\{?/, 'delimiter.handlebars'], [/\}\}\}?/, { token: 'delimiter.handlebars', switchTo: '@$S2.$S3' }], { include: 'handlebarsRoot' } ], handlebarsInEmbeddedState: [ [/\{\{\{?/, 'delimiter.handlebars'], [ /\}\}\}?/, { token: 'delimiter.handlebars', switchTo: '@$S2.$S3', nextEmbedded: '$S3' } ], { include: 'handlebarsRoot' } ], handlebarsRoot: [ [/"[^"]*"/, 'string.handlebars'], [/[#/][^\s}]+/, 'keyword.helper.handlebars'], [/else\b/, 'keyword.helper.handlebars'], [/[\s]+/], [/[^}]/, 'variable.parameter.handlebars'] ] } }; });