3255 lines
		
	
	
		
			127 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
			
		
		
	
	
			3255 lines
		
	
	
		
			127 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
| webpackJsonp([197],{
 | |
| 
 | |
| /***/ 3230:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (immutable) */ __webpack_exports__["a"] = createScanner;
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| /**
 | |
|  * Creates a JSON scanner on the given text.
 | |
|  * If ignoreTrivia is set, whitespaces or comments are ignored.
 | |
|  */
 | |
| function createScanner(text, ignoreTrivia) {
 | |
|     if (ignoreTrivia === void 0) { ignoreTrivia = false; }
 | |
|     var pos = 0, len = text.length, value = '', tokenOffset = 0, token = 16 /* Unknown */, scanError = 0 /* None */;
 | |
|     function scanHexDigits(count, exact) {
 | |
|         var digits = 0;
 | |
|         var value = 0;
 | |
|         while (digits < count || !exact) {
 | |
|             var ch = text.charCodeAt(pos);
 | |
|             if (ch >= 48 /* _0 */ && ch <= 57 /* _9 */) {
 | |
|                 value = value * 16 + ch - 48 /* _0 */;
 | |
|             }
 | |
|             else if (ch >= 65 /* A */ && ch <= 70 /* F */) {
 | |
|                 value = value * 16 + ch - 65 /* A */ + 10;
 | |
|             }
 | |
|             else if (ch >= 97 /* a */ && ch <= 102 /* f */) {
 | |
|                 value = value * 16 + ch - 97 /* a */ + 10;
 | |
|             }
 | |
|             else {
 | |
|                 break;
 | |
|             }
 | |
|             pos++;
 | |
|             digits++;
 | |
|         }
 | |
|         if (digits < count) {
 | |
|             value = -1;
 | |
|         }
 | |
|         return value;
 | |
|     }
 | |
|     function setPosition(newPosition) {
 | |
|         pos = newPosition;
 | |
|         value = '';
 | |
|         tokenOffset = 0;
 | |
|         token = 16 /* Unknown */;
 | |
|         scanError = 0 /* None */;
 | |
|     }
 | |
|     function scanNumber() {
 | |
|         var start = pos;
 | |
|         if (text.charCodeAt(pos) === 48 /* _0 */) {
 | |
|             pos++;
 | |
|         }
 | |
|         else {
 | |
|             pos++;
 | |
|             while (pos < text.length && isDigit(text.charCodeAt(pos))) {
 | |
|                 pos++;
 | |
|             }
 | |
|         }
 | |
|         if (pos < text.length && text.charCodeAt(pos) === 46 /* dot */) {
 | |
|             pos++;
 | |
|             if (pos < text.length && isDigit(text.charCodeAt(pos))) {
 | |
|                 pos++;
 | |
|                 while (pos < text.length && isDigit(text.charCodeAt(pos))) {
 | |
|                     pos++;
 | |
|                 }
 | |
|             }
 | |
|             else {
 | |
|                 scanError = 3 /* UnexpectedEndOfNumber */;
 | |
|                 return text.substring(start, pos);
 | |
|             }
 | |
|         }
 | |
|         var end = pos;
 | |
|         if (pos < text.length && (text.charCodeAt(pos) === 69 /* E */ || text.charCodeAt(pos) === 101 /* e */)) {
 | |
|             pos++;
 | |
|             if (pos < text.length && text.charCodeAt(pos) === 43 /* plus */ || text.charCodeAt(pos) === 45 /* minus */) {
 | |
|                 pos++;
 | |
|             }
 | |
|             if (pos < text.length && isDigit(text.charCodeAt(pos))) {
 | |
|                 pos++;
 | |
|                 while (pos < text.length && isDigit(text.charCodeAt(pos))) {
 | |
|                     pos++;
 | |
|                 }
 | |
|                 end = pos;
 | |
|             }
 | |
|             else {
 | |
|                 scanError = 3 /* UnexpectedEndOfNumber */;
 | |
|             }
 | |
|         }
 | |
|         return text.substring(start, end);
 | |
|     }
 | |
|     function scanString() {
 | |
|         var result = '', start = pos;
 | |
|         while (true) {
 | |
|             if (pos >= len) {
 | |
|                 result += text.substring(start, pos);
 | |
|                 scanError = 2 /* UnexpectedEndOfString */;
 | |
|                 break;
 | |
|             }
 | |
|             var ch = text.charCodeAt(pos);
 | |
|             if (ch === 34 /* doubleQuote */) {
 | |
|                 result += text.substring(start, pos);
 | |
|                 pos++;
 | |
|                 break;
 | |
|             }
 | |
|             if (ch === 92 /* backslash */) {
 | |
|                 result += text.substring(start, pos);
 | |
|                 pos++;
 | |
|                 if (pos >= len) {
 | |
|                     scanError = 2 /* UnexpectedEndOfString */;
 | |
|                     break;
 | |
|                 }
 | |
|                 ch = text.charCodeAt(pos++);
 | |
|                 switch (ch) {
 | |
|                     case 34 /* doubleQuote */:
 | |
|                         result += '\"';
 | |
|                         break;
 | |
|                     case 92 /* backslash */:
 | |
|                         result += '\\';
 | |
|                         break;
 | |
|                     case 47 /* slash */:
 | |
|                         result += '/';
 | |
|                         break;
 | |
|                     case 98 /* b */:
 | |
|                         result += '\b';
 | |
|                         break;
 | |
|                     case 102 /* f */:
 | |
|                         result += '\f';
 | |
|                         break;
 | |
|                     case 110 /* n */:
 | |
|                         result += '\n';
 | |
|                         break;
 | |
|                     case 114 /* r */:
 | |
|                         result += '\r';
 | |
|                         break;
 | |
|                     case 116 /* t */:
 | |
|                         result += '\t';
 | |
|                         break;
 | |
|                     case 117 /* u */:
 | |
|                         var ch_1 = scanHexDigits(4, true);
 | |
|                         if (ch_1 >= 0) {
 | |
|                             result += String.fromCharCode(ch_1);
 | |
|                         }
 | |
|                         else {
 | |
|                             scanError = 4 /* InvalidUnicode */;
 | |
|                         }
 | |
|                         break;
 | |
|                     default:
 | |
|                         scanError = 5 /* InvalidEscapeCharacter */;
 | |
|                 }
 | |
|                 start = pos;
 | |
|                 continue;
 | |
|             }
 | |
|             if (ch >= 0 && ch <= 0x1f) {
 | |
|                 if (isLineBreak(ch)) {
 | |
|                     result += text.substring(start, pos);
 | |
|                     scanError = 2 /* UnexpectedEndOfString */;
 | |
|                     break;
 | |
|                 }
 | |
|                 else {
 | |
|                     scanError = 6 /* InvalidCharacter */;
 | |
|                     // mark as error but continue with string
 | |
|                 }
 | |
|             }
 | |
|             pos++;
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     function scanNext() {
 | |
|         value = '';
 | |
|         scanError = 0 /* None */;
 | |
|         tokenOffset = pos;
 | |
|         if (pos >= len) {
 | |
|             // at the end
 | |
|             tokenOffset = len;
 | |
|             return token = 17 /* EOF */;
 | |
|         }
 | |
|         var code = text.charCodeAt(pos);
 | |
|         // trivia: whitespace
 | |
|         if (isWhiteSpace(code)) {
 | |
|             do {
 | |
|                 pos++;
 | |
|                 value += String.fromCharCode(code);
 | |
|                 code = text.charCodeAt(pos);
 | |
|             } while (isWhiteSpace(code));
 | |
|             return token = 15 /* Trivia */;
 | |
|         }
 | |
|         // trivia: newlines
 | |
|         if (isLineBreak(code)) {
 | |
|             pos++;
 | |
|             value += String.fromCharCode(code);
 | |
|             if (code === 13 /* carriageReturn */ && text.charCodeAt(pos) === 10 /* lineFeed */) {
 | |
|                 pos++;
 | |
|                 value += '\n';
 | |
|             }
 | |
|             return token = 14 /* LineBreakTrivia */;
 | |
|         }
 | |
|         switch (code) {
 | |
|             // tokens: []{}:,
 | |
|             case 123 /* openBrace */:
 | |
|                 pos++;
 | |
|                 return token = 1 /* OpenBraceToken */;
 | |
|             case 125 /* closeBrace */:
 | |
|                 pos++;
 | |
|                 return token = 2 /* CloseBraceToken */;
 | |
|             case 91 /* openBracket */:
 | |
|                 pos++;
 | |
|                 return token = 3 /* OpenBracketToken */;
 | |
|             case 93 /* closeBracket */:
 | |
|                 pos++;
 | |
|                 return token = 4 /* CloseBracketToken */;
 | |
|             case 58 /* colon */:
 | |
|                 pos++;
 | |
|                 return token = 6 /* ColonToken */;
 | |
|             case 44 /* comma */:
 | |
|                 pos++;
 | |
|                 return token = 5 /* CommaToken */;
 | |
|             // strings
 | |
|             case 34 /* doubleQuote */:
 | |
|                 pos++;
 | |
|                 value = scanString();
 | |
|                 return token = 10 /* StringLiteral */;
 | |
|             // comments
 | |
|             case 47 /* slash */:
 | |
|                 var start = pos - 1;
 | |
|                 // Single-line comment
 | |
|                 if (text.charCodeAt(pos + 1) === 47 /* slash */) {
 | |
|                     pos += 2;
 | |
|                     while (pos < len) {
 | |
|                         if (isLineBreak(text.charCodeAt(pos))) {
 | |
|                             break;
 | |
|                         }
 | |
|                         pos++;
 | |
|                     }
 | |
|                     value = text.substring(start, pos);
 | |
|                     return token = 12 /* LineCommentTrivia */;
 | |
|                 }
 | |
|                 // Multi-line comment
 | |
|                 if (text.charCodeAt(pos + 1) === 42 /* asterisk */) {
 | |
|                     pos += 2;
 | |
|                     var commentClosed = false;
 | |
|                     while (pos < len) {
 | |
|                         var ch = text.charCodeAt(pos);
 | |
|                         if (ch === 42 /* asterisk */ && (pos + 1 < len) && text.charCodeAt(pos + 1) === 47 /* slash */) {
 | |
|                             pos += 2;
 | |
|                             commentClosed = true;
 | |
|                             break;
 | |
|                         }
 | |
|                         pos++;
 | |
|                     }
 | |
|                     if (!commentClosed) {
 | |
|                         pos++;
 | |
|                         scanError = 1 /* UnexpectedEndOfComment */;
 | |
|                     }
 | |
|                     value = text.substring(start, pos);
 | |
|                     return token = 13 /* BlockCommentTrivia */;
 | |
|                 }
 | |
|                 // just a single slash
 | |
|                 value += String.fromCharCode(code);
 | |
|                 pos++;
 | |
|                 return token = 16 /* Unknown */;
 | |
|             // numbers
 | |
|             case 45 /* minus */:
 | |
|                 value += String.fromCharCode(code);
 | |
|                 pos++;
 | |
|                 if (pos === len || !isDigit(text.charCodeAt(pos))) {
 | |
|                     return token = 16 /* Unknown */;
 | |
|                 }
 | |
|             // found a minus, followed by a number so
 | |
|             // we fall through to proceed with scanning
 | |
|             // numbers
 | |
|             case 48 /* _0 */:
 | |
|             case 49 /* _1 */:
 | |
|             case 50 /* _2 */:
 | |
|             case 51 /* _3 */:
 | |
|             case 52 /* _4 */:
 | |
|             case 53 /* _5 */:
 | |
|             case 54 /* _6 */:
 | |
|             case 55 /* _7 */:
 | |
|             case 56 /* _8 */:
 | |
|             case 57 /* _9 */:
 | |
|                 value += scanNumber();
 | |
|                 return token = 11 /* NumericLiteral */;
 | |
|             // literals and unknown symbols
 | |
|             default:
 | |
|                 // is a literal? Read the full word.
 | |
|                 while (pos < len && isUnknownContentCharacter(code)) {
 | |
|                     pos++;
 | |
|                     code = text.charCodeAt(pos);
 | |
|                 }
 | |
|                 if (tokenOffset !== pos) {
 | |
|                     value = text.substring(tokenOffset, pos);
 | |
|                     // keywords: true, false, null
 | |
|                     switch (value) {
 | |
|                         case 'true': return token = 8 /* TrueKeyword */;
 | |
|                         case 'false': return token = 9 /* FalseKeyword */;
 | |
|                         case 'null': return token = 7 /* NullKeyword */;
 | |
|                     }
 | |
|                     return token = 16 /* Unknown */;
 | |
|                 }
 | |
|                 // some
 | |
|                 value += String.fromCharCode(code);
 | |
|                 pos++;
 | |
|                 return token = 16 /* Unknown */;
 | |
|         }
 | |
|     }
 | |
|     function isUnknownContentCharacter(code) {
 | |
|         if (isWhiteSpace(code) || isLineBreak(code)) {
 | |
|             return false;
 | |
|         }
 | |
|         switch (code) {
 | |
|             case 125 /* closeBrace */:
 | |
|             case 93 /* closeBracket */:
 | |
|             case 123 /* openBrace */:
 | |
|             case 91 /* openBracket */:
 | |
|             case 34 /* doubleQuote */:
 | |
|             case 58 /* colon */:
 | |
|             case 44 /* comma */:
 | |
|                 return false;
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
|     function scanNextNonTrivia() {
 | |
|         var result;
 | |
|         do {
 | |
|             result = scanNext();
 | |
|         } while (result >= 12 /* LineCommentTrivia */ && result <= 15 /* Trivia */);
 | |
|         return result;
 | |
|     }
 | |
|     return {
 | |
|         setPosition: setPosition,
 | |
|         getPosition: function () { return pos; },
 | |
|         scan: ignoreTrivia ? scanNextNonTrivia : scanNext,
 | |
|         getToken: function () { return token; },
 | |
|         getTokenValue: function () { return value; },
 | |
|         getTokenOffset: function () { return tokenOffset; },
 | |
|         getTokenLength: function () { return pos - tokenOffset; },
 | |
|         getTokenError: function () { return scanError; }
 | |
|     };
 | |
| }
 | |
| function isWhiteSpace(ch) {
 | |
|     return ch === 32 /* space */ || ch === 9 /* tab */ || ch === 11 /* verticalTab */ || ch === 12 /* formFeed */ ||
 | |
|         ch === 160 /* nonBreakingSpace */ || ch === 5760 /* ogham */ || ch >= 8192 /* enQuad */ && ch <= 8203 /* zeroWidthSpace */ ||
 | |
|         ch === 8239 /* narrowNoBreakSpace */ || ch === 8287 /* mathematicalSpace */ || ch === 12288 /* ideographicSpace */ || ch === 65279 /* byteOrderMark */;
 | |
| }
 | |
| function isLineBreak(ch) {
 | |
|     return ch === 10 /* lineFeed */ || ch === 13 /* carriageReturn */ || ch === 8232 /* lineSeparator */ || ch === 8233 /* paragraphSeparator */;
 | |
| }
 | |
| function isDigit(ch) {
 | |
|     return ch >= 48 /* _0 */ && ch <= 57 /* _9 */;
 | |
| }
 | |
| //# sourceMappingURL=scanner.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 3571:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (immutable) */ __webpack_exports__["a"] = format;
 | |
| /* harmony export (immutable) */ __webpack_exports__["b"] = isEOL;
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__scanner_js__ = __webpack_require__(3230);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| function format(documentText, range, options) {
 | |
|     var initialIndentLevel;
 | |
|     var formatText;
 | |
|     var formatTextStart;
 | |
|     var rangeStart;
 | |
|     var rangeEnd;
 | |
|     if (range) {
 | |
|         rangeStart = range.offset;
 | |
|         rangeEnd = rangeStart + range.length;
 | |
|         formatTextStart = rangeStart;
 | |
|         while (formatTextStart > 0 && !isEOL(documentText, formatTextStart - 1)) {
 | |
|             formatTextStart--;
 | |
|         }
 | |
|         var endOffset = rangeEnd;
 | |
|         while (endOffset < documentText.length && !isEOL(documentText, endOffset)) {
 | |
|             endOffset++;
 | |
|         }
 | |
|         formatText = documentText.substring(formatTextStart, endOffset);
 | |
|         initialIndentLevel = computeIndentLevel(formatText, 0, options);
 | |
|     }
 | |
|     else {
 | |
|         formatText = documentText;
 | |
|         initialIndentLevel = 0;
 | |
|         formatTextStart = 0;
 | |
|         rangeStart = 0;
 | |
|         rangeEnd = documentText.length;
 | |
|     }
 | |
|     var eol = getEOL(options, documentText);
 | |
|     var lineBreak = false;
 | |
|     var indentLevel = 0;
 | |
|     var indentValue;
 | |
|     if (options.insertSpaces) {
 | |
|         indentValue = repeat(' ', options.tabSize || 4);
 | |
|     }
 | |
|     else {
 | |
|         indentValue = '\t';
 | |
|     }
 | |
|     var scanner = Object(__WEBPACK_IMPORTED_MODULE_0__scanner_js__["a" /* createScanner */])(formatText, false);
 | |
|     var hasError = false;
 | |
|     function newLineAndIndent() {
 | |
|         return eol + repeat(indentValue, initialIndentLevel + indentLevel);
 | |
|     }
 | |
|     function scanNext() {
 | |
|         var token = scanner.scan();
 | |
|         lineBreak = false;
 | |
|         while (token === 15 /* Trivia */ || token === 14 /* LineBreakTrivia */) {
 | |
|             lineBreak = lineBreak || (token === 14 /* LineBreakTrivia */);
 | |
|             token = scanner.scan();
 | |
|         }
 | |
|         hasError = token === 16 /* Unknown */ || scanner.getTokenError() !== 0 /* None */;
 | |
|         return token;
 | |
|     }
 | |
|     var editOperations = [];
 | |
|     function addEdit(text, startOffset, endOffset) {
 | |
|         if (!hasError && startOffset < rangeEnd && endOffset > rangeStart && documentText.substring(startOffset, endOffset) !== text) {
 | |
|             editOperations.push({ offset: startOffset, length: endOffset - startOffset, content: text });
 | |
|         }
 | |
|     }
 | |
|     var firstToken = scanNext();
 | |
|     if (firstToken !== 17 /* EOF */) {
 | |
|         var firstTokenStart = scanner.getTokenOffset() + formatTextStart;
 | |
|         var initialIndent = repeat(indentValue, initialIndentLevel);
 | |
|         addEdit(initialIndent, formatTextStart, firstTokenStart);
 | |
|     }
 | |
|     while (firstToken !== 17 /* EOF */) {
 | |
|         var firstTokenEnd = scanner.getTokenOffset() + scanner.getTokenLength() + formatTextStart;
 | |
|         var secondToken = scanNext();
 | |
|         var replaceContent = '';
 | |
|         while (!lineBreak && (secondToken === 12 /* LineCommentTrivia */ || secondToken === 13 /* BlockCommentTrivia */)) {
 | |
|             // comments on the same line: keep them on the same line, but ignore them otherwise
 | |
|             var commentTokenStart = scanner.getTokenOffset() + formatTextStart;
 | |
|             addEdit(' ', firstTokenEnd, commentTokenStart);
 | |
|             firstTokenEnd = scanner.getTokenOffset() + scanner.getTokenLength() + formatTextStart;
 | |
|             replaceContent = secondToken === 12 /* LineCommentTrivia */ ? newLineAndIndent() : '';
 | |
|             secondToken = scanNext();
 | |
|         }
 | |
|         if (secondToken === 2 /* CloseBraceToken */) {
 | |
|             if (firstToken !== 1 /* OpenBraceToken */) {
 | |
|                 indentLevel--;
 | |
|                 replaceContent = newLineAndIndent();
 | |
|             }
 | |
|         }
 | |
|         else if (secondToken === 4 /* CloseBracketToken */) {
 | |
|             if (firstToken !== 3 /* OpenBracketToken */) {
 | |
|                 indentLevel--;
 | |
|                 replaceContent = newLineAndIndent();
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             switch (firstToken) {
 | |
|                 case 3 /* OpenBracketToken */:
 | |
|                 case 1 /* OpenBraceToken */:
 | |
|                     indentLevel++;
 | |
|                     replaceContent = newLineAndIndent();
 | |
|                     break;
 | |
|                 case 5 /* CommaToken */:
 | |
|                 case 12 /* LineCommentTrivia */:
 | |
|                     replaceContent = newLineAndIndent();
 | |
|                     break;
 | |
|                 case 13 /* BlockCommentTrivia */:
 | |
|                     if (lineBreak) {
 | |
|                         replaceContent = newLineAndIndent();
 | |
|                     }
 | |
|                     else {
 | |
|                         // symbol following comment on the same line: keep on same line, separate with ' '
 | |
|                         replaceContent = ' ';
 | |
|                     }
 | |
|                     break;
 | |
|                 case 6 /* ColonToken */:
 | |
|                     replaceContent = ' ';
 | |
|                     break;
 | |
|                 case 10 /* StringLiteral */:
 | |
|                     if (secondToken === 6 /* ColonToken */) {
 | |
|                         replaceContent = '';
 | |
|                         break;
 | |
|                     }
 | |
|                 // fall through
 | |
|                 case 7 /* NullKeyword */:
 | |
|                 case 8 /* TrueKeyword */:
 | |
|                 case 9 /* FalseKeyword */:
 | |
|                 case 11 /* NumericLiteral */:
 | |
|                 case 2 /* CloseBraceToken */:
 | |
|                 case 4 /* CloseBracketToken */:
 | |
|                     if (secondToken === 12 /* LineCommentTrivia */ || secondToken === 13 /* BlockCommentTrivia */) {
 | |
|                         replaceContent = ' ';
 | |
|                     }
 | |
|                     else if (secondToken !== 5 /* CommaToken */ && secondToken !== 17 /* EOF */) {
 | |
|                         hasError = true;
 | |
|                     }
 | |
|                     break;
 | |
|                 case 16 /* Unknown */:
 | |
|                     hasError = true;
 | |
|                     break;
 | |
|             }
 | |
|             if (lineBreak && (secondToken === 12 /* LineCommentTrivia */ || secondToken === 13 /* BlockCommentTrivia */)) {
 | |
|                 replaceContent = newLineAndIndent();
 | |
|             }
 | |
|         }
 | |
|         var secondTokenStart = scanner.getTokenOffset() + formatTextStart;
 | |
|         addEdit(replaceContent, firstTokenEnd, secondTokenStart);
 | |
|         firstToken = secondToken;
 | |
|     }
 | |
|     return editOperations;
 | |
| }
 | |
| function repeat(s, count) {
 | |
|     var result = '';
 | |
|     for (var i = 0; i < count; i++) {
 | |
|         result += s;
 | |
|     }
 | |
|     return result;
 | |
| }
 | |
| function computeIndentLevel(content, offset, options) {
 | |
|     var i = 0;
 | |
|     var nChars = 0;
 | |
|     var tabSize = options.tabSize || 4;
 | |
|     while (i < content.length) {
 | |
|         var ch = content.charAt(i);
 | |
|         if (ch === ' ') {
 | |
|             nChars++;
 | |
|         }
 | |
|         else if (ch === '\t') {
 | |
|             nChars += tabSize;
 | |
|         }
 | |
|         else {
 | |
|             break;
 | |
|         }
 | |
|         i++;
 | |
|     }
 | |
|     return Math.floor(nChars / tabSize);
 | |
| }
 | |
| function getEOL(options, text) {
 | |
|     for (var i = 0; i < text.length; i++) {
 | |
|         var ch = text.charAt(i);
 | |
|         if (ch === '\r') {
 | |
|             if (i + 1 < text.length && text.charAt(i + 1) === '\n') {
 | |
|                 return '\r\n';
 | |
|             }
 | |
|             return '\r';
 | |
|         }
 | |
|         else if (ch === '\n') {
 | |
|             return '\n';
 | |
|         }
 | |
|     }
 | |
|     return (options && options.eol) || '\n';
 | |
| }
 | |
| function isEOL(text, offset) {
 | |
|     return '\r\n'.indexOf(text.charAt(offset)) !== -1;
 | |
| }
 | |
| //# sourceMappingURL=format.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 3572:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (immutable) */ __webpack_exports__["b"] = getLocation;
 | |
| /* harmony export (immutable) */ __webpack_exports__["d"] = parse;
 | |
| /* harmony export (immutable) */ __webpack_exports__["e"] = parseTree;
 | |
| /* harmony export (immutable) */ __webpack_exports__["a"] = findNodeAtLocation;
 | |
| /* harmony export (immutable) */ __webpack_exports__["c"] = getNodeValue;
 | |
| /* harmony export (immutable) */ __webpack_exports__["g"] = visit;
 | |
| /* harmony export (immutable) */ __webpack_exports__["f"] = stripComments;
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__scanner_js__ = __webpack_require__(3230);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * For a given offset, evaluate the location in the JSON document. Each segment in the location path is either a property name or an array index.
 | |
|  */
 | |
| function getLocation(text, position) {
 | |
|     var segments = []; // strings or numbers
 | |
|     var earlyReturnException = new Object();
 | |
|     var previousNode = void 0;
 | |
|     var previousNodeInst = {
 | |
|         value: {},
 | |
|         offset: 0,
 | |
|         length: 0,
 | |
|         type: 'object'
 | |
|     };
 | |
|     var isAtPropertyKey = false;
 | |
|     function setPreviousNode(value, offset, length, type) {
 | |
|         previousNodeInst.value = value;
 | |
|         previousNodeInst.offset = offset;
 | |
|         previousNodeInst.length = length;
 | |
|         previousNodeInst.type = type;
 | |
|         previousNodeInst.columnOffset = void 0;
 | |
|         previousNode = previousNodeInst;
 | |
|     }
 | |
|     try {
 | |
|         visit(text, {
 | |
|             onObjectBegin: function (offset, length) {
 | |
|                 if (position <= offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 previousNode = void 0;
 | |
|                 isAtPropertyKey = position > offset;
 | |
|                 segments.push(''); // push a placeholder (will be replaced)
 | |
|             },
 | |
|             onObjectProperty: function (name, offset, length) {
 | |
|                 if (position < offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 setPreviousNode(name, offset, length, 'property');
 | |
|                 segments[segments.length - 1] = name;
 | |
|                 if (position <= offset + length) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|             },
 | |
|             onObjectEnd: function (offset, length) {
 | |
|                 if (position <= offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 previousNode = void 0;
 | |
|                 segments.pop();
 | |
|             },
 | |
|             onArrayBegin: function (offset, length) {
 | |
|                 if (position <= offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 previousNode = void 0;
 | |
|                 segments.push(0);
 | |
|             },
 | |
|             onArrayEnd: function (offset, length) {
 | |
|                 if (position <= offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 previousNode = void 0;
 | |
|                 segments.pop();
 | |
|             },
 | |
|             onLiteralValue: function (value, offset, length) {
 | |
|                 if (position < offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 setPreviousNode(value, offset, length, getLiteralNodeType(value));
 | |
|                 if (position <= offset + length) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|             },
 | |
|             onSeparator: function (sep, offset, length) {
 | |
|                 if (position <= offset) {
 | |
|                     throw earlyReturnException;
 | |
|                 }
 | |
|                 if (sep === ':' && previousNode && previousNode.type === 'property') {
 | |
|                     previousNode.columnOffset = offset;
 | |
|                     isAtPropertyKey = false;
 | |
|                     previousNode = void 0;
 | |
|                 }
 | |
|                 else if (sep === ',') {
 | |
|                     var last = segments[segments.length - 1];
 | |
|                     if (typeof last === 'number') {
 | |
|                         segments[segments.length - 1] = last + 1;
 | |
|                     }
 | |
|                     else {
 | |
|                         isAtPropertyKey = true;
 | |
|                         segments[segments.length - 1] = '';
 | |
|                     }
 | |
|                     previousNode = void 0;
 | |
|                 }
 | |
|             }
 | |
|         });
 | |
|     }
 | |
|     catch (e) {
 | |
|         if (e !== earlyReturnException) {
 | |
|             throw e;
 | |
|         }
 | |
|     }
 | |
|     return {
 | |
|         path: segments,
 | |
|         previousNode: previousNode,
 | |
|         isAtPropertyKey: isAtPropertyKey,
 | |
|         matches: function (pattern) {
 | |
|             var k = 0;
 | |
|             for (var i = 0; k < pattern.length && i < segments.length; i++) {
 | |
|                 if (pattern[k] === segments[i] || pattern[k] === '*') {
 | |
|                     k++;
 | |
|                 }
 | |
|                 else if (pattern[k] !== '**') {
 | |
|                     return false;
 | |
|                 }
 | |
|             }
 | |
|             return k === pattern.length;
 | |
|         }
 | |
|     };
 | |
| }
 | |
| /**
 | |
|  * Parses the given text and returns the object the JSON content represents. On invalid input, the parser tries to be as fault tolerant as possible, but still return a result.
 | |
|  * Therefore always check the errors list to find out if the input was valid.
 | |
|  */
 | |
| function parse(text, errors, options) {
 | |
|     if (errors === void 0) { errors = []; }
 | |
|     var currentProperty = null;
 | |
|     var currentParent = [];
 | |
|     var previousParents = [];
 | |
|     function onValue(value) {
 | |
|         if (Array.isArray(currentParent)) {
 | |
|             currentParent.push(value);
 | |
|         }
 | |
|         else if (currentProperty) {
 | |
|             currentParent[currentProperty] = value;
 | |
|         }
 | |
|     }
 | |
|     var visitor = {
 | |
|         onObjectBegin: function () {
 | |
|             var object = {};
 | |
|             onValue(object);
 | |
|             previousParents.push(currentParent);
 | |
|             currentParent = object;
 | |
|             currentProperty = null;
 | |
|         },
 | |
|         onObjectProperty: function (name) {
 | |
|             currentProperty = name;
 | |
|         },
 | |
|         onObjectEnd: function () {
 | |
|             currentParent = previousParents.pop();
 | |
|         },
 | |
|         onArrayBegin: function () {
 | |
|             var array = [];
 | |
|             onValue(array);
 | |
|             previousParents.push(currentParent);
 | |
|             currentParent = array;
 | |
|             currentProperty = null;
 | |
|         },
 | |
|         onArrayEnd: function () {
 | |
|             currentParent = previousParents.pop();
 | |
|         },
 | |
|         onLiteralValue: onValue,
 | |
|         onError: function (error, offset, length) {
 | |
|             errors.push({ error: error, offset: offset, length: length });
 | |
|         }
 | |
|     };
 | |
|     visit(text, visitor, options);
 | |
|     return currentParent[0];
 | |
| }
 | |
| /**
 | |
|  * Parses the given text and returns a tree representation the JSON content. On invalid input, the parser tries to be as fault tolerant as possible, but still return a result.
 | |
|  */
 | |
| function parseTree(text, errors, options) {
 | |
|     if (errors === void 0) { errors = []; }
 | |
|     var currentParent = { type: 'array', offset: -1, length: -1, children: [] }; // artificial root
 | |
|     function ensurePropertyComplete(endOffset) {
 | |
|         if (currentParent.type === 'property') {
 | |
|             currentParent.length = endOffset - currentParent.offset;
 | |
|             currentParent = currentParent.parent;
 | |
|         }
 | |
|     }
 | |
|     function onValue(valueNode) {
 | |
|         currentParent.children.push(valueNode);
 | |
|         return valueNode;
 | |
|     }
 | |
|     var visitor = {
 | |
|         onObjectBegin: function (offset) {
 | |
|             currentParent = onValue({ type: 'object', offset: offset, length: -1, parent: currentParent, children: [] });
 | |
|         },
 | |
|         onObjectProperty: function (name, offset, length) {
 | |
|             currentParent = onValue({ type: 'property', offset: offset, length: -1, parent: currentParent, children: [] });
 | |
|             currentParent.children.push({ type: 'string', value: name, offset: offset, length: length, parent: currentParent });
 | |
|         },
 | |
|         onObjectEnd: function (offset, length) {
 | |
|             currentParent.length = offset + length - currentParent.offset;
 | |
|             currentParent = currentParent.parent;
 | |
|             ensurePropertyComplete(offset + length);
 | |
|         },
 | |
|         onArrayBegin: function (offset, length) {
 | |
|             currentParent = onValue({ type: 'array', offset: offset, length: -1, parent: currentParent, children: [] });
 | |
|         },
 | |
|         onArrayEnd: function (offset, length) {
 | |
|             currentParent.length = offset + length - currentParent.offset;
 | |
|             currentParent = currentParent.parent;
 | |
|             ensurePropertyComplete(offset + length);
 | |
|         },
 | |
|         onLiteralValue: function (value, offset, length) {
 | |
|             onValue({ type: getLiteralNodeType(value), offset: offset, length: length, parent: currentParent, value: value });
 | |
|             ensurePropertyComplete(offset + length);
 | |
|         },
 | |
|         onSeparator: function (sep, offset, length) {
 | |
|             if (currentParent.type === 'property') {
 | |
|                 if (sep === ':') {
 | |
|                     currentParent.columnOffset = offset;
 | |
|                 }
 | |
|                 else if (sep === ',') {
 | |
|                     ensurePropertyComplete(offset);
 | |
|                 }
 | |
|             }
 | |
|         },
 | |
|         onError: function (error, offset, length) {
 | |
|             errors.push({ error: error, offset: offset, length: length });
 | |
|         }
 | |
|     };
 | |
|     visit(text, visitor, options);
 | |
|     var result = currentParent.children[0];
 | |
|     if (result) {
 | |
|         delete result.parent;
 | |
|     }
 | |
|     return result;
 | |
| }
 | |
| /**
 | |
|  * Finds the node at the given path in a JSON DOM.
 | |
|  */
 | |
| function findNodeAtLocation(root, path) {
 | |
|     if (!root) {
 | |
|         return void 0;
 | |
|     }
 | |
|     var node = root;
 | |
|     for (var _i = 0, path_1 = path; _i < path_1.length; _i++) {
 | |
|         var segment = path_1[_i];
 | |
|         if (typeof segment === 'string') {
 | |
|             if (node.type !== 'object' || !Array.isArray(node.children)) {
 | |
|                 return void 0;
 | |
|             }
 | |
|             var found = false;
 | |
|             for (var _a = 0, _b = node.children; _a < _b.length; _a++) {
 | |
|                 var propertyNode = _b[_a];
 | |
|                 if (Array.isArray(propertyNode.children) && propertyNode.children[0].value === segment) {
 | |
|                     node = propertyNode.children[1];
 | |
|                     found = true;
 | |
|                     break;
 | |
|                 }
 | |
|             }
 | |
|             if (!found) {
 | |
|                 return void 0;
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             var index = segment;
 | |
|             if (node.type !== 'array' || index < 0 || !Array.isArray(node.children) || index >= node.children.length) {
 | |
|                 return void 0;
 | |
|             }
 | |
|             node = node.children[index];
 | |
|         }
 | |
|     }
 | |
|     return node;
 | |
| }
 | |
| /**
 | |
|  * Evaluates the JavaScript object of the given JSON DOM node
 | |
|  */
 | |
| function getNodeValue(node) {
 | |
|     if (node.type === 'array') {
 | |
|         return node.children.map(getNodeValue);
 | |
|     }
 | |
|     else if (node.type === 'object') {
 | |
|         var obj = Object.create(null);
 | |
|         for (var _i = 0, _a = node.children; _i < _a.length; _i++) {
 | |
|             var prop = _a[_i];
 | |
|             obj[prop.children[0].value] = getNodeValue(prop.children[1]);
 | |
|         }
 | |
|         return obj;
 | |
|     }
 | |
|     return node.value;
 | |
| }
 | |
| /**
 | |
|  * Parses the given text and invokes the visitor functions for each object, array and literal reached.
 | |
|  */
 | |
| function visit(text, visitor, options) {
 | |
|     var _scanner = Object(__WEBPACK_IMPORTED_MODULE_0__scanner_js__["a" /* createScanner */])(text, false);
 | |
|     function toNoArgVisit(visitFunction) {
 | |
|         return visitFunction ? function () { return visitFunction(_scanner.getTokenOffset(), _scanner.getTokenLength()); } : function () { return true; };
 | |
|     }
 | |
|     function toOneArgVisit(visitFunction) {
 | |
|         return visitFunction ? function (arg) { return visitFunction(arg, _scanner.getTokenOffset(), _scanner.getTokenLength()); } : function () { return true; };
 | |
|     }
 | |
|     var onObjectBegin = toNoArgVisit(visitor.onObjectBegin), onObjectProperty = toOneArgVisit(visitor.onObjectProperty), onObjectEnd = toNoArgVisit(visitor.onObjectEnd), onArrayBegin = toNoArgVisit(visitor.onArrayBegin), onArrayEnd = toNoArgVisit(visitor.onArrayEnd), onLiteralValue = toOneArgVisit(visitor.onLiteralValue), onSeparator = toOneArgVisit(visitor.onSeparator), onComment = toNoArgVisit(visitor.onComment), onError = toOneArgVisit(visitor.onError);
 | |
|     var disallowComments = options && options.disallowComments;
 | |
|     var allowTrailingComma = options && options.allowTrailingComma;
 | |
|     function scanNext() {
 | |
|         while (true) {
 | |
|             var token = _scanner.scan();
 | |
|             switch (_scanner.getTokenError()) {
 | |
|                 case 4 /* InvalidUnicode */:
 | |
|                     handleError(14 /* InvalidUnicode */);
 | |
|                     break;
 | |
|                 case 5 /* InvalidEscapeCharacter */:
 | |
|                     handleError(15 /* InvalidEscapeCharacter */);
 | |
|                     break;
 | |
|                 case 3 /* UnexpectedEndOfNumber */:
 | |
|                     handleError(13 /* UnexpectedEndOfNumber */);
 | |
|                     break;
 | |
|                 case 1 /* UnexpectedEndOfComment */:
 | |
|                     if (!disallowComments) {
 | |
|                         handleError(11 /* UnexpectedEndOfComment */);
 | |
|                     }
 | |
|                     break;
 | |
|                 case 2 /* UnexpectedEndOfString */:
 | |
|                     handleError(12 /* UnexpectedEndOfString */);
 | |
|                     break;
 | |
|                 case 6 /* InvalidCharacter */:
 | |
|                     handleError(16 /* InvalidCharacter */);
 | |
|                     break;
 | |
|             }
 | |
|             switch (token) {
 | |
|                 case 12 /* LineCommentTrivia */:
 | |
|                 case 13 /* BlockCommentTrivia */:
 | |
|                     if (disallowComments) {
 | |
|                         handleError(10 /* InvalidCommentToken */);
 | |
|                     }
 | |
|                     else {
 | |
|                         onComment();
 | |
|                     }
 | |
|                     break;
 | |
|                 case 16 /* Unknown */:
 | |
|                     handleError(1 /* InvalidSymbol */);
 | |
|                     break;
 | |
|                 case 15 /* Trivia */:
 | |
|                 case 14 /* LineBreakTrivia */:
 | |
|                     break;
 | |
|                 default:
 | |
|                     return token;
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     function handleError(error, skipUntilAfter, skipUntil) {
 | |
|         if (skipUntilAfter === void 0) { skipUntilAfter = []; }
 | |
|         if (skipUntil === void 0) { skipUntil = []; }
 | |
|         onError(error);
 | |
|         if (skipUntilAfter.length + skipUntil.length > 0) {
 | |
|             var token = _scanner.getToken();
 | |
|             while (token !== 17 /* EOF */) {
 | |
|                 if (skipUntilAfter.indexOf(token) !== -1) {
 | |
|                     scanNext();
 | |
|                     break;
 | |
|                 }
 | |
|                 else if (skipUntil.indexOf(token) !== -1) {
 | |
|                     break;
 | |
|                 }
 | |
|                 token = scanNext();
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     function parseString(isValue) {
 | |
|         var value = _scanner.getTokenValue();
 | |
|         if (isValue) {
 | |
|             onLiteralValue(value);
 | |
|         }
 | |
|         else {
 | |
|             onObjectProperty(value);
 | |
|         }
 | |
|         scanNext();
 | |
|         return true;
 | |
|     }
 | |
|     function parseLiteral() {
 | |
|         switch (_scanner.getToken()) {
 | |
|             case 11 /* NumericLiteral */:
 | |
|                 var value = 0;
 | |
|                 try {
 | |
|                     value = JSON.parse(_scanner.getTokenValue());
 | |
|                     if (typeof value !== 'number') {
 | |
|                         handleError(2 /* InvalidNumberFormat */);
 | |
|                         value = 0;
 | |
|                     }
 | |
|                 }
 | |
|                 catch (e) {
 | |
|                     handleError(2 /* InvalidNumberFormat */);
 | |
|                 }
 | |
|                 onLiteralValue(value);
 | |
|                 break;
 | |
|             case 7 /* NullKeyword */:
 | |
|                 onLiteralValue(null);
 | |
|                 break;
 | |
|             case 8 /* TrueKeyword */:
 | |
|                 onLiteralValue(true);
 | |
|                 break;
 | |
|             case 9 /* FalseKeyword */:
 | |
|                 onLiteralValue(false);
 | |
|                 break;
 | |
|             default:
 | |
|                 return false;
 | |
|         }
 | |
|         scanNext();
 | |
|         return true;
 | |
|     }
 | |
|     function parseProperty() {
 | |
|         if (_scanner.getToken() !== 10 /* StringLiteral */) {
 | |
|             handleError(3 /* PropertyNameExpected */, [], [2 /* CloseBraceToken */, 5 /* CommaToken */]);
 | |
|             return false;
 | |
|         }
 | |
|         parseString(false);
 | |
|         if (_scanner.getToken() === 6 /* ColonToken */) {
 | |
|             onSeparator(':');
 | |
|             scanNext(); // consume colon
 | |
|             if (!parseValue()) {
 | |
|                 handleError(4 /* ValueExpected */, [], [2 /* CloseBraceToken */, 5 /* CommaToken */]);
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             handleError(5 /* ColonExpected */, [], [2 /* CloseBraceToken */, 5 /* CommaToken */]);
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
|     function parseObject() {
 | |
|         onObjectBegin();
 | |
|         scanNext(); // consume open brace
 | |
|         var needsComma = false;
 | |
|         while (_scanner.getToken() !== 2 /* CloseBraceToken */ && _scanner.getToken() !== 17 /* EOF */) {
 | |
|             if (_scanner.getToken() === 5 /* CommaToken */) {
 | |
|                 if (!needsComma) {
 | |
|                     handleError(4 /* ValueExpected */, [], []);
 | |
|                 }
 | |
|                 onSeparator(',');
 | |
|                 scanNext(); // consume comma
 | |
|                 if (_scanner.getToken() === 2 /* CloseBraceToken */ && allowTrailingComma) {
 | |
|                     break;
 | |
|                 }
 | |
|             }
 | |
|             else if (needsComma) {
 | |
|                 handleError(6 /* CommaExpected */, [], []);
 | |
|             }
 | |
|             if (!parseProperty()) {
 | |
|                 handleError(4 /* ValueExpected */, [], [2 /* CloseBraceToken */, 5 /* CommaToken */]);
 | |
|             }
 | |
|             needsComma = true;
 | |
|         }
 | |
|         onObjectEnd();
 | |
|         if (_scanner.getToken() !== 2 /* CloseBraceToken */) {
 | |
|             handleError(7 /* CloseBraceExpected */, [2 /* CloseBraceToken */], []);
 | |
|         }
 | |
|         else {
 | |
|             scanNext(); // consume close brace
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
|     function parseArray() {
 | |
|         onArrayBegin();
 | |
|         scanNext(); // consume open bracket
 | |
|         var needsComma = false;
 | |
|         while (_scanner.getToken() !== 4 /* CloseBracketToken */ && _scanner.getToken() !== 17 /* EOF */) {
 | |
|             if (_scanner.getToken() === 5 /* CommaToken */) {
 | |
|                 if (!needsComma) {
 | |
|                     handleError(4 /* ValueExpected */, [], []);
 | |
|                 }
 | |
|                 onSeparator(',');
 | |
|                 scanNext(); // consume comma
 | |
|                 if (_scanner.getToken() === 4 /* CloseBracketToken */ && allowTrailingComma) {
 | |
|                     break;
 | |
|                 }
 | |
|             }
 | |
|             else if (needsComma) {
 | |
|                 handleError(6 /* CommaExpected */, [], []);
 | |
|             }
 | |
|             if (!parseValue()) {
 | |
|                 handleError(4 /* ValueExpected */, [], [4 /* CloseBracketToken */, 5 /* CommaToken */]);
 | |
|             }
 | |
|             needsComma = true;
 | |
|         }
 | |
|         onArrayEnd();
 | |
|         if (_scanner.getToken() !== 4 /* CloseBracketToken */) {
 | |
|             handleError(8 /* CloseBracketExpected */, [4 /* CloseBracketToken */], []);
 | |
|         }
 | |
|         else {
 | |
|             scanNext(); // consume close bracket
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
|     function parseValue() {
 | |
|         switch (_scanner.getToken()) {
 | |
|             case 3 /* OpenBracketToken */:
 | |
|                 return parseArray();
 | |
|             case 1 /* OpenBraceToken */:
 | |
|                 return parseObject();
 | |
|             case 10 /* StringLiteral */:
 | |
|                 return parseString(true);
 | |
|             default:
 | |
|                 return parseLiteral();
 | |
|         }
 | |
|     }
 | |
|     scanNext();
 | |
|     if (_scanner.getToken() === 17 /* EOF */) {
 | |
|         return true;
 | |
|     }
 | |
|     if (!parseValue()) {
 | |
|         handleError(4 /* ValueExpected */, [], []);
 | |
|         return false;
 | |
|     }
 | |
|     if (_scanner.getToken() !== 17 /* EOF */) {
 | |
|         handleError(9 /* EndOfFileExpected */, [], []);
 | |
|     }
 | |
|     return true;
 | |
| }
 | |
| /**
 | |
|  * Takes JSON with JavaScript-style comments and remove
 | |
|  * them. Optionally replaces every none-newline character
 | |
|  * of comments with a replaceCharacter
 | |
|  */
 | |
| function stripComments(text, replaceCh) {
 | |
|     var _scanner = Object(__WEBPACK_IMPORTED_MODULE_0__scanner_js__["a" /* createScanner */])(text), parts = [], kind, offset = 0, pos;
 | |
|     do {
 | |
|         pos = _scanner.getPosition();
 | |
|         kind = _scanner.scan();
 | |
|         switch (kind) {
 | |
|             case 12 /* LineCommentTrivia */:
 | |
|             case 13 /* BlockCommentTrivia */:
 | |
|             case 17 /* EOF */:
 | |
|                 if (offset !== pos) {
 | |
|                     parts.push(text.substring(offset, pos));
 | |
|                 }
 | |
|                 if (replaceCh !== void 0) {
 | |
|                     parts.push(_scanner.getTokenValue().replace(/[^\r\n]/g, replaceCh));
 | |
|                 }
 | |
|                 offset = _scanner.getPosition();
 | |
|                 break;
 | |
|         }
 | |
|     } while (kind !== 17 /* EOF */);
 | |
|     return parts.join('');
 | |
| }
 | |
| function getLiteralNodeType(value) {
 | |
|     switch (typeof value) {
 | |
|         case 'boolean': return 'boolean';
 | |
|         case 'number': return 'number';
 | |
|         case 'string': return 'string';
 | |
|         default: return 'null';
 | |
|     }
 | |
| }
 | |
| //# sourceMappingURL=parser.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4060:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
 | |
| /* harmony export (immutable) */ __webpack_exports__["setupMode"] = setupMode;
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__workerManager_js__ = __webpack_require__(4061);
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__ = __webpack_require__(4062);
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__tokenization_js__ = __webpack_require__(4064);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| function setupMode(defaults) {
 | |
|     var disposables = [];
 | |
|     var client = new __WEBPACK_IMPORTED_MODULE_0__workerManager_js__["a" /* WorkerManager */](defaults);
 | |
|     disposables.push(client);
 | |
|     var worker = function () {
 | |
|         var uris = [];
 | |
|         for (var _i = 0; _i < arguments.length; _i++) {
 | |
|             uris[_i] = arguments[_i];
 | |
|         }
 | |
|         return client.getLanguageServiceWorker.apply(client, uris);
 | |
|     };
 | |
|     var languageId = defaults.languageId;
 | |
|     disposables.push(monaco.languages.registerCompletionItemProvider(languageId, new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["a" /* CompletionAdapter */](worker)));
 | |
|     disposables.push(monaco.languages.registerHoverProvider(languageId, new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["g" /* HoverAdapter */](worker)));
 | |
|     disposables.push(monaco.languages.registerDocumentSymbolProvider(languageId, new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["f" /* DocumentSymbolAdapter */](worker)));
 | |
|     disposables.push(monaco.languages.registerDocumentFormattingEditProvider(languageId, new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["d" /* DocumentFormattingEditProvider */](worker)));
 | |
|     disposables.push(monaco.languages.registerDocumentRangeFormattingEditProvider(languageId, new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["e" /* DocumentRangeFormattingEditProvider */](worker)));
 | |
|     disposables.push(new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["b" /* DiagnosticsAdapter */](languageId, worker, defaults));
 | |
|     disposables.push(monaco.languages.setTokensProvider(languageId, Object(__WEBPACK_IMPORTED_MODULE_2__tokenization_js__["a" /* createTokenizationSupport */])(true)));
 | |
|     disposables.push(monaco.languages.setLanguageConfiguration(languageId, richEditConfiguration));
 | |
|     disposables.push(monaco.languages.registerColorProvider(languageId, new __WEBPACK_IMPORTED_MODULE_1__languageFeatures_js__["c" /* DocumentColorAdapter */](worker)));
 | |
| }
 | |
| var richEditConfiguration = {
 | |
|     wordPattern: /(-?\d*\.\d\w*)|([^\[\{\]\}\:\"\,\s]+)/g,
 | |
|     comments: {
 | |
|         lineComment: '//',
 | |
|         blockComment: ['/*', '*/']
 | |
|     },
 | |
|     brackets: [
 | |
|         ['{', '}'],
 | |
|         ['[', ']']
 | |
|     ],
 | |
|     autoClosingPairs: [
 | |
|         { open: '{', close: '}', notIn: ['string'] },
 | |
|         { open: '[', close: ']', notIn: ['string'] },
 | |
|         { open: '"', close: '"', notIn: ['string'] }
 | |
|     ]
 | |
| };
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4061:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return WorkerManager; });
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| var Promise = monaco.Promise;
 | |
| var STOP_WHEN_IDLE_FOR = 2 * 60 * 1000; // 2min
 | |
| var WorkerManager = /** @class */ (function () {
 | |
|     function WorkerManager(defaults) {
 | |
|         var _this = this;
 | |
|         this._defaults = defaults;
 | |
|         this._worker = null;
 | |
|         this._idleCheckInterval = setInterval(function () { return _this._checkIfIdle(); }, 30 * 1000);
 | |
|         this._lastUsedTime = 0;
 | |
|         this._configChangeListener = this._defaults.onDidChange(function () { return _this._stopWorker(); });
 | |
|     }
 | |
|     WorkerManager.prototype._stopWorker = function () {
 | |
|         if (this._worker) {
 | |
|             this._worker.dispose();
 | |
|             this._worker = null;
 | |
|         }
 | |
|         this._client = null;
 | |
|     };
 | |
|     WorkerManager.prototype.dispose = function () {
 | |
|         clearInterval(this._idleCheckInterval);
 | |
|         this._configChangeListener.dispose();
 | |
|         this._stopWorker();
 | |
|     };
 | |
|     WorkerManager.prototype._checkIfIdle = function () {
 | |
|         if (!this._worker) {
 | |
|             return;
 | |
|         }
 | |
|         var timePassedSinceLastUsed = Date.now() - this._lastUsedTime;
 | |
|         if (timePassedSinceLastUsed > STOP_WHEN_IDLE_FOR) {
 | |
|             this._stopWorker();
 | |
|         }
 | |
|     };
 | |
|     WorkerManager.prototype._getClient = function () {
 | |
|         this._lastUsedTime = Date.now();
 | |
|         if (!this._client) {
 | |
|             this._worker = monaco.editor.createWebWorker({
 | |
|                 // module that exports the create() method and returns a `JSONWorker` instance
 | |
|                 moduleId: 'vs/language/json/jsonWorker',
 | |
|                 label: this._defaults.languageId,
 | |
|                 // passed in to the create() method
 | |
|                 createData: {
 | |
|                     languageSettings: this._defaults.diagnosticsOptions,
 | |
|                     languageId: this._defaults.languageId
 | |
|                 }
 | |
|             });
 | |
|             this._client = this._worker.getProxy();
 | |
|         }
 | |
|         return this._client;
 | |
|     };
 | |
|     WorkerManager.prototype.getLanguageServiceWorker = function () {
 | |
|         var _this = this;
 | |
|         var resources = [];
 | |
|         for (var _i = 0; _i < arguments.length; _i++) {
 | |
|             resources[_i] = arguments[_i];
 | |
|         }
 | |
|         var _client;
 | |
|         return toShallowCancelPromise(this._getClient().then(function (client) {
 | |
|             _client = client;
 | |
|         }).then(function (_) {
 | |
|             return _this._worker.withSyncedResources(resources);
 | |
|         }).then(function (_) { return _client; }));
 | |
|     };
 | |
|     return WorkerManager;
 | |
| }());
 | |
| 
 | |
| function toShallowCancelPromise(p) {
 | |
|     var completeCallback;
 | |
|     var errorCallback;
 | |
|     var r = new Promise(function (c, e) {
 | |
|         completeCallback = c;
 | |
|         errorCallback = e;
 | |
|     }, function () { });
 | |
|     p.then(completeCallback, errorCallback);
 | |
|     return r;
 | |
| }
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4062:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return DiagnosticsAdapter; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return CompletionAdapter; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "g", function() { return HoverAdapter; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return DocumentSymbolAdapter; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return DocumentFormattingEditProvider; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "e", function() { return DocumentRangeFormattingEditProvider; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return DocumentColorAdapter; });
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__ = __webpack_require__(4063);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| var Uri = monaco.Uri;
 | |
| var Range = monaco.Range;
 | |
| // --- diagnostics --- ---
 | |
| var DiagnosticsAdapter = /** @class */ (function () {
 | |
|     function DiagnosticsAdapter(_languageId, _worker, defaults) {
 | |
|         var _this = this;
 | |
|         this._languageId = _languageId;
 | |
|         this._worker = _worker;
 | |
|         this._disposables = [];
 | |
|         this._listener = Object.create(null);
 | |
|         var onModelAdd = function (model) {
 | |
|             var modeId = model.getModeId();
 | |
|             if (modeId !== _this._languageId) {
 | |
|                 return;
 | |
|             }
 | |
|             var handle;
 | |
|             _this._listener[model.uri.toString()] = model.onDidChangeContent(function () {
 | |
|                 clearTimeout(handle);
 | |
|                 handle = setTimeout(function () { return _this._doValidate(model.uri, modeId); }, 500);
 | |
|             });
 | |
|             _this._doValidate(model.uri, modeId);
 | |
|         };
 | |
|         var onModelRemoved = function (model) {
 | |
|             monaco.editor.setModelMarkers(model, _this._languageId, []);
 | |
|             var uriStr = model.uri.toString();
 | |
|             var listener = _this._listener[uriStr];
 | |
|             if (listener) {
 | |
|                 listener.dispose();
 | |
|                 delete _this._listener[uriStr];
 | |
|             }
 | |
|         };
 | |
|         this._disposables.push(monaco.editor.onDidCreateModel(onModelAdd));
 | |
|         this._disposables.push(monaco.editor.onWillDisposeModel(function (model) {
 | |
|             onModelRemoved(model);
 | |
|             _this._resetSchema(model.uri);
 | |
|         }));
 | |
|         this._disposables.push(monaco.editor.onDidChangeModelLanguage(function (event) {
 | |
|             onModelRemoved(event.model);
 | |
|             onModelAdd(event.model);
 | |
|             _this._resetSchema(event.model.uri);
 | |
|         }));
 | |
|         this._disposables.push(defaults.onDidChange(function (_) {
 | |
|             monaco.editor.getModels().forEach(function (model) {
 | |
|                 if (model.getModeId() === _this._languageId) {
 | |
|                     onModelRemoved(model);
 | |
|                     onModelAdd(model);
 | |
|                 }
 | |
|             });
 | |
|         }));
 | |
|         this._disposables.push({
 | |
|             dispose: function () {
 | |
|                 monaco.editor.getModels().forEach(onModelRemoved);
 | |
|                 for (var key in _this._listener) {
 | |
|                     _this._listener[key].dispose();
 | |
|                 }
 | |
|             }
 | |
|         });
 | |
|         monaco.editor.getModels().forEach(onModelAdd);
 | |
|     }
 | |
|     DiagnosticsAdapter.prototype.dispose = function () {
 | |
|         this._disposables.forEach(function (d) { return d && d.dispose(); });
 | |
|         this._disposables = [];
 | |
|     };
 | |
|     DiagnosticsAdapter.prototype._resetSchema = function (resource) {
 | |
|         this._worker().then(function (worker) {
 | |
|             worker.resetSchema(resource.toString());
 | |
|         });
 | |
|     };
 | |
|     DiagnosticsAdapter.prototype._doValidate = function (resource, languageId) {
 | |
|         this._worker(resource).then(function (worker) {
 | |
|             return worker.doValidation(resource.toString()).then(function (diagnostics) {
 | |
|                 var markers = diagnostics.map(function (d) { return toDiagnostics(resource, d); });
 | |
|                 var model = monaco.editor.getModel(resource);
 | |
|                 if (model.getModeId() === languageId) {
 | |
|                     monaco.editor.setModelMarkers(model, languageId, markers);
 | |
|                 }
 | |
|             });
 | |
|         }).then(undefined, function (err) {
 | |
|             console.error(err);
 | |
|         });
 | |
|     };
 | |
|     return DiagnosticsAdapter;
 | |
| }());
 | |
| 
 | |
| function toSeverity(lsSeverity) {
 | |
|     switch (lsSeverity) {
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["b" /* DiagnosticSeverity */].Error: return monaco.MarkerSeverity.Error;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["b" /* DiagnosticSeverity */].Warning: return monaco.MarkerSeverity.Warning;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["b" /* DiagnosticSeverity */].Information: return monaco.MarkerSeverity.Info;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["b" /* DiagnosticSeverity */].Hint: return monaco.MarkerSeverity.Hint;
 | |
|         default:
 | |
|             return monaco.MarkerSeverity.Info;
 | |
|     }
 | |
| }
 | |
| function toDiagnostics(resource, diag) {
 | |
|     var code = typeof diag.code === 'number' ? String(diag.code) : diag.code;
 | |
|     return {
 | |
|         severity: toSeverity(diag.severity),
 | |
|         startLineNumber: diag.range.start.line + 1,
 | |
|         startColumn: diag.range.start.character + 1,
 | |
|         endLineNumber: diag.range.end.line + 1,
 | |
|         endColumn: diag.range.end.character + 1,
 | |
|         message: diag.message,
 | |
|         code: code,
 | |
|         source: diag.source
 | |
|     };
 | |
| }
 | |
| // --- completion ------
 | |
| function fromPosition(position) {
 | |
|     if (!position) {
 | |
|         return void 0;
 | |
|     }
 | |
|     return { character: position.column - 1, line: position.lineNumber - 1 };
 | |
| }
 | |
| function fromRange(range) {
 | |
|     if (!range) {
 | |
|         return void 0;
 | |
|     }
 | |
|     return { start: { line: range.startLineNumber - 1, character: range.startColumn - 1 }, end: { line: range.endLineNumber - 1, character: range.endColumn - 1 } };
 | |
| }
 | |
| function toRange(range) {
 | |
|     if (!range) {
 | |
|         return void 0;
 | |
|     }
 | |
|     return new Range(range.start.line + 1, range.start.character + 1, range.end.line + 1, range.end.character + 1);
 | |
| }
 | |
| function toCompletionItemKind(kind) {
 | |
|     var mItemKind = monaco.languages.CompletionItemKind;
 | |
|     switch (kind) {
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Text: return mItemKind.Text;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Method: return mItemKind.Method;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Function: return mItemKind.Function;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Constructor: return mItemKind.Constructor;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Field: return mItemKind.Field;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Variable: return mItemKind.Variable;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Class: return mItemKind.Class;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Interface: return mItemKind.Interface;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Module: return mItemKind.Module;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Property: return mItemKind.Property;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Unit: return mItemKind.Unit;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Value: return mItemKind.Value;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Enum: return mItemKind.Enum;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Keyword: return mItemKind.Keyword;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Snippet: return mItemKind.Snippet;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Color: return mItemKind.Color;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].File: return mItemKind.File;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Reference: return mItemKind.Reference;
 | |
|     }
 | |
|     return mItemKind.Property;
 | |
| }
 | |
| function fromCompletionItemKind(kind) {
 | |
|     var mItemKind = monaco.languages.CompletionItemKind;
 | |
|     switch (kind) {
 | |
|         case mItemKind.Text: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Text;
 | |
|         case mItemKind.Method: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Method;
 | |
|         case mItemKind.Function: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Function;
 | |
|         case mItemKind.Constructor: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Constructor;
 | |
|         case mItemKind.Field: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Field;
 | |
|         case mItemKind.Variable: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Variable;
 | |
|         case mItemKind.Class: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Class;
 | |
|         case mItemKind.Interface: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Interface;
 | |
|         case mItemKind.Module: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Module;
 | |
|         case mItemKind.Property: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Property;
 | |
|         case mItemKind.Unit: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Unit;
 | |
|         case mItemKind.Value: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Value;
 | |
|         case mItemKind.Enum: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Enum;
 | |
|         case mItemKind.Keyword: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Keyword;
 | |
|         case mItemKind.Snippet: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Snippet;
 | |
|         case mItemKind.Color: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Color;
 | |
|         case mItemKind.File: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].File;
 | |
|         case mItemKind.Reference: return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Reference;
 | |
|     }
 | |
|     return __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["a" /* CompletionItemKind */].Property;
 | |
| }
 | |
| function toTextEdit(textEdit) {
 | |
|     if (!textEdit) {
 | |
|         return void 0;
 | |
|     }
 | |
|     return {
 | |
|         range: toRange(textEdit.range),
 | |
|         text: textEdit.newText
 | |
|     };
 | |
| }
 | |
| function toCompletionItem(entry) {
 | |
|     return {
 | |
|         label: entry.label,
 | |
|         insertText: entry.insertText,
 | |
|         sortText: entry.sortText,
 | |
|         filterText: entry.filterText,
 | |
|         documentation: entry.documentation,
 | |
|         detail: entry.detail,
 | |
|         kind: toCompletionItemKind(entry.kind),
 | |
|         textEdit: toTextEdit(entry.textEdit),
 | |
|         data: entry.data
 | |
|     };
 | |
| }
 | |
| function fromMarkdownString(entry) {
 | |
|     return {
 | |
|         kind: (typeof entry === 'string' ? __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["d" /* MarkupKind */].PlainText : __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["d" /* MarkupKind */].Markdown),
 | |
|         value: (typeof entry === 'string' ? entry : entry.value)
 | |
|     };
 | |
| }
 | |
| function fromCompletionItem(entry) {
 | |
|     var item = {
 | |
|         label: entry.label,
 | |
|         sortText: entry.sortText,
 | |
|         filterText: entry.filterText,
 | |
|         documentation: fromMarkdownString(entry.documentation),
 | |
|         detail: entry.detail,
 | |
|         kind: fromCompletionItemKind(entry.kind),
 | |
|         data: entry.data
 | |
|     };
 | |
|     if (typeof entry.insertText === 'object' && typeof entry.insertText.value === 'string') {
 | |
|         item.insertText = entry.insertText.value;
 | |
|         item.insertTextFormat = __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["c" /* InsertTextFormat */].Snippet;
 | |
|     }
 | |
|     else {
 | |
|         item.insertText = entry.insertText;
 | |
|     }
 | |
|     if (entry.range) {
 | |
|         item.textEdit = __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["f" /* TextEdit */].replace(fromRange(entry.range), item.insertText);
 | |
|     }
 | |
|     return item;
 | |
| }
 | |
| var CompletionAdapter = /** @class */ (function () {
 | |
|     function CompletionAdapter(_worker) {
 | |
|         this._worker = _worker;
 | |
|     }
 | |
|     Object.defineProperty(CompletionAdapter.prototype, "triggerCharacters", {
 | |
|         get: function () {
 | |
|             return [' ', ':'];
 | |
|         },
 | |
|         enumerable: true,
 | |
|         configurable: true
 | |
|     });
 | |
|     CompletionAdapter.prototype.provideCompletionItems = function (model, position, token) {
 | |
|         var wordInfo = model.getWordUntilPosition(position);
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) {
 | |
|             return worker.doComplete(resource.toString(), fromPosition(position));
 | |
|         }).then(function (info) {
 | |
|             if (!info) {
 | |
|                 return;
 | |
|             }
 | |
|             var items = info.items.map(function (entry) {
 | |
|                 var item = {
 | |
|                     label: entry.label,
 | |
|                     insertText: entry.insertText,
 | |
|                     sortText: entry.sortText,
 | |
|                     filterText: entry.filterText,
 | |
|                     documentation: entry.documentation,
 | |
|                     detail: entry.detail,
 | |
|                     kind: toCompletionItemKind(entry.kind),
 | |
|                 };
 | |
|                 if (entry.textEdit) {
 | |
|                     item.range = toRange(entry.textEdit.range);
 | |
|                     item.insertText = entry.textEdit.newText;
 | |
|                 }
 | |
|                 if (entry.insertTextFormat === __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["c" /* InsertTextFormat */].Snippet) {
 | |
|                     item.insertText = { value: item.insertText };
 | |
|                 }
 | |
|                 return item;
 | |
|             });
 | |
|             return {
 | |
|                 isIncomplete: info.isIncomplete,
 | |
|                 items: items
 | |
|             };
 | |
|         }));
 | |
|     };
 | |
|     return CompletionAdapter;
 | |
| }());
 | |
| 
 | |
| function isMarkupContent(thing) {
 | |
|     return thing && typeof thing === 'object' && typeof thing.kind === 'string';
 | |
| }
 | |
| function toMarkdownString(entry) {
 | |
|     if (typeof entry === 'string') {
 | |
|         return {
 | |
|             value: entry
 | |
|         };
 | |
|     }
 | |
|     if (isMarkupContent(entry)) {
 | |
|         if (entry.kind === 'plaintext') {
 | |
|             return {
 | |
|                 value: entry.value.replace(/[\\`*_{}[\]()#+\-.!]/g, '\\$&')
 | |
|             };
 | |
|         }
 | |
|         return {
 | |
|             value: entry.value
 | |
|         };
 | |
|     }
 | |
|     return { value: '```' + entry.language + '\n' + entry.value + '\n```\n' };
 | |
| }
 | |
| function toMarkedStringArray(contents) {
 | |
|     if (!contents) {
 | |
|         return void 0;
 | |
|     }
 | |
|     if (Array.isArray(contents)) {
 | |
|         return contents.map(toMarkdownString);
 | |
|     }
 | |
|     return [toMarkdownString(contents)];
 | |
| }
 | |
| // --- hover ------
 | |
| var HoverAdapter = /** @class */ (function () {
 | |
|     function HoverAdapter(_worker) {
 | |
|         this._worker = _worker;
 | |
|     }
 | |
|     HoverAdapter.prototype.provideHover = function (model, position, token) {
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) {
 | |
|             return worker.doHover(resource.toString(), fromPosition(position));
 | |
|         }).then(function (info) {
 | |
|             if (!info) {
 | |
|                 return;
 | |
|             }
 | |
|             return {
 | |
|                 range: toRange(info.range),
 | |
|                 contents: toMarkedStringArray(info.contents)
 | |
|             };
 | |
|         }));
 | |
|     };
 | |
|     return HoverAdapter;
 | |
| }());
 | |
| 
 | |
| // --- definition ------
 | |
| function toLocation(location) {
 | |
|     return {
 | |
|         uri: Uri.parse(location.uri),
 | |
|         range: toRange(location.range)
 | |
|     };
 | |
| }
 | |
| // --- document symbols ------
 | |
| function toSymbolKind(kind) {
 | |
|     var mKind = monaco.languages.SymbolKind;
 | |
|     switch (kind) {
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].File: return mKind.Array;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Module: return mKind.Module;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Namespace: return mKind.Namespace;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Package: return mKind.Package;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Class: return mKind.Class;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Method: return mKind.Method;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Property: return mKind.Property;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Field: return mKind.Field;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Constructor: return mKind.Constructor;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Enum: return mKind.Enum;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Interface: return mKind.Interface;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Function: return mKind.Function;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Variable: return mKind.Variable;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Constant: return mKind.Constant;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].String: return mKind.String;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Number: return mKind.Number;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Boolean: return mKind.Boolean;
 | |
|         case __WEBPACK_IMPORTED_MODULE_0__deps_vscode_languageserver_types_main_js__["e" /* SymbolKind */].Array: return mKind.Array;
 | |
|     }
 | |
|     return mKind.Function;
 | |
| }
 | |
| var DocumentSymbolAdapter = /** @class */ (function () {
 | |
|     function DocumentSymbolAdapter(_worker) {
 | |
|         this._worker = _worker;
 | |
|     }
 | |
|     DocumentSymbolAdapter.prototype.provideDocumentSymbols = function (model, token) {
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) { return worker.findDocumentSymbols(resource.toString()); }).then(function (items) {
 | |
|             if (!items) {
 | |
|                 return;
 | |
|             }
 | |
|             return items.map(function (item) { return ({
 | |
|                 name: item.name,
 | |
|                 containerName: item.containerName,
 | |
|                 kind: toSymbolKind(item.kind),
 | |
|                 location: toLocation(item.location)
 | |
|             }); });
 | |
|         }));
 | |
|     };
 | |
|     return DocumentSymbolAdapter;
 | |
| }());
 | |
| 
 | |
| function fromFormattingOptions(options) {
 | |
|     return {
 | |
|         tabSize: options.tabSize,
 | |
|         insertSpaces: options.insertSpaces
 | |
|     };
 | |
| }
 | |
| var DocumentFormattingEditProvider = /** @class */ (function () {
 | |
|     function DocumentFormattingEditProvider(_worker) {
 | |
|         this._worker = _worker;
 | |
|     }
 | |
|     DocumentFormattingEditProvider.prototype.provideDocumentFormattingEdits = function (model, options, token) {
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) {
 | |
|             return worker.format(resource.toString(), null, fromFormattingOptions(options)).then(function (edits) {
 | |
|                 if (!edits || edits.length === 0) {
 | |
|                     return;
 | |
|                 }
 | |
|                 return edits.map(toTextEdit);
 | |
|             });
 | |
|         }));
 | |
|     };
 | |
|     return DocumentFormattingEditProvider;
 | |
| }());
 | |
| 
 | |
| var DocumentRangeFormattingEditProvider = /** @class */ (function () {
 | |
|     function DocumentRangeFormattingEditProvider(_worker) {
 | |
|         this._worker = _worker;
 | |
|     }
 | |
|     DocumentRangeFormattingEditProvider.prototype.provideDocumentRangeFormattingEdits = function (model, range, options, token) {
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) {
 | |
|             return worker.format(resource.toString(), fromRange(range), fromFormattingOptions(options)).then(function (edits) {
 | |
|                 if (!edits || edits.length === 0) {
 | |
|                     return;
 | |
|                 }
 | |
|                 return edits.map(toTextEdit);
 | |
|             });
 | |
|         }));
 | |
|     };
 | |
|     return DocumentRangeFormattingEditProvider;
 | |
| }());
 | |
| 
 | |
| var DocumentColorAdapter = /** @class */ (function () {
 | |
|     function DocumentColorAdapter(_worker) {
 | |
|         this._worker = _worker;
 | |
|     }
 | |
|     DocumentColorAdapter.prototype.provideDocumentColors = function (model, token) {
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) { return worker.findDocumentColors(resource.toString()); }).then(function (infos) {
 | |
|             if (!infos) {
 | |
|                 return;
 | |
|             }
 | |
|             return infos.map(function (item) { return ({
 | |
|                 color: item.color,
 | |
|                 range: toRange(item.range)
 | |
|             }); });
 | |
|         }));
 | |
|     };
 | |
|     DocumentColorAdapter.prototype.provideColorPresentations = function (model, info, token) {
 | |
|         var resource = model.uri;
 | |
|         return wireCancellationToken(token, this._worker(resource).then(function (worker) { return worker.getColorPresentations(resource.toString(), info.color, fromRange(info.range)); }).then(function (presentations) {
 | |
|             if (!presentations) {
 | |
|                 return;
 | |
|             }
 | |
|             return presentations.map(function (presentation) {
 | |
|                 var item = {
 | |
|                     label: presentation.label,
 | |
|                 };
 | |
|                 if (presentation.textEdit) {
 | |
|                     item.textEdit = toTextEdit(presentation.textEdit);
 | |
|                 }
 | |
|                 if (presentation.additionalTextEdits) {
 | |
|                     item.additionalTextEdits = presentation.additionalTextEdits.map(toTextEdit);
 | |
|                 }
 | |
|                 return item;
 | |
|             });
 | |
|         }));
 | |
|     };
 | |
|     return DocumentColorAdapter;
 | |
| }());
 | |
| 
 | |
| /**
 | |
|  * Hook a cancellation token to a WinJS Promise
 | |
|  */
 | |
| function wireCancellationToken(token, promise) {
 | |
|     if (promise.cancel) {
 | |
|         token.onCancellationRequested(function () { return promise.cancel(); });
 | |
|     }
 | |
|     return promise;
 | |
| }
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4063:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* unused harmony export Position */
 | |
| /* unused harmony export Range */
 | |
| /* unused harmony export Location */
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return DiagnosticSeverity; });
 | |
| /* unused harmony export Diagnostic */
 | |
| /* unused harmony export Command */
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return TextEdit; });
 | |
| /* unused harmony export TextDocumentEdit */
 | |
| /* unused harmony export WorkspaceChange */
 | |
| /* unused harmony export TextDocumentIdentifier */
 | |
| /* unused harmony export VersionedTextDocumentIdentifier */
 | |
| /* unused harmony export TextDocumentItem */
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return MarkupKind; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return CompletionItemKind; });
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return InsertTextFormat; });
 | |
| /* unused harmony export CompletionItem */
 | |
| /* unused harmony export CompletionList */
 | |
| /* unused harmony export MarkedString */
 | |
| /* unused harmony export ParameterInformation */
 | |
| /* unused harmony export SignatureInformation */
 | |
| /* unused harmony export DocumentHighlightKind */
 | |
| /* unused harmony export DocumentHighlight */
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "e", function() { return SymbolKind; });
 | |
| /* unused harmony export SymbolInformation */
 | |
| /* unused harmony export CodeActionContext */
 | |
| /* unused harmony export CodeLens */
 | |
| /* unused harmony export FormattingOptions */
 | |
| /* unused harmony export DocumentLink */
 | |
| /* unused harmony export EOL */
 | |
| /* unused harmony export TextDocument */
 | |
| /* unused harmony export TextDocumentSaveReason */
 | |
| /* --------------------------------------------------------------------------------------------
 | |
|  * Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  * Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  * ------------------------------------------------------------------------------------------ */
 | |
| 
 | |
| /**
 | |
|  * The Position namespace provides helper functions to work with
 | |
|  * [Position](#Position) literals.
 | |
|  */
 | |
| var Position;
 | |
| (function (Position) {
 | |
|     /**
 | |
|      * Creates a new Position literal from the given line and character.
 | |
|      * @param line The position's line.
 | |
|      * @param character The position's character.
 | |
|      */
 | |
|     function create(line, character) {
 | |
|         return { line: line, character: character };
 | |
|     }
 | |
|     Position.create = create;
 | |
|     /**
 | |
|      * Checks whether the given liternal conforms to the [Position](#Position) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.number(candidate.line) && Is.number(candidate.character);
 | |
|     }
 | |
|     Position.is = is;
 | |
| })(Position || (Position = {}));
 | |
| /**
 | |
|  * The Range namespace provides helper functions to work with
 | |
|  * [Range](#Range) literals.
 | |
|  */
 | |
| var Range;
 | |
| (function (Range) {
 | |
|     function create(one, two, three, four) {
 | |
|         if (Is.number(one) && Is.number(two) && Is.number(three) && Is.number(four)) {
 | |
|             return { start: Position.create(one, two), end: Position.create(three, four) };
 | |
|         }
 | |
|         else if (Position.is(one) && Position.is(two)) {
 | |
|             return { start: one, end: two };
 | |
|         }
 | |
|         else {
 | |
|             throw new Error("Range#create called with invalid arguments[" + one + ", " + two + ", " + three + ", " + four + "]");
 | |
|         }
 | |
|     }
 | |
|     Range.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [Range](#Range) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Position.is(candidate.start) && Position.is(candidate.end);
 | |
|     }
 | |
|     Range.is = is;
 | |
| })(Range || (Range = {}));
 | |
| /**
 | |
|  * The Location namespace provides helper functions to work with
 | |
|  * [Location](#Location) literals.
 | |
|  */
 | |
| var Location;
 | |
| (function (Location) {
 | |
|     /**
 | |
|      * Creates a Location literal.
 | |
|      * @param uri The location's uri.
 | |
|      * @param range The location's range.
 | |
|      */
 | |
|     function create(uri, range) {
 | |
|         return { uri: uri, range: range };
 | |
|     }
 | |
|     Location.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [Location](#Location) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Range.is(candidate.range) && (Is.string(candidate.uri) || Is.undefined(candidate.uri));
 | |
|     }
 | |
|     Location.is = is;
 | |
| })(Location || (Location = {}));
 | |
| /**
 | |
|  * The diagnostic's serverity.
 | |
|  */
 | |
| var DiagnosticSeverity;
 | |
| (function (DiagnosticSeverity) {
 | |
|     /**
 | |
|      * Reports an error.
 | |
|      */
 | |
|     DiagnosticSeverity.Error = 1;
 | |
|     /**
 | |
|      * Reports a warning.
 | |
|      */
 | |
|     DiagnosticSeverity.Warning = 2;
 | |
|     /**
 | |
|      * Reports an information.
 | |
|      */
 | |
|     DiagnosticSeverity.Information = 3;
 | |
|     /**
 | |
|      * Reports a hint.
 | |
|      */
 | |
|     DiagnosticSeverity.Hint = 4;
 | |
| })(DiagnosticSeverity || (DiagnosticSeverity = {}));
 | |
| /**
 | |
|  * The Diagnostic namespace provides helper functions to work with
 | |
|  * [Diagnostic](#Diagnostic) literals.
 | |
|  */
 | |
| var Diagnostic;
 | |
| (function (Diagnostic) {
 | |
|     /**
 | |
|      * Creates a new Diagnostic literal.
 | |
|      */
 | |
|     function create(range, message, severity, code, source) {
 | |
|         var result = { range: range, message: message };
 | |
|         if (Is.defined(severity)) {
 | |
|             result.severity = severity;
 | |
|         }
 | |
|         if (Is.defined(code)) {
 | |
|             result.code = code;
 | |
|         }
 | |
|         if (Is.defined(source)) {
 | |
|             result.source = source;
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     Diagnostic.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [Diagnostic](#Diagnostic) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate)
 | |
|             && Range.is(candidate.range)
 | |
|             && Is.string(candidate.message)
 | |
|             && (Is.number(candidate.severity) || Is.undefined(candidate.severity))
 | |
|             && (Is.number(candidate.code) || Is.string(candidate.code) || Is.undefined(candidate.code))
 | |
|             && (Is.string(candidate.source) || Is.undefined(candidate.source));
 | |
|     }
 | |
|     Diagnostic.is = is;
 | |
| })(Diagnostic || (Diagnostic = {}));
 | |
| /**
 | |
|  * The Command namespace provides helper functions to work with
 | |
|  * [Command](#Command) literals.
 | |
|  */
 | |
| var Command;
 | |
| (function (Command) {
 | |
|     /**
 | |
|      * Creates a new Command literal.
 | |
|      */
 | |
|     function create(title, command) {
 | |
|         var args = [];
 | |
|         for (var _i = 2; _i < arguments.length; _i++) {
 | |
|             args[_i - 2] = arguments[_i];
 | |
|         }
 | |
|         var result = { title: title, command: command };
 | |
|         if (Is.defined(args) && args.length > 0) {
 | |
|             result.arguments = args;
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     Command.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [Command](#Command) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.string(candidate.title) && Is.string(candidate.title);
 | |
|     }
 | |
|     Command.is = is;
 | |
| })(Command || (Command = {}));
 | |
| /**
 | |
|  * The TextEdit namespace provides helper function to create replace,
 | |
|  * insert and delete edits more easily.
 | |
|  */
 | |
| var TextEdit;
 | |
| (function (TextEdit) {
 | |
|     /**
 | |
|      * Creates a replace text edit.
 | |
|      * @param range The range of text to be replaced.
 | |
|      * @param newText The new text.
 | |
|      */
 | |
|     function replace(range, newText) {
 | |
|         return { range: range, newText: newText };
 | |
|     }
 | |
|     TextEdit.replace = replace;
 | |
|     /**
 | |
|      * Creates a insert text edit.
 | |
|      * @param position The position to insert the text at.
 | |
|      * @param newText The text to be inserted.
 | |
|      */
 | |
|     function insert(position, newText) {
 | |
|         return { range: { start: position, end: position }, newText: newText };
 | |
|     }
 | |
|     TextEdit.insert = insert;
 | |
|     /**
 | |
|      * Creates a delete text edit.
 | |
|      * @param range The range of text to be deleted.
 | |
|      */
 | |
|     function del(range) {
 | |
|         return { range: range, newText: '' };
 | |
|     }
 | |
|     TextEdit.del = del;
 | |
| })(TextEdit || (TextEdit = {}));
 | |
| /**
 | |
|  * The TextDocumentEdit namespace provides helper function to create
 | |
|  * an edit that manipulates a text document.
 | |
|  */
 | |
| var TextDocumentEdit;
 | |
| (function (TextDocumentEdit) {
 | |
|     /**
 | |
|      * Creates a new `TextDocumentEdit`
 | |
|      */
 | |
|     function create(textDocument, edits) {
 | |
|         return { textDocument: textDocument, edits: edits };
 | |
|     }
 | |
|     TextDocumentEdit.create = create;
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate)
 | |
|             && VersionedTextDocumentIdentifier.is(candidate.textDocument)
 | |
|             && Array.isArray(candidate.edits);
 | |
|     }
 | |
|     TextDocumentEdit.is = is;
 | |
| })(TextDocumentEdit || (TextDocumentEdit = {}));
 | |
| var TextEditChangeImpl = /** @class */ (function () {
 | |
|     function TextEditChangeImpl(edits) {
 | |
|         this.edits = edits;
 | |
|     }
 | |
|     TextEditChangeImpl.prototype.insert = function (position, newText) {
 | |
|         this.edits.push(TextEdit.insert(position, newText));
 | |
|     };
 | |
|     TextEditChangeImpl.prototype.replace = function (range, newText) {
 | |
|         this.edits.push(TextEdit.replace(range, newText));
 | |
|     };
 | |
|     TextEditChangeImpl.prototype.delete = function (range) {
 | |
|         this.edits.push(TextEdit.del(range));
 | |
|     };
 | |
|     TextEditChangeImpl.prototype.add = function (edit) {
 | |
|         this.edits.push(edit);
 | |
|     };
 | |
|     TextEditChangeImpl.prototype.all = function () {
 | |
|         return this.edits;
 | |
|     };
 | |
|     TextEditChangeImpl.prototype.clear = function () {
 | |
|         this.edits.splice(0, this.edits.length);
 | |
|     };
 | |
|     return TextEditChangeImpl;
 | |
| }());
 | |
| /**
 | |
|  * A workspace change helps constructing changes to a workspace.
 | |
|  */
 | |
| var WorkspaceChange = /** @class */ (function () {
 | |
|     function WorkspaceChange(workspaceEdit) {
 | |
|         var _this = this;
 | |
|         this._textEditChanges = Object.create(null);
 | |
|         if (workspaceEdit) {
 | |
|             this._workspaceEdit = workspaceEdit;
 | |
|             if (workspaceEdit.documentChanges) {
 | |
|                 workspaceEdit.documentChanges.forEach(function (textDocumentEdit) {
 | |
|                     var textEditChange = new TextEditChangeImpl(textDocumentEdit.edits);
 | |
|                     _this._textEditChanges[textDocumentEdit.textDocument.uri] = textEditChange;
 | |
|                 });
 | |
|             }
 | |
|             else if (workspaceEdit.changes) {
 | |
|                 Object.keys(workspaceEdit.changes).forEach(function (key) {
 | |
|                     var textEditChange = new TextEditChangeImpl(workspaceEdit.changes[key]);
 | |
|                     _this._textEditChanges[key] = textEditChange;
 | |
|                 });
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     Object.defineProperty(WorkspaceChange.prototype, "edit", {
 | |
|         /**
 | |
|          * Returns the underlying [WorkspaceEdit](#WorkspaceEdit) literal
 | |
|          * use to be returned from a workspace edit operation like rename.
 | |
|          */
 | |
|         get: function () {
 | |
|             return this._workspaceEdit;
 | |
|         },
 | |
|         enumerable: true,
 | |
|         configurable: true
 | |
|     });
 | |
|     WorkspaceChange.prototype.getTextEditChange = function (key) {
 | |
|         if (VersionedTextDocumentIdentifier.is(key)) {
 | |
|             if (!this._workspaceEdit) {
 | |
|                 this._workspaceEdit = {
 | |
|                     documentChanges: []
 | |
|                 };
 | |
|             }
 | |
|             if (!this._workspaceEdit.documentChanges) {
 | |
|                 throw new Error('Workspace edit is not configured for versioned document changes.');
 | |
|             }
 | |
|             var textDocument = key;
 | |
|             var result = this._textEditChanges[textDocument.uri];
 | |
|             if (!result) {
 | |
|                 var edits = [];
 | |
|                 var textDocumentEdit = {
 | |
|                     textDocument: textDocument,
 | |
|                     edits: edits
 | |
|                 };
 | |
|                 this._workspaceEdit.documentChanges.push(textDocumentEdit);
 | |
|                 result = new TextEditChangeImpl(edits);
 | |
|                 this._textEditChanges[textDocument.uri] = result;
 | |
|             }
 | |
|             return result;
 | |
|         }
 | |
|         else {
 | |
|             if (!this._workspaceEdit) {
 | |
|                 this._workspaceEdit = {
 | |
|                     changes: Object.create(null)
 | |
|                 };
 | |
|             }
 | |
|             if (!this._workspaceEdit.changes) {
 | |
|                 throw new Error('Workspace edit is not configured for normal text edit changes.');
 | |
|             }
 | |
|             var result = this._textEditChanges[key];
 | |
|             if (!result) {
 | |
|                 var edits = [];
 | |
|                 this._workspaceEdit.changes[key] = edits;
 | |
|                 result = new TextEditChangeImpl(edits);
 | |
|                 this._textEditChanges[key] = result;
 | |
|             }
 | |
|             return result;
 | |
|         }
 | |
|     };
 | |
|     return WorkspaceChange;
 | |
| }());
 | |
| 
 | |
| /**
 | |
|  * The TextDocumentIdentifier namespace provides helper functions to work with
 | |
|  * [TextDocumentIdentifier](#TextDocumentIdentifier) literals.
 | |
|  */
 | |
| var TextDocumentIdentifier;
 | |
| (function (TextDocumentIdentifier) {
 | |
|     /**
 | |
|      * Creates a new TextDocumentIdentifier literal.
 | |
|      * @param uri The document's uri.
 | |
|      */
 | |
|     function create(uri) {
 | |
|         return { uri: uri };
 | |
|     }
 | |
|     TextDocumentIdentifier.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [TextDocumentIdentifier](#TextDocumentIdentifier) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.string(candidate.uri);
 | |
|     }
 | |
|     TextDocumentIdentifier.is = is;
 | |
| })(TextDocumentIdentifier || (TextDocumentIdentifier = {}));
 | |
| /**
 | |
|  * The VersionedTextDocumentIdentifier namespace provides helper functions to work with
 | |
|  * [VersionedTextDocumentIdentifier](#VersionedTextDocumentIdentifier) literals.
 | |
|  */
 | |
| var VersionedTextDocumentIdentifier;
 | |
| (function (VersionedTextDocumentIdentifier) {
 | |
|     /**
 | |
|      * Creates a new VersionedTextDocumentIdentifier literal.
 | |
|      * @param uri The document's uri.
 | |
|      * @param uri The document's text.
 | |
|      */
 | |
|     function create(uri, version) {
 | |
|         return { uri: uri, version: version };
 | |
|     }
 | |
|     VersionedTextDocumentIdentifier.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [VersionedTextDocumentIdentifier](#VersionedTextDocumentIdentifier) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.string(candidate.uri) && Is.number(candidate.version);
 | |
|     }
 | |
|     VersionedTextDocumentIdentifier.is = is;
 | |
| })(VersionedTextDocumentIdentifier || (VersionedTextDocumentIdentifier = {}));
 | |
| /**
 | |
|  * The TextDocumentItem namespace provides helper functions to work with
 | |
|  * [TextDocumentItem](#TextDocumentItem) literals.
 | |
|  */
 | |
| var TextDocumentItem;
 | |
| (function (TextDocumentItem) {
 | |
|     /**
 | |
|      * Creates a new TextDocumentItem literal.
 | |
|      * @param uri The document's uri.
 | |
|      * @param languageId The document's language identifier.
 | |
|      * @param version The document's version number.
 | |
|      * @param text The document's text.
 | |
|      */
 | |
|     function create(uri, languageId, version, text) {
 | |
|         return { uri: uri, languageId: languageId, version: version, text: text };
 | |
|     }
 | |
|     TextDocumentItem.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [TextDocumentItem](#TextDocumentItem) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.string(candidate.uri) && Is.string(candidate.languageId) && Is.number(candidate.version) && Is.string(candidate.text);
 | |
|     }
 | |
|     TextDocumentItem.is = is;
 | |
| })(TextDocumentItem || (TextDocumentItem = {}));
 | |
| /**
 | |
|  * Describes the content type that a client supports in various
 | |
|  * result literals like `Hover`, `ParameterInfo` or `CompletionItem`.
 | |
|  *
 | |
|  * Please note that `MarkupKinds` must not start with a `$`. This kinds
 | |
|  * are reserved for internal usage.
 | |
|  */
 | |
| var MarkupKind;
 | |
| (function (MarkupKind) {
 | |
|     /**
 | |
|      * Plain text is supported as a content format
 | |
|      */
 | |
|     MarkupKind.PlainText = 'plaintext';
 | |
|     /**
 | |
|      * Markdown is supported as a content format
 | |
|      */
 | |
|     MarkupKind.Markdown = 'markdown';
 | |
| })(MarkupKind || (MarkupKind = {}));
 | |
| /**
 | |
|  * The kind of a completion entry.
 | |
|  */
 | |
| var CompletionItemKind;
 | |
| (function (CompletionItemKind) {
 | |
|     CompletionItemKind.Text = 1;
 | |
|     CompletionItemKind.Method = 2;
 | |
|     CompletionItemKind.Function = 3;
 | |
|     CompletionItemKind.Constructor = 4;
 | |
|     CompletionItemKind.Field = 5;
 | |
|     CompletionItemKind.Variable = 6;
 | |
|     CompletionItemKind.Class = 7;
 | |
|     CompletionItemKind.Interface = 8;
 | |
|     CompletionItemKind.Module = 9;
 | |
|     CompletionItemKind.Property = 10;
 | |
|     CompletionItemKind.Unit = 11;
 | |
|     CompletionItemKind.Value = 12;
 | |
|     CompletionItemKind.Enum = 13;
 | |
|     CompletionItemKind.Keyword = 14;
 | |
|     CompletionItemKind.Snippet = 15;
 | |
|     CompletionItemKind.Color = 16;
 | |
|     CompletionItemKind.File = 17;
 | |
|     CompletionItemKind.Reference = 18;
 | |
|     CompletionItemKind.Folder = 19;
 | |
|     CompletionItemKind.EnumMember = 20;
 | |
|     CompletionItemKind.Constant = 21;
 | |
|     CompletionItemKind.Struct = 22;
 | |
|     CompletionItemKind.Event = 23;
 | |
|     CompletionItemKind.Operator = 24;
 | |
|     CompletionItemKind.TypeParameter = 25;
 | |
| })(CompletionItemKind || (CompletionItemKind = {}));
 | |
| /**
 | |
|  * Defines whether the insert text in a completion item should be interpreted as
 | |
|  * plain text or a snippet.
 | |
|  */
 | |
| var InsertTextFormat;
 | |
| (function (InsertTextFormat) {
 | |
|     /**
 | |
|      * The primary text to be inserted is treated as a plain string.
 | |
|      */
 | |
|     InsertTextFormat.PlainText = 1;
 | |
|     /**
 | |
|      * The primary text to be inserted is treated as a snippet.
 | |
|      *
 | |
|      * A snippet can define tab stops and placeholders with `$1`, `$2`
 | |
|      * and `${3:foo}`. `$0` defines the final tab stop, it defaults to
 | |
|      * the end of the snippet. Placeholders with equal identifiers are linked,
 | |
|      * that is typing in one will update others too.
 | |
|      *
 | |
|      * See also: https://github.com/Microsoft/vscode/blob/master/src/vs/editor/contrib/snippet/common/snippet.md
 | |
|      */
 | |
|     InsertTextFormat.Snippet = 2;
 | |
| })(InsertTextFormat || (InsertTextFormat = {}));
 | |
| /**
 | |
|  * The CompletionItem namespace provides functions to deal with
 | |
|  * completion items.
 | |
|  */
 | |
| var CompletionItem;
 | |
| (function (CompletionItem) {
 | |
|     /**
 | |
|      * Create a completion item and seed it with a label.
 | |
|      * @param label The completion item's label
 | |
|      */
 | |
|     function create(label) {
 | |
|         return { label: label };
 | |
|     }
 | |
|     CompletionItem.create = create;
 | |
| })(CompletionItem || (CompletionItem = {}));
 | |
| /**
 | |
|  * The CompletionList namespace provides functions to deal with
 | |
|  * completion lists.
 | |
|  */
 | |
| var CompletionList;
 | |
| (function (CompletionList) {
 | |
|     /**
 | |
|      * Creates a new completion list.
 | |
|      *
 | |
|      * @param items The completion items.
 | |
|      * @param isIncomplete The list is not complete.
 | |
|      */
 | |
|     function create(items, isIncomplete) {
 | |
|         return { items: items ? items : [], isIncomplete: !!isIncomplete };
 | |
|     }
 | |
|     CompletionList.create = create;
 | |
| })(CompletionList || (CompletionList = {}));
 | |
| var MarkedString;
 | |
| (function (MarkedString) {
 | |
|     /**
 | |
|      * Creates a marked string from plain text.
 | |
|      *
 | |
|      * @param plainText The plain text.
 | |
|      */
 | |
|     function fromPlainText(plainText) {
 | |
|         return plainText.replace(/[\\`*_{}[\]()#+\-.!]/g, "\\$&"); // escape markdown syntax tokens: http://daringfireball.net/projects/markdown/syntax#backslash
 | |
|     }
 | |
|     MarkedString.fromPlainText = fromPlainText;
 | |
| })(MarkedString || (MarkedString = {}));
 | |
| /**
 | |
|  * The ParameterInformation namespace provides helper functions to work with
 | |
|  * [ParameterInformation](#ParameterInformation) literals.
 | |
|  */
 | |
| var ParameterInformation;
 | |
| (function (ParameterInformation) {
 | |
|     /**
 | |
|      * Creates a new parameter information literal.
 | |
|      *
 | |
|      * @param label A label string.
 | |
|      * @param documentation A doc string.
 | |
|      */
 | |
|     function create(label, documentation) {
 | |
|         return documentation ? { label: label, documentation: documentation } : { label: label };
 | |
|     }
 | |
|     ParameterInformation.create = create;
 | |
|     ;
 | |
| })(ParameterInformation || (ParameterInformation = {}));
 | |
| /**
 | |
|  * The SignatureInformation namespace provides helper functions to work with
 | |
|  * [SignatureInformation](#SignatureInformation) literals.
 | |
|  */
 | |
| var SignatureInformation;
 | |
| (function (SignatureInformation) {
 | |
|     function create(label, documentation) {
 | |
|         var parameters = [];
 | |
|         for (var _i = 2; _i < arguments.length; _i++) {
 | |
|             parameters[_i - 2] = arguments[_i];
 | |
|         }
 | |
|         var result = { label: label };
 | |
|         if (Is.defined(documentation)) {
 | |
|             result.documentation = documentation;
 | |
|         }
 | |
|         if (Is.defined(parameters)) {
 | |
|             result.parameters = parameters;
 | |
|         }
 | |
|         else {
 | |
|             result.parameters = [];
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     SignatureInformation.create = create;
 | |
| })(SignatureInformation || (SignatureInformation = {}));
 | |
| /**
 | |
|  * A document highlight kind.
 | |
|  */
 | |
| var DocumentHighlightKind;
 | |
| (function (DocumentHighlightKind) {
 | |
|     /**
 | |
|      * A textual occurrance.
 | |
|      */
 | |
|     DocumentHighlightKind.Text = 1;
 | |
|     /**
 | |
|      * Read-access of a symbol, like reading a variable.
 | |
|      */
 | |
|     DocumentHighlightKind.Read = 2;
 | |
|     /**
 | |
|      * Write-access of a symbol, like writing to a variable.
 | |
|      */
 | |
|     DocumentHighlightKind.Write = 3;
 | |
| })(DocumentHighlightKind || (DocumentHighlightKind = {}));
 | |
| /**
 | |
|  * DocumentHighlight namespace to provide helper functions to work with
 | |
|  * [DocumentHighlight](#DocumentHighlight) literals.
 | |
|  */
 | |
| var DocumentHighlight;
 | |
| (function (DocumentHighlight) {
 | |
|     /**
 | |
|      * Create a DocumentHighlight object.
 | |
|      * @param range The range the highlight applies to.
 | |
|      */
 | |
|     function create(range, kind) {
 | |
|         var result = { range: range };
 | |
|         if (Is.number(kind)) {
 | |
|             result.kind = kind;
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     DocumentHighlight.create = create;
 | |
| })(DocumentHighlight || (DocumentHighlight = {}));
 | |
| /**
 | |
|  * A symbol kind.
 | |
|  */
 | |
| var SymbolKind;
 | |
| (function (SymbolKind) {
 | |
|     SymbolKind.File = 1;
 | |
|     SymbolKind.Module = 2;
 | |
|     SymbolKind.Namespace = 3;
 | |
|     SymbolKind.Package = 4;
 | |
|     SymbolKind.Class = 5;
 | |
|     SymbolKind.Method = 6;
 | |
|     SymbolKind.Property = 7;
 | |
|     SymbolKind.Field = 8;
 | |
|     SymbolKind.Constructor = 9;
 | |
|     SymbolKind.Enum = 10;
 | |
|     SymbolKind.Interface = 11;
 | |
|     SymbolKind.Function = 12;
 | |
|     SymbolKind.Variable = 13;
 | |
|     SymbolKind.Constant = 14;
 | |
|     SymbolKind.String = 15;
 | |
|     SymbolKind.Number = 16;
 | |
|     SymbolKind.Boolean = 17;
 | |
|     SymbolKind.Array = 18;
 | |
|     SymbolKind.Object = 19;
 | |
|     SymbolKind.Key = 20;
 | |
|     SymbolKind.Null = 21;
 | |
|     SymbolKind.EnumMember = 22;
 | |
|     SymbolKind.Struct = 23;
 | |
|     SymbolKind.Event = 24;
 | |
|     SymbolKind.Operator = 25;
 | |
|     SymbolKind.TypeParameter = 26;
 | |
| })(SymbolKind || (SymbolKind = {}));
 | |
| var SymbolInformation;
 | |
| (function (SymbolInformation) {
 | |
|     /**
 | |
|      * Creates a new symbol information literal.
 | |
|      *
 | |
|      * @param name The name of the symbol.
 | |
|      * @param kind The kind of the symbol.
 | |
|      * @param range The range of the location of the symbol.
 | |
|      * @param uri The resource of the location of symbol, defaults to the current document.
 | |
|      * @param containerName The name of the symbol containg the symbol.
 | |
|      */
 | |
|     function create(name, kind, range, uri, containerName) {
 | |
|         var result = {
 | |
|             name: name,
 | |
|             kind: kind,
 | |
|             location: { uri: uri, range: range }
 | |
|         };
 | |
|         if (containerName) {
 | |
|             result.containerName = containerName;
 | |
|         }
 | |
|         return result;
 | |
|     }
 | |
|     SymbolInformation.create = create;
 | |
| })(SymbolInformation || (SymbolInformation = {}));
 | |
| /**
 | |
|  * The CodeActionContext namespace provides helper functions to work with
 | |
|  * [CodeActionContext](#CodeActionContext) literals.
 | |
|  */
 | |
| var CodeActionContext;
 | |
| (function (CodeActionContext) {
 | |
|     /**
 | |
|      * Creates a new CodeActionContext literal.
 | |
|      */
 | |
|     function create(diagnostics) {
 | |
|         return { diagnostics: diagnostics };
 | |
|     }
 | |
|     CodeActionContext.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [CodeActionContext](#CodeActionContext) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.typedArray(candidate.diagnostics, Diagnostic.is);
 | |
|     }
 | |
|     CodeActionContext.is = is;
 | |
| })(CodeActionContext || (CodeActionContext = {}));
 | |
| /**
 | |
|  * The CodeLens namespace provides helper functions to work with
 | |
|  * [CodeLens](#CodeLens) literals.
 | |
|  */
 | |
| var CodeLens;
 | |
| (function (CodeLens) {
 | |
|     /**
 | |
|      * Creates a new CodeLens literal.
 | |
|      */
 | |
|     function create(range, data) {
 | |
|         var result = { range: range };
 | |
|         if (Is.defined(data))
 | |
|             result.data = data;
 | |
|         return result;
 | |
|     }
 | |
|     CodeLens.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [CodeLens](#CodeLens) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Range.is(candidate.range) && (Is.undefined(candidate.command) || Command.is(candidate.command));
 | |
|     }
 | |
|     CodeLens.is = is;
 | |
| })(CodeLens || (CodeLens = {}));
 | |
| /**
 | |
|  * The FormattingOptions namespace provides helper functions to work with
 | |
|  * [FormattingOptions](#FormattingOptions) literals.
 | |
|  */
 | |
| var FormattingOptions;
 | |
| (function (FormattingOptions) {
 | |
|     /**
 | |
|      * Creates a new FormattingOptions literal.
 | |
|      */
 | |
|     function create(tabSize, insertSpaces) {
 | |
|         return { tabSize: tabSize, insertSpaces: insertSpaces };
 | |
|     }
 | |
|     FormattingOptions.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [FormattingOptions](#FormattingOptions) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.number(candidate.tabSize) && Is.boolean(candidate.insertSpaces);
 | |
|     }
 | |
|     FormattingOptions.is = is;
 | |
| })(FormattingOptions || (FormattingOptions = {}));
 | |
| /**
 | |
|  * A document link is a range in a text document that links to an internal or external resource, like another
 | |
|  * text document or a web site.
 | |
|  */
 | |
| var DocumentLink = /** @class */ (function () {
 | |
|     function DocumentLink() {
 | |
|     }
 | |
|     return DocumentLink;
 | |
| }());
 | |
| 
 | |
| /**
 | |
|  * The DocumentLink namespace provides helper functions to work with
 | |
|  * [DocumentLink](#DocumentLink) literals.
 | |
|  */
 | |
| (function (DocumentLink) {
 | |
|     /**
 | |
|      * Creates a new DocumentLink literal.
 | |
|      */
 | |
|     function create(range, target) {
 | |
|         return { range: range, target: target };
 | |
|     }
 | |
|     DocumentLink.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [DocumentLink](#DocumentLink) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Range.is(candidate.range) && (Is.undefined(candidate.target) || Is.string(candidate.target));
 | |
|     }
 | |
|     DocumentLink.is = is;
 | |
| })(DocumentLink || (DocumentLink = {}));
 | |
| var EOL = ['\n', '\r\n', '\r'];
 | |
| var TextDocument;
 | |
| (function (TextDocument) {
 | |
|     /**
 | |
|      * Creates a new ITextDocument literal from the given uri and content.
 | |
|      * @param uri The document's uri.
 | |
|      * @param languageId  The document's language Id.
 | |
|      * @param content The document's content.
 | |
|      */
 | |
|     function create(uri, languageId, version, content) {
 | |
|         return new FullTextDocument(uri, languageId, version, content);
 | |
|     }
 | |
|     TextDocument.create = create;
 | |
|     /**
 | |
|      * Checks whether the given literal conforms to the [ITextDocument](#ITextDocument) interface.
 | |
|      */
 | |
|     function is(value) {
 | |
|         var candidate = value;
 | |
|         return Is.defined(candidate) && Is.string(candidate.uri) && (Is.undefined(candidate.languageId) || Is.string(candidate.languageId)) && Is.number(candidate.lineCount)
 | |
|             && Is.func(candidate.getText) && Is.func(candidate.positionAt) && Is.func(candidate.offsetAt) ? true : false;
 | |
|     }
 | |
|     TextDocument.is = is;
 | |
|     function applyEdits(document, edits) {
 | |
|         var text = document.getText();
 | |
|         var sortedEdits = mergeSort(edits, function (a, b) {
 | |
|             var diff = a.range.start.line - b.range.start.line;
 | |
|             if (diff === 0) {
 | |
|                 return a.range.start.character - b.range.start.character;
 | |
|             }
 | |
|             return 0;
 | |
|         });
 | |
|         var lastModifiedOffset = text.length;
 | |
|         for (var i = sortedEdits.length - 1; i >= 0; i--) {
 | |
|             var e = sortedEdits[i];
 | |
|             var startOffset = document.offsetAt(e.range.start);
 | |
|             var endOffset = document.offsetAt(e.range.end);
 | |
|             if (endOffset <= lastModifiedOffset) {
 | |
|                 text = text.substring(0, startOffset) + e.newText + text.substring(endOffset, text.length);
 | |
|             }
 | |
|             else {
 | |
|                 throw new Error('Ovelapping edit');
 | |
|             }
 | |
|             lastModifiedOffset = startOffset;
 | |
|         }
 | |
|         return text;
 | |
|     }
 | |
|     TextDocument.applyEdits = applyEdits;
 | |
|     function mergeSort(data, compare) {
 | |
|         if (data.length <= 1) {
 | |
|             // sorted
 | |
|             return data;
 | |
|         }
 | |
|         var p = (data.length / 2) | 0;
 | |
|         var left = data.slice(0, p);
 | |
|         var right = data.slice(p);
 | |
|         mergeSort(left, compare);
 | |
|         mergeSort(right, compare);
 | |
|         var leftIdx = 0;
 | |
|         var rightIdx = 0;
 | |
|         var i = 0;
 | |
|         while (leftIdx < left.length && rightIdx < right.length) {
 | |
|             var ret = compare(left[leftIdx], right[rightIdx]);
 | |
|             if (ret <= 0) {
 | |
|                 // smaller_equal -> take left to preserve order
 | |
|                 data[i++] = left[leftIdx++];
 | |
|             }
 | |
|             else {
 | |
|                 // greater -> take right
 | |
|                 data[i++] = right[rightIdx++];
 | |
|             }
 | |
|         }
 | |
|         while (leftIdx < left.length) {
 | |
|             data[i++] = left[leftIdx++];
 | |
|         }
 | |
|         while (rightIdx < right.length) {
 | |
|             data[i++] = right[rightIdx++];
 | |
|         }
 | |
|         return data;
 | |
|     }
 | |
| })(TextDocument || (TextDocument = {}));
 | |
| /**
 | |
|  * Represents reasons why a text document is saved.
 | |
|  */
 | |
| var TextDocumentSaveReason;
 | |
| (function (TextDocumentSaveReason) {
 | |
|     /**
 | |
|      * Manually triggered, e.g. by the user pressing save, by starting debugging,
 | |
|      * or by an API call.
 | |
|      */
 | |
|     TextDocumentSaveReason.Manual = 1;
 | |
|     /**
 | |
|      * Automatic after a delay.
 | |
|      */
 | |
|     TextDocumentSaveReason.AfterDelay = 2;
 | |
|     /**
 | |
|      * When the editor lost focus.
 | |
|      */
 | |
|     TextDocumentSaveReason.FocusOut = 3;
 | |
| })(TextDocumentSaveReason || (TextDocumentSaveReason = {}));
 | |
| var FullTextDocument = /** @class */ (function () {
 | |
|     function FullTextDocument(uri, languageId, version, content) {
 | |
|         this._uri = uri;
 | |
|         this._languageId = languageId;
 | |
|         this._version = version;
 | |
|         this._content = content;
 | |
|         this._lineOffsets = null;
 | |
|     }
 | |
|     Object.defineProperty(FullTextDocument.prototype, "uri", {
 | |
|         get: function () {
 | |
|             return this._uri;
 | |
|         },
 | |
|         enumerable: true,
 | |
|         configurable: true
 | |
|     });
 | |
|     Object.defineProperty(FullTextDocument.prototype, "languageId", {
 | |
|         get: function () {
 | |
|             return this._languageId;
 | |
|         },
 | |
|         enumerable: true,
 | |
|         configurable: true
 | |
|     });
 | |
|     Object.defineProperty(FullTextDocument.prototype, "version", {
 | |
|         get: function () {
 | |
|             return this._version;
 | |
|         },
 | |
|         enumerable: true,
 | |
|         configurable: true
 | |
|     });
 | |
|     FullTextDocument.prototype.getText = function (range) {
 | |
|         if (range) {
 | |
|             var start = this.offsetAt(range.start);
 | |
|             var end = this.offsetAt(range.end);
 | |
|             return this._content.substring(start, end);
 | |
|         }
 | |
|         return this._content;
 | |
|     };
 | |
|     FullTextDocument.prototype.update = function (event, version) {
 | |
|         this._content = event.text;
 | |
|         this._version = version;
 | |
|         this._lineOffsets = null;
 | |
|     };
 | |
|     FullTextDocument.prototype.getLineOffsets = function () {
 | |
|         if (this._lineOffsets === null) {
 | |
|             var lineOffsets = [];
 | |
|             var text = this._content;
 | |
|             var isLineStart = true;
 | |
|             for (var i = 0; i < text.length; i++) {
 | |
|                 if (isLineStart) {
 | |
|                     lineOffsets.push(i);
 | |
|                     isLineStart = false;
 | |
|                 }
 | |
|                 var ch = text.charAt(i);
 | |
|                 isLineStart = (ch === '\r' || ch === '\n');
 | |
|                 if (ch === '\r' && i + 1 < text.length && text.charAt(i + 1) === '\n') {
 | |
|                     i++;
 | |
|                 }
 | |
|             }
 | |
|             if (isLineStart && text.length > 0) {
 | |
|                 lineOffsets.push(text.length);
 | |
|             }
 | |
|             this._lineOffsets = lineOffsets;
 | |
|         }
 | |
|         return this._lineOffsets;
 | |
|     };
 | |
|     FullTextDocument.prototype.positionAt = function (offset) {
 | |
|         offset = Math.max(Math.min(offset, this._content.length), 0);
 | |
|         var lineOffsets = this.getLineOffsets();
 | |
|         var low = 0, high = lineOffsets.length;
 | |
|         if (high === 0) {
 | |
|             return Position.create(0, offset);
 | |
|         }
 | |
|         while (low < high) {
 | |
|             var mid = Math.floor((low + high) / 2);
 | |
|             if (lineOffsets[mid] > offset) {
 | |
|                 high = mid;
 | |
|             }
 | |
|             else {
 | |
|                 low = mid + 1;
 | |
|             }
 | |
|         }
 | |
|         // low is the least x for which the line offset is larger than the current offset
 | |
|         // or array.length if no line offset is larger than the current offset
 | |
|         var line = low - 1;
 | |
|         return Position.create(line, offset - lineOffsets[line]);
 | |
|     };
 | |
|     FullTextDocument.prototype.offsetAt = function (position) {
 | |
|         var lineOffsets = this.getLineOffsets();
 | |
|         if (position.line >= lineOffsets.length) {
 | |
|             return this._content.length;
 | |
|         }
 | |
|         else if (position.line < 0) {
 | |
|             return 0;
 | |
|         }
 | |
|         var lineOffset = lineOffsets[position.line];
 | |
|         var nextLineOffset = (position.line + 1 < lineOffsets.length) ? lineOffsets[position.line + 1] : this._content.length;
 | |
|         return Math.max(Math.min(lineOffset + position.character, nextLineOffset), lineOffset);
 | |
|     };
 | |
|     Object.defineProperty(FullTextDocument.prototype, "lineCount", {
 | |
|         get: function () {
 | |
|             return this.getLineOffsets().length;
 | |
|         },
 | |
|         enumerable: true,
 | |
|         configurable: true
 | |
|     });
 | |
|     return FullTextDocument;
 | |
| }());
 | |
| var Is;
 | |
| (function (Is) {
 | |
|     var toString = Object.prototype.toString;
 | |
|     function defined(value) {
 | |
|         return typeof value !== 'undefined';
 | |
|     }
 | |
|     Is.defined = defined;
 | |
|     function undefined(value) {
 | |
|         return typeof value === 'undefined';
 | |
|     }
 | |
|     Is.undefined = undefined;
 | |
|     function boolean(value) {
 | |
|         return value === true || value === false;
 | |
|     }
 | |
|     Is.boolean = boolean;
 | |
|     function string(value) {
 | |
|         return toString.call(value) === '[object String]';
 | |
|     }
 | |
|     Is.string = string;
 | |
|     function number(value) {
 | |
|         return toString.call(value) === '[object Number]';
 | |
|     }
 | |
|     Is.number = number;
 | |
|     function func(value) {
 | |
|         return toString.call(value) === '[object Function]';
 | |
|     }
 | |
|     Is.func = func;
 | |
|     function typedArray(value, check) {
 | |
|         return Array.isArray(value) && value.every(check);
 | |
|     }
 | |
|     Is.typedArray = typedArray;
 | |
| })(Is || (Is = {}));
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4064:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (immutable) */ __webpack_exports__["a"] = createTokenizationSupport;
 | |
| /* unused harmony export TOKEN_DELIM_OBJECT */
 | |
| /* unused harmony export TOKEN_DELIM_ARRAY */
 | |
| /* unused harmony export TOKEN_DELIM_COLON */
 | |
| /* unused harmony export TOKEN_DELIM_COMMA */
 | |
| /* unused harmony export TOKEN_VALUE_BOOLEAN */
 | |
| /* unused harmony export TOKEN_VALUE_NULL */
 | |
| /* unused harmony export TOKEN_VALUE_STRING */
 | |
| /* unused harmony export TOKEN_VALUE_NUMBER */
 | |
| /* unused harmony export TOKEN_PROPERTY_NAME */
 | |
| /* unused harmony export TOKEN_COMMENT_BLOCK */
 | |
| /* unused harmony export TOKEN_COMMENT_LINE */
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__deps_jsonc_parser_main_js__ = __webpack_require__(4065);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| function createTokenizationSupport(supportComments) {
 | |
|     return {
 | |
|         getInitialState: function () { return new JSONState(null, null, false); },
 | |
|         tokenize: function (line, state, offsetDelta, stopAtOffset) { return tokenize(supportComments, line, state, offsetDelta, stopAtOffset); }
 | |
|     };
 | |
| }
 | |
| var TOKEN_DELIM_OBJECT = 'delimiter.bracket.json';
 | |
| var TOKEN_DELIM_ARRAY = 'delimiter.array.json';
 | |
| var TOKEN_DELIM_COLON = 'delimiter.colon.json';
 | |
| var TOKEN_DELIM_COMMA = 'delimiter.comma.json';
 | |
| var TOKEN_VALUE_BOOLEAN = 'keyword.json';
 | |
| var TOKEN_VALUE_NULL = 'keyword.json';
 | |
| var TOKEN_VALUE_STRING = 'string.value.json';
 | |
| var TOKEN_VALUE_NUMBER = 'number.json';
 | |
| var TOKEN_PROPERTY_NAME = 'string.key.json';
 | |
| var TOKEN_COMMENT_BLOCK = 'comment.block.json';
 | |
| var TOKEN_COMMENT_LINE = 'comment.line.json';
 | |
| var JSONState = /** @class */ (function () {
 | |
|     function JSONState(state, scanError, lastWasColon) {
 | |
|         this._state = state;
 | |
|         this.scanError = scanError;
 | |
|         this.lastWasColon = lastWasColon;
 | |
|     }
 | |
|     JSONState.prototype.clone = function () {
 | |
|         return new JSONState(this._state, this.scanError, this.lastWasColon);
 | |
|     };
 | |
|     JSONState.prototype.equals = function (other) {
 | |
|         if (other === this) {
 | |
|             return true;
 | |
|         }
 | |
|         if (!other || !(other instanceof JSONState)) {
 | |
|             return false;
 | |
|         }
 | |
|         return this.scanError === other.scanError &&
 | |
|             this.lastWasColon === other.lastWasColon;
 | |
|     };
 | |
|     JSONState.prototype.getStateData = function () {
 | |
|         return this._state;
 | |
|     };
 | |
|     JSONState.prototype.setStateData = function (state) {
 | |
|         this._state = state;
 | |
|     };
 | |
|     return JSONState;
 | |
| }());
 | |
| function tokenize(comments, line, state, offsetDelta, stopAtOffset) {
 | |
|     if (offsetDelta === void 0) { offsetDelta = 0; }
 | |
|     // handle multiline strings and block comments
 | |
|     var numberOfInsertedCharacters = 0, adjustOffset = false;
 | |
|     switch (state.scanError) {
 | |
|         case 2 /* UnexpectedEndOfString */:
 | |
|             line = '"' + line;
 | |
|             numberOfInsertedCharacters = 1;
 | |
|             break;
 | |
|         case 1 /* UnexpectedEndOfComment */:
 | |
|             line = '/*' + line;
 | |
|             numberOfInsertedCharacters = 2;
 | |
|             break;
 | |
|     }
 | |
|     var scanner = __WEBPACK_IMPORTED_MODULE_0__deps_jsonc_parser_main_js__["a" /* createScanner */](line), kind, ret, lastWasColon = state.lastWasColon;
 | |
|     ret = {
 | |
|         tokens: [],
 | |
|         endState: state.clone()
 | |
|     };
 | |
|     while (true) {
 | |
|         var offset = offsetDelta + scanner.getPosition(), type = '';
 | |
|         kind = scanner.scan();
 | |
|         if (kind === 17 /* EOF */) {
 | |
|             break;
 | |
|         }
 | |
|         // Check that the scanner has advanced
 | |
|         if (offset === offsetDelta + scanner.getPosition()) {
 | |
|             throw new Error('Scanner did not advance, next 3 characters are: ' + line.substr(scanner.getPosition(), 3));
 | |
|         }
 | |
|         // In case we inserted /* or " character, we need to
 | |
|         // adjust the offset of all tokens (except the first)
 | |
|         if (adjustOffset) {
 | |
|             offset -= numberOfInsertedCharacters;
 | |
|         }
 | |
|         adjustOffset = numberOfInsertedCharacters > 0;
 | |
|         // brackets and type
 | |
|         switch (kind) {
 | |
|             case 1 /* OpenBraceToken */:
 | |
|                 type = TOKEN_DELIM_OBJECT;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 2 /* CloseBraceToken */:
 | |
|                 type = TOKEN_DELIM_OBJECT;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 3 /* OpenBracketToken */:
 | |
|                 type = TOKEN_DELIM_ARRAY;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 4 /* CloseBracketToken */:
 | |
|                 type = TOKEN_DELIM_ARRAY;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 6 /* ColonToken */:
 | |
|                 type = TOKEN_DELIM_COLON;
 | |
|                 lastWasColon = true;
 | |
|                 break;
 | |
|             case 5 /* CommaToken */:
 | |
|                 type = TOKEN_DELIM_COMMA;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 8 /* TrueKeyword */:
 | |
|             case 9 /* FalseKeyword */:
 | |
|                 type = TOKEN_VALUE_BOOLEAN;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 7 /* NullKeyword */:
 | |
|                 type = TOKEN_VALUE_NULL;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 10 /* StringLiteral */:
 | |
|                 type = lastWasColon ? TOKEN_VALUE_STRING : TOKEN_PROPERTY_NAME;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|             case 11 /* NumericLiteral */:
 | |
|                 type = TOKEN_VALUE_NUMBER;
 | |
|                 lastWasColon = false;
 | |
|                 break;
 | |
|         }
 | |
|         // comments, iff enabled
 | |
|         if (comments) {
 | |
|             switch (kind) {
 | |
|                 case 12 /* LineCommentTrivia */:
 | |
|                     type = TOKEN_COMMENT_LINE;
 | |
|                     break;
 | |
|                 case 13 /* BlockCommentTrivia */:
 | |
|                     type = TOKEN_COMMENT_BLOCK;
 | |
|                     break;
 | |
|             }
 | |
|         }
 | |
|         ret.endState = new JSONState(state.getStateData(), scanner.getTokenError(), lastWasColon);
 | |
|         ret.tokens.push({
 | |
|             startIndex: offset,
 | |
|             scopes: type
 | |
|         });
 | |
|     }
 | |
|     return ret;
 | |
| }
 | |
| 
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4065:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return createScanner; });
 | |
| /* unused harmony export getLocation */
 | |
| /* unused harmony export parse */
 | |
| /* unused harmony export parseTree */
 | |
| /* unused harmony export findNodeAtLocation */
 | |
| /* unused harmony export getNodeValue */
 | |
| /* unused harmony export visit */
 | |
| /* unused harmony export stripComments */
 | |
| /* unused harmony export format */
 | |
| /* unused harmony export modify */
 | |
| /* unused harmony export applyEdits */
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__impl_format_js__ = __webpack_require__(3571);
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__impl_edit_js__ = __webpack_require__(4066);
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_2__impl_scanner_js__ = __webpack_require__(3230);
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__ = __webpack_require__(3572);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| 
 | |
| /**
 | |
|  * Creates a JSON scanner on the given text.
 | |
|  * If ignoreTrivia is set, whitespaces or comments are ignored.
 | |
|  */
 | |
| var createScanner = __WEBPACK_IMPORTED_MODULE_2__impl_scanner_js__["a" /* createScanner */];
 | |
| /**
 | |
|  * For a given offset, evaluate the location in the JSON document. Each segment in the location path is either a property name or an array index.
 | |
|  */
 | |
| var getLocation = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["b" /* getLocation */];
 | |
| /**
 | |
|  * Parses the given text and returns the object the JSON content represents. On invalid input, the parser tries to be as fault tolerant as possible, but still return a result.
 | |
|  * Therefore always check the errors list to find out if the input was valid.
 | |
|  */
 | |
| var parse = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["d" /* parse */];
 | |
| /**
 | |
|  * Parses the given text and returns a tree representation the JSON content. On invalid input, the parser tries to be as fault tolerant as possible, but still return a result.
 | |
|  */
 | |
| var parseTree = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["e" /* parseTree */];
 | |
| /**
 | |
|  * Finds the node at the given path in a JSON DOM.
 | |
|  */
 | |
| var findNodeAtLocation = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["a" /* findNodeAtLocation */];
 | |
| /**
 | |
|  * Evaluates the JavaScript object of the given JSON DOM node
 | |
|  */
 | |
| var getNodeValue = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["c" /* getNodeValue */];
 | |
| /**
 | |
|  * Parses the given text and invokes the visitor functions for each object, array and literal reached.
 | |
|  */
 | |
| var visit = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["g" /* visit */];
 | |
| /**
 | |
|  * Takes JSON with JavaScript-style comments and remove
 | |
|  * them. Optionally replaces every none-newline character
 | |
|  * of comments with a replaceCharacter
 | |
|  */
 | |
| var stripComments = __WEBPACK_IMPORTED_MODULE_3__impl_parser_js__["f" /* stripComments */];
 | |
| /**
 | |
|  * Computes the edits needed to format a JSON document.
 | |
|  *
 | |
|  * @param documentText The input text
 | |
|  * @param range The range to format or `undefined` to format the full content
 | |
|  * @param options The formatting options
 | |
|  * @returns A list of edit operations describing the formatting changes to the original document. Edits can be either inserts, replacements or
 | |
|  * removals of text segments. All offsets refer to the original state of the document. No two edits must change or remove the same range of
 | |
|  * text in the original document. However, multiple edits can have
 | |
|  * the same offset, for example multiple inserts, or an insert followed by a remove or replace. The order in the array defines which edit is applied first.
 | |
|  * To apply edits to an input, you can use `applyEdits`
 | |
|  */
 | |
| function format(documentText, range, options) {
 | |
|     return __WEBPACK_IMPORTED_MODULE_0__impl_format_js__["a" /* format */](documentText, range, options);
 | |
| }
 | |
| /**
 | |
|  * Computes the edits needed to modify a value in the JSON document.
 | |
|  *
 | |
|  * @param documentText The input text
 | |
|  * @param path The path of the value to change. The path represents either to the document root, a property or an array item.
 | |
|  * If the path points to an non-existing property or item, it will be created.
 | |
|  * @param value The new value for the specified property or item. If the value is undefined,
 | |
|  * the property or item will be removed.
 | |
|  * @param options Options
 | |
|  * @returns A list of edit operations describing the formatting changes to the original document. Edits can be either inserts, replacements or
 | |
|  * removals of text segments. All offsets refer to the original state of the document. No two edits must change or remove the same range of
 | |
|  * text in the original document. However, multiple edits can have
 | |
|  * the same offset, for example multiple inserts, or an insert followed by a remove or replace. The order in the array defines which edit is applied first.
 | |
|  * To apply edits to an input, you can use `applyEdits`
 | |
|  */
 | |
| function modify(text, path, value, options) {
 | |
|     return __WEBPACK_IMPORTED_MODULE_1__impl_edit_js__["b" /* setProperty */](text, path, value, options.formattingOptions, options.getInsertionIndex);
 | |
| }
 | |
| /**
 | |
|  * Applies edits to a input string.
 | |
|  */
 | |
| function applyEdits(text, edits) {
 | |
|     for (var i = edits.length - 1; i >= 0; i--) {
 | |
|         text = __WEBPACK_IMPORTED_MODULE_1__impl_edit_js__["a" /* applyEdit */](text, edits[i]);
 | |
|     }
 | |
|     return text;
 | |
| }
 | |
| //# sourceMappingURL=main.js.map
 | |
| 
 | |
| /***/ }),
 | |
| 
 | |
| /***/ 4066:
 | |
| /***/ (function(module, __webpack_exports__, __webpack_require__) {
 | |
| 
 | |
| "use strict";
 | |
| /* unused harmony export removeProperty */
 | |
| /* harmony export (immutable) */ __webpack_exports__["b"] = setProperty;
 | |
| /* harmony export (immutable) */ __webpack_exports__["a"] = applyEdit;
 | |
| /* unused harmony export isWS */
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__format_js__ = __webpack_require__(3571);
 | |
| /* harmony import */ var __WEBPACK_IMPORTED_MODULE_1__parser_js__ = __webpack_require__(3572);
 | |
| /*---------------------------------------------------------------------------------------------
 | |
|  *  Copyright (c) Microsoft Corporation. All rights reserved.
 | |
|  *  Licensed under the MIT License. See License.txt in the project root for license information.
 | |
|  *--------------------------------------------------------------------------------------------*/
 | |
| 
 | |
| 
 | |
| 
 | |
| function removeProperty(text, path, formattingOptions) {
 | |
|     return setProperty(text, path, void 0, formattingOptions);
 | |
| }
 | |
| function setProperty(text, path, value, formattingOptions, getInsertionIndex) {
 | |
|     var errors = [];
 | |
|     var root = Object(__WEBPACK_IMPORTED_MODULE_1__parser_js__["e" /* parseTree */])(text, errors);
 | |
|     var parent = void 0;
 | |
|     var lastSegment = void 0;
 | |
|     while (path.length > 0) {
 | |
|         lastSegment = path.pop();
 | |
|         parent = Object(__WEBPACK_IMPORTED_MODULE_1__parser_js__["a" /* findNodeAtLocation */])(root, path);
 | |
|         if (parent === void 0 && value !== void 0) {
 | |
|             if (typeof lastSegment === 'string') {
 | |
|                 value = (_a = {}, _a[lastSegment] = value, _a);
 | |
|             }
 | |
|             else {
 | |
|                 value = [value];
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             break;
 | |
|         }
 | |
|     }
 | |
|     if (!parent) {
 | |
|         // empty document
 | |
|         if (value === void 0) {
 | |
|             throw new Error('Can not delete in empty document');
 | |
|         }
 | |
|         return withFormatting(text, { offset: root ? root.offset : 0, length: root ? root.length : 0, content: JSON.stringify(value) }, formattingOptions);
 | |
|     }
 | |
|     else if (parent.type === 'object' && typeof lastSegment === 'string' && Array.isArray(parent.children)) {
 | |
|         var existing = Object(__WEBPACK_IMPORTED_MODULE_1__parser_js__["a" /* findNodeAtLocation */])(parent, [lastSegment]);
 | |
|         if (existing !== void 0) {
 | |
|             if (value === void 0) {
 | |
|                 if (!existing.parent) {
 | |
|                     throw new Error('Malformed AST');
 | |
|                 }
 | |
|                 var propertyIndex = parent.children.indexOf(existing.parent);
 | |
|                 var removeBegin = void 0;
 | |
|                 var removeEnd = existing.parent.offset + existing.parent.length;
 | |
|                 if (propertyIndex > 0) {
 | |
|                     // remove the comma of the previous node
 | |
|                     var previous = parent.children[propertyIndex - 1];
 | |
|                     removeBegin = previous.offset + previous.length;
 | |
|                 }
 | |
|                 else {
 | |
|                     removeBegin = parent.offset + 1;
 | |
|                     if (parent.children.length > 1) {
 | |
|                         // remove the comma of the next node
 | |
|                         var next = parent.children[1];
 | |
|                         removeEnd = next.offset;
 | |
|                     }
 | |
|                 }
 | |
|                 return withFormatting(text, { offset: removeBegin, length: removeEnd - removeBegin, content: '' }, formattingOptions);
 | |
|             }
 | |
|             else {
 | |
|                 // set value of existing property
 | |
|                 return withFormatting(text, { offset: existing.offset, length: existing.length, content: JSON.stringify(value) }, formattingOptions);
 | |
|             }
 | |
|         }
 | |
|         else {
 | |
|             if (value === void 0) {
 | |
|                 return []; // property does not exist, nothing to do
 | |
|             }
 | |
|             var newProperty = JSON.stringify(lastSegment) + ": " + JSON.stringify(value);
 | |
|             var index = getInsertionIndex ? getInsertionIndex(parent.children.map(function (p) { return p.children[0].value; })) : parent.children.length;
 | |
|             var edit = void 0;
 | |
|             if (index > 0) {
 | |
|                 var previous = parent.children[index - 1];
 | |
|                 edit = { offset: previous.offset + previous.length, length: 0, content: ',' + newProperty };
 | |
|             }
 | |
|             else if (parent.children.length === 0) {
 | |
|                 edit = { offset: parent.offset + 1, length: 0, content: newProperty };
 | |
|             }
 | |
|             else {
 | |
|                 edit = { offset: parent.offset + 1, length: 0, content: newProperty + ',' };
 | |
|             }
 | |
|             return withFormatting(text, edit, formattingOptions);
 | |
|         }
 | |
|     }
 | |
|     else if (parent.type === 'array' && typeof lastSegment === 'number' && Array.isArray(parent.children)) {
 | |
|         var insertIndex = lastSegment;
 | |
|         if (insertIndex === -1) {
 | |
|             // Insert
 | |
|             var newProperty = "" + JSON.stringify(value);
 | |
|             var edit = void 0;
 | |
|             if (parent.children.length === 0) {
 | |
|                 edit = { offset: parent.offset + 1, length: 0, content: newProperty };
 | |
|             }
 | |
|             else {
 | |
|                 var previous = parent.children[parent.children.length - 1];
 | |
|                 edit = { offset: previous.offset + previous.length, length: 0, content: ',' + newProperty };
 | |
|             }
 | |
|             return withFormatting(text, edit, formattingOptions);
 | |
|         }
 | |
|         else {
 | |
|             if (value === void 0 && parent.children.length >= 0) {
 | |
|                 //Removal
 | |
|                 var removalIndex = lastSegment;
 | |
|                 var toRemove = parent.children[removalIndex];
 | |
|                 var edit = void 0;
 | |
|                 if (parent.children.length === 1) {
 | |
|                     // only item
 | |
|                     edit = { offset: parent.offset + 1, length: parent.length - 2, content: '' };
 | |
|                 }
 | |
|                 else if (parent.children.length - 1 === removalIndex) {
 | |
|                     // last item
 | |
|                     var previous = parent.children[removalIndex - 1];
 | |
|                     var offset = previous.offset + previous.length;
 | |
|                     var parentEndOffset = parent.offset + parent.length;
 | |
|                     edit = { offset: offset, length: parentEndOffset - 2 - offset, content: '' };
 | |
|                 }
 | |
|                 else {
 | |
|                     edit = { offset: toRemove.offset, length: parent.children[removalIndex + 1].offset - toRemove.offset, content: '' };
 | |
|                 }
 | |
|                 return withFormatting(text, edit, formattingOptions);
 | |
|             }
 | |
|             else {
 | |
|                 throw new Error('Array modification not supported yet');
 | |
|             }
 | |
|         }
 | |
|     }
 | |
|     else {
 | |
|         throw new Error("Can not add " + (typeof lastSegment !== 'number' ? 'index' : 'property') + " to parent of type " + parent.type);
 | |
|     }
 | |
|     var _a;
 | |
| }
 | |
| function withFormatting(text, edit, formattingOptions) {
 | |
|     // apply the edit
 | |
|     var newText = applyEdit(text, edit);
 | |
|     // format the new text
 | |
|     var begin = edit.offset;
 | |
|     var end = edit.offset + edit.content.length;
 | |
|     if (edit.length === 0 || edit.content.length === 0) {
 | |
|         while (begin > 0 && !Object(__WEBPACK_IMPORTED_MODULE_0__format_js__["b" /* isEOL */])(newText, begin - 1)) {
 | |
|             begin--;
 | |
|         }
 | |
|         while (end < newText.length && !Object(__WEBPACK_IMPORTED_MODULE_0__format_js__["b" /* isEOL */])(newText, end)) {
 | |
|             end++;
 | |
|         }
 | |
|     }
 | |
|     var edits = Object(__WEBPACK_IMPORTED_MODULE_0__format_js__["a" /* format */])(newText, { offset: begin, length: end - begin }, formattingOptions);
 | |
|     // apply the formatting edits and track the begin and end offsets of the changes
 | |
|     for (var i = edits.length - 1; i >= 0; i--) {
 | |
|         var edit_1 = edits[i];
 | |
|         newText = applyEdit(newText, edit_1);
 | |
|         begin = Math.min(begin, edit_1.offset);
 | |
|         end = Math.max(end, edit_1.offset + edit_1.length);
 | |
|         end += edit_1.content.length - edit_1.length;
 | |
|     }
 | |
|     // create a single edit with all changes
 | |
|     var editLength = text.length - (newText.length - end) - begin;
 | |
|     return [{ offset: begin, length: editLength, content: newText.substring(begin, end) }];
 | |
| }
 | |
| function applyEdit(text, edit) {
 | |
|     return text.substring(0, edit.offset) + edit.content + text.substring(edit.offset + edit.length);
 | |
| }
 | |
| function isWS(text, offset) {
 | |
|     return '\r\n \t'.indexOf(text.charAt(offset)) !== -1;
 | |
| }
 | |
| //# sourceMappingURL=edit.js.map
 | |
| 
 | |
| /***/ })
 | |
| 
 | |
| }); |