monaco-editor11 1.0.7 → 1.0.9
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/assets/css.worker-C7FogG4G.js +93 -0
- package/dist/assets/editor.worker-iXcRX1Tq.js +26 -0
- package/dist/assets/html.worker-C8VxctEJ.js +470 -0
- package/dist/assets/json.worker-CMC9kgPL.js +58 -0
- package/dist/assets/ts.worker-CtTJ3hNN.js +67731 -0
- package/dist/index.d.ts +0 -6
- package/dist/monaco-editor11.es.js +49 -78
- package/dist/monaco-editor11.umd.js +1 -50
- package/dist/monaco.d.ts +8 -0
- package/dist/workers/common/initialize.js +16 -0
- package/dist/workers/common/workers.js +141 -0
- package/dist/workers/editor/common/abstractSyntaxTokenBackend.js +128 -0
- package/dist/workers/editor/common/abstractText.js +89 -0
- package/dist/workers/editor/common/ast.js +485 -0
- package/dist/workers/editor/common/autoIndent.js +390 -0
- package/dist/workers/editor/common/beforeEditPositionMapper.js +110 -0
- package/dist/workers/editor/common/bracketPairsImpl.js +717 -0
- package/dist/workers/editor/common/bracketPairsTree.js +343 -0
- package/dist/workers/editor/common/brackets.js +108 -0
- package/dist/workers/editor/common/characterClassifier.js +59 -0
- package/dist/workers/editor/common/characterPair.js +40 -0
- package/dist/workers/editor/common/colorizedBracketPairsDecorationProvider.js +97 -0
- package/dist/workers/editor/common/columnRange.js +35 -0
- package/dist/workers/editor/common/combineTextEditInfos.js +124 -0
- package/dist/workers/editor/common/common.js +20 -0
- package/dist/workers/editor/common/computeMovedLines.js +249 -0
- package/dist/workers/editor/common/concat23Trees.js +192 -0
- package/dist/workers/editor/common/contiguousMultilineTokens.js +32 -0
- package/dist/workers/editor/common/contiguousMultilineTokensBuilder.js +23 -0
- package/dist/workers/editor/common/contiguousTokensEditing.js +128 -0
- package/dist/workers/editor/common/contiguousTokensStore.js +207 -0
- package/dist/workers/editor/common/coordinatesConverter.js +51 -0
- package/dist/workers/editor/common/cursor.js +899 -0
- package/dist/workers/editor/common/cursorAtomicMoveOperations.js +145 -0
- package/dist/workers/editor/common/cursorCollection.js +194 -0
- package/dist/workers/editor/common/cursorColumnSelection.js +93 -0
- package/dist/workers/editor/common/cursorColumns.js +112 -0
- package/dist/workers/editor/common/cursorCommon.js +250 -0
- package/dist/workers/editor/common/cursorContext.js +15 -0
- package/dist/workers/editor/common/cursorDeleteOperations.js +231 -0
- package/dist/workers/editor/common/cursorMoveCommands.js +676 -0
- package/dist/workers/editor/common/cursorMoveOperations.js +290 -0
- package/dist/workers/editor/common/cursorTypeEditOperations.js +968 -0
- package/dist/workers/editor/common/cursorTypeOperations.js +173 -0
- package/dist/workers/editor/common/cursorUtils.js +75 -0
- package/dist/workers/editor/common/cursorWordOperations.js +720 -0
- package/dist/workers/editor/common/defaultDocumentColorsComputer.js +138 -0
- package/dist/workers/editor/common/defaultLinesDiffComputer.js +188 -0
- package/dist/workers/editor/common/diffAlgorithm.js +139 -0
- package/dist/workers/editor/common/diffEditor.js +38 -0
- package/dist/workers/editor/common/dynamicProgrammingDiffing.js +101 -0
- package/dist/workers/editor/common/edit.js +183 -0
- package/dist/workers/editor/common/editOperation.js +36 -0
- package/dist/workers/editor/common/editStack.js +363 -0
- package/dist/workers/editor/common/editorAction.js +26 -0
- package/dist/workers/editor/common/editorBaseApi.js +43 -0
- package/dist/workers/editor/common/editorColorRegistry.js +102 -0
- package/dist/workers/editor/common/editorCommon.js +13 -0
- package/dist/workers/editor/common/editorConfigurationSchema.js +338 -0
- package/dist/workers/editor/common/editorContextKeys.js +84 -0
- package/dist/workers/editor/common/editorFeatures.js +17 -0
- package/dist/workers/editor/common/editorOptions.js +3440 -0
- package/dist/workers/editor/common/editorTheme.js +23 -0
- package/dist/workers/editor/common/editorWebWorker.js +299 -0
- package/dist/workers/editor/common/editorWorker.js +9 -0
- package/dist/workers/editor/common/editorWorkerHost.js +15 -0
- package/dist/workers/editor/common/editorZoom.js +26 -0
- package/dist/workers/editor/common/electricCharacter.js +55 -0
- package/dist/workers/editor/common/encodedTokenAttributes.js +79 -0
- package/dist/workers/editor/common/enterAction.js +53 -0
- package/dist/workers/editor/common/eolCounter.js +44 -0
- package/dist/workers/editor/common/findSectionHeaders.js +128 -0
- package/dist/workers/editor/common/fixBrackets.js +67 -0
- package/dist/workers/editor/common/fixedArray.js +70 -0
- package/dist/workers/editor/common/fontInfo.js +172 -0
- package/dist/workers/editor/common/fontInfoFromSettings.js +29 -0
- package/dist/workers/editor/common/getIconClasses.js +106 -0
- package/dist/workers/editor/common/getPositionOffsetTransformerFromTextModel.js +24 -0
- package/dist/workers/editor/common/glyphLanesModel.js +61 -0
- package/dist/workers/editor/common/guidesTextModelPart.js +405 -0
- package/dist/workers/editor/common/heuristicSequenceOptimizations.js +374 -0
- package/dist/workers/editor/common/indentRules.js +63 -0
- package/dist/workers/editor/common/indentation.js +39 -0
- package/dist/workers/editor/common/indentationGuesser.js +178 -0
- package/dist/workers/editor/common/indentationLineProcessor.js +193 -0
- package/dist/workers/editor/common/inlineDecorations.js +26 -0
- package/dist/workers/editor/common/inplaceReplaceSupport.js +87 -0
- package/dist/workers/editor/common/inputMode.js +22 -0
- package/dist/workers/editor/common/intervalTree.js +1002 -0
- package/dist/workers/editor/common/language.js +9 -0
- package/dist/workers/editor/common/languageBracketsConfiguration.js +133 -0
- package/dist/workers/editor/common/languageConfiguration.js +138 -0
- package/dist/workers/editor/common/languageConfigurationRegistry.js +361 -0
- package/dist/workers/editor/common/languageFeatureDebounce.js +137 -0
- package/dist/workers/editor/common/languageFeatureRegistry.js +180 -0
- package/dist/workers/editor/common/languageFeatures.js +9 -0
- package/dist/workers/editor/common/languageFeaturesService.js +47 -0
- package/dist/workers/editor/common/languageSelector.js +112 -0
- package/dist/workers/editor/common/languageService.js +92 -0
- package/dist/workers/editor/common/languages.js +522 -0
- package/dist/workers/editor/common/languagesAssociations.js +193 -0
- package/dist/workers/editor/common/languagesRegistry.js +237 -0
- package/dist/workers/editor/common/legacyLinesDiffComputer.js +468 -0
- package/dist/workers/editor/common/length.js +129 -0
- package/dist/workers/editor/common/lineDecorations.js +208 -0
- package/dist/workers/editor/common/lineEdit.js +75 -0
- package/dist/workers/editor/common/lineHeights.js +370 -0
- package/dist/workers/editor/common/linePart.js +25 -0
- package/dist/workers/editor/common/lineRange.js +312 -0
- package/dist/workers/editor/common/lineSequence.js +36 -0
- package/dist/workers/editor/common/lineTokens.js +405 -0
- package/dist/workers/editor/common/linesDiffComputer.js +29 -0
- package/dist/workers/editor/common/linesDiffComputers.js +13 -0
- package/dist/workers/editor/common/linesLayout.js +765 -0
- package/dist/workers/editor/common/linesSliceCharSequence.js +205 -0
- package/dist/workers/editor/common/linkComputer.js +269 -0
- package/dist/workers/editor/common/markerDecorations.js +9 -0
- package/dist/workers/editor/common/markerDecorationsService.js +248 -0
- package/dist/workers/editor/common/minimapTokensColorTracker.js +58 -0
- package/dist/workers/editor/common/mirrorTextModel.js +117 -0
- package/dist/workers/editor/common/model.js +9 -0
- package/dist/workers/editor/common/modelLineProjection.js +350 -0
- package/dist/workers/editor/common/modelLineProjectionData.js +297 -0
- package/dist/workers/editor/common/modelService.js +413 -0
- package/dist/workers/editor/common/modesRegistry.js +75 -0
- package/dist/workers/editor/common/monospaceLineBreaksComputer.js +473 -0
- package/dist/workers/editor/common/myersDiffAlgorithm.js +159 -0
- package/dist/workers/editor/common/nodeReader.js +127 -0
- package/dist/workers/editor/common/nullTokenize.js +29 -0
- package/dist/workers/editor/common/offsetRange.js +225 -0
- package/dist/workers/editor/common/onEnter.js +109 -0
- package/dist/workers/editor/common/oneCursor.js +117 -0
- package/dist/workers/editor/common/overviewZoneManager.js +176 -0
- package/dist/workers/editor/common/parser.js +121 -0
- package/dist/workers/editor/common/pieceTreeBase.js +1473 -0
- package/dist/workers/editor/common/pieceTreeTextBuffer.js +461 -0
- package/dist/workers/editor/common/pieceTreeTextBufferBuilder.js +140 -0
- package/dist/workers/editor/common/point.js +50 -0
- package/dist/workers/editor/common/position.js +142 -0
- package/dist/workers/editor/common/positionToOffset.js +17 -0
- package/dist/workers/editor/common/positionToOffsetImpl.js +98 -0
- package/dist/workers/editor/common/prefixSumComputer.js +226 -0
- package/dist/workers/editor/common/range.js +421 -0
- package/dist/workers/editor/common/rangeMapping.js +229 -0
- package/dist/workers/editor/common/rangeSingleLine.js +17 -0
- package/dist/workers/editor/common/rbTreeBase.js +362 -0
- package/dist/workers/editor/common/rect.js +163 -0
- package/dist/workers/editor/common/replaceCommand.js +158 -0
- package/dist/workers/editor/common/resolverService.js +5 -0
- package/dist/workers/editor/common/rgba.js +35 -0
- package/dist/workers/editor/common/richEditBrackets.js +356 -0
- package/dist/workers/editor/common/selection.js +145 -0
- package/dist/workers/editor/common/semanticTokensDto.js +82 -0
- package/dist/workers/editor/common/semanticTokensProviderStyling.js +263 -0
- package/dist/workers/editor/common/semanticTokensStyling.js +9 -0
- package/dist/workers/editor/common/semanticTokensStylingService.js +47 -0
- package/dist/workers/editor/common/shiftCommand.js +241 -0
- package/dist/workers/editor/common/smallImmutableSet.js +108 -0
- package/dist/workers/editor/common/sparseMultilineTokens.js +548 -0
- package/dist/workers/editor/common/sparseTokensStore.js +210 -0
- package/dist/workers/editor/common/standaloneEnums.js +1017 -0
- package/dist/workers/editor/common/standaloneStrings.js +42 -0
- package/dist/workers/editor/common/stringBuilder.js +122 -0
- package/dist/workers/editor/common/stringEdit.js +165 -0
- package/dist/workers/editor/common/supports.js +58 -0
- package/dist/workers/editor/common/surroundSelectionCommand.js +44 -0
- package/dist/workers/editor/common/textChange.js +248 -0
- package/dist/workers/editor/common/textEdit.js +269 -0
- package/dist/workers/editor/common/textLength.js +87 -0
- package/dist/workers/editor/common/textModel.js +2031 -0
- package/dist/workers/editor/common/textModelBracketPairs.js +45 -0
- package/dist/workers/editor/common/textModelDefaults.js +18 -0
- package/dist/workers/editor/common/textModelEditSource.js +166 -0
- package/dist/workers/editor/common/textModelEvents.js +216 -0
- package/dist/workers/editor/common/textModelGuides.js +40 -0
- package/dist/workers/editor/common/textModelPart.js +23 -0
- package/dist/workers/editor/common/textModelSearch.js +455 -0
- package/dist/workers/editor/common/textModelStringEdit.js +11 -0
- package/dist/workers/editor/common/textModelSync.impl.js +307 -0
- package/dist/workers/editor/common/textModelText.js +26 -0
- package/dist/workers/editor/common/textModelTokens.js +436 -0
- package/dist/workers/editor/common/textResourceConfiguration.js +6 -0
- package/dist/workers/editor/common/textToHtmlTokenizer.js +139 -0
- package/dist/workers/editor/common/tokenStore.js +407 -0
- package/dist/workers/editor/common/tokenWithTextArray.js +73 -0
- package/dist/workers/editor/common/tokenization.js +287 -0
- package/dist/workers/editor/common/tokenizationRegistry.js +123 -0
- package/dist/workers/editor/common/tokenizationTextModelPart.js +275 -0
- package/dist/workers/editor/common/tokenizer.js +301 -0
- package/dist/workers/editor/common/tokenizerSyntaxTokenBackend.js +261 -0
- package/dist/workers/editor/common/treeSitterLibraryService.js +9 -0
- package/dist/workers/editor/common/treeSitterSyntaxTokenBackend.js +167 -0
- package/dist/workers/editor/common/treeSitterThemeService.js +9 -0
- package/dist/workers/editor/common/treeSitterTokenizationImpl.js +713 -0
- package/dist/workers/editor/common/treeSitterTree.js +395 -0
- package/dist/workers/editor/common/treeViewsDnd.js +24 -0
- package/dist/workers/editor/common/treeViewsDndService.js +12 -0
- package/dist/workers/editor/common/trimTrailingWhitespaceCommand.js +98 -0
- package/dist/workers/editor/common/unicodeTextModelHighlighter.js +188 -0
- package/dist/workers/editor/common/utils.js +62 -0
- package/dist/workers/editor/common/viewContext.js +22 -0
- package/dist/workers/editor/common/viewEventHandler.js +186 -0
- package/dist/workers/editor/common/viewEvents.js +180 -0
- package/dist/workers/editor/common/viewLayout.js +368 -0
- package/dist/workers/editor/common/viewLineRenderer.js +948 -0
- package/dist/workers/editor/common/viewLinesViewportData.js +30 -0
- package/dist/workers/editor/common/viewModel.js +98 -0
- package/dist/workers/editor/common/viewModelDecoration.js +55 -0
- package/dist/workers/editor/common/viewModelDecorations.js +132 -0
- package/dist/workers/editor/common/viewModelEventDispatcher.js +398 -0
- package/dist/workers/editor/common/viewModelImpl.js +1163 -0
- package/dist/workers/editor/common/viewModelLines.js +938 -0
- package/dist/workers/editor/common/wordCharacterClassifier.js +87 -0
- package/dist/workers/editor/common/wordHelper.js +127 -0
- package/dist/workers/editor/editor.worker.js +11 -0
- package/dist/workers/language/css.worker.js +8 -0
- package/dist/workers/language/cssMode.js +198 -0
- package/dist/workers/language/cssWorker.js +183 -0
- package/dist/workers/language/html.worker.js +8 -0
- package/dist/workers/language/htmlMode.js +213 -0
- package/dist/workers/language/htmlWorker.js +126 -0
- package/dist/workers/language/json.worker.js +8 -0
- package/dist/workers/language/jsonMode.js +224 -0
- package/dist/workers/language/jsonWorker.js +187 -0
- package/dist/workers/language/languageFeatures.js +1009 -0
- package/dist/workers/language/lib.index.js +103 -0
- package/dist/workers/language/lib.js +1107 -0
- package/dist/workers/language/lspLanguageFeatures.js +716 -0
- package/dist/workers/language/monaco.contribution.js +144 -0
- package/dist/workers/language/tokenization.js +189 -0
- package/dist/workers/language/ts.worker.js +14 -0
- package/dist/workers/language/tsMode.js +212 -0
- package/dist/workers/language/tsWorker.js +352 -0
- package/dist/workers/language/typescriptServices.js +210154 -0
- package/dist/workers/language/typescriptServicesMetadata.js +3 -0
- package/dist/workers/language/workerManager.js +65 -0
- package/package.json +3 -2
|
@@ -0,0 +1,717 @@
|
|
|
1
|
+
import { CallbackIterable, compareBy } from '../../../../base/common/arrays.js';
|
|
2
|
+
import { Emitter } from '../../../../base/common/event.js';
|
|
3
|
+
import { Disposable, MutableDisposable, DisposableStore } from '../../../../base/common/lifecycle.js';
|
|
4
|
+
import { Range } from '../../core/range.js';
|
|
5
|
+
import { ignoreBracketsInToken } from '../../languages/supports.js';
|
|
6
|
+
import { BracketsUtils } from '../../languages/supports/richEditBrackets.js';
|
|
7
|
+
import { BracketPairsTree } from './bracketPairsTree/bracketPairsTree.js';
|
|
8
|
+
|
|
9
|
+
/*---------------------------------------------------------------------------------------------
|
|
10
|
+
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
11
|
+
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
12
|
+
*--------------------------------------------------------------------------------------------*/
|
|
13
|
+
class BracketPairsTextModelPart extends Disposable {
|
|
14
|
+
get canBuildAST() {
|
|
15
|
+
const maxSupportedDocumentLength = /* max lines */ 50_000 * /* average column count */ 100;
|
|
16
|
+
return this.textModel.getValueLength() <= maxSupportedDocumentLength;
|
|
17
|
+
}
|
|
18
|
+
constructor(textModel, languageConfigurationService) {
|
|
19
|
+
super();
|
|
20
|
+
this.textModel = textModel;
|
|
21
|
+
this.languageConfigurationService = languageConfigurationService;
|
|
22
|
+
this.bracketPairsTree = this._register(new MutableDisposable());
|
|
23
|
+
this.onDidChangeEmitter = new Emitter();
|
|
24
|
+
this.onDidChange = this.onDidChangeEmitter.event;
|
|
25
|
+
this.bracketsRequested = false;
|
|
26
|
+
}
|
|
27
|
+
//#region TextModel events
|
|
28
|
+
handleLanguageConfigurationServiceChange(e) {
|
|
29
|
+
if (!e.languageId || this.bracketPairsTree.value?.object.didLanguageChange(e.languageId)) {
|
|
30
|
+
this.bracketPairsTree.clear();
|
|
31
|
+
this.updateBracketPairsTree();
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
handleDidChangeOptions(e) {
|
|
35
|
+
this.bracketPairsTree.clear();
|
|
36
|
+
this.updateBracketPairsTree();
|
|
37
|
+
}
|
|
38
|
+
handleDidChangeLanguage(e) {
|
|
39
|
+
this.bracketPairsTree.clear();
|
|
40
|
+
this.updateBracketPairsTree();
|
|
41
|
+
}
|
|
42
|
+
handleDidChangeContent(change) {
|
|
43
|
+
this.bracketPairsTree.value?.object.handleContentChanged(change);
|
|
44
|
+
}
|
|
45
|
+
handleDidChangeBackgroundTokenizationState() {
|
|
46
|
+
this.bracketPairsTree.value?.object.handleDidChangeBackgroundTokenizationState();
|
|
47
|
+
}
|
|
48
|
+
handleDidChangeTokens(e) {
|
|
49
|
+
this.bracketPairsTree.value?.object.handleDidChangeTokens(e);
|
|
50
|
+
}
|
|
51
|
+
//#endregion
|
|
52
|
+
updateBracketPairsTree() {
|
|
53
|
+
if (this.bracketsRequested && this.canBuildAST) {
|
|
54
|
+
if (!this.bracketPairsTree.value) {
|
|
55
|
+
const store = new DisposableStore();
|
|
56
|
+
this.bracketPairsTree.value = createDisposableRef(store.add(new BracketPairsTree(this.textModel, (languageId) => {
|
|
57
|
+
return this.languageConfigurationService.getLanguageConfiguration(languageId);
|
|
58
|
+
})), store);
|
|
59
|
+
store.add(this.bracketPairsTree.value.object.onDidChange(e => this.onDidChangeEmitter.fire(e)));
|
|
60
|
+
this.onDidChangeEmitter.fire();
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
if (this.bracketPairsTree.value) {
|
|
65
|
+
this.bracketPairsTree.clear();
|
|
66
|
+
// Important: Don't call fire if there was no change!
|
|
67
|
+
this.onDidChangeEmitter.fire();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
/**
|
|
72
|
+
* Returns all bracket pairs that intersect the given range.
|
|
73
|
+
* The result is sorted by the start position.
|
|
74
|
+
*/
|
|
75
|
+
getBracketPairsInRange(range) {
|
|
76
|
+
this.bracketsRequested = true;
|
|
77
|
+
this.updateBracketPairsTree();
|
|
78
|
+
return this.bracketPairsTree.value?.object.getBracketPairsInRange(range, false) || CallbackIterable.empty;
|
|
79
|
+
}
|
|
80
|
+
getBracketPairsInRangeWithMinIndentation(range) {
|
|
81
|
+
this.bracketsRequested = true;
|
|
82
|
+
this.updateBracketPairsTree();
|
|
83
|
+
return this.bracketPairsTree.value?.object.getBracketPairsInRange(range, true) || CallbackIterable.empty;
|
|
84
|
+
}
|
|
85
|
+
getBracketsInRange(range, onlyColorizedBrackets = false) {
|
|
86
|
+
this.bracketsRequested = true;
|
|
87
|
+
this.updateBracketPairsTree();
|
|
88
|
+
return this.bracketPairsTree.value?.object.getBracketsInRange(range, onlyColorizedBrackets) || CallbackIterable.empty;
|
|
89
|
+
}
|
|
90
|
+
findMatchingBracketUp(_bracket, _position, maxDuration) {
|
|
91
|
+
const position = this.textModel.validatePosition(_position);
|
|
92
|
+
const languageId = this.textModel.getLanguageIdAtPosition(position.lineNumber, position.column);
|
|
93
|
+
if (this.canBuildAST) {
|
|
94
|
+
const closingBracketInfo = this.languageConfigurationService
|
|
95
|
+
.getLanguageConfiguration(languageId)
|
|
96
|
+
.bracketsNew.getClosingBracketInfo(_bracket);
|
|
97
|
+
if (!closingBracketInfo) {
|
|
98
|
+
return null;
|
|
99
|
+
}
|
|
100
|
+
const bracketPair = this.getBracketPairsInRange(Range.fromPositions(_position, _position)).findLast((b) => closingBracketInfo.closes(b.openingBracketInfo));
|
|
101
|
+
if (bracketPair) {
|
|
102
|
+
return bracketPair.openingBracketRange;
|
|
103
|
+
}
|
|
104
|
+
return null;
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
// Fallback to old bracket matching code:
|
|
108
|
+
const bracket = _bracket.toLowerCase();
|
|
109
|
+
const bracketsSupport = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
110
|
+
if (!bracketsSupport) {
|
|
111
|
+
return null;
|
|
112
|
+
}
|
|
113
|
+
const data = bracketsSupport.textIsBracket[bracket];
|
|
114
|
+
if (!data) {
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
return stripBracketSearchCanceled(this._findMatchingBracketUp(data, position, createTimeBasedContinueBracketSearchPredicate(maxDuration)));
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
matchBracket(position, maxDuration) {
|
|
121
|
+
if (this.canBuildAST) {
|
|
122
|
+
const bracketPair = this.getBracketPairsInRange(Range.fromPositions(position, position)).filter((item) => item.closingBracketRange !== undefined &&
|
|
123
|
+
(item.openingBracketRange.containsPosition(position) ||
|
|
124
|
+
item.closingBracketRange.containsPosition(position))).findLastMaxBy(compareBy((item) => item.openingBracketRange.containsPosition(position)
|
|
125
|
+
? item.openingBracketRange
|
|
126
|
+
: item.closingBracketRange, Range.compareRangesUsingStarts));
|
|
127
|
+
if (bracketPair) {
|
|
128
|
+
return [bracketPair.openingBracketRange, bracketPair.closingBracketRange];
|
|
129
|
+
}
|
|
130
|
+
return null;
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
// Fallback to old bracket matching code:
|
|
134
|
+
const continueSearchPredicate = createTimeBasedContinueBracketSearchPredicate(maxDuration);
|
|
135
|
+
return this._matchBracket(this.textModel.validatePosition(position), continueSearchPredicate);
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
_establishBracketSearchOffsets(position, lineTokens, modeBrackets, tokenIndex) {
|
|
139
|
+
const tokenCount = lineTokens.getCount();
|
|
140
|
+
const currentLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
141
|
+
// limit search to not go before `maxBracketLength`
|
|
142
|
+
let searchStartOffset = Math.max(0, position.column - 1 - modeBrackets.maxBracketLength);
|
|
143
|
+
for (let i = tokenIndex - 1; i >= 0; i--) {
|
|
144
|
+
const tokenEndOffset = lineTokens.getEndOffset(i);
|
|
145
|
+
if (tokenEndOffset <= searchStartOffset) {
|
|
146
|
+
break;
|
|
147
|
+
}
|
|
148
|
+
if (ignoreBracketsInToken(lineTokens.getStandardTokenType(i)) || lineTokens.getLanguageId(i) !== currentLanguageId) {
|
|
149
|
+
searchStartOffset = tokenEndOffset;
|
|
150
|
+
break;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
// limit search to not go after `maxBracketLength`
|
|
154
|
+
let searchEndOffset = Math.min(lineTokens.getLineContent().length, position.column - 1 + modeBrackets.maxBracketLength);
|
|
155
|
+
for (let i = tokenIndex + 1; i < tokenCount; i++) {
|
|
156
|
+
const tokenStartOffset = lineTokens.getStartOffset(i);
|
|
157
|
+
if (tokenStartOffset >= searchEndOffset) {
|
|
158
|
+
break;
|
|
159
|
+
}
|
|
160
|
+
if (ignoreBracketsInToken(lineTokens.getStandardTokenType(i)) || lineTokens.getLanguageId(i) !== currentLanguageId) {
|
|
161
|
+
searchEndOffset = tokenStartOffset;
|
|
162
|
+
break;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
return { searchStartOffset, searchEndOffset };
|
|
166
|
+
}
|
|
167
|
+
_matchBracket(position, continueSearchPredicate) {
|
|
168
|
+
const lineNumber = position.lineNumber;
|
|
169
|
+
const lineTokens = this.textModel.tokenization.getLineTokens(lineNumber);
|
|
170
|
+
const lineText = this.textModel.getLineContent(lineNumber);
|
|
171
|
+
const tokenIndex = lineTokens.findTokenIndexAtOffset(position.column - 1);
|
|
172
|
+
if (tokenIndex < 0) {
|
|
173
|
+
return null;
|
|
174
|
+
}
|
|
175
|
+
const currentModeBrackets = this.languageConfigurationService.getLanguageConfiguration(lineTokens.getLanguageId(tokenIndex)).brackets;
|
|
176
|
+
// check that the token is not to be ignored
|
|
177
|
+
if (currentModeBrackets && !ignoreBracketsInToken(lineTokens.getStandardTokenType(tokenIndex))) {
|
|
178
|
+
let { searchStartOffset, searchEndOffset } = this._establishBracketSearchOffsets(position, lineTokens, currentModeBrackets, tokenIndex);
|
|
179
|
+
// it might be the case that [currentTokenStart -> currentTokenEnd] contains multiple brackets
|
|
180
|
+
// `bestResult` will contain the most right-side result
|
|
181
|
+
let bestResult = null;
|
|
182
|
+
while (true) {
|
|
183
|
+
const foundBracket = BracketsUtils.findNextBracketInRange(currentModeBrackets.forwardRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
184
|
+
if (!foundBracket) {
|
|
185
|
+
// there are no more brackets in this text
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
// check that we didn't hit a bracket too far away from position
|
|
189
|
+
if (foundBracket.startColumn <= position.column && position.column <= foundBracket.endColumn) {
|
|
190
|
+
const foundBracketText = lineText.substring(foundBracket.startColumn - 1, foundBracket.endColumn - 1).toLowerCase();
|
|
191
|
+
const r = this._matchFoundBracket(foundBracket, currentModeBrackets.textIsBracket[foundBracketText], currentModeBrackets.textIsOpenBracket[foundBracketText], continueSearchPredicate);
|
|
192
|
+
if (r) {
|
|
193
|
+
if (r instanceof BracketSearchCanceled) {
|
|
194
|
+
return null;
|
|
195
|
+
}
|
|
196
|
+
bestResult = r;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
searchStartOffset = foundBracket.endColumn - 1;
|
|
200
|
+
}
|
|
201
|
+
if (bestResult) {
|
|
202
|
+
return bestResult;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
// If position is in between two tokens, try also looking in the previous token
|
|
206
|
+
if (tokenIndex > 0 && lineTokens.getStartOffset(tokenIndex) === position.column - 1) {
|
|
207
|
+
const prevTokenIndex = tokenIndex - 1;
|
|
208
|
+
const prevModeBrackets = this.languageConfigurationService.getLanguageConfiguration(lineTokens.getLanguageId(prevTokenIndex)).brackets;
|
|
209
|
+
// check that previous token is not to be ignored
|
|
210
|
+
if (prevModeBrackets && !ignoreBracketsInToken(lineTokens.getStandardTokenType(prevTokenIndex))) {
|
|
211
|
+
const { searchStartOffset, searchEndOffset } = this._establishBracketSearchOffsets(position, lineTokens, prevModeBrackets, prevTokenIndex);
|
|
212
|
+
const foundBracket = BracketsUtils.findPrevBracketInRange(prevModeBrackets.reversedRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
213
|
+
// check that we didn't hit a bracket too far away from position
|
|
214
|
+
if (foundBracket && foundBracket.startColumn <= position.column && position.column <= foundBracket.endColumn) {
|
|
215
|
+
const foundBracketText = lineText.substring(foundBracket.startColumn - 1, foundBracket.endColumn - 1).toLowerCase();
|
|
216
|
+
const r = this._matchFoundBracket(foundBracket, prevModeBrackets.textIsBracket[foundBracketText], prevModeBrackets.textIsOpenBracket[foundBracketText], continueSearchPredicate);
|
|
217
|
+
if (r) {
|
|
218
|
+
if (r instanceof BracketSearchCanceled) {
|
|
219
|
+
return null;
|
|
220
|
+
}
|
|
221
|
+
return r;
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
return null;
|
|
227
|
+
}
|
|
228
|
+
_matchFoundBracket(foundBracket, data, isOpen, continueSearchPredicate) {
|
|
229
|
+
if (!data) {
|
|
230
|
+
return null;
|
|
231
|
+
}
|
|
232
|
+
const matched = (isOpen
|
|
233
|
+
? this._findMatchingBracketDown(data, foundBracket.getEndPosition(), continueSearchPredicate)
|
|
234
|
+
: this._findMatchingBracketUp(data, foundBracket.getStartPosition(), continueSearchPredicate));
|
|
235
|
+
if (!matched) {
|
|
236
|
+
return null;
|
|
237
|
+
}
|
|
238
|
+
if (matched instanceof BracketSearchCanceled) {
|
|
239
|
+
return matched;
|
|
240
|
+
}
|
|
241
|
+
return [foundBracket, matched];
|
|
242
|
+
}
|
|
243
|
+
_findMatchingBracketUp(bracket, position, continueSearchPredicate) {
|
|
244
|
+
// console.log('_findMatchingBracketUp: ', 'bracket: ', JSON.stringify(bracket), 'startPosition: ', String(position));
|
|
245
|
+
const languageId = bracket.languageId;
|
|
246
|
+
const reversedBracketRegex = bracket.reversedRegex;
|
|
247
|
+
let count = -1;
|
|
248
|
+
let totalCallCount = 0;
|
|
249
|
+
const searchPrevMatchingBracketInRange = (lineNumber, lineText, searchStartOffset, searchEndOffset) => {
|
|
250
|
+
while (true) {
|
|
251
|
+
if (continueSearchPredicate && (++totalCallCount) % 100 === 0 && !continueSearchPredicate()) {
|
|
252
|
+
return BracketSearchCanceled.INSTANCE;
|
|
253
|
+
}
|
|
254
|
+
const r = BracketsUtils.findPrevBracketInRange(reversedBracketRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
255
|
+
if (!r) {
|
|
256
|
+
break;
|
|
257
|
+
}
|
|
258
|
+
const hitText = lineText.substring(r.startColumn - 1, r.endColumn - 1).toLowerCase();
|
|
259
|
+
if (bracket.isOpen(hitText)) {
|
|
260
|
+
count++;
|
|
261
|
+
}
|
|
262
|
+
else if (bracket.isClose(hitText)) {
|
|
263
|
+
count--;
|
|
264
|
+
}
|
|
265
|
+
if (count === 0) {
|
|
266
|
+
return r;
|
|
267
|
+
}
|
|
268
|
+
searchEndOffset = r.startColumn - 1;
|
|
269
|
+
}
|
|
270
|
+
return null;
|
|
271
|
+
};
|
|
272
|
+
for (let lineNumber = position.lineNumber; lineNumber >= 1; lineNumber--) {
|
|
273
|
+
const lineTokens = this.textModel.tokenization.getLineTokens(lineNumber);
|
|
274
|
+
const tokenCount = lineTokens.getCount();
|
|
275
|
+
const lineText = this.textModel.getLineContent(lineNumber);
|
|
276
|
+
let tokenIndex = tokenCount - 1;
|
|
277
|
+
let searchStartOffset = lineText.length;
|
|
278
|
+
let searchEndOffset = lineText.length;
|
|
279
|
+
if (lineNumber === position.lineNumber) {
|
|
280
|
+
tokenIndex = lineTokens.findTokenIndexAtOffset(position.column - 1);
|
|
281
|
+
searchStartOffset = position.column - 1;
|
|
282
|
+
searchEndOffset = position.column - 1;
|
|
283
|
+
}
|
|
284
|
+
let prevSearchInToken = true;
|
|
285
|
+
for (; tokenIndex >= 0; tokenIndex--) {
|
|
286
|
+
const searchInToken = (lineTokens.getLanguageId(tokenIndex) === languageId && !ignoreBracketsInToken(lineTokens.getStandardTokenType(tokenIndex)));
|
|
287
|
+
if (searchInToken) {
|
|
288
|
+
// this token should be searched
|
|
289
|
+
if (prevSearchInToken) {
|
|
290
|
+
// the previous token should be searched, simply extend searchStartOffset
|
|
291
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
292
|
+
}
|
|
293
|
+
else {
|
|
294
|
+
// the previous token should not be searched
|
|
295
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
296
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
297
|
+
}
|
|
298
|
+
}
|
|
299
|
+
else {
|
|
300
|
+
// this token should not be searched
|
|
301
|
+
if (prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
302
|
+
const r = searchPrevMatchingBracketInRange(lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
303
|
+
if (r) {
|
|
304
|
+
return r;
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
prevSearchInToken = searchInToken;
|
|
309
|
+
}
|
|
310
|
+
if (prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
311
|
+
const r = searchPrevMatchingBracketInRange(lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
312
|
+
if (r) {
|
|
313
|
+
return r;
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
return null;
|
|
318
|
+
}
|
|
319
|
+
_findMatchingBracketDown(bracket, position, continueSearchPredicate) {
|
|
320
|
+
// console.log('_findMatchingBracketDown: ', 'bracket: ', JSON.stringify(bracket), 'startPosition: ', String(position));
|
|
321
|
+
const languageId = bracket.languageId;
|
|
322
|
+
const bracketRegex = bracket.forwardRegex;
|
|
323
|
+
let count = 1;
|
|
324
|
+
let totalCallCount = 0;
|
|
325
|
+
const searchNextMatchingBracketInRange = (lineNumber, lineText, searchStartOffset, searchEndOffset) => {
|
|
326
|
+
while (true) {
|
|
327
|
+
if (continueSearchPredicate && (++totalCallCount) % 100 === 0 && !continueSearchPredicate()) {
|
|
328
|
+
return BracketSearchCanceled.INSTANCE;
|
|
329
|
+
}
|
|
330
|
+
const r = BracketsUtils.findNextBracketInRange(bracketRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
331
|
+
if (!r) {
|
|
332
|
+
break;
|
|
333
|
+
}
|
|
334
|
+
const hitText = lineText.substring(r.startColumn - 1, r.endColumn - 1).toLowerCase();
|
|
335
|
+
if (bracket.isOpen(hitText)) {
|
|
336
|
+
count++;
|
|
337
|
+
}
|
|
338
|
+
else if (bracket.isClose(hitText)) {
|
|
339
|
+
count--;
|
|
340
|
+
}
|
|
341
|
+
if (count === 0) {
|
|
342
|
+
return r;
|
|
343
|
+
}
|
|
344
|
+
searchStartOffset = r.endColumn - 1;
|
|
345
|
+
}
|
|
346
|
+
return null;
|
|
347
|
+
};
|
|
348
|
+
const lineCount = this.textModel.getLineCount();
|
|
349
|
+
for (let lineNumber = position.lineNumber; lineNumber <= lineCount; lineNumber++) {
|
|
350
|
+
const lineTokens = this.textModel.tokenization.getLineTokens(lineNumber);
|
|
351
|
+
const tokenCount = lineTokens.getCount();
|
|
352
|
+
const lineText = this.textModel.getLineContent(lineNumber);
|
|
353
|
+
let tokenIndex = 0;
|
|
354
|
+
let searchStartOffset = 0;
|
|
355
|
+
let searchEndOffset = 0;
|
|
356
|
+
if (lineNumber === position.lineNumber) {
|
|
357
|
+
tokenIndex = lineTokens.findTokenIndexAtOffset(position.column - 1);
|
|
358
|
+
searchStartOffset = position.column - 1;
|
|
359
|
+
searchEndOffset = position.column - 1;
|
|
360
|
+
}
|
|
361
|
+
let prevSearchInToken = true;
|
|
362
|
+
for (; tokenIndex < tokenCount; tokenIndex++) {
|
|
363
|
+
const searchInToken = (lineTokens.getLanguageId(tokenIndex) === languageId && !ignoreBracketsInToken(lineTokens.getStandardTokenType(tokenIndex)));
|
|
364
|
+
if (searchInToken) {
|
|
365
|
+
// this token should be searched
|
|
366
|
+
if (prevSearchInToken) {
|
|
367
|
+
// the previous token should be searched, simply extend searchEndOffset
|
|
368
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
369
|
+
}
|
|
370
|
+
else {
|
|
371
|
+
// the previous token should not be searched
|
|
372
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
373
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
else {
|
|
377
|
+
// this token should not be searched
|
|
378
|
+
if (prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
379
|
+
const r = searchNextMatchingBracketInRange(lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
380
|
+
if (r) {
|
|
381
|
+
return r;
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
}
|
|
385
|
+
prevSearchInToken = searchInToken;
|
|
386
|
+
}
|
|
387
|
+
if (prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
388
|
+
const r = searchNextMatchingBracketInRange(lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
389
|
+
if (r) {
|
|
390
|
+
return r;
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
return null;
|
|
395
|
+
}
|
|
396
|
+
findPrevBracket(_position) {
|
|
397
|
+
const position = this.textModel.validatePosition(_position);
|
|
398
|
+
if (this.canBuildAST) {
|
|
399
|
+
this.bracketsRequested = true;
|
|
400
|
+
this.updateBracketPairsTree();
|
|
401
|
+
return this.bracketPairsTree.value?.object.getFirstBracketBefore(position) || null;
|
|
402
|
+
}
|
|
403
|
+
let languageId = null;
|
|
404
|
+
let modeBrackets = null;
|
|
405
|
+
let bracketConfig = null;
|
|
406
|
+
for (let lineNumber = position.lineNumber; lineNumber >= 1; lineNumber--) {
|
|
407
|
+
const lineTokens = this.textModel.tokenization.getLineTokens(lineNumber);
|
|
408
|
+
const tokenCount = lineTokens.getCount();
|
|
409
|
+
const lineText = this.textModel.getLineContent(lineNumber);
|
|
410
|
+
let tokenIndex = tokenCount - 1;
|
|
411
|
+
let searchStartOffset = lineText.length;
|
|
412
|
+
let searchEndOffset = lineText.length;
|
|
413
|
+
if (lineNumber === position.lineNumber) {
|
|
414
|
+
tokenIndex = lineTokens.findTokenIndexAtOffset(position.column - 1);
|
|
415
|
+
searchStartOffset = position.column - 1;
|
|
416
|
+
searchEndOffset = position.column - 1;
|
|
417
|
+
const tokenLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
418
|
+
if (languageId !== tokenLanguageId) {
|
|
419
|
+
languageId = tokenLanguageId;
|
|
420
|
+
modeBrackets = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
421
|
+
bracketConfig = this.languageConfigurationService.getLanguageConfiguration(languageId).bracketsNew;
|
|
422
|
+
}
|
|
423
|
+
}
|
|
424
|
+
let prevSearchInToken = true;
|
|
425
|
+
for (; tokenIndex >= 0; tokenIndex--) {
|
|
426
|
+
const tokenLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
427
|
+
if (languageId !== tokenLanguageId) {
|
|
428
|
+
// language id change!
|
|
429
|
+
if (modeBrackets && bracketConfig && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
430
|
+
const r = BracketsUtils.findPrevBracketInRange(modeBrackets.reversedRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
431
|
+
if (r) {
|
|
432
|
+
return this._toFoundBracket(bracketConfig, r);
|
|
433
|
+
}
|
|
434
|
+
prevSearchInToken = false;
|
|
435
|
+
}
|
|
436
|
+
languageId = tokenLanguageId;
|
|
437
|
+
modeBrackets = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
438
|
+
bracketConfig = this.languageConfigurationService.getLanguageConfiguration(languageId).bracketsNew;
|
|
439
|
+
}
|
|
440
|
+
const searchInToken = (!!modeBrackets && !ignoreBracketsInToken(lineTokens.getStandardTokenType(tokenIndex)));
|
|
441
|
+
if (searchInToken) {
|
|
442
|
+
// this token should be searched
|
|
443
|
+
if (prevSearchInToken) {
|
|
444
|
+
// the previous token should be searched, simply extend searchStartOffset
|
|
445
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
446
|
+
}
|
|
447
|
+
else {
|
|
448
|
+
// the previous token should not be searched
|
|
449
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
450
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
451
|
+
}
|
|
452
|
+
}
|
|
453
|
+
else {
|
|
454
|
+
// this token should not be searched
|
|
455
|
+
if (bracketConfig && modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
456
|
+
const r = BracketsUtils.findPrevBracketInRange(modeBrackets.reversedRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
457
|
+
if (r) {
|
|
458
|
+
return this._toFoundBracket(bracketConfig, r);
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
prevSearchInToken = searchInToken;
|
|
463
|
+
}
|
|
464
|
+
if (bracketConfig && modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
465
|
+
const r = BracketsUtils.findPrevBracketInRange(modeBrackets.reversedRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
466
|
+
if (r) {
|
|
467
|
+
return this._toFoundBracket(bracketConfig, r);
|
|
468
|
+
}
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
return null;
|
|
472
|
+
}
|
|
473
|
+
findNextBracket(_position) {
|
|
474
|
+
const position = this.textModel.validatePosition(_position);
|
|
475
|
+
if (this.canBuildAST) {
|
|
476
|
+
this.bracketsRequested = true;
|
|
477
|
+
this.updateBracketPairsTree();
|
|
478
|
+
return this.bracketPairsTree.value?.object.getFirstBracketAfter(position) || null;
|
|
479
|
+
}
|
|
480
|
+
const lineCount = this.textModel.getLineCount();
|
|
481
|
+
let languageId = null;
|
|
482
|
+
let modeBrackets = null;
|
|
483
|
+
let bracketConfig = null;
|
|
484
|
+
for (let lineNumber = position.lineNumber; lineNumber <= lineCount; lineNumber++) {
|
|
485
|
+
const lineTokens = this.textModel.tokenization.getLineTokens(lineNumber);
|
|
486
|
+
const tokenCount = lineTokens.getCount();
|
|
487
|
+
const lineText = this.textModel.getLineContent(lineNumber);
|
|
488
|
+
let tokenIndex = 0;
|
|
489
|
+
let searchStartOffset = 0;
|
|
490
|
+
let searchEndOffset = 0;
|
|
491
|
+
if (lineNumber === position.lineNumber) {
|
|
492
|
+
tokenIndex = lineTokens.findTokenIndexAtOffset(position.column - 1);
|
|
493
|
+
searchStartOffset = position.column - 1;
|
|
494
|
+
searchEndOffset = position.column - 1;
|
|
495
|
+
const tokenLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
496
|
+
if (languageId !== tokenLanguageId) {
|
|
497
|
+
languageId = tokenLanguageId;
|
|
498
|
+
modeBrackets = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
499
|
+
bracketConfig = this.languageConfigurationService.getLanguageConfiguration(languageId).bracketsNew;
|
|
500
|
+
}
|
|
501
|
+
}
|
|
502
|
+
let prevSearchInToken = true;
|
|
503
|
+
for (; tokenIndex < tokenCount; tokenIndex++) {
|
|
504
|
+
const tokenLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
505
|
+
if (languageId !== tokenLanguageId) {
|
|
506
|
+
// language id change!
|
|
507
|
+
if (bracketConfig && modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
508
|
+
const r = BracketsUtils.findNextBracketInRange(modeBrackets.forwardRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
509
|
+
if (r) {
|
|
510
|
+
return this._toFoundBracket(bracketConfig, r);
|
|
511
|
+
}
|
|
512
|
+
prevSearchInToken = false;
|
|
513
|
+
}
|
|
514
|
+
languageId = tokenLanguageId;
|
|
515
|
+
modeBrackets = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
516
|
+
bracketConfig = this.languageConfigurationService.getLanguageConfiguration(languageId).bracketsNew;
|
|
517
|
+
}
|
|
518
|
+
const searchInToken = (!!modeBrackets && !ignoreBracketsInToken(lineTokens.getStandardTokenType(tokenIndex)));
|
|
519
|
+
if (searchInToken) {
|
|
520
|
+
// this token should be searched
|
|
521
|
+
if (prevSearchInToken) {
|
|
522
|
+
// the previous token should be searched, simply extend searchEndOffset
|
|
523
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
524
|
+
}
|
|
525
|
+
else {
|
|
526
|
+
// the previous token should not be searched
|
|
527
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
528
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
529
|
+
}
|
|
530
|
+
}
|
|
531
|
+
else {
|
|
532
|
+
// this token should not be searched
|
|
533
|
+
if (bracketConfig && modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
534
|
+
const r = BracketsUtils.findNextBracketInRange(modeBrackets.forwardRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
535
|
+
if (r) {
|
|
536
|
+
return this._toFoundBracket(bracketConfig, r);
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
}
|
|
540
|
+
prevSearchInToken = searchInToken;
|
|
541
|
+
}
|
|
542
|
+
if (bracketConfig && modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
543
|
+
const r = BracketsUtils.findNextBracketInRange(modeBrackets.forwardRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
544
|
+
if (r) {
|
|
545
|
+
return this._toFoundBracket(bracketConfig, r);
|
|
546
|
+
}
|
|
547
|
+
}
|
|
548
|
+
}
|
|
549
|
+
return null;
|
|
550
|
+
}
|
|
551
|
+
findEnclosingBrackets(_position, maxDuration) {
|
|
552
|
+
const position = this.textModel.validatePosition(_position);
|
|
553
|
+
if (this.canBuildAST) {
|
|
554
|
+
const range = Range.fromPositions(position);
|
|
555
|
+
const bracketPair = this.getBracketPairsInRange(Range.fromPositions(position, position)).findLast((item) => item.closingBracketRange !== undefined && item.range.strictContainsRange(range));
|
|
556
|
+
if (bracketPair) {
|
|
557
|
+
return [bracketPair.openingBracketRange, bracketPair.closingBracketRange];
|
|
558
|
+
}
|
|
559
|
+
return null;
|
|
560
|
+
}
|
|
561
|
+
const continueSearchPredicate = createTimeBasedContinueBracketSearchPredicate(maxDuration);
|
|
562
|
+
const lineCount = this.textModel.getLineCount();
|
|
563
|
+
const savedCounts = new Map();
|
|
564
|
+
let counts = [];
|
|
565
|
+
const resetCounts = (languageId, modeBrackets) => {
|
|
566
|
+
if (!savedCounts.has(languageId)) {
|
|
567
|
+
const tmp = [];
|
|
568
|
+
for (let i = 0, len = modeBrackets ? modeBrackets.brackets.length : 0; i < len; i++) {
|
|
569
|
+
tmp[i] = 0;
|
|
570
|
+
}
|
|
571
|
+
savedCounts.set(languageId, tmp);
|
|
572
|
+
}
|
|
573
|
+
counts = savedCounts.get(languageId);
|
|
574
|
+
};
|
|
575
|
+
let totalCallCount = 0;
|
|
576
|
+
const searchInRange = (modeBrackets, lineNumber, lineText, searchStartOffset, searchEndOffset) => {
|
|
577
|
+
while (true) {
|
|
578
|
+
if (continueSearchPredicate && (++totalCallCount) % 100 === 0 && !continueSearchPredicate()) {
|
|
579
|
+
return BracketSearchCanceled.INSTANCE;
|
|
580
|
+
}
|
|
581
|
+
const r = BracketsUtils.findNextBracketInRange(modeBrackets.forwardRegex, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
582
|
+
if (!r) {
|
|
583
|
+
break;
|
|
584
|
+
}
|
|
585
|
+
const hitText = lineText.substring(r.startColumn - 1, r.endColumn - 1).toLowerCase();
|
|
586
|
+
const bracket = modeBrackets.textIsBracket[hitText];
|
|
587
|
+
if (bracket) {
|
|
588
|
+
if (bracket.isOpen(hitText)) {
|
|
589
|
+
counts[bracket.index]++;
|
|
590
|
+
}
|
|
591
|
+
else if (bracket.isClose(hitText)) {
|
|
592
|
+
counts[bracket.index]--;
|
|
593
|
+
}
|
|
594
|
+
if (counts[bracket.index] === -1) {
|
|
595
|
+
return this._matchFoundBracket(r, bracket, false, continueSearchPredicate);
|
|
596
|
+
}
|
|
597
|
+
}
|
|
598
|
+
searchStartOffset = r.endColumn - 1;
|
|
599
|
+
}
|
|
600
|
+
return null;
|
|
601
|
+
};
|
|
602
|
+
let languageId = null;
|
|
603
|
+
let modeBrackets = null;
|
|
604
|
+
for (let lineNumber = position.lineNumber; lineNumber <= lineCount; lineNumber++) {
|
|
605
|
+
const lineTokens = this.textModel.tokenization.getLineTokens(lineNumber);
|
|
606
|
+
const tokenCount = lineTokens.getCount();
|
|
607
|
+
const lineText = this.textModel.getLineContent(lineNumber);
|
|
608
|
+
let tokenIndex = 0;
|
|
609
|
+
let searchStartOffset = 0;
|
|
610
|
+
let searchEndOffset = 0;
|
|
611
|
+
if (lineNumber === position.lineNumber) {
|
|
612
|
+
tokenIndex = lineTokens.findTokenIndexAtOffset(position.column - 1);
|
|
613
|
+
searchStartOffset = position.column - 1;
|
|
614
|
+
searchEndOffset = position.column - 1;
|
|
615
|
+
const tokenLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
616
|
+
if (languageId !== tokenLanguageId) {
|
|
617
|
+
languageId = tokenLanguageId;
|
|
618
|
+
modeBrackets = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
619
|
+
resetCounts(languageId, modeBrackets);
|
|
620
|
+
}
|
|
621
|
+
}
|
|
622
|
+
let prevSearchInToken = true;
|
|
623
|
+
for (; tokenIndex < tokenCount; tokenIndex++) {
|
|
624
|
+
const tokenLanguageId = lineTokens.getLanguageId(tokenIndex);
|
|
625
|
+
if (languageId !== tokenLanguageId) {
|
|
626
|
+
// language id change!
|
|
627
|
+
if (modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
628
|
+
const r = searchInRange(modeBrackets, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
629
|
+
if (r) {
|
|
630
|
+
return stripBracketSearchCanceled(r);
|
|
631
|
+
}
|
|
632
|
+
prevSearchInToken = false;
|
|
633
|
+
}
|
|
634
|
+
languageId = tokenLanguageId;
|
|
635
|
+
modeBrackets = this.languageConfigurationService.getLanguageConfiguration(languageId).brackets;
|
|
636
|
+
resetCounts(languageId, modeBrackets);
|
|
637
|
+
}
|
|
638
|
+
const searchInToken = (!!modeBrackets && !ignoreBracketsInToken(lineTokens.getStandardTokenType(tokenIndex)));
|
|
639
|
+
if (searchInToken) {
|
|
640
|
+
// this token should be searched
|
|
641
|
+
if (prevSearchInToken) {
|
|
642
|
+
// the previous token should be searched, simply extend searchEndOffset
|
|
643
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
644
|
+
}
|
|
645
|
+
else {
|
|
646
|
+
// the previous token should not be searched
|
|
647
|
+
searchStartOffset = lineTokens.getStartOffset(tokenIndex);
|
|
648
|
+
searchEndOffset = lineTokens.getEndOffset(tokenIndex);
|
|
649
|
+
}
|
|
650
|
+
}
|
|
651
|
+
else {
|
|
652
|
+
// this token should not be searched
|
|
653
|
+
if (modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
654
|
+
const r = searchInRange(modeBrackets, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
655
|
+
if (r) {
|
|
656
|
+
return stripBracketSearchCanceled(r);
|
|
657
|
+
}
|
|
658
|
+
}
|
|
659
|
+
}
|
|
660
|
+
prevSearchInToken = searchInToken;
|
|
661
|
+
}
|
|
662
|
+
if (modeBrackets && prevSearchInToken && searchStartOffset !== searchEndOffset) {
|
|
663
|
+
const r = searchInRange(modeBrackets, lineNumber, lineText, searchStartOffset, searchEndOffset);
|
|
664
|
+
if (r) {
|
|
665
|
+
return stripBracketSearchCanceled(r);
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
}
|
|
669
|
+
return null;
|
|
670
|
+
}
|
|
671
|
+
_toFoundBracket(bracketConfig, r) {
|
|
672
|
+
if (!r) {
|
|
673
|
+
return null;
|
|
674
|
+
}
|
|
675
|
+
let text = this.textModel.getValueInRange(r);
|
|
676
|
+
text = text.toLowerCase();
|
|
677
|
+
const bracketInfo = bracketConfig.getBracketInfo(text);
|
|
678
|
+
if (!bracketInfo) {
|
|
679
|
+
return null;
|
|
680
|
+
}
|
|
681
|
+
return {
|
|
682
|
+
range: r,
|
|
683
|
+
bracketInfo
|
|
684
|
+
};
|
|
685
|
+
}
|
|
686
|
+
}
|
|
687
|
+
function createDisposableRef(object, disposable) {
|
|
688
|
+
return {
|
|
689
|
+
object,
|
|
690
|
+
dispose: () => disposable?.dispose(),
|
|
691
|
+
};
|
|
692
|
+
}
|
|
693
|
+
function createTimeBasedContinueBracketSearchPredicate(maxDuration) {
|
|
694
|
+
if (typeof maxDuration === 'undefined') {
|
|
695
|
+
return () => true;
|
|
696
|
+
}
|
|
697
|
+
else {
|
|
698
|
+
const startTime = Date.now();
|
|
699
|
+
return () => {
|
|
700
|
+
return (Date.now() - startTime <= maxDuration);
|
|
701
|
+
};
|
|
702
|
+
}
|
|
703
|
+
}
|
|
704
|
+
class BracketSearchCanceled {
|
|
705
|
+
static { this.INSTANCE = new BracketSearchCanceled(); }
|
|
706
|
+
constructor() {
|
|
707
|
+
this._searchCanceledBrand = undefined;
|
|
708
|
+
}
|
|
709
|
+
}
|
|
710
|
+
function stripBracketSearchCanceled(result) {
|
|
711
|
+
if (result instanceof BracketSearchCanceled) {
|
|
712
|
+
return null;
|
|
713
|
+
}
|
|
714
|
+
return result;
|
|
715
|
+
}
|
|
716
|
+
|
|
717
|
+
export { BracketPairsTextModelPart };
|