monaco-editor11 1.0.9 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.d.ts +1 -1
- package/dist/monaco-editor11.es.js +11 -16
- package/dist/monaco-editor11.umd.js +1 -1
- package/package.json +2 -2
- package/dist/monaco.d.ts +0 -8
- package/dist/workers/common/initialize.js +0 -16
- package/dist/workers/common/workers.js +0 -141
- package/dist/workers/editor/common/abstractSyntaxTokenBackend.js +0 -128
- package/dist/workers/editor/common/abstractText.js +0 -89
- package/dist/workers/editor/common/ast.js +0 -485
- package/dist/workers/editor/common/autoIndent.js +0 -390
- package/dist/workers/editor/common/beforeEditPositionMapper.js +0 -110
- package/dist/workers/editor/common/bracketPairsImpl.js +0 -717
- package/dist/workers/editor/common/bracketPairsTree.js +0 -343
- package/dist/workers/editor/common/brackets.js +0 -108
- package/dist/workers/editor/common/characterClassifier.js +0 -59
- package/dist/workers/editor/common/characterPair.js +0 -40
- package/dist/workers/editor/common/colorizedBracketPairsDecorationProvider.js +0 -97
- package/dist/workers/editor/common/columnRange.js +0 -35
- package/dist/workers/editor/common/combineTextEditInfos.js +0 -124
- package/dist/workers/editor/common/common.js +0 -20
- package/dist/workers/editor/common/computeMovedLines.js +0 -249
- package/dist/workers/editor/common/concat23Trees.js +0 -192
- package/dist/workers/editor/common/contiguousMultilineTokens.js +0 -32
- package/dist/workers/editor/common/contiguousMultilineTokensBuilder.js +0 -23
- package/dist/workers/editor/common/contiguousTokensEditing.js +0 -128
- package/dist/workers/editor/common/contiguousTokensStore.js +0 -207
- package/dist/workers/editor/common/coordinatesConverter.js +0 -51
- package/dist/workers/editor/common/cursor.js +0 -899
- package/dist/workers/editor/common/cursorAtomicMoveOperations.js +0 -145
- package/dist/workers/editor/common/cursorCollection.js +0 -194
- package/dist/workers/editor/common/cursorColumnSelection.js +0 -93
- package/dist/workers/editor/common/cursorColumns.js +0 -112
- package/dist/workers/editor/common/cursorCommon.js +0 -250
- package/dist/workers/editor/common/cursorContext.js +0 -15
- package/dist/workers/editor/common/cursorDeleteOperations.js +0 -231
- package/dist/workers/editor/common/cursorMoveCommands.js +0 -676
- package/dist/workers/editor/common/cursorMoveOperations.js +0 -290
- package/dist/workers/editor/common/cursorTypeEditOperations.js +0 -968
- package/dist/workers/editor/common/cursorTypeOperations.js +0 -173
- package/dist/workers/editor/common/cursorUtils.js +0 -75
- package/dist/workers/editor/common/cursorWordOperations.js +0 -720
- package/dist/workers/editor/common/defaultDocumentColorsComputer.js +0 -138
- package/dist/workers/editor/common/defaultLinesDiffComputer.js +0 -188
- package/dist/workers/editor/common/diffAlgorithm.js +0 -139
- package/dist/workers/editor/common/diffEditor.js +0 -38
- package/dist/workers/editor/common/dynamicProgrammingDiffing.js +0 -101
- package/dist/workers/editor/common/edit.js +0 -183
- package/dist/workers/editor/common/editOperation.js +0 -36
- package/dist/workers/editor/common/editStack.js +0 -363
- package/dist/workers/editor/common/editorAction.js +0 -26
- package/dist/workers/editor/common/editorBaseApi.js +0 -43
- package/dist/workers/editor/common/editorColorRegistry.js +0 -102
- package/dist/workers/editor/common/editorCommon.js +0 -13
- package/dist/workers/editor/common/editorConfigurationSchema.js +0 -338
- package/dist/workers/editor/common/editorContextKeys.js +0 -84
- package/dist/workers/editor/common/editorFeatures.js +0 -17
- package/dist/workers/editor/common/editorOptions.js +0 -3440
- package/dist/workers/editor/common/editorTheme.js +0 -23
- package/dist/workers/editor/common/editorWebWorker.js +0 -299
- package/dist/workers/editor/common/editorWorker.js +0 -9
- package/dist/workers/editor/common/editorWorkerHost.js +0 -15
- package/dist/workers/editor/common/editorZoom.js +0 -26
- package/dist/workers/editor/common/electricCharacter.js +0 -55
- package/dist/workers/editor/common/encodedTokenAttributes.js +0 -79
- package/dist/workers/editor/common/enterAction.js +0 -53
- package/dist/workers/editor/common/eolCounter.js +0 -44
- package/dist/workers/editor/common/findSectionHeaders.js +0 -128
- package/dist/workers/editor/common/fixBrackets.js +0 -67
- package/dist/workers/editor/common/fixedArray.js +0 -70
- package/dist/workers/editor/common/fontInfo.js +0 -172
- package/dist/workers/editor/common/fontInfoFromSettings.js +0 -29
- package/dist/workers/editor/common/getIconClasses.js +0 -106
- package/dist/workers/editor/common/getPositionOffsetTransformerFromTextModel.js +0 -24
- package/dist/workers/editor/common/glyphLanesModel.js +0 -61
- package/dist/workers/editor/common/guidesTextModelPart.js +0 -405
- package/dist/workers/editor/common/heuristicSequenceOptimizations.js +0 -374
- package/dist/workers/editor/common/indentRules.js +0 -63
- package/dist/workers/editor/common/indentation.js +0 -39
- package/dist/workers/editor/common/indentationGuesser.js +0 -178
- package/dist/workers/editor/common/indentationLineProcessor.js +0 -193
- package/dist/workers/editor/common/inlineDecorations.js +0 -26
- package/dist/workers/editor/common/inplaceReplaceSupport.js +0 -87
- package/dist/workers/editor/common/inputMode.js +0 -22
- package/dist/workers/editor/common/intervalTree.js +0 -1002
- package/dist/workers/editor/common/language.js +0 -9
- package/dist/workers/editor/common/languageBracketsConfiguration.js +0 -133
- package/dist/workers/editor/common/languageConfiguration.js +0 -138
- package/dist/workers/editor/common/languageConfigurationRegistry.js +0 -361
- package/dist/workers/editor/common/languageFeatureDebounce.js +0 -137
- package/dist/workers/editor/common/languageFeatureRegistry.js +0 -180
- package/dist/workers/editor/common/languageFeatures.js +0 -9
- package/dist/workers/editor/common/languageFeaturesService.js +0 -47
- package/dist/workers/editor/common/languageSelector.js +0 -112
- package/dist/workers/editor/common/languageService.js +0 -92
- package/dist/workers/editor/common/languages.js +0 -522
- package/dist/workers/editor/common/languagesAssociations.js +0 -193
- package/dist/workers/editor/common/languagesRegistry.js +0 -237
- package/dist/workers/editor/common/legacyLinesDiffComputer.js +0 -468
- package/dist/workers/editor/common/length.js +0 -129
- package/dist/workers/editor/common/lineDecorations.js +0 -208
- package/dist/workers/editor/common/lineEdit.js +0 -75
- package/dist/workers/editor/common/lineHeights.js +0 -370
- package/dist/workers/editor/common/linePart.js +0 -25
- package/dist/workers/editor/common/lineRange.js +0 -312
- package/dist/workers/editor/common/lineSequence.js +0 -36
- package/dist/workers/editor/common/lineTokens.js +0 -405
- package/dist/workers/editor/common/linesDiffComputer.js +0 -29
- package/dist/workers/editor/common/linesDiffComputers.js +0 -13
- package/dist/workers/editor/common/linesLayout.js +0 -765
- package/dist/workers/editor/common/linesSliceCharSequence.js +0 -205
- package/dist/workers/editor/common/linkComputer.js +0 -269
- package/dist/workers/editor/common/markerDecorations.js +0 -9
- package/dist/workers/editor/common/markerDecorationsService.js +0 -248
- package/dist/workers/editor/common/minimapTokensColorTracker.js +0 -58
- package/dist/workers/editor/common/mirrorTextModel.js +0 -117
- package/dist/workers/editor/common/model.js +0 -9
- package/dist/workers/editor/common/modelLineProjection.js +0 -350
- package/dist/workers/editor/common/modelLineProjectionData.js +0 -297
- package/dist/workers/editor/common/modelService.js +0 -413
- package/dist/workers/editor/common/modesRegistry.js +0 -75
- package/dist/workers/editor/common/monospaceLineBreaksComputer.js +0 -473
- package/dist/workers/editor/common/myersDiffAlgorithm.js +0 -159
- package/dist/workers/editor/common/nodeReader.js +0 -127
- package/dist/workers/editor/common/nullTokenize.js +0 -29
- package/dist/workers/editor/common/offsetRange.js +0 -225
- package/dist/workers/editor/common/onEnter.js +0 -109
- package/dist/workers/editor/common/oneCursor.js +0 -117
- package/dist/workers/editor/common/overviewZoneManager.js +0 -176
- package/dist/workers/editor/common/parser.js +0 -121
- package/dist/workers/editor/common/pieceTreeBase.js +0 -1473
- package/dist/workers/editor/common/pieceTreeTextBuffer.js +0 -461
- package/dist/workers/editor/common/pieceTreeTextBufferBuilder.js +0 -140
- package/dist/workers/editor/common/point.js +0 -50
- package/dist/workers/editor/common/position.js +0 -142
- package/dist/workers/editor/common/positionToOffset.js +0 -17
- package/dist/workers/editor/common/positionToOffsetImpl.js +0 -98
- package/dist/workers/editor/common/prefixSumComputer.js +0 -226
- package/dist/workers/editor/common/range.js +0 -421
- package/dist/workers/editor/common/rangeMapping.js +0 -229
- package/dist/workers/editor/common/rangeSingleLine.js +0 -17
- package/dist/workers/editor/common/rbTreeBase.js +0 -362
- package/dist/workers/editor/common/rect.js +0 -163
- package/dist/workers/editor/common/replaceCommand.js +0 -158
- package/dist/workers/editor/common/resolverService.js +0 -5
- package/dist/workers/editor/common/rgba.js +0 -35
- package/dist/workers/editor/common/richEditBrackets.js +0 -356
- package/dist/workers/editor/common/selection.js +0 -145
- package/dist/workers/editor/common/semanticTokensDto.js +0 -82
- package/dist/workers/editor/common/semanticTokensProviderStyling.js +0 -263
- package/dist/workers/editor/common/semanticTokensStyling.js +0 -9
- package/dist/workers/editor/common/semanticTokensStylingService.js +0 -47
- package/dist/workers/editor/common/shiftCommand.js +0 -241
- package/dist/workers/editor/common/smallImmutableSet.js +0 -108
- package/dist/workers/editor/common/sparseMultilineTokens.js +0 -548
- package/dist/workers/editor/common/sparseTokensStore.js +0 -210
- package/dist/workers/editor/common/standaloneEnums.js +0 -1017
- package/dist/workers/editor/common/standaloneStrings.js +0 -42
- package/dist/workers/editor/common/stringBuilder.js +0 -122
- package/dist/workers/editor/common/stringEdit.js +0 -165
- package/dist/workers/editor/common/supports.js +0 -58
- package/dist/workers/editor/common/surroundSelectionCommand.js +0 -44
- package/dist/workers/editor/common/textChange.js +0 -248
- package/dist/workers/editor/common/textEdit.js +0 -269
- package/dist/workers/editor/common/textLength.js +0 -87
- package/dist/workers/editor/common/textModel.js +0 -2031
- package/dist/workers/editor/common/textModelBracketPairs.js +0 -45
- package/dist/workers/editor/common/textModelDefaults.js +0 -18
- package/dist/workers/editor/common/textModelEditSource.js +0 -166
- package/dist/workers/editor/common/textModelEvents.js +0 -216
- package/dist/workers/editor/common/textModelGuides.js +0 -40
- package/dist/workers/editor/common/textModelPart.js +0 -23
- package/dist/workers/editor/common/textModelSearch.js +0 -455
- package/dist/workers/editor/common/textModelStringEdit.js +0 -11
- package/dist/workers/editor/common/textModelSync.impl.js +0 -307
- package/dist/workers/editor/common/textModelText.js +0 -26
- package/dist/workers/editor/common/textModelTokens.js +0 -436
- package/dist/workers/editor/common/textResourceConfiguration.js +0 -6
- package/dist/workers/editor/common/textToHtmlTokenizer.js +0 -139
- package/dist/workers/editor/common/tokenStore.js +0 -407
- package/dist/workers/editor/common/tokenWithTextArray.js +0 -73
- package/dist/workers/editor/common/tokenization.js +0 -287
- package/dist/workers/editor/common/tokenizationRegistry.js +0 -123
- package/dist/workers/editor/common/tokenizationTextModelPart.js +0 -275
- package/dist/workers/editor/common/tokenizer.js +0 -301
- package/dist/workers/editor/common/tokenizerSyntaxTokenBackend.js +0 -261
- package/dist/workers/editor/common/treeSitterLibraryService.js +0 -9
- package/dist/workers/editor/common/treeSitterSyntaxTokenBackend.js +0 -167
- package/dist/workers/editor/common/treeSitterThemeService.js +0 -9
- package/dist/workers/editor/common/treeSitterTokenizationImpl.js +0 -713
- package/dist/workers/editor/common/treeSitterTree.js +0 -395
- package/dist/workers/editor/common/treeViewsDnd.js +0 -24
- package/dist/workers/editor/common/treeViewsDndService.js +0 -12
- package/dist/workers/editor/common/trimTrailingWhitespaceCommand.js +0 -98
- package/dist/workers/editor/common/unicodeTextModelHighlighter.js +0 -188
- package/dist/workers/editor/common/utils.js +0 -62
- package/dist/workers/editor/common/viewContext.js +0 -22
- package/dist/workers/editor/common/viewEventHandler.js +0 -186
- package/dist/workers/editor/common/viewEvents.js +0 -180
- package/dist/workers/editor/common/viewLayout.js +0 -368
- package/dist/workers/editor/common/viewLineRenderer.js +0 -948
- package/dist/workers/editor/common/viewLinesViewportData.js +0 -30
- package/dist/workers/editor/common/viewModel.js +0 -98
- package/dist/workers/editor/common/viewModelDecoration.js +0 -55
- package/dist/workers/editor/common/viewModelDecorations.js +0 -132
- package/dist/workers/editor/common/viewModelEventDispatcher.js +0 -398
- package/dist/workers/editor/common/viewModelImpl.js +0 -1163
- package/dist/workers/editor/common/viewModelLines.js +0 -938
- package/dist/workers/editor/common/wordCharacterClassifier.js +0 -87
- package/dist/workers/editor/common/wordHelper.js +0 -127
- package/dist/workers/language/cssMode.js +0 -198
- package/dist/workers/language/cssWorker.js +0 -183
- package/dist/workers/language/htmlMode.js +0 -213
- package/dist/workers/language/htmlWorker.js +0 -126
- package/dist/workers/language/jsonMode.js +0 -224
- package/dist/workers/language/jsonWorker.js +0 -187
- package/dist/workers/language/languageFeatures.js +0 -1009
- package/dist/workers/language/lib.index.js +0 -103
- package/dist/workers/language/lib.js +0 -1107
- package/dist/workers/language/lspLanguageFeatures.js +0 -716
- package/dist/workers/language/monaco.contribution.js +0 -144
- package/dist/workers/language/tokenization.js +0 -189
- package/dist/workers/language/tsMode.js +0 -212
- package/dist/workers/language/tsWorker.js +0 -352
- package/dist/workers/language/typescriptServices.js +0 -210154
- package/dist/workers/language/typescriptServicesMetadata.js +0 -3
- package/dist/workers/language/workerManager.js +0 -65
- /package/dist/workers/{language/css.worker.js → css.worker.js} +0 -0
- /package/dist/workers/{editor/editor.worker.js → editor.worker.js} +0 -0
- /package/dist/workers/{language/html.worker.js → html.worker.js} +0 -0
- /package/dist/workers/{language/json.worker.js → json.worker.js} +0 -0
- /package/dist/workers/{language/ts.worker.js → ts.worker.js} +0 -0
|
@@ -1,765 +0,0 @@
|
|
|
1
|
-
import { singleLetterHash } from '../../../base/common/strings.js';
|
|
2
|
-
import { LineHeightsManager } from './lineHeights.js';
|
|
3
|
-
|
|
4
|
-
/*---------------------------------------------------------------------------------------------
|
|
5
|
-
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
6
|
-
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
7
|
-
*--------------------------------------------------------------------------------------------*/
|
|
8
|
-
class PendingChanges {
|
|
9
|
-
constructor() {
|
|
10
|
-
this._hasPending = false;
|
|
11
|
-
this._inserts = [];
|
|
12
|
-
this._changes = [];
|
|
13
|
-
this._removes = [];
|
|
14
|
-
}
|
|
15
|
-
insert(x) {
|
|
16
|
-
this._hasPending = true;
|
|
17
|
-
this._inserts.push(x);
|
|
18
|
-
}
|
|
19
|
-
change(x) {
|
|
20
|
-
this._hasPending = true;
|
|
21
|
-
this._changes.push(x);
|
|
22
|
-
}
|
|
23
|
-
remove(x) {
|
|
24
|
-
this._hasPending = true;
|
|
25
|
-
this._removes.push(x);
|
|
26
|
-
}
|
|
27
|
-
commit(linesLayout) {
|
|
28
|
-
if (!this._hasPending) {
|
|
29
|
-
return;
|
|
30
|
-
}
|
|
31
|
-
const inserts = this._inserts;
|
|
32
|
-
const changes = this._changes;
|
|
33
|
-
const removes = this._removes;
|
|
34
|
-
this._hasPending = false;
|
|
35
|
-
this._inserts = [];
|
|
36
|
-
this._changes = [];
|
|
37
|
-
this._removes = [];
|
|
38
|
-
linesLayout._commitPendingChanges(inserts, changes, removes);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
class EditorWhitespace {
|
|
42
|
-
constructor(id, afterLineNumber, ordinal, height, minWidth) {
|
|
43
|
-
this.id = id;
|
|
44
|
-
this.afterLineNumber = afterLineNumber;
|
|
45
|
-
this.ordinal = ordinal;
|
|
46
|
-
this.height = height;
|
|
47
|
-
this.minWidth = minWidth;
|
|
48
|
-
this.prefixSum = 0;
|
|
49
|
-
}
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Layouting of objects that take vertical space (by having a height) and push down other objects.
|
|
53
|
-
*
|
|
54
|
-
* These objects are basically either text (lines) or spaces between those lines (whitespaces).
|
|
55
|
-
* This provides commodity operations for working with lines that contain whitespace that pushes lines lower (vertically).
|
|
56
|
-
*/
|
|
57
|
-
class LinesLayout {
|
|
58
|
-
static { this.INSTANCE_COUNT = 0; }
|
|
59
|
-
constructor(lineCount, defaultLineHeight, paddingTop, paddingBottom, customLineHeightData) {
|
|
60
|
-
this._instanceId = singleLetterHash(++LinesLayout.INSTANCE_COUNT);
|
|
61
|
-
this._pendingChanges = new PendingChanges();
|
|
62
|
-
this._lastWhitespaceId = 0;
|
|
63
|
-
this._arr = [];
|
|
64
|
-
this._prefixSumValidIndex = -1;
|
|
65
|
-
this._minWidth = -1; /* marker for not being computed */
|
|
66
|
-
this._lineCount = lineCount;
|
|
67
|
-
this._paddingTop = paddingTop;
|
|
68
|
-
this._paddingBottom = paddingBottom;
|
|
69
|
-
this._lineHeightsManager = new LineHeightsManager(defaultLineHeight, customLineHeightData);
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* Find the insertion index for a new value inside a sorted array of values.
|
|
73
|
-
* If the value is already present in the sorted array, the insertion index will be after the already existing value.
|
|
74
|
-
*/
|
|
75
|
-
static findInsertionIndex(arr, afterLineNumber, ordinal) {
|
|
76
|
-
let low = 0;
|
|
77
|
-
let high = arr.length;
|
|
78
|
-
while (low < high) {
|
|
79
|
-
const mid = ((low + high) >>> 1);
|
|
80
|
-
if (afterLineNumber === arr[mid].afterLineNumber) {
|
|
81
|
-
if (ordinal < arr[mid].ordinal) {
|
|
82
|
-
high = mid;
|
|
83
|
-
}
|
|
84
|
-
else {
|
|
85
|
-
low = mid + 1;
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
else if (afterLineNumber < arr[mid].afterLineNumber) {
|
|
89
|
-
high = mid;
|
|
90
|
-
}
|
|
91
|
-
else {
|
|
92
|
-
low = mid + 1;
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
return low;
|
|
96
|
-
}
|
|
97
|
-
/**
|
|
98
|
-
* Change the height of a line in pixels.
|
|
99
|
-
*/
|
|
100
|
-
setDefaultLineHeight(lineHeight) {
|
|
101
|
-
this._lineHeightsManager.defaultLineHeight = lineHeight;
|
|
102
|
-
}
|
|
103
|
-
/**
|
|
104
|
-
* Changes the padding used to calculate vertical offsets.
|
|
105
|
-
*/
|
|
106
|
-
setPadding(paddingTop, paddingBottom) {
|
|
107
|
-
this._paddingTop = paddingTop;
|
|
108
|
-
this._paddingBottom = paddingBottom;
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Set the number of lines.
|
|
112
|
-
*
|
|
113
|
-
* @param lineCount New number of lines.
|
|
114
|
-
*/
|
|
115
|
-
onFlushed(lineCount, customLineHeightData) {
|
|
116
|
-
this._lineCount = lineCount;
|
|
117
|
-
this._lineHeightsManager = new LineHeightsManager(this._lineHeightsManager.defaultLineHeight, customLineHeightData);
|
|
118
|
-
}
|
|
119
|
-
changeLineHeights(callback) {
|
|
120
|
-
let hadAChange = false;
|
|
121
|
-
try {
|
|
122
|
-
const accessor = {
|
|
123
|
-
insertOrChangeCustomLineHeight: (decorationId, startLineNumber, endLineNumber, lineHeight) => {
|
|
124
|
-
hadAChange = true;
|
|
125
|
-
this._lineHeightsManager.insertOrChangeCustomLineHeight(decorationId, startLineNumber, endLineNumber, lineHeight);
|
|
126
|
-
},
|
|
127
|
-
removeCustomLineHeight: (decorationId) => {
|
|
128
|
-
hadAChange = true;
|
|
129
|
-
this._lineHeightsManager.removeCustomLineHeight(decorationId);
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
callback(accessor);
|
|
133
|
-
}
|
|
134
|
-
finally {
|
|
135
|
-
this._lineHeightsManager.commit();
|
|
136
|
-
}
|
|
137
|
-
return hadAChange;
|
|
138
|
-
}
|
|
139
|
-
changeWhitespace(callback) {
|
|
140
|
-
let hadAChange = false;
|
|
141
|
-
try {
|
|
142
|
-
const accessor = {
|
|
143
|
-
insertWhitespace: (afterLineNumber, ordinal, heightInPx, minWidth) => {
|
|
144
|
-
hadAChange = true;
|
|
145
|
-
afterLineNumber = afterLineNumber | 0;
|
|
146
|
-
ordinal = ordinal | 0;
|
|
147
|
-
heightInPx = heightInPx | 0;
|
|
148
|
-
minWidth = minWidth | 0;
|
|
149
|
-
const id = this._instanceId + (++this._lastWhitespaceId);
|
|
150
|
-
this._pendingChanges.insert(new EditorWhitespace(id, afterLineNumber, ordinal, heightInPx, minWidth));
|
|
151
|
-
return id;
|
|
152
|
-
},
|
|
153
|
-
changeOneWhitespace: (id, newAfterLineNumber, newHeight) => {
|
|
154
|
-
hadAChange = true;
|
|
155
|
-
newAfterLineNumber = newAfterLineNumber | 0;
|
|
156
|
-
newHeight = newHeight | 0;
|
|
157
|
-
this._pendingChanges.change({ id, newAfterLineNumber, newHeight });
|
|
158
|
-
},
|
|
159
|
-
removeWhitespace: (id) => {
|
|
160
|
-
hadAChange = true;
|
|
161
|
-
this._pendingChanges.remove({ id });
|
|
162
|
-
}
|
|
163
|
-
};
|
|
164
|
-
callback(accessor);
|
|
165
|
-
}
|
|
166
|
-
finally {
|
|
167
|
-
this._pendingChanges.commit(this);
|
|
168
|
-
}
|
|
169
|
-
return hadAChange;
|
|
170
|
-
}
|
|
171
|
-
_commitPendingChanges(inserts, changes, removes) {
|
|
172
|
-
if (inserts.length > 0 || removes.length > 0) {
|
|
173
|
-
this._minWidth = -1; /* marker for not being computed */
|
|
174
|
-
}
|
|
175
|
-
if (inserts.length + changes.length + removes.length <= 1) {
|
|
176
|
-
// when only one thing happened, handle it "delicately"
|
|
177
|
-
for (const insert of inserts) {
|
|
178
|
-
this._insertWhitespace(insert);
|
|
179
|
-
}
|
|
180
|
-
for (const change of changes) {
|
|
181
|
-
this._changeOneWhitespace(change.id, change.newAfterLineNumber, change.newHeight);
|
|
182
|
-
}
|
|
183
|
-
for (const remove of removes) {
|
|
184
|
-
const index = this._findWhitespaceIndex(remove.id);
|
|
185
|
-
if (index === -1) {
|
|
186
|
-
continue;
|
|
187
|
-
}
|
|
188
|
-
this._removeWhitespace(index);
|
|
189
|
-
}
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
// simply rebuild the entire datastructure
|
|
193
|
-
const toRemove = new Set();
|
|
194
|
-
for (const remove of removes) {
|
|
195
|
-
toRemove.add(remove.id);
|
|
196
|
-
}
|
|
197
|
-
const toChange = new Map();
|
|
198
|
-
for (const change of changes) {
|
|
199
|
-
toChange.set(change.id, change);
|
|
200
|
-
}
|
|
201
|
-
const applyRemoveAndChange = (whitespaces) => {
|
|
202
|
-
const result = [];
|
|
203
|
-
for (const whitespace of whitespaces) {
|
|
204
|
-
if (toRemove.has(whitespace.id)) {
|
|
205
|
-
continue;
|
|
206
|
-
}
|
|
207
|
-
if (toChange.has(whitespace.id)) {
|
|
208
|
-
const change = toChange.get(whitespace.id);
|
|
209
|
-
whitespace.afterLineNumber = change.newAfterLineNumber;
|
|
210
|
-
whitespace.height = change.newHeight;
|
|
211
|
-
}
|
|
212
|
-
result.push(whitespace);
|
|
213
|
-
}
|
|
214
|
-
return result;
|
|
215
|
-
};
|
|
216
|
-
const result = applyRemoveAndChange(this._arr).concat(applyRemoveAndChange(inserts));
|
|
217
|
-
result.sort((a, b) => {
|
|
218
|
-
if (a.afterLineNumber === b.afterLineNumber) {
|
|
219
|
-
return a.ordinal - b.ordinal;
|
|
220
|
-
}
|
|
221
|
-
return a.afterLineNumber - b.afterLineNumber;
|
|
222
|
-
});
|
|
223
|
-
this._arr = result;
|
|
224
|
-
this._prefixSumValidIndex = -1;
|
|
225
|
-
}
|
|
226
|
-
_insertWhitespace(whitespace) {
|
|
227
|
-
const insertIndex = LinesLayout.findInsertionIndex(this._arr, whitespace.afterLineNumber, whitespace.ordinal);
|
|
228
|
-
this._arr.splice(insertIndex, 0, whitespace);
|
|
229
|
-
this._prefixSumValidIndex = Math.min(this._prefixSumValidIndex, insertIndex - 1);
|
|
230
|
-
}
|
|
231
|
-
_findWhitespaceIndex(id) {
|
|
232
|
-
const arr = this._arr;
|
|
233
|
-
for (let i = 0, len = arr.length; i < len; i++) {
|
|
234
|
-
if (arr[i].id === id) {
|
|
235
|
-
return i;
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
return -1;
|
|
239
|
-
}
|
|
240
|
-
_changeOneWhitespace(id, newAfterLineNumber, newHeight) {
|
|
241
|
-
const index = this._findWhitespaceIndex(id);
|
|
242
|
-
if (index === -1) {
|
|
243
|
-
return;
|
|
244
|
-
}
|
|
245
|
-
if (this._arr[index].height !== newHeight) {
|
|
246
|
-
this._arr[index].height = newHeight;
|
|
247
|
-
this._prefixSumValidIndex = Math.min(this._prefixSumValidIndex, index - 1);
|
|
248
|
-
}
|
|
249
|
-
if (this._arr[index].afterLineNumber !== newAfterLineNumber) {
|
|
250
|
-
// `afterLineNumber` changed for this whitespace
|
|
251
|
-
// Record old whitespace
|
|
252
|
-
const whitespace = this._arr[index];
|
|
253
|
-
// Since changing `afterLineNumber` can trigger a reordering, we're gonna remove this whitespace
|
|
254
|
-
this._removeWhitespace(index);
|
|
255
|
-
whitespace.afterLineNumber = newAfterLineNumber;
|
|
256
|
-
// And add it again
|
|
257
|
-
this._insertWhitespace(whitespace);
|
|
258
|
-
}
|
|
259
|
-
}
|
|
260
|
-
_removeWhitespace(removeIndex) {
|
|
261
|
-
this._arr.splice(removeIndex, 1);
|
|
262
|
-
this._prefixSumValidIndex = Math.min(this._prefixSumValidIndex, removeIndex - 1);
|
|
263
|
-
}
|
|
264
|
-
/**
|
|
265
|
-
* Notify the layouter that lines have been deleted (a continuous zone of lines).
|
|
266
|
-
*
|
|
267
|
-
* @param fromLineNumber The line number at which the deletion started, inclusive
|
|
268
|
-
* @param toLineNumber The line number at which the deletion ended, inclusive
|
|
269
|
-
*/
|
|
270
|
-
onLinesDeleted(fromLineNumber, toLineNumber) {
|
|
271
|
-
fromLineNumber = fromLineNumber | 0;
|
|
272
|
-
toLineNumber = toLineNumber | 0;
|
|
273
|
-
this._lineCount -= (toLineNumber - fromLineNumber + 1);
|
|
274
|
-
for (let i = 0, len = this._arr.length; i < len; i++) {
|
|
275
|
-
const afterLineNumber = this._arr[i].afterLineNumber;
|
|
276
|
-
if (fromLineNumber <= afterLineNumber && afterLineNumber <= toLineNumber) {
|
|
277
|
-
// The line this whitespace was after has been deleted
|
|
278
|
-
// => move whitespace to before first deleted line
|
|
279
|
-
this._arr[i].afterLineNumber = fromLineNumber - 1;
|
|
280
|
-
}
|
|
281
|
-
else if (afterLineNumber > toLineNumber) {
|
|
282
|
-
// The line this whitespace was after has been moved up
|
|
283
|
-
// => move whitespace up
|
|
284
|
-
this._arr[i].afterLineNumber -= (toLineNumber - fromLineNumber + 1);
|
|
285
|
-
}
|
|
286
|
-
}
|
|
287
|
-
this._lineHeightsManager.onLinesDeleted(fromLineNumber, toLineNumber);
|
|
288
|
-
}
|
|
289
|
-
/**
|
|
290
|
-
* Notify the layouter that lines have been inserted (a continuous zone of lines).
|
|
291
|
-
*
|
|
292
|
-
* @param fromLineNumber The line number at which the insertion started, inclusive
|
|
293
|
-
* @param toLineNumber The line number at which the insertion ended, inclusive.
|
|
294
|
-
*/
|
|
295
|
-
onLinesInserted(fromLineNumber, toLineNumber) {
|
|
296
|
-
fromLineNumber = fromLineNumber | 0;
|
|
297
|
-
toLineNumber = toLineNumber | 0;
|
|
298
|
-
this._lineCount += (toLineNumber - fromLineNumber + 1);
|
|
299
|
-
for (let i = 0, len = this._arr.length; i < len; i++) {
|
|
300
|
-
const afterLineNumber = this._arr[i].afterLineNumber;
|
|
301
|
-
if (fromLineNumber <= afterLineNumber) {
|
|
302
|
-
this._arr[i].afterLineNumber += (toLineNumber - fromLineNumber + 1);
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
this._lineHeightsManager.onLinesInserted(fromLineNumber, toLineNumber);
|
|
306
|
-
}
|
|
307
|
-
/**
|
|
308
|
-
* Get the sum of all the whitespaces.
|
|
309
|
-
*/
|
|
310
|
-
getWhitespacesTotalHeight() {
|
|
311
|
-
if (this._arr.length === 0) {
|
|
312
|
-
return 0;
|
|
313
|
-
}
|
|
314
|
-
return this.getWhitespacesAccumulatedHeight(this._arr.length - 1);
|
|
315
|
-
}
|
|
316
|
-
/**
|
|
317
|
-
* Return the sum of the heights of the whitespaces at [0..index].
|
|
318
|
-
* This includes the whitespace at `index`.
|
|
319
|
-
*
|
|
320
|
-
* @param index The index of the whitespace.
|
|
321
|
-
* @return The sum of the heights of all whitespaces before the one at `index`, including the one at `index`.
|
|
322
|
-
*/
|
|
323
|
-
getWhitespacesAccumulatedHeight(index) {
|
|
324
|
-
index = index | 0;
|
|
325
|
-
let startIndex = Math.max(0, this._prefixSumValidIndex + 1);
|
|
326
|
-
if (startIndex === 0) {
|
|
327
|
-
this._arr[0].prefixSum = this._arr[0].height;
|
|
328
|
-
startIndex++;
|
|
329
|
-
}
|
|
330
|
-
for (let i = startIndex; i <= index; i++) {
|
|
331
|
-
this._arr[i].prefixSum = this._arr[i - 1].prefixSum + this._arr[i].height;
|
|
332
|
-
}
|
|
333
|
-
this._prefixSumValidIndex = Math.max(this._prefixSumValidIndex, index);
|
|
334
|
-
return this._arr[index].prefixSum;
|
|
335
|
-
}
|
|
336
|
-
/**
|
|
337
|
-
* Get the sum of heights for all objects.
|
|
338
|
-
*
|
|
339
|
-
* @return The sum of heights for all objects.
|
|
340
|
-
*/
|
|
341
|
-
getLinesTotalHeight() {
|
|
342
|
-
const linesHeight = this._lineHeightsManager.getAccumulatedLineHeightsIncludingLineNumber(this._lineCount);
|
|
343
|
-
const whitespacesHeight = this.getWhitespacesTotalHeight();
|
|
344
|
-
return linesHeight + whitespacesHeight + this._paddingTop + this._paddingBottom;
|
|
345
|
-
}
|
|
346
|
-
/**
|
|
347
|
-
* Returns the accumulated height of whitespaces before the given line number.
|
|
348
|
-
*
|
|
349
|
-
* @param lineNumber The line number
|
|
350
|
-
*/
|
|
351
|
-
getWhitespaceAccumulatedHeightBeforeLineNumber(lineNumber) {
|
|
352
|
-
lineNumber = lineNumber | 0;
|
|
353
|
-
const lastWhitespaceBeforeLineNumber = this._findLastWhitespaceBeforeLineNumber(lineNumber);
|
|
354
|
-
if (lastWhitespaceBeforeLineNumber === -1) {
|
|
355
|
-
return 0;
|
|
356
|
-
}
|
|
357
|
-
return this.getWhitespacesAccumulatedHeight(lastWhitespaceBeforeLineNumber);
|
|
358
|
-
}
|
|
359
|
-
_findLastWhitespaceBeforeLineNumber(lineNumber) {
|
|
360
|
-
lineNumber = lineNumber | 0;
|
|
361
|
-
// Find the whitespace before line number
|
|
362
|
-
const arr = this._arr;
|
|
363
|
-
let low = 0;
|
|
364
|
-
let high = arr.length - 1;
|
|
365
|
-
while (low <= high) {
|
|
366
|
-
const delta = (high - low) | 0;
|
|
367
|
-
const halfDelta = (delta / 2) | 0;
|
|
368
|
-
const mid = (low + halfDelta) | 0;
|
|
369
|
-
if (arr[mid].afterLineNumber < lineNumber) {
|
|
370
|
-
if (mid + 1 >= arr.length || arr[mid + 1].afterLineNumber >= lineNumber) {
|
|
371
|
-
return mid;
|
|
372
|
-
}
|
|
373
|
-
else {
|
|
374
|
-
low = (mid + 1) | 0;
|
|
375
|
-
}
|
|
376
|
-
}
|
|
377
|
-
else {
|
|
378
|
-
high = (mid - 1) | 0;
|
|
379
|
-
}
|
|
380
|
-
}
|
|
381
|
-
return -1;
|
|
382
|
-
}
|
|
383
|
-
_findFirstWhitespaceAfterLineNumber(lineNumber) {
|
|
384
|
-
lineNumber = lineNumber | 0;
|
|
385
|
-
const lastWhitespaceBeforeLineNumber = this._findLastWhitespaceBeforeLineNumber(lineNumber);
|
|
386
|
-
const firstWhitespaceAfterLineNumber = lastWhitespaceBeforeLineNumber + 1;
|
|
387
|
-
if (firstWhitespaceAfterLineNumber < this._arr.length) {
|
|
388
|
-
return firstWhitespaceAfterLineNumber;
|
|
389
|
-
}
|
|
390
|
-
return -1;
|
|
391
|
-
}
|
|
392
|
-
/**
|
|
393
|
-
* Find the index of the first whitespace which has `afterLineNumber` >= `lineNumber`.
|
|
394
|
-
* @return The index of the first whitespace with `afterLineNumber` >= `lineNumber` or -1 if no whitespace is found.
|
|
395
|
-
*/
|
|
396
|
-
getFirstWhitespaceIndexAfterLineNumber(lineNumber) {
|
|
397
|
-
lineNumber = lineNumber | 0;
|
|
398
|
-
return this._findFirstWhitespaceAfterLineNumber(lineNumber);
|
|
399
|
-
}
|
|
400
|
-
/**
|
|
401
|
-
* Get the vertical offset (the sum of heights for all objects above) a certain line number.
|
|
402
|
-
*
|
|
403
|
-
* @param lineNumber The line number
|
|
404
|
-
* @return The sum of heights for all objects above `lineNumber`.
|
|
405
|
-
*/
|
|
406
|
-
getVerticalOffsetForLineNumber(lineNumber, includeViewZones = false) {
|
|
407
|
-
lineNumber = lineNumber | 0;
|
|
408
|
-
let previousLinesHeight;
|
|
409
|
-
if (lineNumber > 1) {
|
|
410
|
-
previousLinesHeight = this._lineHeightsManager.getAccumulatedLineHeightsIncludingLineNumber(lineNumber - 1);
|
|
411
|
-
}
|
|
412
|
-
else {
|
|
413
|
-
previousLinesHeight = 0;
|
|
414
|
-
}
|
|
415
|
-
const previousWhitespacesHeight = this.getWhitespaceAccumulatedHeightBeforeLineNumber(lineNumber - (includeViewZones ? 1 : 0));
|
|
416
|
-
return previousLinesHeight + previousWhitespacesHeight + this._paddingTop;
|
|
417
|
-
}
|
|
418
|
-
getLineHeightForLineNumber(lineNumber) {
|
|
419
|
-
return this._lineHeightsManager.heightForLineNumber(lineNumber);
|
|
420
|
-
}
|
|
421
|
-
/**
|
|
422
|
-
* Get the vertical offset (the sum of heights for all objects above) a certain line number and also the line height of the line.
|
|
423
|
-
*
|
|
424
|
-
* @param lineNumber The line number
|
|
425
|
-
* @return The sum of heights for all objects above `lineNumber`.
|
|
426
|
-
*/
|
|
427
|
-
getVerticalOffsetAfterLineNumber(lineNumber, includeViewZones = false) {
|
|
428
|
-
lineNumber = lineNumber | 0;
|
|
429
|
-
const previousLinesHeight = this._lineHeightsManager.getAccumulatedLineHeightsIncludingLineNumber(lineNumber);
|
|
430
|
-
const previousWhitespacesHeight = this.getWhitespaceAccumulatedHeightBeforeLineNumber(lineNumber + (includeViewZones ? 1 : 0));
|
|
431
|
-
return previousLinesHeight + previousWhitespacesHeight + this._paddingTop;
|
|
432
|
-
}
|
|
433
|
-
/**
|
|
434
|
-
* The maximum min width for all whitespaces.
|
|
435
|
-
*/
|
|
436
|
-
getWhitespaceMinWidth() {
|
|
437
|
-
if (this._minWidth === -1) {
|
|
438
|
-
let minWidth = 0;
|
|
439
|
-
for (let i = 0, len = this._arr.length; i < len; i++) {
|
|
440
|
-
minWidth = Math.max(minWidth, this._arr[i].minWidth);
|
|
441
|
-
}
|
|
442
|
-
this._minWidth = minWidth;
|
|
443
|
-
}
|
|
444
|
-
return this._minWidth;
|
|
445
|
-
}
|
|
446
|
-
/**
|
|
447
|
-
* Check if `verticalOffset` is below all lines.
|
|
448
|
-
*/
|
|
449
|
-
isAfterLines(verticalOffset) {
|
|
450
|
-
const totalHeight = this.getLinesTotalHeight();
|
|
451
|
-
return verticalOffset > totalHeight;
|
|
452
|
-
}
|
|
453
|
-
isInTopPadding(verticalOffset) {
|
|
454
|
-
if (this._paddingTop === 0) {
|
|
455
|
-
return false;
|
|
456
|
-
}
|
|
457
|
-
return (verticalOffset < this._paddingTop);
|
|
458
|
-
}
|
|
459
|
-
isInBottomPadding(verticalOffset) {
|
|
460
|
-
if (this._paddingBottom === 0) {
|
|
461
|
-
return false;
|
|
462
|
-
}
|
|
463
|
-
const totalHeight = this.getLinesTotalHeight();
|
|
464
|
-
return (verticalOffset >= totalHeight - this._paddingBottom);
|
|
465
|
-
}
|
|
466
|
-
/**
|
|
467
|
-
* Find the first line number that is at or after vertical offset `verticalOffset`.
|
|
468
|
-
* i.e. if getVerticalOffsetForLine(line) is x and getVerticalOffsetForLine(line + 1) is y, then
|
|
469
|
-
* getLineNumberAtOrAfterVerticalOffset(i) = line, x <= i < y.
|
|
470
|
-
*
|
|
471
|
-
* @param verticalOffset The vertical offset to search at.
|
|
472
|
-
* @return The line number at or after vertical offset `verticalOffset`.
|
|
473
|
-
*/
|
|
474
|
-
getLineNumberAtOrAfterVerticalOffset(verticalOffset) {
|
|
475
|
-
verticalOffset = verticalOffset | 0;
|
|
476
|
-
if (verticalOffset < 0) {
|
|
477
|
-
return 1;
|
|
478
|
-
}
|
|
479
|
-
const linesCount = this._lineCount | 0;
|
|
480
|
-
let minLineNumber = 1;
|
|
481
|
-
let maxLineNumber = linesCount;
|
|
482
|
-
while (minLineNumber < maxLineNumber) {
|
|
483
|
-
const midLineNumber = ((minLineNumber + maxLineNumber) / 2) | 0;
|
|
484
|
-
const lineHeight = this.getLineHeightForLineNumber(midLineNumber);
|
|
485
|
-
const midLineNumberVerticalOffset = this.getVerticalOffsetForLineNumber(midLineNumber) | 0;
|
|
486
|
-
if (verticalOffset >= midLineNumberVerticalOffset + lineHeight) {
|
|
487
|
-
// vertical offset is after mid line number
|
|
488
|
-
minLineNumber = midLineNumber + 1;
|
|
489
|
-
}
|
|
490
|
-
else if (verticalOffset >= midLineNumberVerticalOffset) {
|
|
491
|
-
// Hit
|
|
492
|
-
return midLineNumber;
|
|
493
|
-
}
|
|
494
|
-
else {
|
|
495
|
-
// vertical offset is before mid line number, but mid line number could still be what we're searching for
|
|
496
|
-
maxLineNumber = midLineNumber;
|
|
497
|
-
}
|
|
498
|
-
}
|
|
499
|
-
if (minLineNumber > linesCount) {
|
|
500
|
-
return linesCount;
|
|
501
|
-
}
|
|
502
|
-
return minLineNumber;
|
|
503
|
-
}
|
|
504
|
-
/**
|
|
505
|
-
* Get all the lines and their relative vertical offsets that are positioned between `verticalOffset1` and `verticalOffset2`.
|
|
506
|
-
*
|
|
507
|
-
* @param verticalOffset1 The beginning of the viewport.
|
|
508
|
-
* @param verticalOffset2 The end of the viewport.
|
|
509
|
-
* @return A structure describing the lines positioned between `verticalOffset1` and `verticalOffset2`.
|
|
510
|
-
*/
|
|
511
|
-
getLinesViewportData(verticalOffset1, verticalOffset2) {
|
|
512
|
-
verticalOffset1 = verticalOffset1 | 0;
|
|
513
|
-
verticalOffset2 = verticalOffset2 | 0;
|
|
514
|
-
// Find first line number
|
|
515
|
-
// We don't live in a perfect world, so the line number might start before or after verticalOffset1
|
|
516
|
-
const startLineNumber = this.getLineNumberAtOrAfterVerticalOffset(verticalOffset1) | 0;
|
|
517
|
-
const startLineNumberVerticalOffset = this.getVerticalOffsetForLineNumber(startLineNumber) | 0;
|
|
518
|
-
let endLineNumber = this._lineCount | 0;
|
|
519
|
-
// Also keep track of what whitespace we've got
|
|
520
|
-
let whitespaceIndex = this.getFirstWhitespaceIndexAfterLineNumber(startLineNumber) | 0;
|
|
521
|
-
const whitespaceCount = this.getWhitespacesCount() | 0;
|
|
522
|
-
let currentWhitespaceHeight;
|
|
523
|
-
let currentWhitespaceAfterLineNumber;
|
|
524
|
-
if (whitespaceIndex === -1) {
|
|
525
|
-
whitespaceIndex = whitespaceCount;
|
|
526
|
-
currentWhitespaceAfterLineNumber = endLineNumber + 1;
|
|
527
|
-
currentWhitespaceHeight = 0;
|
|
528
|
-
}
|
|
529
|
-
else {
|
|
530
|
-
currentWhitespaceAfterLineNumber = this.getAfterLineNumberForWhitespaceIndex(whitespaceIndex) | 0;
|
|
531
|
-
currentWhitespaceHeight = this.getHeightForWhitespaceIndex(whitespaceIndex) | 0;
|
|
532
|
-
}
|
|
533
|
-
let currentVerticalOffset = startLineNumberVerticalOffset;
|
|
534
|
-
let currentLineRelativeOffset = currentVerticalOffset;
|
|
535
|
-
// IE (all versions) cannot handle units above about 1,533,908 px, so every 500k pixels bring numbers down
|
|
536
|
-
const STEP_SIZE = 500000;
|
|
537
|
-
let bigNumbersDelta = 0;
|
|
538
|
-
if (startLineNumberVerticalOffset >= STEP_SIZE) {
|
|
539
|
-
// Compute a delta that guarantees that lines are positioned at `lineHeight` increments
|
|
540
|
-
bigNumbersDelta = Math.floor(startLineNumberVerticalOffset / STEP_SIZE) * STEP_SIZE;
|
|
541
|
-
bigNumbersDelta = Math.floor(bigNumbersDelta / this._lineHeightsManager.defaultLineHeight) * this._lineHeightsManager.defaultLineHeight;
|
|
542
|
-
currentLineRelativeOffset -= bigNumbersDelta;
|
|
543
|
-
}
|
|
544
|
-
const linesOffsets = [];
|
|
545
|
-
const verticalCenter = verticalOffset1 + (verticalOffset2 - verticalOffset1) / 2;
|
|
546
|
-
let centeredLineNumber = -1;
|
|
547
|
-
// Figure out how far the lines go
|
|
548
|
-
for (let lineNumber = startLineNumber; lineNumber <= endLineNumber; lineNumber++) {
|
|
549
|
-
const lineHeight = this.getLineHeightForLineNumber(lineNumber);
|
|
550
|
-
if (centeredLineNumber === -1) {
|
|
551
|
-
const currentLineTop = currentVerticalOffset;
|
|
552
|
-
const currentLineBottom = currentVerticalOffset + lineHeight;
|
|
553
|
-
if ((currentLineTop <= verticalCenter && verticalCenter < currentLineBottom) || currentLineTop > verticalCenter) {
|
|
554
|
-
centeredLineNumber = lineNumber;
|
|
555
|
-
}
|
|
556
|
-
}
|
|
557
|
-
// Count current line height in the vertical offsets
|
|
558
|
-
currentVerticalOffset += lineHeight;
|
|
559
|
-
linesOffsets[lineNumber - startLineNumber] = currentLineRelativeOffset;
|
|
560
|
-
// Next line starts immediately after this one
|
|
561
|
-
currentLineRelativeOffset += lineHeight;
|
|
562
|
-
while (currentWhitespaceAfterLineNumber === lineNumber) {
|
|
563
|
-
// Push down next line with the height of the current whitespace
|
|
564
|
-
currentLineRelativeOffset += currentWhitespaceHeight;
|
|
565
|
-
// Count current whitespace in the vertical offsets
|
|
566
|
-
currentVerticalOffset += currentWhitespaceHeight;
|
|
567
|
-
whitespaceIndex++;
|
|
568
|
-
if (whitespaceIndex >= whitespaceCount) {
|
|
569
|
-
currentWhitespaceAfterLineNumber = endLineNumber + 1;
|
|
570
|
-
}
|
|
571
|
-
else {
|
|
572
|
-
currentWhitespaceAfterLineNumber = this.getAfterLineNumberForWhitespaceIndex(whitespaceIndex) | 0;
|
|
573
|
-
currentWhitespaceHeight = this.getHeightForWhitespaceIndex(whitespaceIndex) | 0;
|
|
574
|
-
}
|
|
575
|
-
}
|
|
576
|
-
if (currentVerticalOffset >= verticalOffset2) {
|
|
577
|
-
// We have covered the entire viewport area, time to stop
|
|
578
|
-
endLineNumber = lineNumber;
|
|
579
|
-
break;
|
|
580
|
-
}
|
|
581
|
-
}
|
|
582
|
-
if (centeredLineNumber === -1) {
|
|
583
|
-
centeredLineNumber = endLineNumber;
|
|
584
|
-
}
|
|
585
|
-
const endLineNumberVerticalOffset = this.getVerticalOffsetForLineNumber(endLineNumber) | 0;
|
|
586
|
-
let completelyVisibleStartLineNumber = startLineNumber;
|
|
587
|
-
let completelyVisibleEndLineNumber = endLineNumber;
|
|
588
|
-
if (completelyVisibleStartLineNumber < completelyVisibleEndLineNumber) {
|
|
589
|
-
if (startLineNumberVerticalOffset < verticalOffset1) {
|
|
590
|
-
completelyVisibleStartLineNumber++;
|
|
591
|
-
}
|
|
592
|
-
}
|
|
593
|
-
if (completelyVisibleStartLineNumber < completelyVisibleEndLineNumber) {
|
|
594
|
-
const endLineHeight = this.getLineHeightForLineNumber(endLineNumber);
|
|
595
|
-
if (endLineNumberVerticalOffset + endLineHeight > verticalOffset2) {
|
|
596
|
-
completelyVisibleEndLineNumber--;
|
|
597
|
-
}
|
|
598
|
-
}
|
|
599
|
-
return {
|
|
600
|
-
bigNumbersDelta: bigNumbersDelta,
|
|
601
|
-
startLineNumber: startLineNumber,
|
|
602
|
-
endLineNumber: endLineNumber,
|
|
603
|
-
relativeVerticalOffset: linesOffsets,
|
|
604
|
-
centeredLineNumber: centeredLineNumber,
|
|
605
|
-
completelyVisibleStartLineNumber: completelyVisibleStartLineNumber,
|
|
606
|
-
completelyVisibleEndLineNumber: completelyVisibleEndLineNumber,
|
|
607
|
-
lineHeight: this._lineHeightsManager.defaultLineHeight,
|
|
608
|
-
};
|
|
609
|
-
}
|
|
610
|
-
getVerticalOffsetForWhitespaceIndex(whitespaceIndex) {
|
|
611
|
-
whitespaceIndex = whitespaceIndex | 0;
|
|
612
|
-
const afterLineNumber = this.getAfterLineNumberForWhitespaceIndex(whitespaceIndex);
|
|
613
|
-
let previousLinesHeight;
|
|
614
|
-
if (afterLineNumber >= 1) {
|
|
615
|
-
previousLinesHeight = this._lineHeightsManager.getAccumulatedLineHeightsIncludingLineNumber(afterLineNumber);
|
|
616
|
-
}
|
|
617
|
-
else {
|
|
618
|
-
previousLinesHeight = 0;
|
|
619
|
-
}
|
|
620
|
-
let previousWhitespacesHeight;
|
|
621
|
-
if (whitespaceIndex > 0) {
|
|
622
|
-
previousWhitespacesHeight = this.getWhitespacesAccumulatedHeight(whitespaceIndex - 1);
|
|
623
|
-
}
|
|
624
|
-
else {
|
|
625
|
-
previousWhitespacesHeight = 0;
|
|
626
|
-
}
|
|
627
|
-
return previousLinesHeight + previousWhitespacesHeight + this._paddingTop;
|
|
628
|
-
}
|
|
629
|
-
getWhitespaceIndexAtOrAfterVerticallOffset(verticalOffset) {
|
|
630
|
-
verticalOffset = verticalOffset | 0;
|
|
631
|
-
let minWhitespaceIndex = 0;
|
|
632
|
-
let maxWhitespaceIndex = this.getWhitespacesCount() - 1;
|
|
633
|
-
if (maxWhitespaceIndex < 0) {
|
|
634
|
-
return -1;
|
|
635
|
-
}
|
|
636
|
-
// Special case: nothing to be found
|
|
637
|
-
const maxWhitespaceVerticalOffset = this.getVerticalOffsetForWhitespaceIndex(maxWhitespaceIndex);
|
|
638
|
-
const maxWhitespaceHeight = this.getHeightForWhitespaceIndex(maxWhitespaceIndex);
|
|
639
|
-
if (verticalOffset >= maxWhitespaceVerticalOffset + maxWhitespaceHeight) {
|
|
640
|
-
return -1;
|
|
641
|
-
}
|
|
642
|
-
while (minWhitespaceIndex < maxWhitespaceIndex) {
|
|
643
|
-
const midWhitespaceIndex = Math.floor((minWhitespaceIndex + maxWhitespaceIndex) / 2);
|
|
644
|
-
const midWhitespaceVerticalOffset = this.getVerticalOffsetForWhitespaceIndex(midWhitespaceIndex);
|
|
645
|
-
const midWhitespaceHeight = this.getHeightForWhitespaceIndex(midWhitespaceIndex);
|
|
646
|
-
if (verticalOffset >= midWhitespaceVerticalOffset + midWhitespaceHeight) {
|
|
647
|
-
// vertical offset is after whitespace
|
|
648
|
-
minWhitespaceIndex = midWhitespaceIndex + 1;
|
|
649
|
-
}
|
|
650
|
-
else if (verticalOffset >= midWhitespaceVerticalOffset) {
|
|
651
|
-
// Hit
|
|
652
|
-
return midWhitespaceIndex;
|
|
653
|
-
}
|
|
654
|
-
else {
|
|
655
|
-
// vertical offset is before whitespace, but midWhitespaceIndex might still be what we're searching for
|
|
656
|
-
maxWhitespaceIndex = midWhitespaceIndex;
|
|
657
|
-
}
|
|
658
|
-
}
|
|
659
|
-
return minWhitespaceIndex;
|
|
660
|
-
}
|
|
661
|
-
/**
|
|
662
|
-
* Get exactly the whitespace that is layouted at `verticalOffset`.
|
|
663
|
-
*
|
|
664
|
-
* @param verticalOffset The vertical offset.
|
|
665
|
-
* @return Precisely the whitespace that is layouted at `verticaloffset` or null.
|
|
666
|
-
*/
|
|
667
|
-
getWhitespaceAtVerticalOffset(verticalOffset) {
|
|
668
|
-
verticalOffset = verticalOffset | 0;
|
|
669
|
-
const candidateIndex = this.getWhitespaceIndexAtOrAfterVerticallOffset(verticalOffset);
|
|
670
|
-
if (candidateIndex < 0) {
|
|
671
|
-
return null;
|
|
672
|
-
}
|
|
673
|
-
if (candidateIndex >= this.getWhitespacesCount()) {
|
|
674
|
-
return null;
|
|
675
|
-
}
|
|
676
|
-
const candidateTop = this.getVerticalOffsetForWhitespaceIndex(candidateIndex);
|
|
677
|
-
if (candidateTop > verticalOffset) {
|
|
678
|
-
return null;
|
|
679
|
-
}
|
|
680
|
-
const candidateHeight = this.getHeightForWhitespaceIndex(candidateIndex);
|
|
681
|
-
const candidateId = this.getIdForWhitespaceIndex(candidateIndex);
|
|
682
|
-
const candidateAfterLineNumber = this.getAfterLineNumberForWhitespaceIndex(candidateIndex);
|
|
683
|
-
return {
|
|
684
|
-
id: candidateId,
|
|
685
|
-
afterLineNumber: candidateAfterLineNumber,
|
|
686
|
-
verticalOffset: candidateTop,
|
|
687
|
-
height: candidateHeight
|
|
688
|
-
};
|
|
689
|
-
}
|
|
690
|
-
/**
|
|
691
|
-
* Get a list of whitespaces that are positioned between `verticalOffset1` and `verticalOffset2`.
|
|
692
|
-
*
|
|
693
|
-
* @param verticalOffset1 The beginning of the viewport.
|
|
694
|
-
* @param verticalOffset2 The end of the viewport.
|
|
695
|
-
* @return An array with all the whitespaces in the viewport. If no whitespace is in viewport, the array is empty.
|
|
696
|
-
*/
|
|
697
|
-
getWhitespaceViewportData(verticalOffset1, verticalOffset2) {
|
|
698
|
-
verticalOffset1 = verticalOffset1 | 0;
|
|
699
|
-
verticalOffset2 = verticalOffset2 | 0;
|
|
700
|
-
const startIndex = this.getWhitespaceIndexAtOrAfterVerticallOffset(verticalOffset1);
|
|
701
|
-
const endIndex = this.getWhitespacesCount() - 1;
|
|
702
|
-
if (startIndex < 0) {
|
|
703
|
-
return [];
|
|
704
|
-
}
|
|
705
|
-
const result = [];
|
|
706
|
-
for (let i = startIndex; i <= endIndex; i++) {
|
|
707
|
-
const top = this.getVerticalOffsetForWhitespaceIndex(i);
|
|
708
|
-
const height = this.getHeightForWhitespaceIndex(i);
|
|
709
|
-
if (top >= verticalOffset2) {
|
|
710
|
-
break;
|
|
711
|
-
}
|
|
712
|
-
result.push({
|
|
713
|
-
id: this.getIdForWhitespaceIndex(i),
|
|
714
|
-
afterLineNumber: this.getAfterLineNumberForWhitespaceIndex(i),
|
|
715
|
-
verticalOffset: top,
|
|
716
|
-
height: height
|
|
717
|
-
});
|
|
718
|
-
}
|
|
719
|
-
return result;
|
|
720
|
-
}
|
|
721
|
-
/**
|
|
722
|
-
* Get all whitespaces.
|
|
723
|
-
*/
|
|
724
|
-
getWhitespaces() {
|
|
725
|
-
return this._arr.slice(0);
|
|
726
|
-
}
|
|
727
|
-
/**
|
|
728
|
-
* The number of whitespaces.
|
|
729
|
-
*/
|
|
730
|
-
getWhitespacesCount() {
|
|
731
|
-
return this._arr.length;
|
|
732
|
-
}
|
|
733
|
-
/**
|
|
734
|
-
* Get the `id` for whitespace at index `index`.
|
|
735
|
-
*
|
|
736
|
-
* @param index The index of the whitespace.
|
|
737
|
-
* @return `id` of whitespace at `index`.
|
|
738
|
-
*/
|
|
739
|
-
getIdForWhitespaceIndex(index) {
|
|
740
|
-
index = index | 0;
|
|
741
|
-
return this._arr[index].id;
|
|
742
|
-
}
|
|
743
|
-
/**
|
|
744
|
-
* Get the `afterLineNumber` for whitespace at index `index`.
|
|
745
|
-
*
|
|
746
|
-
* @param index The index of the whitespace.
|
|
747
|
-
* @return `afterLineNumber` of whitespace at `index`.
|
|
748
|
-
*/
|
|
749
|
-
getAfterLineNumberForWhitespaceIndex(index) {
|
|
750
|
-
index = index | 0;
|
|
751
|
-
return this._arr[index].afterLineNumber;
|
|
752
|
-
}
|
|
753
|
-
/**
|
|
754
|
-
* Get the `height` for whitespace at index `index`.
|
|
755
|
-
*
|
|
756
|
-
* @param index The index of the whitespace.
|
|
757
|
-
* @return `height` of whitespace at `index`.
|
|
758
|
-
*/
|
|
759
|
-
getHeightForWhitespaceIndex(index) {
|
|
760
|
-
index = index | 0;
|
|
761
|
-
return this._arr[index].height;
|
|
762
|
-
}
|
|
763
|
-
}
|
|
764
|
-
|
|
765
|
-
export { EditorWhitespace, LinesLayout };
|