monaco-editor11 1.0.9 → 1.1.1

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.
Files changed (232) hide show
  1. package/dist/index.d.ts +1 -1
  2. package/dist/monaco-editor11.es.js +12 -16
  3. package/dist/monaco-editor11.umd.js +1 -1
  4. package/package.json +2 -2
  5. package/dist/monaco.d.ts +0 -8
  6. package/dist/workers/common/initialize.js +0 -16
  7. package/dist/workers/common/workers.js +0 -141
  8. package/dist/workers/editor/common/abstractSyntaxTokenBackend.js +0 -128
  9. package/dist/workers/editor/common/abstractText.js +0 -89
  10. package/dist/workers/editor/common/ast.js +0 -485
  11. package/dist/workers/editor/common/autoIndent.js +0 -390
  12. package/dist/workers/editor/common/beforeEditPositionMapper.js +0 -110
  13. package/dist/workers/editor/common/bracketPairsImpl.js +0 -717
  14. package/dist/workers/editor/common/bracketPairsTree.js +0 -343
  15. package/dist/workers/editor/common/brackets.js +0 -108
  16. package/dist/workers/editor/common/characterClassifier.js +0 -59
  17. package/dist/workers/editor/common/characterPair.js +0 -40
  18. package/dist/workers/editor/common/colorizedBracketPairsDecorationProvider.js +0 -97
  19. package/dist/workers/editor/common/columnRange.js +0 -35
  20. package/dist/workers/editor/common/combineTextEditInfos.js +0 -124
  21. package/dist/workers/editor/common/common.js +0 -20
  22. package/dist/workers/editor/common/computeMovedLines.js +0 -249
  23. package/dist/workers/editor/common/concat23Trees.js +0 -192
  24. package/dist/workers/editor/common/contiguousMultilineTokens.js +0 -32
  25. package/dist/workers/editor/common/contiguousMultilineTokensBuilder.js +0 -23
  26. package/dist/workers/editor/common/contiguousTokensEditing.js +0 -128
  27. package/dist/workers/editor/common/contiguousTokensStore.js +0 -207
  28. package/dist/workers/editor/common/coordinatesConverter.js +0 -51
  29. package/dist/workers/editor/common/cursor.js +0 -899
  30. package/dist/workers/editor/common/cursorAtomicMoveOperations.js +0 -145
  31. package/dist/workers/editor/common/cursorCollection.js +0 -194
  32. package/dist/workers/editor/common/cursorColumnSelection.js +0 -93
  33. package/dist/workers/editor/common/cursorColumns.js +0 -112
  34. package/dist/workers/editor/common/cursorCommon.js +0 -250
  35. package/dist/workers/editor/common/cursorContext.js +0 -15
  36. package/dist/workers/editor/common/cursorDeleteOperations.js +0 -231
  37. package/dist/workers/editor/common/cursorMoveCommands.js +0 -676
  38. package/dist/workers/editor/common/cursorMoveOperations.js +0 -290
  39. package/dist/workers/editor/common/cursorTypeEditOperations.js +0 -968
  40. package/dist/workers/editor/common/cursorTypeOperations.js +0 -173
  41. package/dist/workers/editor/common/cursorUtils.js +0 -75
  42. package/dist/workers/editor/common/cursorWordOperations.js +0 -720
  43. package/dist/workers/editor/common/defaultDocumentColorsComputer.js +0 -138
  44. package/dist/workers/editor/common/defaultLinesDiffComputer.js +0 -188
  45. package/dist/workers/editor/common/diffAlgorithm.js +0 -139
  46. package/dist/workers/editor/common/diffEditor.js +0 -38
  47. package/dist/workers/editor/common/dynamicProgrammingDiffing.js +0 -101
  48. package/dist/workers/editor/common/edit.js +0 -183
  49. package/dist/workers/editor/common/editOperation.js +0 -36
  50. package/dist/workers/editor/common/editStack.js +0 -363
  51. package/dist/workers/editor/common/editorAction.js +0 -26
  52. package/dist/workers/editor/common/editorBaseApi.js +0 -43
  53. package/dist/workers/editor/common/editorColorRegistry.js +0 -102
  54. package/dist/workers/editor/common/editorCommon.js +0 -13
  55. package/dist/workers/editor/common/editorConfigurationSchema.js +0 -338
  56. package/dist/workers/editor/common/editorContextKeys.js +0 -84
  57. package/dist/workers/editor/common/editorFeatures.js +0 -17
  58. package/dist/workers/editor/common/editorOptions.js +0 -3440
  59. package/dist/workers/editor/common/editorTheme.js +0 -23
  60. package/dist/workers/editor/common/editorWebWorker.js +0 -299
  61. package/dist/workers/editor/common/editorWorker.js +0 -9
  62. package/dist/workers/editor/common/editorWorkerHost.js +0 -15
  63. package/dist/workers/editor/common/editorZoom.js +0 -26
  64. package/dist/workers/editor/common/electricCharacter.js +0 -55
  65. package/dist/workers/editor/common/encodedTokenAttributes.js +0 -79
  66. package/dist/workers/editor/common/enterAction.js +0 -53
  67. package/dist/workers/editor/common/eolCounter.js +0 -44
  68. package/dist/workers/editor/common/findSectionHeaders.js +0 -128
  69. package/dist/workers/editor/common/fixBrackets.js +0 -67
  70. package/dist/workers/editor/common/fixedArray.js +0 -70
  71. package/dist/workers/editor/common/fontInfo.js +0 -172
  72. package/dist/workers/editor/common/fontInfoFromSettings.js +0 -29
  73. package/dist/workers/editor/common/getIconClasses.js +0 -106
  74. package/dist/workers/editor/common/getPositionOffsetTransformerFromTextModel.js +0 -24
  75. package/dist/workers/editor/common/glyphLanesModel.js +0 -61
  76. package/dist/workers/editor/common/guidesTextModelPart.js +0 -405
  77. package/dist/workers/editor/common/heuristicSequenceOptimizations.js +0 -374
  78. package/dist/workers/editor/common/indentRules.js +0 -63
  79. package/dist/workers/editor/common/indentation.js +0 -39
  80. package/dist/workers/editor/common/indentationGuesser.js +0 -178
  81. package/dist/workers/editor/common/indentationLineProcessor.js +0 -193
  82. package/dist/workers/editor/common/inlineDecorations.js +0 -26
  83. package/dist/workers/editor/common/inplaceReplaceSupport.js +0 -87
  84. package/dist/workers/editor/common/inputMode.js +0 -22
  85. package/dist/workers/editor/common/intervalTree.js +0 -1002
  86. package/dist/workers/editor/common/language.js +0 -9
  87. package/dist/workers/editor/common/languageBracketsConfiguration.js +0 -133
  88. package/dist/workers/editor/common/languageConfiguration.js +0 -138
  89. package/dist/workers/editor/common/languageConfigurationRegistry.js +0 -361
  90. package/dist/workers/editor/common/languageFeatureDebounce.js +0 -137
  91. package/dist/workers/editor/common/languageFeatureRegistry.js +0 -180
  92. package/dist/workers/editor/common/languageFeatures.js +0 -9
  93. package/dist/workers/editor/common/languageFeaturesService.js +0 -47
  94. package/dist/workers/editor/common/languageSelector.js +0 -112
  95. package/dist/workers/editor/common/languageService.js +0 -92
  96. package/dist/workers/editor/common/languages.js +0 -522
  97. package/dist/workers/editor/common/languagesAssociations.js +0 -193
  98. package/dist/workers/editor/common/languagesRegistry.js +0 -237
  99. package/dist/workers/editor/common/legacyLinesDiffComputer.js +0 -468
  100. package/dist/workers/editor/common/length.js +0 -129
  101. package/dist/workers/editor/common/lineDecorations.js +0 -208
  102. package/dist/workers/editor/common/lineEdit.js +0 -75
  103. package/dist/workers/editor/common/lineHeights.js +0 -370
  104. package/dist/workers/editor/common/linePart.js +0 -25
  105. package/dist/workers/editor/common/lineRange.js +0 -312
  106. package/dist/workers/editor/common/lineSequence.js +0 -36
  107. package/dist/workers/editor/common/lineTokens.js +0 -405
  108. package/dist/workers/editor/common/linesDiffComputer.js +0 -29
  109. package/dist/workers/editor/common/linesDiffComputers.js +0 -13
  110. package/dist/workers/editor/common/linesLayout.js +0 -765
  111. package/dist/workers/editor/common/linesSliceCharSequence.js +0 -205
  112. package/dist/workers/editor/common/linkComputer.js +0 -269
  113. package/dist/workers/editor/common/markerDecorations.js +0 -9
  114. package/dist/workers/editor/common/markerDecorationsService.js +0 -248
  115. package/dist/workers/editor/common/minimapTokensColorTracker.js +0 -58
  116. package/dist/workers/editor/common/mirrorTextModel.js +0 -117
  117. package/dist/workers/editor/common/model.js +0 -9
  118. package/dist/workers/editor/common/modelLineProjection.js +0 -350
  119. package/dist/workers/editor/common/modelLineProjectionData.js +0 -297
  120. package/dist/workers/editor/common/modelService.js +0 -413
  121. package/dist/workers/editor/common/modesRegistry.js +0 -75
  122. package/dist/workers/editor/common/monospaceLineBreaksComputer.js +0 -473
  123. package/dist/workers/editor/common/myersDiffAlgorithm.js +0 -159
  124. package/dist/workers/editor/common/nodeReader.js +0 -127
  125. package/dist/workers/editor/common/nullTokenize.js +0 -29
  126. package/dist/workers/editor/common/offsetRange.js +0 -225
  127. package/dist/workers/editor/common/onEnter.js +0 -109
  128. package/dist/workers/editor/common/oneCursor.js +0 -117
  129. package/dist/workers/editor/common/overviewZoneManager.js +0 -176
  130. package/dist/workers/editor/common/parser.js +0 -121
  131. package/dist/workers/editor/common/pieceTreeBase.js +0 -1473
  132. package/dist/workers/editor/common/pieceTreeTextBuffer.js +0 -461
  133. package/dist/workers/editor/common/pieceTreeTextBufferBuilder.js +0 -140
  134. package/dist/workers/editor/common/point.js +0 -50
  135. package/dist/workers/editor/common/position.js +0 -142
  136. package/dist/workers/editor/common/positionToOffset.js +0 -17
  137. package/dist/workers/editor/common/positionToOffsetImpl.js +0 -98
  138. package/dist/workers/editor/common/prefixSumComputer.js +0 -226
  139. package/dist/workers/editor/common/range.js +0 -421
  140. package/dist/workers/editor/common/rangeMapping.js +0 -229
  141. package/dist/workers/editor/common/rangeSingleLine.js +0 -17
  142. package/dist/workers/editor/common/rbTreeBase.js +0 -362
  143. package/dist/workers/editor/common/rect.js +0 -163
  144. package/dist/workers/editor/common/replaceCommand.js +0 -158
  145. package/dist/workers/editor/common/resolverService.js +0 -5
  146. package/dist/workers/editor/common/rgba.js +0 -35
  147. package/dist/workers/editor/common/richEditBrackets.js +0 -356
  148. package/dist/workers/editor/common/selection.js +0 -145
  149. package/dist/workers/editor/common/semanticTokensDto.js +0 -82
  150. package/dist/workers/editor/common/semanticTokensProviderStyling.js +0 -263
  151. package/dist/workers/editor/common/semanticTokensStyling.js +0 -9
  152. package/dist/workers/editor/common/semanticTokensStylingService.js +0 -47
  153. package/dist/workers/editor/common/shiftCommand.js +0 -241
  154. package/dist/workers/editor/common/smallImmutableSet.js +0 -108
  155. package/dist/workers/editor/common/sparseMultilineTokens.js +0 -548
  156. package/dist/workers/editor/common/sparseTokensStore.js +0 -210
  157. package/dist/workers/editor/common/standaloneEnums.js +0 -1017
  158. package/dist/workers/editor/common/standaloneStrings.js +0 -42
  159. package/dist/workers/editor/common/stringBuilder.js +0 -122
  160. package/dist/workers/editor/common/stringEdit.js +0 -165
  161. package/dist/workers/editor/common/supports.js +0 -58
  162. package/dist/workers/editor/common/surroundSelectionCommand.js +0 -44
  163. package/dist/workers/editor/common/textChange.js +0 -248
  164. package/dist/workers/editor/common/textEdit.js +0 -269
  165. package/dist/workers/editor/common/textLength.js +0 -87
  166. package/dist/workers/editor/common/textModel.js +0 -2031
  167. package/dist/workers/editor/common/textModelBracketPairs.js +0 -45
  168. package/dist/workers/editor/common/textModelDefaults.js +0 -18
  169. package/dist/workers/editor/common/textModelEditSource.js +0 -166
  170. package/dist/workers/editor/common/textModelEvents.js +0 -216
  171. package/dist/workers/editor/common/textModelGuides.js +0 -40
  172. package/dist/workers/editor/common/textModelPart.js +0 -23
  173. package/dist/workers/editor/common/textModelSearch.js +0 -455
  174. package/dist/workers/editor/common/textModelStringEdit.js +0 -11
  175. package/dist/workers/editor/common/textModelSync.impl.js +0 -307
  176. package/dist/workers/editor/common/textModelText.js +0 -26
  177. package/dist/workers/editor/common/textModelTokens.js +0 -436
  178. package/dist/workers/editor/common/textResourceConfiguration.js +0 -6
  179. package/dist/workers/editor/common/textToHtmlTokenizer.js +0 -139
  180. package/dist/workers/editor/common/tokenStore.js +0 -407
  181. package/dist/workers/editor/common/tokenWithTextArray.js +0 -73
  182. package/dist/workers/editor/common/tokenization.js +0 -287
  183. package/dist/workers/editor/common/tokenizationRegistry.js +0 -123
  184. package/dist/workers/editor/common/tokenizationTextModelPart.js +0 -275
  185. package/dist/workers/editor/common/tokenizer.js +0 -301
  186. package/dist/workers/editor/common/tokenizerSyntaxTokenBackend.js +0 -261
  187. package/dist/workers/editor/common/treeSitterLibraryService.js +0 -9
  188. package/dist/workers/editor/common/treeSitterSyntaxTokenBackend.js +0 -167
  189. package/dist/workers/editor/common/treeSitterThemeService.js +0 -9
  190. package/dist/workers/editor/common/treeSitterTokenizationImpl.js +0 -713
  191. package/dist/workers/editor/common/treeSitterTree.js +0 -395
  192. package/dist/workers/editor/common/treeViewsDnd.js +0 -24
  193. package/dist/workers/editor/common/treeViewsDndService.js +0 -12
  194. package/dist/workers/editor/common/trimTrailingWhitespaceCommand.js +0 -98
  195. package/dist/workers/editor/common/unicodeTextModelHighlighter.js +0 -188
  196. package/dist/workers/editor/common/utils.js +0 -62
  197. package/dist/workers/editor/common/viewContext.js +0 -22
  198. package/dist/workers/editor/common/viewEventHandler.js +0 -186
  199. package/dist/workers/editor/common/viewEvents.js +0 -180
  200. package/dist/workers/editor/common/viewLayout.js +0 -368
  201. package/dist/workers/editor/common/viewLineRenderer.js +0 -948
  202. package/dist/workers/editor/common/viewLinesViewportData.js +0 -30
  203. package/dist/workers/editor/common/viewModel.js +0 -98
  204. package/dist/workers/editor/common/viewModelDecoration.js +0 -55
  205. package/dist/workers/editor/common/viewModelDecorations.js +0 -132
  206. package/dist/workers/editor/common/viewModelEventDispatcher.js +0 -398
  207. package/dist/workers/editor/common/viewModelImpl.js +0 -1163
  208. package/dist/workers/editor/common/viewModelLines.js +0 -938
  209. package/dist/workers/editor/common/wordCharacterClassifier.js +0 -87
  210. package/dist/workers/editor/common/wordHelper.js +0 -127
  211. package/dist/workers/language/cssMode.js +0 -198
  212. package/dist/workers/language/cssWorker.js +0 -183
  213. package/dist/workers/language/htmlMode.js +0 -213
  214. package/dist/workers/language/htmlWorker.js +0 -126
  215. package/dist/workers/language/jsonMode.js +0 -224
  216. package/dist/workers/language/jsonWorker.js +0 -187
  217. package/dist/workers/language/languageFeatures.js +0 -1009
  218. package/dist/workers/language/lib.index.js +0 -103
  219. package/dist/workers/language/lib.js +0 -1107
  220. package/dist/workers/language/lspLanguageFeatures.js +0 -716
  221. package/dist/workers/language/monaco.contribution.js +0 -144
  222. package/dist/workers/language/tokenization.js +0 -189
  223. package/dist/workers/language/tsMode.js +0 -212
  224. package/dist/workers/language/tsWorker.js +0 -352
  225. package/dist/workers/language/typescriptServices.js +0 -210154
  226. package/dist/workers/language/typescriptServicesMetadata.js +0 -3
  227. package/dist/workers/language/workerManager.js +0 -65
  228. /package/dist/workers/{language/css.worker.js → css.worker.js} +0 -0
  229. /package/dist/workers/{editor/editor.worker.js → editor.worker.js} +0 -0
  230. /package/dist/workers/{language/html.worker.js → html.worker.js} +0 -0
  231. /package/dist/workers/{language/json.worker.js → json.worker.js} +0 -0
  232. /package/dist/workers/{language/ts.worker.js → ts.worker.js} +0 -0
@@ -1,717 +0,0 @@
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 };