monaco-editor11 1.0.9 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +1 -1
- package/dist/monaco-editor11.es.js +11 -16
- package/dist/monaco-editor11.umd.js +1 -1
- package/package.json +2 -2
- package/dist/monaco.d.ts +0 -8
- package/dist/workers/common/initialize.js +0 -16
- package/dist/workers/common/workers.js +0 -141
- package/dist/workers/editor/common/abstractSyntaxTokenBackend.js +0 -128
- package/dist/workers/editor/common/abstractText.js +0 -89
- package/dist/workers/editor/common/ast.js +0 -485
- package/dist/workers/editor/common/autoIndent.js +0 -390
- package/dist/workers/editor/common/beforeEditPositionMapper.js +0 -110
- package/dist/workers/editor/common/bracketPairsImpl.js +0 -717
- package/dist/workers/editor/common/bracketPairsTree.js +0 -343
- package/dist/workers/editor/common/brackets.js +0 -108
- package/dist/workers/editor/common/characterClassifier.js +0 -59
- package/dist/workers/editor/common/characterPair.js +0 -40
- package/dist/workers/editor/common/colorizedBracketPairsDecorationProvider.js +0 -97
- package/dist/workers/editor/common/columnRange.js +0 -35
- package/dist/workers/editor/common/combineTextEditInfos.js +0 -124
- package/dist/workers/editor/common/common.js +0 -20
- package/dist/workers/editor/common/computeMovedLines.js +0 -249
- package/dist/workers/editor/common/concat23Trees.js +0 -192
- package/dist/workers/editor/common/contiguousMultilineTokens.js +0 -32
- package/dist/workers/editor/common/contiguousMultilineTokensBuilder.js +0 -23
- package/dist/workers/editor/common/contiguousTokensEditing.js +0 -128
- package/dist/workers/editor/common/contiguousTokensStore.js +0 -207
- package/dist/workers/editor/common/coordinatesConverter.js +0 -51
- package/dist/workers/editor/common/cursor.js +0 -899
- package/dist/workers/editor/common/cursorAtomicMoveOperations.js +0 -145
- package/dist/workers/editor/common/cursorCollection.js +0 -194
- package/dist/workers/editor/common/cursorColumnSelection.js +0 -93
- package/dist/workers/editor/common/cursorColumns.js +0 -112
- package/dist/workers/editor/common/cursorCommon.js +0 -250
- package/dist/workers/editor/common/cursorContext.js +0 -15
- package/dist/workers/editor/common/cursorDeleteOperations.js +0 -231
- package/dist/workers/editor/common/cursorMoveCommands.js +0 -676
- package/dist/workers/editor/common/cursorMoveOperations.js +0 -290
- package/dist/workers/editor/common/cursorTypeEditOperations.js +0 -968
- package/dist/workers/editor/common/cursorTypeOperations.js +0 -173
- package/dist/workers/editor/common/cursorUtils.js +0 -75
- package/dist/workers/editor/common/cursorWordOperations.js +0 -720
- package/dist/workers/editor/common/defaultDocumentColorsComputer.js +0 -138
- package/dist/workers/editor/common/defaultLinesDiffComputer.js +0 -188
- package/dist/workers/editor/common/diffAlgorithm.js +0 -139
- package/dist/workers/editor/common/diffEditor.js +0 -38
- package/dist/workers/editor/common/dynamicProgrammingDiffing.js +0 -101
- package/dist/workers/editor/common/edit.js +0 -183
- package/dist/workers/editor/common/editOperation.js +0 -36
- package/dist/workers/editor/common/editStack.js +0 -363
- package/dist/workers/editor/common/editorAction.js +0 -26
- package/dist/workers/editor/common/editorBaseApi.js +0 -43
- package/dist/workers/editor/common/editorColorRegistry.js +0 -102
- package/dist/workers/editor/common/editorCommon.js +0 -13
- package/dist/workers/editor/common/editorConfigurationSchema.js +0 -338
- package/dist/workers/editor/common/editorContextKeys.js +0 -84
- package/dist/workers/editor/common/editorFeatures.js +0 -17
- package/dist/workers/editor/common/editorOptions.js +0 -3440
- package/dist/workers/editor/common/editorTheme.js +0 -23
- package/dist/workers/editor/common/editorWebWorker.js +0 -299
- package/dist/workers/editor/common/editorWorker.js +0 -9
- package/dist/workers/editor/common/editorWorkerHost.js +0 -15
- package/dist/workers/editor/common/editorZoom.js +0 -26
- package/dist/workers/editor/common/electricCharacter.js +0 -55
- package/dist/workers/editor/common/encodedTokenAttributes.js +0 -79
- package/dist/workers/editor/common/enterAction.js +0 -53
- package/dist/workers/editor/common/eolCounter.js +0 -44
- package/dist/workers/editor/common/findSectionHeaders.js +0 -128
- package/dist/workers/editor/common/fixBrackets.js +0 -67
- package/dist/workers/editor/common/fixedArray.js +0 -70
- package/dist/workers/editor/common/fontInfo.js +0 -172
- package/dist/workers/editor/common/fontInfoFromSettings.js +0 -29
- package/dist/workers/editor/common/getIconClasses.js +0 -106
- package/dist/workers/editor/common/getPositionOffsetTransformerFromTextModel.js +0 -24
- package/dist/workers/editor/common/glyphLanesModel.js +0 -61
- package/dist/workers/editor/common/guidesTextModelPart.js +0 -405
- package/dist/workers/editor/common/heuristicSequenceOptimizations.js +0 -374
- package/dist/workers/editor/common/indentRules.js +0 -63
- package/dist/workers/editor/common/indentation.js +0 -39
- package/dist/workers/editor/common/indentationGuesser.js +0 -178
- package/dist/workers/editor/common/indentationLineProcessor.js +0 -193
- package/dist/workers/editor/common/inlineDecorations.js +0 -26
- package/dist/workers/editor/common/inplaceReplaceSupport.js +0 -87
- package/dist/workers/editor/common/inputMode.js +0 -22
- package/dist/workers/editor/common/intervalTree.js +0 -1002
- package/dist/workers/editor/common/language.js +0 -9
- package/dist/workers/editor/common/languageBracketsConfiguration.js +0 -133
- package/dist/workers/editor/common/languageConfiguration.js +0 -138
- package/dist/workers/editor/common/languageConfigurationRegistry.js +0 -361
- package/dist/workers/editor/common/languageFeatureDebounce.js +0 -137
- package/dist/workers/editor/common/languageFeatureRegistry.js +0 -180
- package/dist/workers/editor/common/languageFeatures.js +0 -9
- package/dist/workers/editor/common/languageFeaturesService.js +0 -47
- package/dist/workers/editor/common/languageSelector.js +0 -112
- package/dist/workers/editor/common/languageService.js +0 -92
- package/dist/workers/editor/common/languages.js +0 -522
- package/dist/workers/editor/common/languagesAssociations.js +0 -193
- package/dist/workers/editor/common/languagesRegistry.js +0 -237
- package/dist/workers/editor/common/legacyLinesDiffComputer.js +0 -468
- package/dist/workers/editor/common/length.js +0 -129
- package/dist/workers/editor/common/lineDecorations.js +0 -208
- package/dist/workers/editor/common/lineEdit.js +0 -75
- package/dist/workers/editor/common/lineHeights.js +0 -370
- package/dist/workers/editor/common/linePart.js +0 -25
- package/dist/workers/editor/common/lineRange.js +0 -312
- package/dist/workers/editor/common/lineSequence.js +0 -36
- package/dist/workers/editor/common/lineTokens.js +0 -405
- package/dist/workers/editor/common/linesDiffComputer.js +0 -29
- package/dist/workers/editor/common/linesDiffComputers.js +0 -13
- package/dist/workers/editor/common/linesLayout.js +0 -765
- package/dist/workers/editor/common/linesSliceCharSequence.js +0 -205
- package/dist/workers/editor/common/linkComputer.js +0 -269
- package/dist/workers/editor/common/markerDecorations.js +0 -9
- package/dist/workers/editor/common/markerDecorationsService.js +0 -248
- package/dist/workers/editor/common/minimapTokensColorTracker.js +0 -58
- package/dist/workers/editor/common/mirrorTextModel.js +0 -117
- package/dist/workers/editor/common/model.js +0 -9
- package/dist/workers/editor/common/modelLineProjection.js +0 -350
- package/dist/workers/editor/common/modelLineProjectionData.js +0 -297
- package/dist/workers/editor/common/modelService.js +0 -413
- package/dist/workers/editor/common/modesRegistry.js +0 -75
- package/dist/workers/editor/common/monospaceLineBreaksComputer.js +0 -473
- package/dist/workers/editor/common/myersDiffAlgorithm.js +0 -159
- package/dist/workers/editor/common/nodeReader.js +0 -127
- package/dist/workers/editor/common/nullTokenize.js +0 -29
- package/dist/workers/editor/common/offsetRange.js +0 -225
- package/dist/workers/editor/common/onEnter.js +0 -109
- package/dist/workers/editor/common/oneCursor.js +0 -117
- package/dist/workers/editor/common/overviewZoneManager.js +0 -176
- package/dist/workers/editor/common/parser.js +0 -121
- package/dist/workers/editor/common/pieceTreeBase.js +0 -1473
- package/dist/workers/editor/common/pieceTreeTextBuffer.js +0 -461
- package/dist/workers/editor/common/pieceTreeTextBufferBuilder.js +0 -140
- package/dist/workers/editor/common/point.js +0 -50
- package/dist/workers/editor/common/position.js +0 -142
- package/dist/workers/editor/common/positionToOffset.js +0 -17
- package/dist/workers/editor/common/positionToOffsetImpl.js +0 -98
- package/dist/workers/editor/common/prefixSumComputer.js +0 -226
- package/dist/workers/editor/common/range.js +0 -421
- package/dist/workers/editor/common/rangeMapping.js +0 -229
- package/dist/workers/editor/common/rangeSingleLine.js +0 -17
- package/dist/workers/editor/common/rbTreeBase.js +0 -362
- package/dist/workers/editor/common/rect.js +0 -163
- package/dist/workers/editor/common/replaceCommand.js +0 -158
- package/dist/workers/editor/common/resolverService.js +0 -5
- package/dist/workers/editor/common/rgba.js +0 -35
- package/dist/workers/editor/common/richEditBrackets.js +0 -356
- package/dist/workers/editor/common/selection.js +0 -145
- package/dist/workers/editor/common/semanticTokensDto.js +0 -82
- package/dist/workers/editor/common/semanticTokensProviderStyling.js +0 -263
- package/dist/workers/editor/common/semanticTokensStyling.js +0 -9
- package/dist/workers/editor/common/semanticTokensStylingService.js +0 -47
- package/dist/workers/editor/common/shiftCommand.js +0 -241
- package/dist/workers/editor/common/smallImmutableSet.js +0 -108
- package/dist/workers/editor/common/sparseMultilineTokens.js +0 -548
- package/dist/workers/editor/common/sparseTokensStore.js +0 -210
- package/dist/workers/editor/common/standaloneEnums.js +0 -1017
- package/dist/workers/editor/common/standaloneStrings.js +0 -42
- package/dist/workers/editor/common/stringBuilder.js +0 -122
- package/dist/workers/editor/common/stringEdit.js +0 -165
- package/dist/workers/editor/common/supports.js +0 -58
- package/dist/workers/editor/common/surroundSelectionCommand.js +0 -44
- package/dist/workers/editor/common/textChange.js +0 -248
- package/dist/workers/editor/common/textEdit.js +0 -269
- package/dist/workers/editor/common/textLength.js +0 -87
- package/dist/workers/editor/common/textModel.js +0 -2031
- package/dist/workers/editor/common/textModelBracketPairs.js +0 -45
- package/dist/workers/editor/common/textModelDefaults.js +0 -18
- package/dist/workers/editor/common/textModelEditSource.js +0 -166
- package/dist/workers/editor/common/textModelEvents.js +0 -216
- package/dist/workers/editor/common/textModelGuides.js +0 -40
- package/dist/workers/editor/common/textModelPart.js +0 -23
- package/dist/workers/editor/common/textModelSearch.js +0 -455
- package/dist/workers/editor/common/textModelStringEdit.js +0 -11
- package/dist/workers/editor/common/textModelSync.impl.js +0 -307
- package/dist/workers/editor/common/textModelText.js +0 -26
- package/dist/workers/editor/common/textModelTokens.js +0 -436
- package/dist/workers/editor/common/textResourceConfiguration.js +0 -6
- package/dist/workers/editor/common/textToHtmlTokenizer.js +0 -139
- package/dist/workers/editor/common/tokenStore.js +0 -407
- package/dist/workers/editor/common/tokenWithTextArray.js +0 -73
- package/dist/workers/editor/common/tokenization.js +0 -287
- package/dist/workers/editor/common/tokenizationRegistry.js +0 -123
- package/dist/workers/editor/common/tokenizationTextModelPart.js +0 -275
- package/dist/workers/editor/common/tokenizer.js +0 -301
- package/dist/workers/editor/common/tokenizerSyntaxTokenBackend.js +0 -261
- package/dist/workers/editor/common/treeSitterLibraryService.js +0 -9
- package/dist/workers/editor/common/treeSitterSyntaxTokenBackend.js +0 -167
- package/dist/workers/editor/common/treeSitterThemeService.js +0 -9
- package/dist/workers/editor/common/treeSitterTokenizationImpl.js +0 -713
- package/dist/workers/editor/common/treeSitterTree.js +0 -395
- package/dist/workers/editor/common/treeViewsDnd.js +0 -24
- package/dist/workers/editor/common/treeViewsDndService.js +0 -12
- package/dist/workers/editor/common/trimTrailingWhitespaceCommand.js +0 -98
- package/dist/workers/editor/common/unicodeTextModelHighlighter.js +0 -188
- package/dist/workers/editor/common/utils.js +0 -62
- package/dist/workers/editor/common/viewContext.js +0 -22
- package/dist/workers/editor/common/viewEventHandler.js +0 -186
- package/dist/workers/editor/common/viewEvents.js +0 -180
- package/dist/workers/editor/common/viewLayout.js +0 -368
- package/dist/workers/editor/common/viewLineRenderer.js +0 -948
- package/dist/workers/editor/common/viewLinesViewportData.js +0 -30
- package/dist/workers/editor/common/viewModel.js +0 -98
- package/dist/workers/editor/common/viewModelDecoration.js +0 -55
- package/dist/workers/editor/common/viewModelDecorations.js +0 -132
- package/dist/workers/editor/common/viewModelEventDispatcher.js +0 -398
- package/dist/workers/editor/common/viewModelImpl.js +0 -1163
- package/dist/workers/editor/common/viewModelLines.js +0 -938
- package/dist/workers/editor/common/wordCharacterClassifier.js +0 -87
- package/dist/workers/editor/common/wordHelper.js +0 -127
- package/dist/workers/language/cssMode.js +0 -198
- package/dist/workers/language/cssWorker.js +0 -183
- package/dist/workers/language/htmlMode.js +0 -213
- package/dist/workers/language/htmlWorker.js +0 -126
- package/dist/workers/language/jsonMode.js +0 -224
- package/dist/workers/language/jsonWorker.js +0 -187
- package/dist/workers/language/languageFeatures.js +0 -1009
- package/dist/workers/language/lib.index.js +0 -103
- package/dist/workers/language/lib.js +0 -1107
- package/dist/workers/language/lspLanguageFeatures.js +0 -716
- package/dist/workers/language/monaco.contribution.js +0 -144
- package/dist/workers/language/tokenization.js +0 -189
- package/dist/workers/language/tsMode.js +0 -212
- package/dist/workers/language/tsWorker.js +0 -352
- package/dist/workers/language/typescriptServices.js +0 -210154
- package/dist/workers/language/typescriptServicesMetadata.js +0 -3
- package/dist/workers/language/workerManager.js +0 -65
- /package/dist/workers/{language/css.worker.js → css.worker.js} +0 -0
- /package/dist/workers/{editor/editor.worker.js → editor.worker.js} +0 -0
- /package/dist/workers/{language/html.worker.js → html.worker.js} +0 -0
- /package/dist/workers/{language/json.worker.js → json.worker.js} +0 -0
- /package/dist/workers/{language/ts.worker.js → ts.worker.js} +0 -0
|
@@ -1,193 +0,0 @@
|
|
|
1
|
-
import { getLeadingWhitespace } from '../../../../base/common/strings.js';
|
|
2
|
-
import { createScopedLineTokens } from '../supports.js';
|
|
3
|
-
import { LineTokens } from '../../tokens/lineTokens.js';
|
|
4
|
-
|
|
5
|
-
/*---------------------------------------------------------------------------------------------
|
|
6
|
-
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
7
|
-
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
8
|
-
*--------------------------------------------------------------------------------------------*/
|
|
9
|
-
/**
|
|
10
|
-
* This class is a wrapper class around {@link IndentRulesSupport}.
|
|
11
|
-
* It processes the lines by removing the language configuration brackets from the regex, string and comment tokens.
|
|
12
|
-
* It then calls into the {@link IndentRulesSupport} to validate the indentation conditions.
|
|
13
|
-
*/
|
|
14
|
-
class ProcessedIndentRulesSupport {
|
|
15
|
-
constructor(model, indentRulesSupport, languageConfigurationService) {
|
|
16
|
-
this._indentRulesSupport = indentRulesSupport;
|
|
17
|
-
this._indentationLineProcessor = new IndentationLineProcessor(model, languageConfigurationService);
|
|
18
|
-
}
|
|
19
|
-
/**
|
|
20
|
-
* Apply the new indentation and return whether the indentation level should be increased after the given line number
|
|
21
|
-
*/
|
|
22
|
-
shouldIncrease(lineNumber, newIndentation) {
|
|
23
|
-
const processedLine = this._indentationLineProcessor.getProcessedLine(lineNumber, newIndentation);
|
|
24
|
-
return this._indentRulesSupport.shouldIncrease(processedLine);
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* Apply the new indentation and return whether the indentation level should be decreased after the given line number
|
|
28
|
-
*/
|
|
29
|
-
shouldDecrease(lineNumber, newIndentation) {
|
|
30
|
-
const processedLine = this._indentationLineProcessor.getProcessedLine(lineNumber, newIndentation);
|
|
31
|
-
return this._indentRulesSupport.shouldDecrease(processedLine);
|
|
32
|
-
}
|
|
33
|
-
/**
|
|
34
|
-
* Apply the new indentation and return whether the indentation level should remain unchanged at the given line number
|
|
35
|
-
*/
|
|
36
|
-
shouldIgnore(lineNumber, newIndentation) {
|
|
37
|
-
const processedLine = this._indentationLineProcessor.getProcessedLine(lineNumber, newIndentation);
|
|
38
|
-
return this._indentRulesSupport.shouldIgnore(processedLine);
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Apply the new indentation and return whether the indentation level should increase on the line after the given line number
|
|
42
|
-
*/
|
|
43
|
-
shouldIndentNextLine(lineNumber, newIndentation) {
|
|
44
|
-
const processedLine = this._indentationLineProcessor.getProcessedLine(lineNumber, newIndentation);
|
|
45
|
-
return this._indentRulesSupport.shouldIndentNextLine(processedLine);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
/**
|
|
49
|
-
* This class fetches the processed text around a range which can be used for indentation evaluation.
|
|
50
|
-
* It returns:
|
|
51
|
-
* - The processed text before the given range and on the same start line
|
|
52
|
-
* - The processed text after the given range and on the same end line
|
|
53
|
-
* - The processed text on the previous line
|
|
54
|
-
*/
|
|
55
|
-
class IndentationContextProcessor {
|
|
56
|
-
constructor(model, languageConfigurationService) {
|
|
57
|
-
this.model = model;
|
|
58
|
-
this.indentationLineProcessor = new IndentationLineProcessor(model, languageConfigurationService);
|
|
59
|
-
}
|
|
60
|
-
/**
|
|
61
|
-
* Returns the processed text, stripped from the language configuration brackets within the string, comment and regex tokens, around the given range
|
|
62
|
-
*/
|
|
63
|
-
getProcessedTokenContextAroundRange(range) {
|
|
64
|
-
const beforeRangeProcessedTokens = this._getProcessedTokensBeforeRange(range);
|
|
65
|
-
const afterRangeProcessedTokens = this._getProcessedTokensAfterRange(range);
|
|
66
|
-
const previousLineProcessedTokens = this._getProcessedPreviousLineTokens(range);
|
|
67
|
-
return { beforeRangeProcessedTokens, afterRangeProcessedTokens, previousLineProcessedTokens };
|
|
68
|
-
}
|
|
69
|
-
_getProcessedTokensBeforeRange(range) {
|
|
70
|
-
this.model.tokenization.forceTokenization(range.startLineNumber);
|
|
71
|
-
const lineTokens = this.model.tokenization.getLineTokens(range.startLineNumber);
|
|
72
|
-
const scopedLineTokens = createScopedLineTokens(lineTokens, range.startColumn - 1);
|
|
73
|
-
let slicedTokens;
|
|
74
|
-
if (isLanguageDifferentFromLineStart(this.model, range.getStartPosition())) {
|
|
75
|
-
const columnIndexWithinScope = (range.startColumn - 1) - scopedLineTokens.firstCharOffset;
|
|
76
|
-
const firstCharacterOffset = scopedLineTokens.firstCharOffset;
|
|
77
|
-
const lastCharacterOffset = firstCharacterOffset + columnIndexWithinScope;
|
|
78
|
-
slicedTokens = lineTokens.sliceAndInflate(firstCharacterOffset, lastCharacterOffset, 0);
|
|
79
|
-
}
|
|
80
|
-
else {
|
|
81
|
-
const columnWithinLine = range.startColumn - 1;
|
|
82
|
-
slicedTokens = lineTokens.sliceAndInflate(0, columnWithinLine, 0);
|
|
83
|
-
}
|
|
84
|
-
const processedTokens = this.indentationLineProcessor.getProcessedTokens(slicedTokens);
|
|
85
|
-
return processedTokens;
|
|
86
|
-
}
|
|
87
|
-
_getProcessedTokensAfterRange(range) {
|
|
88
|
-
const position = range.isEmpty() ? range.getStartPosition() : range.getEndPosition();
|
|
89
|
-
this.model.tokenization.forceTokenization(position.lineNumber);
|
|
90
|
-
const lineTokens = this.model.tokenization.getLineTokens(position.lineNumber);
|
|
91
|
-
const scopedLineTokens = createScopedLineTokens(lineTokens, position.column - 1);
|
|
92
|
-
const columnIndexWithinScope = position.column - 1 - scopedLineTokens.firstCharOffset;
|
|
93
|
-
const firstCharacterOffset = scopedLineTokens.firstCharOffset + columnIndexWithinScope;
|
|
94
|
-
const lastCharacterOffset = scopedLineTokens.firstCharOffset + scopedLineTokens.getLineLength();
|
|
95
|
-
const slicedTokens = lineTokens.sliceAndInflate(firstCharacterOffset, lastCharacterOffset, 0);
|
|
96
|
-
const processedTokens = this.indentationLineProcessor.getProcessedTokens(slicedTokens);
|
|
97
|
-
return processedTokens;
|
|
98
|
-
}
|
|
99
|
-
_getProcessedPreviousLineTokens(range) {
|
|
100
|
-
const getScopedLineTokensAtEndColumnOfLine = (lineNumber) => {
|
|
101
|
-
this.model.tokenization.forceTokenization(lineNumber);
|
|
102
|
-
const lineTokens = this.model.tokenization.getLineTokens(lineNumber);
|
|
103
|
-
const endColumnOfLine = this.model.getLineMaxColumn(lineNumber) - 1;
|
|
104
|
-
const scopedLineTokensAtEndColumn = createScopedLineTokens(lineTokens, endColumnOfLine);
|
|
105
|
-
return scopedLineTokensAtEndColumn;
|
|
106
|
-
};
|
|
107
|
-
this.model.tokenization.forceTokenization(range.startLineNumber);
|
|
108
|
-
const lineTokens = this.model.tokenization.getLineTokens(range.startLineNumber);
|
|
109
|
-
const scopedLineTokens = createScopedLineTokens(lineTokens, range.startColumn - 1);
|
|
110
|
-
const emptyTokens = LineTokens.createEmpty('', scopedLineTokens.languageIdCodec);
|
|
111
|
-
const previousLineNumber = range.startLineNumber - 1;
|
|
112
|
-
const isFirstLine = previousLineNumber === 0;
|
|
113
|
-
if (isFirstLine) {
|
|
114
|
-
return emptyTokens;
|
|
115
|
-
}
|
|
116
|
-
const canScopeExtendOnPreviousLine = scopedLineTokens.firstCharOffset === 0;
|
|
117
|
-
if (!canScopeExtendOnPreviousLine) {
|
|
118
|
-
return emptyTokens;
|
|
119
|
-
}
|
|
120
|
-
const scopedLineTokensAtEndColumnOfPreviousLine = getScopedLineTokensAtEndColumnOfLine(previousLineNumber);
|
|
121
|
-
const doesLanguageContinueOnPreviousLine = scopedLineTokens.languageId === scopedLineTokensAtEndColumnOfPreviousLine.languageId;
|
|
122
|
-
if (!doesLanguageContinueOnPreviousLine) {
|
|
123
|
-
return emptyTokens;
|
|
124
|
-
}
|
|
125
|
-
const previousSlicedLineTokens = scopedLineTokensAtEndColumnOfPreviousLine.toIViewLineTokens();
|
|
126
|
-
const processedTokens = this.indentationLineProcessor.getProcessedTokens(previousSlicedLineTokens);
|
|
127
|
-
return processedTokens;
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
/**
|
|
131
|
-
* This class performs the actual processing of the indentation lines.
|
|
132
|
-
* The brackets of the language configuration are removed from the regex, string and comment tokens.
|
|
133
|
-
*/
|
|
134
|
-
class IndentationLineProcessor {
|
|
135
|
-
constructor(model, languageConfigurationService) {
|
|
136
|
-
this.model = model;
|
|
137
|
-
this.languageConfigurationService = languageConfigurationService;
|
|
138
|
-
}
|
|
139
|
-
/**
|
|
140
|
-
* Get the processed line for the given line number and potentially adjust the indentation level.
|
|
141
|
-
* Remove the language configuration brackets from the regex, string and comment tokens.
|
|
142
|
-
*/
|
|
143
|
-
getProcessedLine(lineNumber, newIndentation) {
|
|
144
|
-
const replaceIndentation = (line, newIndentation) => {
|
|
145
|
-
const currentIndentation = getLeadingWhitespace(line);
|
|
146
|
-
const adjustedLine = newIndentation + line.substring(currentIndentation.length);
|
|
147
|
-
return adjustedLine;
|
|
148
|
-
};
|
|
149
|
-
this.model.tokenization.forceTokenization?.(lineNumber);
|
|
150
|
-
const tokens = this.model.tokenization.getLineTokens(lineNumber);
|
|
151
|
-
let processedLine = this.getProcessedTokens(tokens).getLineContent();
|
|
152
|
-
if (newIndentation !== undefined) {
|
|
153
|
-
processedLine = replaceIndentation(processedLine, newIndentation);
|
|
154
|
-
}
|
|
155
|
-
return processedLine;
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* Process the line with the given tokens, remove the language configuration brackets from the regex, string and comment tokens.
|
|
159
|
-
*/
|
|
160
|
-
getProcessedTokens(tokens) {
|
|
161
|
-
const shouldRemoveBracketsFromTokenType = (tokenType) => {
|
|
162
|
-
return tokenType === 2 /* StandardTokenType.String */
|
|
163
|
-
|| tokenType === 3 /* StandardTokenType.RegEx */
|
|
164
|
-
|| tokenType === 1 /* StandardTokenType.Comment */;
|
|
165
|
-
};
|
|
166
|
-
const languageId = tokens.getLanguageId(0);
|
|
167
|
-
const bracketsConfiguration = this.languageConfigurationService.getLanguageConfiguration(languageId).bracketsNew;
|
|
168
|
-
const bracketsRegExp = bracketsConfiguration.getBracketRegExp({ global: true });
|
|
169
|
-
const textAndMetadata = [];
|
|
170
|
-
tokens.forEach((tokenIndex) => {
|
|
171
|
-
const tokenType = tokens.getStandardTokenType(tokenIndex);
|
|
172
|
-
let text = tokens.getTokenText(tokenIndex);
|
|
173
|
-
if (shouldRemoveBracketsFromTokenType(tokenType)) {
|
|
174
|
-
text = text.replace(bracketsRegExp, '');
|
|
175
|
-
}
|
|
176
|
-
const metadata = tokens.getMetadata(tokenIndex);
|
|
177
|
-
textAndMetadata.push({ text, metadata });
|
|
178
|
-
});
|
|
179
|
-
const processedLineTokens = LineTokens.createFromTextAndMetadata(textAndMetadata, tokens.languageIdCodec);
|
|
180
|
-
return processedLineTokens;
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
function isLanguageDifferentFromLineStart(model, position) {
|
|
184
|
-
model.tokenization.forceTokenization(position.lineNumber);
|
|
185
|
-
const lineTokens = model.tokenization.getLineTokens(position.lineNumber);
|
|
186
|
-
const scopedLineTokens = createScopedLineTokens(lineTokens, position.column - 1);
|
|
187
|
-
const doesScopeStartAtOffsetZero = scopedLineTokens.firstCharOffset === 0;
|
|
188
|
-
const isScopedLanguageEqualToFirstLanguageOnLine = lineTokens.getLanguageId(0) === scopedLineTokens.languageId;
|
|
189
|
-
const languageIsDifferentFromLineStart = !doesScopeStartAtOffsetZero && !isScopedLanguageEqualToFirstLanguageOnLine;
|
|
190
|
-
return languageIsDifferentFromLineStart;
|
|
191
|
-
}
|
|
192
|
-
|
|
193
|
-
export { IndentationContextProcessor, ProcessedIndentRulesSupport, isLanguageDifferentFromLineStart };
|
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { Range } from '../core/range.js';
|
|
2
|
-
|
|
3
|
-
/*---------------------------------------------------------------------------------------------
|
|
4
|
-
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
5
|
-
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
6
|
-
*--------------------------------------------------------------------------------------------*/
|
|
7
|
-
class InlineDecoration {
|
|
8
|
-
constructor(range, inlineClassName, type) {
|
|
9
|
-
this.range = range;
|
|
10
|
-
this.inlineClassName = inlineClassName;
|
|
11
|
-
this.type = type;
|
|
12
|
-
}
|
|
13
|
-
}
|
|
14
|
-
class SingleLineInlineDecoration {
|
|
15
|
-
constructor(startOffset, endOffset, inlineClassName, inlineClassNameAffectsLetterSpacing) {
|
|
16
|
-
this.startOffset = startOffset;
|
|
17
|
-
this.endOffset = endOffset;
|
|
18
|
-
this.inlineClassName = inlineClassName;
|
|
19
|
-
this.inlineClassNameAffectsLetterSpacing = inlineClassNameAffectsLetterSpacing;
|
|
20
|
-
}
|
|
21
|
-
toInlineDecoration(lineNumber) {
|
|
22
|
-
return new InlineDecoration(new Range(lineNumber, this.startOffset + 1, lineNumber, this.endOffset + 1), this.inlineClassName, this.inlineClassNameAffectsLetterSpacing ? 3 /* InlineDecorationType.RegularAffectingLetterSpacing */ : 0 /* InlineDecorationType.Regular */);
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
export { InlineDecoration, SingleLineInlineDecoration };
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
/*---------------------------------------------------------------------------------------------
|
|
2
|
-
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
3
|
-
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
4
|
-
*--------------------------------------------------------------------------------------------*/
|
|
5
|
-
class BasicInplaceReplace {
|
|
6
|
-
constructor() {
|
|
7
|
-
this._defaultValueSet = [
|
|
8
|
-
['true', 'false'],
|
|
9
|
-
['True', 'False'],
|
|
10
|
-
['Private', 'Public', 'Friend', 'ReadOnly', 'Partial', 'Protected', 'WriteOnly'],
|
|
11
|
-
['public', 'protected', 'private'],
|
|
12
|
-
];
|
|
13
|
-
}
|
|
14
|
-
static { this.INSTANCE = new BasicInplaceReplace(); }
|
|
15
|
-
navigateValueSet(range1, text1, range2, text2, up) {
|
|
16
|
-
if (range1 && text1) {
|
|
17
|
-
const result = this.doNavigateValueSet(text1, up);
|
|
18
|
-
if (result) {
|
|
19
|
-
return {
|
|
20
|
-
range: range1,
|
|
21
|
-
value: result
|
|
22
|
-
};
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
if (range2 && text2) {
|
|
26
|
-
const result = this.doNavigateValueSet(text2, up);
|
|
27
|
-
if (result) {
|
|
28
|
-
return {
|
|
29
|
-
range: range2,
|
|
30
|
-
value: result
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
return null;
|
|
35
|
-
}
|
|
36
|
-
doNavigateValueSet(text, up) {
|
|
37
|
-
const numberResult = this.numberReplace(text, up);
|
|
38
|
-
if (numberResult !== null) {
|
|
39
|
-
return numberResult;
|
|
40
|
-
}
|
|
41
|
-
return this.textReplace(text, up);
|
|
42
|
-
}
|
|
43
|
-
numberReplace(value, up) {
|
|
44
|
-
const precision = Math.pow(10, value.length - (value.lastIndexOf('.') + 1));
|
|
45
|
-
let n1 = Number(value);
|
|
46
|
-
const n2 = parseFloat(value);
|
|
47
|
-
if (!isNaN(n1) && !isNaN(n2) && n1 === n2) {
|
|
48
|
-
if (n1 === 0 && !up) {
|
|
49
|
-
return null; // don't do negative
|
|
50
|
-
// } else if(n1 === 9 && up) {
|
|
51
|
-
// return null; // don't insert 10 into a number
|
|
52
|
-
}
|
|
53
|
-
else {
|
|
54
|
-
n1 = Math.floor(n1 * precision);
|
|
55
|
-
n1 += up ? precision : -precision;
|
|
56
|
-
return String(n1 / precision);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
return null;
|
|
60
|
-
}
|
|
61
|
-
textReplace(value, up) {
|
|
62
|
-
return this.valueSetsReplace(this._defaultValueSet, value, up);
|
|
63
|
-
}
|
|
64
|
-
valueSetsReplace(valueSets, value, up) {
|
|
65
|
-
let result = null;
|
|
66
|
-
for (let i = 0, len = valueSets.length; result === null && i < len; i++) {
|
|
67
|
-
result = this.valueSetReplace(valueSets[i], value, up);
|
|
68
|
-
}
|
|
69
|
-
return result;
|
|
70
|
-
}
|
|
71
|
-
valueSetReplace(valueSet, value, up) {
|
|
72
|
-
let idx = valueSet.indexOf(value);
|
|
73
|
-
if (idx >= 0) {
|
|
74
|
-
idx += up ? 1 : -1;
|
|
75
|
-
if (idx < 0) {
|
|
76
|
-
idx = valueSet.length - 1;
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
idx %= valueSet.length;
|
|
80
|
-
}
|
|
81
|
-
return valueSet[idx];
|
|
82
|
-
}
|
|
83
|
-
return null;
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
export { BasicInplaceReplace };
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import { Emitter } from '../../base/common/event.js';
|
|
2
|
-
|
|
3
|
-
/*---------------------------------------------------------------------------------------------
|
|
4
|
-
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
5
|
-
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
6
|
-
*--------------------------------------------------------------------------------------------*/
|
|
7
|
-
class InputModeImpl {
|
|
8
|
-
constructor() {
|
|
9
|
-
this._inputMode = 'insert';
|
|
10
|
-
this._onDidChangeInputMode = new Emitter();
|
|
11
|
-
this.onDidChangeInputMode = this._onDidChangeInputMode.event;
|
|
12
|
-
}
|
|
13
|
-
getInputMode() {
|
|
14
|
-
return this._inputMode;
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
/**
|
|
18
|
-
* Controls the type mode, whether insert or overtype
|
|
19
|
-
*/
|
|
20
|
-
const InputMode = new InputModeImpl();
|
|
21
|
-
|
|
22
|
-
export { InputMode };
|