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,405 @@
|
|
|
1
|
+
import { findLast } from '../../../base/common/arraysFind.js';
|
|
2
|
+
import { firstNonWhitespaceIndex } from '../../../base/common/strings.js';
|
|
3
|
+
import { CursorColumns } from '../core/cursorColumns.js';
|
|
4
|
+
import { Range } from '../core/range.js';
|
|
5
|
+
import { TextModelPart } from './textModelPart.js';
|
|
6
|
+
import { computeIndentLevel } from './utils.js';
|
|
7
|
+
import { HorizontalGuidesState, IndentGuide, IndentGuideHorizontalLine } from '../textModelGuides.js';
|
|
8
|
+
import { BugIndicatingError } from '../../../base/common/errors.js';
|
|
9
|
+
|
|
10
|
+
/*---------------------------------------------------------------------------------------------
|
|
11
|
+
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
12
|
+
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
13
|
+
*--------------------------------------------------------------------------------------------*/
|
|
14
|
+
class GuidesTextModelPart extends TextModelPart {
|
|
15
|
+
constructor(textModel, languageConfigurationService) {
|
|
16
|
+
super();
|
|
17
|
+
this.textModel = textModel;
|
|
18
|
+
this.languageConfigurationService = languageConfigurationService;
|
|
19
|
+
}
|
|
20
|
+
getLanguageConfiguration(languageId) {
|
|
21
|
+
return this.languageConfigurationService.getLanguageConfiguration(languageId);
|
|
22
|
+
}
|
|
23
|
+
_computeIndentLevel(lineIndex) {
|
|
24
|
+
return computeIndentLevel(this.textModel.getLineContent(lineIndex + 1), this.textModel.getOptions().tabSize);
|
|
25
|
+
}
|
|
26
|
+
getActiveIndentGuide(lineNumber, minLineNumber, maxLineNumber) {
|
|
27
|
+
this.assertNotDisposed();
|
|
28
|
+
const lineCount = this.textModel.getLineCount();
|
|
29
|
+
if (lineNumber < 1 || lineNumber > lineCount) {
|
|
30
|
+
throw new BugIndicatingError('Illegal value for lineNumber');
|
|
31
|
+
}
|
|
32
|
+
const foldingRules = this.getLanguageConfiguration(this.textModel.getLanguageId()).foldingRules;
|
|
33
|
+
const offSide = Boolean(foldingRules && foldingRules.offSide);
|
|
34
|
+
let up_aboveContentLineIndex = -2; /* -2 is a marker for not having computed it */
|
|
35
|
+
let up_aboveContentLineIndent = -1;
|
|
36
|
+
let up_belowContentLineIndex = -2; /* -2 is a marker for not having computed it */
|
|
37
|
+
let up_belowContentLineIndent = -1;
|
|
38
|
+
const up_resolveIndents = (lineNumber) => {
|
|
39
|
+
if (up_aboveContentLineIndex !== -1 &&
|
|
40
|
+
(up_aboveContentLineIndex === -2 ||
|
|
41
|
+
up_aboveContentLineIndex > lineNumber - 1)) {
|
|
42
|
+
up_aboveContentLineIndex = -1;
|
|
43
|
+
up_aboveContentLineIndent = -1;
|
|
44
|
+
// must find previous line with content
|
|
45
|
+
for (let lineIndex = lineNumber - 2; lineIndex >= 0; lineIndex--) {
|
|
46
|
+
const indent = this._computeIndentLevel(lineIndex);
|
|
47
|
+
if (indent >= 0) {
|
|
48
|
+
up_aboveContentLineIndex = lineIndex;
|
|
49
|
+
up_aboveContentLineIndent = indent;
|
|
50
|
+
break;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
if (up_belowContentLineIndex === -2) {
|
|
55
|
+
up_belowContentLineIndex = -1;
|
|
56
|
+
up_belowContentLineIndent = -1;
|
|
57
|
+
// must find next line with content
|
|
58
|
+
for (let lineIndex = lineNumber; lineIndex < lineCount; lineIndex++) {
|
|
59
|
+
const indent = this._computeIndentLevel(lineIndex);
|
|
60
|
+
if (indent >= 0) {
|
|
61
|
+
up_belowContentLineIndex = lineIndex;
|
|
62
|
+
up_belowContentLineIndent = indent;
|
|
63
|
+
break;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
let down_aboveContentLineIndex = -2; /* -2 is a marker for not having computed it */
|
|
69
|
+
let down_aboveContentLineIndent = -1;
|
|
70
|
+
let down_belowContentLineIndex = -2; /* -2 is a marker for not having computed it */
|
|
71
|
+
let down_belowContentLineIndent = -1;
|
|
72
|
+
const down_resolveIndents = (lineNumber) => {
|
|
73
|
+
if (down_aboveContentLineIndex === -2) {
|
|
74
|
+
down_aboveContentLineIndex = -1;
|
|
75
|
+
down_aboveContentLineIndent = -1;
|
|
76
|
+
// must find previous line with content
|
|
77
|
+
for (let lineIndex = lineNumber - 2; lineIndex >= 0; lineIndex--) {
|
|
78
|
+
const indent = this._computeIndentLevel(lineIndex);
|
|
79
|
+
if (indent >= 0) {
|
|
80
|
+
down_aboveContentLineIndex = lineIndex;
|
|
81
|
+
down_aboveContentLineIndent = indent;
|
|
82
|
+
break;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
if (down_belowContentLineIndex !== -1 &&
|
|
87
|
+
(down_belowContentLineIndex === -2 ||
|
|
88
|
+
down_belowContentLineIndex < lineNumber - 1)) {
|
|
89
|
+
down_belowContentLineIndex = -1;
|
|
90
|
+
down_belowContentLineIndent = -1;
|
|
91
|
+
// must find next line with content
|
|
92
|
+
for (let lineIndex = lineNumber; lineIndex < lineCount; lineIndex++) {
|
|
93
|
+
const indent = this._computeIndentLevel(lineIndex);
|
|
94
|
+
if (indent >= 0) {
|
|
95
|
+
down_belowContentLineIndex = lineIndex;
|
|
96
|
+
down_belowContentLineIndent = indent;
|
|
97
|
+
break;
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
};
|
|
102
|
+
let startLineNumber = 0;
|
|
103
|
+
let goUp = true;
|
|
104
|
+
let endLineNumber = 0;
|
|
105
|
+
let goDown = true;
|
|
106
|
+
let indent = 0;
|
|
107
|
+
let initialIndent = 0;
|
|
108
|
+
for (let distance = 0; goUp || goDown; distance++) {
|
|
109
|
+
const upLineNumber = lineNumber - distance;
|
|
110
|
+
const downLineNumber = lineNumber + distance;
|
|
111
|
+
if (distance > 1 && (upLineNumber < 1 || upLineNumber < minLineNumber)) {
|
|
112
|
+
goUp = false;
|
|
113
|
+
}
|
|
114
|
+
if (distance > 1 &&
|
|
115
|
+
(downLineNumber > lineCount || downLineNumber > maxLineNumber)) {
|
|
116
|
+
goDown = false;
|
|
117
|
+
}
|
|
118
|
+
if (distance > 50000) {
|
|
119
|
+
// stop processing
|
|
120
|
+
goUp = false;
|
|
121
|
+
goDown = false;
|
|
122
|
+
}
|
|
123
|
+
let upLineIndentLevel = -1;
|
|
124
|
+
if (goUp && upLineNumber >= 1) {
|
|
125
|
+
// compute indent level going up
|
|
126
|
+
const currentIndent = this._computeIndentLevel(upLineNumber - 1);
|
|
127
|
+
if (currentIndent >= 0) {
|
|
128
|
+
// This line has content (besides whitespace)
|
|
129
|
+
// Use the line's indent
|
|
130
|
+
up_belowContentLineIndex = upLineNumber - 1;
|
|
131
|
+
up_belowContentLineIndent = currentIndent;
|
|
132
|
+
upLineIndentLevel = Math.ceil(currentIndent / this.textModel.getOptions().indentSize);
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
up_resolveIndents(upLineNumber);
|
|
136
|
+
upLineIndentLevel = this._getIndentLevelForWhitespaceLine(offSide, up_aboveContentLineIndent, up_belowContentLineIndent);
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
let downLineIndentLevel = -1;
|
|
140
|
+
if (goDown && downLineNumber <= lineCount) {
|
|
141
|
+
// compute indent level going down
|
|
142
|
+
const currentIndent = this._computeIndentLevel(downLineNumber - 1);
|
|
143
|
+
if (currentIndent >= 0) {
|
|
144
|
+
// This line has content (besides whitespace)
|
|
145
|
+
// Use the line's indent
|
|
146
|
+
down_aboveContentLineIndex = downLineNumber - 1;
|
|
147
|
+
down_aboveContentLineIndent = currentIndent;
|
|
148
|
+
downLineIndentLevel = Math.ceil(currentIndent / this.textModel.getOptions().indentSize);
|
|
149
|
+
}
|
|
150
|
+
else {
|
|
151
|
+
down_resolveIndents(downLineNumber);
|
|
152
|
+
downLineIndentLevel = this._getIndentLevelForWhitespaceLine(offSide, down_aboveContentLineIndent, down_belowContentLineIndent);
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
if (distance === 0) {
|
|
156
|
+
initialIndent = upLineIndentLevel;
|
|
157
|
+
continue;
|
|
158
|
+
}
|
|
159
|
+
if (distance === 1) {
|
|
160
|
+
if (downLineNumber <= lineCount &&
|
|
161
|
+
downLineIndentLevel >= 0 &&
|
|
162
|
+
initialIndent + 1 === downLineIndentLevel) {
|
|
163
|
+
// This is the beginning of a scope, we have special handling here, since we want the
|
|
164
|
+
// child scope indent to be active, not the parent scope
|
|
165
|
+
goUp = false;
|
|
166
|
+
startLineNumber = downLineNumber;
|
|
167
|
+
endLineNumber = downLineNumber;
|
|
168
|
+
indent = downLineIndentLevel;
|
|
169
|
+
continue;
|
|
170
|
+
}
|
|
171
|
+
if (upLineNumber >= 1 &&
|
|
172
|
+
upLineIndentLevel >= 0 &&
|
|
173
|
+
upLineIndentLevel - 1 === initialIndent) {
|
|
174
|
+
// This is the end of a scope, just like above
|
|
175
|
+
goDown = false;
|
|
176
|
+
startLineNumber = upLineNumber;
|
|
177
|
+
endLineNumber = upLineNumber;
|
|
178
|
+
indent = upLineIndentLevel;
|
|
179
|
+
continue;
|
|
180
|
+
}
|
|
181
|
+
startLineNumber = lineNumber;
|
|
182
|
+
endLineNumber = lineNumber;
|
|
183
|
+
indent = initialIndent;
|
|
184
|
+
if (indent === 0) {
|
|
185
|
+
// No need to continue
|
|
186
|
+
return { startLineNumber, endLineNumber, indent };
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
if (goUp) {
|
|
190
|
+
if (upLineIndentLevel >= indent) {
|
|
191
|
+
startLineNumber = upLineNumber;
|
|
192
|
+
}
|
|
193
|
+
else {
|
|
194
|
+
goUp = false;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
if (goDown) {
|
|
198
|
+
if (downLineIndentLevel >= indent) {
|
|
199
|
+
endLineNumber = downLineNumber;
|
|
200
|
+
}
|
|
201
|
+
else {
|
|
202
|
+
goDown = false;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
return { startLineNumber, endLineNumber, indent };
|
|
207
|
+
}
|
|
208
|
+
getLinesBracketGuides(startLineNumber, endLineNumber, activePosition, options) {
|
|
209
|
+
const result = [];
|
|
210
|
+
for (let lineNumber = startLineNumber; lineNumber <= endLineNumber; lineNumber++) {
|
|
211
|
+
result.push([]);
|
|
212
|
+
}
|
|
213
|
+
// If requested, this could be made configurable.
|
|
214
|
+
const includeSingleLinePairs = true;
|
|
215
|
+
const bracketPairs = this.textModel.bracketPairs.getBracketPairsInRangeWithMinIndentation(new Range(startLineNumber, 1, endLineNumber, this.textModel.getLineMaxColumn(endLineNumber))).toArray();
|
|
216
|
+
let activeBracketPairRange = undefined;
|
|
217
|
+
if (activePosition && bracketPairs.length > 0) {
|
|
218
|
+
const bracketsContainingActivePosition = (startLineNumber <= activePosition.lineNumber &&
|
|
219
|
+
activePosition.lineNumber <= endLineNumber
|
|
220
|
+
// We don't need to query the brackets again if the cursor is in the viewport
|
|
221
|
+
? bracketPairs
|
|
222
|
+
: this.textModel.bracketPairs.getBracketPairsInRange(Range.fromPositions(activePosition)).toArray()).filter((bp) => Range.strictContainsPosition(bp.range, activePosition));
|
|
223
|
+
activeBracketPairRange = findLast(bracketsContainingActivePosition, (i) => includeSingleLinePairs)?.range;
|
|
224
|
+
}
|
|
225
|
+
const independentColorPoolPerBracketType = this.textModel.getOptions().bracketPairColorizationOptions.independentColorPoolPerBracketType;
|
|
226
|
+
const colorProvider = new BracketPairGuidesClassNames();
|
|
227
|
+
for (const pair of bracketPairs) {
|
|
228
|
+
/*
|
|
229
|
+
|
|
230
|
+
|
|
231
|
+
{
|
|
232
|
+
|
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
{
|
|
236
|
+
|
|
|
237
|
+
----}
|
|
238
|
+
|
|
239
|
+
____{
|
|
240
|
+
|test
|
|
241
|
+
----}
|
|
242
|
+
|
|
243
|
+
renderHorizontalEndLineAtTheBottom:
|
|
244
|
+
{
|
|
245
|
+
|
|
|
246
|
+
|x}
|
|
247
|
+
--
|
|
248
|
+
renderHorizontalEndLineAtTheBottom:
|
|
249
|
+
____{
|
|
250
|
+
|test
|
|
251
|
+
| x }
|
|
252
|
+
----
|
|
253
|
+
*/
|
|
254
|
+
if (!pair.closingBracketRange) {
|
|
255
|
+
continue;
|
|
256
|
+
}
|
|
257
|
+
const isActive = activeBracketPairRange && pair.range.equalsRange(activeBracketPairRange);
|
|
258
|
+
if (!isActive && !options.includeInactive) {
|
|
259
|
+
continue;
|
|
260
|
+
}
|
|
261
|
+
const className = colorProvider.getInlineClassName(pair.nestingLevel, pair.nestingLevelOfEqualBracketType, independentColorPoolPerBracketType) +
|
|
262
|
+
(options.highlightActive && isActive
|
|
263
|
+
? ' ' + colorProvider.activeClassName
|
|
264
|
+
: '');
|
|
265
|
+
const start = pair.openingBracketRange.getStartPosition();
|
|
266
|
+
const end = pair.closingBracketRange.getStartPosition();
|
|
267
|
+
const horizontalGuides = options.horizontalGuides === HorizontalGuidesState.Enabled || (options.horizontalGuides === HorizontalGuidesState.EnabledForActive && isActive);
|
|
268
|
+
if (pair.range.startLineNumber === pair.range.endLineNumber) {
|
|
269
|
+
if (horizontalGuides) {
|
|
270
|
+
result[pair.range.startLineNumber - startLineNumber].push(new IndentGuide(-1, pair.openingBracketRange.getEndPosition().column, className, new IndentGuideHorizontalLine(false, end.column), -1, -1));
|
|
271
|
+
}
|
|
272
|
+
continue;
|
|
273
|
+
}
|
|
274
|
+
const endVisibleColumn = this.getVisibleColumnFromPosition(end);
|
|
275
|
+
const startVisibleColumn = this.getVisibleColumnFromPosition(pair.openingBracketRange.getStartPosition());
|
|
276
|
+
const guideVisibleColumn = Math.min(startVisibleColumn, endVisibleColumn, pair.minVisibleColumnIndentation + 1);
|
|
277
|
+
let renderHorizontalEndLineAtTheBottom = false;
|
|
278
|
+
const firstNonWsIndex = firstNonWhitespaceIndex(this.textModel.getLineContent(pair.closingBracketRange.startLineNumber));
|
|
279
|
+
const hasTextBeforeClosingBracket = firstNonWsIndex < pair.closingBracketRange.startColumn - 1;
|
|
280
|
+
if (hasTextBeforeClosingBracket) {
|
|
281
|
+
renderHorizontalEndLineAtTheBottom = true;
|
|
282
|
+
}
|
|
283
|
+
const visibleGuideStartLineNumber = Math.max(start.lineNumber, startLineNumber);
|
|
284
|
+
const visibleGuideEndLineNumber = Math.min(end.lineNumber, endLineNumber);
|
|
285
|
+
const offset = renderHorizontalEndLineAtTheBottom ? 1 : 0;
|
|
286
|
+
for (let l = visibleGuideStartLineNumber; l < visibleGuideEndLineNumber + offset; l++) {
|
|
287
|
+
result[l - startLineNumber].push(new IndentGuide(guideVisibleColumn, -1, className, null, l === start.lineNumber ? start.column : -1, l === end.lineNumber ? end.column : -1));
|
|
288
|
+
}
|
|
289
|
+
if (horizontalGuides) {
|
|
290
|
+
if (start.lineNumber >= startLineNumber && startVisibleColumn > guideVisibleColumn) {
|
|
291
|
+
result[start.lineNumber - startLineNumber].push(new IndentGuide(guideVisibleColumn, -1, className, new IndentGuideHorizontalLine(false, start.column), -1, -1));
|
|
292
|
+
}
|
|
293
|
+
if (end.lineNumber <= endLineNumber && endVisibleColumn > guideVisibleColumn) {
|
|
294
|
+
result[end.lineNumber - startLineNumber].push(new IndentGuide(guideVisibleColumn, -1, className, new IndentGuideHorizontalLine(!renderHorizontalEndLineAtTheBottom, end.column), -1, -1));
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
for (const guides of result) {
|
|
299
|
+
guides.sort((a, b) => a.visibleColumn - b.visibleColumn);
|
|
300
|
+
}
|
|
301
|
+
return result;
|
|
302
|
+
}
|
|
303
|
+
getVisibleColumnFromPosition(position) {
|
|
304
|
+
return (CursorColumns.visibleColumnFromColumn(this.textModel.getLineContent(position.lineNumber), position.column, this.textModel.getOptions().tabSize) + 1);
|
|
305
|
+
}
|
|
306
|
+
getLinesIndentGuides(startLineNumber, endLineNumber) {
|
|
307
|
+
this.assertNotDisposed();
|
|
308
|
+
const lineCount = this.textModel.getLineCount();
|
|
309
|
+
if (startLineNumber < 1 || startLineNumber > lineCount) {
|
|
310
|
+
throw new Error('Illegal value for startLineNumber');
|
|
311
|
+
}
|
|
312
|
+
if (endLineNumber < 1 || endLineNumber > lineCount) {
|
|
313
|
+
throw new Error('Illegal value for endLineNumber');
|
|
314
|
+
}
|
|
315
|
+
const options = this.textModel.getOptions();
|
|
316
|
+
const foldingRules = this.getLanguageConfiguration(this.textModel.getLanguageId()).foldingRules;
|
|
317
|
+
const offSide = Boolean(foldingRules && foldingRules.offSide);
|
|
318
|
+
const result = new Array(endLineNumber - startLineNumber + 1);
|
|
319
|
+
let aboveContentLineIndex = -2; /* -2 is a marker for not having computed it */
|
|
320
|
+
let aboveContentLineIndent = -1;
|
|
321
|
+
let belowContentLineIndex = -2; /* -2 is a marker for not having computed it */
|
|
322
|
+
let belowContentLineIndent = -1;
|
|
323
|
+
for (let lineNumber = startLineNumber; lineNumber <= endLineNumber; lineNumber++) {
|
|
324
|
+
const resultIndex = lineNumber - startLineNumber;
|
|
325
|
+
const currentIndent = this._computeIndentLevel(lineNumber - 1);
|
|
326
|
+
if (currentIndent >= 0) {
|
|
327
|
+
// This line has content (besides whitespace)
|
|
328
|
+
// Use the line's indent
|
|
329
|
+
aboveContentLineIndex = lineNumber - 1;
|
|
330
|
+
aboveContentLineIndent = currentIndent;
|
|
331
|
+
result[resultIndex] = Math.ceil(currentIndent / options.indentSize);
|
|
332
|
+
continue;
|
|
333
|
+
}
|
|
334
|
+
if (aboveContentLineIndex === -2) {
|
|
335
|
+
aboveContentLineIndex = -1;
|
|
336
|
+
aboveContentLineIndent = -1;
|
|
337
|
+
// must find previous line with content
|
|
338
|
+
for (let lineIndex = lineNumber - 2; lineIndex >= 0; lineIndex--) {
|
|
339
|
+
const indent = this._computeIndentLevel(lineIndex);
|
|
340
|
+
if (indent >= 0) {
|
|
341
|
+
aboveContentLineIndex = lineIndex;
|
|
342
|
+
aboveContentLineIndent = indent;
|
|
343
|
+
break;
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
}
|
|
347
|
+
if (belowContentLineIndex !== -1 &&
|
|
348
|
+
(belowContentLineIndex === -2 || belowContentLineIndex < lineNumber - 1)) {
|
|
349
|
+
belowContentLineIndex = -1;
|
|
350
|
+
belowContentLineIndent = -1;
|
|
351
|
+
// must find next line with content
|
|
352
|
+
for (let lineIndex = lineNumber; lineIndex < lineCount; lineIndex++) {
|
|
353
|
+
const indent = this._computeIndentLevel(lineIndex);
|
|
354
|
+
if (indent >= 0) {
|
|
355
|
+
belowContentLineIndex = lineIndex;
|
|
356
|
+
belowContentLineIndent = indent;
|
|
357
|
+
break;
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
result[resultIndex] = this._getIndentLevelForWhitespaceLine(offSide, aboveContentLineIndent, belowContentLineIndent);
|
|
362
|
+
}
|
|
363
|
+
return result;
|
|
364
|
+
}
|
|
365
|
+
_getIndentLevelForWhitespaceLine(offSide, aboveContentLineIndent, belowContentLineIndent) {
|
|
366
|
+
const options = this.textModel.getOptions();
|
|
367
|
+
if (aboveContentLineIndent === -1 || belowContentLineIndent === -1) {
|
|
368
|
+
// At the top or bottom of the file
|
|
369
|
+
return 0;
|
|
370
|
+
}
|
|
371
|
+
else if (aboveContentLineIndent < belowContentLineIndent) {
|
|
372
|
+
// we are inside the region above
|
|
373
|
+
return 1 + Math.floor(aboveContentLineIndent / options.indentSize);
|
|
374
|
+
}
|
|
375
|
+
else if (aboveContentLineIndent === belowContentLineIndent) {
|
|
376
|
+
// we are in between two regions
|
|
377
|
+
return Math.ceil(belowContentLineIndent / options.indentSize);
|
|
378
|
+
}
|
|
379
|
+
else {
|
|
380
|
+
if (offSide) {
|
|
381
|
+
// same level as region below
|
|
382
|
+
return Math.ceil(belowContentLineIndent / options.indentSize);
|
|
383
|
+
}
|
|
384
|
+
else {
|
|
385
|
+
// we are inside the region that ends below
|
|
386
|
+
return 1 + Math.floor(belowContentLineIndent / options.indentSize);
|
|
387
|
+
}
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
class BracketPairGuidesClassNames {
|
|
392
|
+
constructor() {
|
|
393
|
+
this.activeClassName = 'indent-active';
|
|
394
|
+
}
|
|
395
|
+
getInlineClassName(nestingLevel, nestingLevelOfEqualBracketType, independentColorPoolPerBracketType) {
|
|
396
|
+
return this.getInlineClassNameOfLevel(independentColorPoolPerBracketType ? nestingLevelOfEqualBracketType : nestingLevel);
|
|
397
|
+
}
|
|
398
|
+
getInlineClassNameOfLevel(level) {
|
|
399
|
+
// To support a dynamic amount of colors up to 6 colors,
|
|
400
|
+
// we use a number that is a lcm of all numbers from 1 to 6.
|
|
401
|
+
return `bracket-indent-guide lvl-${level % 30}`;
|
|
402
|
+
}
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
export { BracketPairGuidesClassNames, GuidesTextModelPart };
|