|
- webpackJsonp([256],{
-
- /***/ 4075:
- /***/ (function(module, __webpack_exports__, __webpack_require__) {
-
- "use strict";
- Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "conf", function() { return conf; });
- /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "language", function() { return language; });
- /*---------------------------------------------------------------------------------------------
- * Copyright (c) Microsoft Corporation. All rights reserved.
- * Licensed under the MIT License. See License.txt in the project root for license information.
- *--------------------------------------------------------------------------------------------*/
-
- var TOKEN_HEADER_LEAD = 'keyword';
- var TOKEN_HEADER = 'keyword';
- var TOKEN_EXT_HEADER = 'keyword';
- var TOKEN_SEPARATOR = 'meta.separator';
- var TOKEN_QUOTE = 'comment';
- var TOKEN_LIST = 'keyword';
- var TOKEN_BLOCK = 'string';
- var TOKEN_BLOCK_CODE = 'variable.source';
- var DELIM_ASSIGN = 'delimiter.html';
- var ATTRIB_NAME = 'attribute.name.html';
- var ATTRIB_VALUE = 'string.html';
- function getTag(name) {
- return 'tag';
- }
- var conf = {
- comments: {
- blockComment: ['<!--', '-->',]
- },
- brackets: [
- ['{', '}'],
- ['[', ']'],
- ['(', ')']
- ],
- autoClosingPairs: [
- { open: '{', close: '}' },
- { open: '[', close: ']' },
- { open: '(', close: ')' },
- { open: '<', close: '>', notIn: ['string'] }
- ],
- surroundingPairs: [
- { open: '(', close: ')' },
- { open: '[', close: ']' },
- { open: '`', close: '`' },
- ],
- folding: {
- markers: {
- start: new RegExp("^\\s*<!--\\s*#?region\\b.*-->"),
- end: new RegExp("^\\s*<!--\\s*#?endregion\\b.*-->")
- }
- }
- };
- var language = {
- defaultToken: '',
- tokenPostfix: '.md',
- // escape codes
- control: /[\\`*_\[\]{}()#+\-\.!]/,
- noncontrol: /[^\\`*_\[\]{}()#+\-\.!]/,
- escapes: /\\(?:@control)/,
- // escape codes for javascript/CSS strings
- jsescapes: /\\(?:[btnfr\\"']|[0-7][0-7]?|[0-3][0-7]{2})/,
- // non matched elements
- empty: [
- 'area', 'base', 'basefont', 'br', 'col', 'frame',
- 'hr', 'img', 'input', 'isindex', 'link', 'meta', 'param'
- ],
- tokenizer: {
- root: [
- // headers (with #)
- [/^(\s{0,3})(#+)((?:[^\\#]|@escapes)+)((?:#+)?)/, ['white', TOKEN_HEADER_LEAD, TOKEN_HEADER, TOKEN_HEADER]],
- // headers (with =)
- [/^\s*(=+|\-+)\s*$/, TOKEN_EXT_HEADER],
- // headers (with ***)
- [/^\s*((\*[ ]?)+)\s*$/, TOKEN_SEPARATOR],
- // quote
- [/^\s*>+/, TOKEN_QUOTE],
- // list (starting with * or number)
- [/^\s*([\*\-+:]|\d+\.)\s/, TOKEN_LIST],
- // code block (4 spaces indent)
- [/^(\t|[ ]{4})[^ ].*$/, TOKEN_BLOCK],
- // code block (3 tilde)
- [/^\s*~~~\s*((?:\w|[\/\-#])+)?\s*$/, { token: TOKEN_BLOCK, next: '@codeblock' }],
- // github style code blocks (with backticks and language)
- [/^\s*```\s*((?:\w|[\/\-#])+)\s*$/, { token: TOKEN_BLOCK, next: '@codeblockgh', nextEmbedded: '$1' }],
- // github style code blocks (with backticks but no language)
- [/^\s*```\s*$/, { token: TOKEN_BLOCK, next: '@codeblock' }],
- // markup within lines
- { include: '@linecontent' },
- ],
- codeblock: [
- [/^\s*~~~\s*$/, { token: TOKEN_BLOCK, next: '@pop' }],
- [/^\s*```\s*$/, { token: TOKEN_BLOCK, next: '@pop' }],
- [/.*$/, TOKEN_BLOCK_CODE],
- ],
- // github style code blocks
- codeblockgh: [
- [/```\s*$/, { token: TOKEN_BLOCK_CODE, next: '@pop', nextEmbedded: '@pop' }],
- [/[^`]+/, TOKEN_BLOCK_CODE],
- ],
- linecontent: [
- // escapes
- [/&\w+;/, 'string.escape'],
- [/@escapes/, 'escape'],
- // various markup
- [/\b__([^\\_]|@escapes|_(?!_))+__\b/, 'strong'],
- [/\*\*([^\\*]|@escapes|\*(?!\*))+\*\*/, 'strong'],
- [/\b_[^_]+_\b/, 'emphasis'],
- [/\*([^\\*]|@escapes)+\*/, 'emphasis'],
- [/`([^\\`]|@escapes)+`/, 'variable'],
- // links
- [/\{[^}]+\}/, 'string.target'],
- [/(!?\[)((?:[^\]\\]|@escapes)*)(\]\([^\)]+\))/, ['string.link', '', 'string.link']],
- [/(!?\[)((?:[^\]\\]|@escapes)*)(\])/, 'string.link'],
- // or html
- { include: 'html' },
- ],
- // Note: it is tempting to rather switch to the real HTML mode instead of building our own here
- // but currently there is a limitation in Monarch that prevents us from doing it: The opening
- // '<' would start the HTML mode, however there is no way to jump 1 character back to let the
- // HTML mode also tokenize the opening angle bracket. Thus, even though we could jump to HTML,
- // we cannot correctly tokenize it in that mode yet.
- html: [
- // html tags
- [/<(\w+)\/>/, getTag('$1')],
- [/<(\w+)/, {
- cases: {
- '@empty': { token: getTag('$1'), next: '@tag.$1' },
- '@default': { token: getTag('$1'), next: '@tag.$1' }
- }
- }],
- [/<\/(\w+)\s*>/, { token: getTag('$1') }],
- [/<!--/, 'comment', '@comment']
- ],
- comment: [
- [/[^<\-]+/, 'comment.content'],
- [/-->/, 'comment', '@pop'],
- [/<!--/, 'comment.content.invalid'],
- [/[<\-]/, 'comment.content']
- ],
- // Almost full HTML tag matching, complete with embedded scripts & styles
- tag: [
- [/[ \t\r\n]+/, 'white'],
- [/(type)(\s*=\s*)(")([^"]+)(")/, [ATTRIB_NAME, DELIM_ASSIGN, ATTRIB_VALUE,
- { token: ATTRIB_VALUE, switchTo: '@tag.$S2.$4' },
- ATTRIB_VALUE]],
- [/(type)(\s*=\s*)(')([^']+)(')/, [ATTRIB_NAME, DELIM_ASSIGN, ATTRIB_VALUE,
- { token: ATTRIB_VALUE, switchTo: '@tag.$S2.$4' },
- ATTRIB_VALUE]],
- [/(\w+)(\s*=\s*)("[^"]*"|'[^']*')/, [ATTRIB_NAME, DELIM_ASSIGN, ATTRIB_VALUE]],
- [/\w+/, ATTRIB_NAME],
- [/\/>/, getTag('$S2'), '@pop'],
- [/>/, {
- cases: {
- '$S2==style': { token: getTag('$S2'), switchTo: 'embeddedStyle', nextEmbedded: 'text/css' },
- '$S2==script': {
- cases: {
- '$S3': { token: getTag('$S2'), switchTo: 'embeddedScript', nextEmbedded: '$S3' },
- '@default': { token: getTag('$S2'), switchTo: 'embeddedScript', nextEmbedded: 'text/javascript' }
- }
- },
- '@default': { token: getTag('$S2'), next: '@pop' }
- }
- }],
- ],
- embeddedStyle: [
- [/[^<]+/, ''],
- [/<\/style\s*>/, { token: '@rematch', next: '@pop', nextEmbedded: '@pop' }],
- [/</, '']
- ],
- embeddedScript: [
- [/[^<]+/, ''],
- [/<\/script\s*>/, { token: '@rematch', next: '@pop', nextEmbedded: '@pop' }],
- [/</, '']
- ],
- }
- };
-
-
- /***/ })
-
- });
|