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.
Files changed (237) hide show
  1. package/dist/assets/css.worker-C7FogG4G.js +93 -0
  2. package/dist/assets/editor.worker-iXcRX1Tq.js +26 -0
  3. package/dist/assets/html.worker-C8VxctEJ.js +470 -0
  4. package/dist/assets/json.worker-CMC9kgPL.js +58 -0
  5. package/dist/assets/ts.worker-CtTJ3hNN.js +67731 -0
  6. package/dist/index.d.ts +0 -6
  7. package/dist/monaco-editor11.es.js +49 -78
  8. package/dist/monaco-editor11.umd.js +1 -50
  9. package/dist/monaco.d.ts +8 -0
  10. package/dist/workers/common/initialize.js +16 -0
  11. package/dist/workers/common/workers.js +141 -0
  12. package/dist/workers/editor/common/abstractSyntaxTokenBackend.js +128 -0
  13. package/dist/workers/editor/common/abstractText.js +89 -0
  14. package/dist/workers/editor/common/ast.js +485 -0
  15. package/dist/workers/editor/common/autoIndent.js +390 -0
  16. package/dist/workers/editor/common/beforeEditPositionMapper.js +110 -0
  17. package/dist/workers/editor/common/bracketPairsImpl.js +717 -0
  18. package/dist/workers/editor/common/bracketPairsTree.js +343 -0
  19. package/dist/workers/editor/common/brackets.js +108 -0
  20. package/dist/workers/editor/common/characterClassifier.js +59 -0
  21. package/dist/workers/editor/common/characterPair.js +40 -0
  22. package/dist/workers/editor/common/colorizedBracketPairsDecorationProvider.js +97 -0
  23. package/dist/workers/editor/common/columnRange.js +35 -0
  24. package/dist/workers/editor/common/combineTextEditInfos.js +124 -0
  25. package/dist/workers/editor/common/common.js +20 -0
  26. package/dist/workers/editor/common/computeMovedLines.js +249 -0
  27. package/dist/workers/editor/common/concat23Trees.js +192 -0
  28. package/dist/workers/editor/common/contiguousMultilineTokens.js +32 -0
  29. package/dist/workers/editor/common/contiguousMultilineTokensBuilder.js +23 -0
  30. package/dist/workers/editor/common/contiguousTokensEditing.js +128 -0
  31. package/dist/workers/editor/common/contiguousTokensStore.js +207 -0
  32. package/dist/workers/editor/common/coordinatesConverter.js +51 -0
  33. package/dist/workers/editor/common/cursor.js +899 -0
  34. package/dist/workers/editor/common/cursorAtomicMoveOperations.js +145 -0
  35. package/dist/workers/editor/common/cursorCollection.js +194 -0
  36. package/dist/workers/editor/common/cursorColumnSelection.js +93 -0
  37. package/dist/workers/editor/common/cursorColumns.js +112 -0
  38. package/dist/workers/editor/common/cursorCommon.js +250 -0
  39. package/dist/workers/editor/common/cursorContext.js +15 -0
  40. package/dist/workers/editor/common/cursorDeleteOperations.js +231 -0
  41. package/dist/workers/editor/common/cursorMoveCommands.js +676 -0
  42. package/dist/workers/editor/common/cursorMoveOperations.js +290 -0
  43. package/dist/workers/editor/common/cursorTypeEditOperations.js +968 -0
  44. package/dist/workers/editor/common/cursorTypeOperations.js +173 -0
  45. package/dist/workers/editor/common/cursorUtils.js +75 -0
  46. package/dist/workers/editor/common/cursorWordOperations.js +720 -0
  47. package/dist/workers/editor/common/defaultDocumentColorsComputer.js +138 -0
  48. package/dist/workers/editor/common/defaultLinesDiffComputer.js +188 -0
  49. package/dist/workers/editor/common/diffAlgorithm.js +139 -0
  50. package/dist/workers/editor/common/diffEditor.js +38 -0
  51. package/dist/workers/editor/common/dynamicProgrammingDiffing.js +101 -0
  52. package/dist/workers/editor/common/edit.js +183 -0
  53. package/dist/workers/editor/common/editOperation.js +36 -0
  54. package/dist/workers/editor/common/editStack.js +363 -0
  55. package/dist/workers/editor/common/editorAction.js +26 -0
  56. package/dist/workers/editor/common/editorBaseApi.js +43 -0
  57. package/dist/workers/editor/common/editorColorRegistry.js +102 -0
  58. package/dist/workers/editor/common/editorCommon.js +13 -0
  59. package/dist/workers/editor/common/editorConfigurationSchema.js +338 -0
  60. package/dist/workers/editor/common/editorContextKeys.js +84 -0
  61. package/dist/workers/editor/common/editorFeatures.js +17 -0
  62. package/dist/workers/editor/common/editorOptions.js +3440 -0
  63. package/dist/workers/editor/common/editorTheme.js +23 -0
  64. package/dist/workers/editor/common/editorWebWorker.js +299 -0
  65. package/dist/workers/editor/common/editorWorker.js +9 -0
  66. package/dist/workers/editor/common/editorWorkerHost.js +15 -0
  67. package/dist/workers/editor/common/editorZoom.js +26 -0
  68. package/dist/workers/editor/common/electricCharacter.js +55 -0
  69. package/dist/workers/editor/common/encodedTokenAttributes.js +79 -0
  70. package/dist/workers/editor/common/enterAction.js +53 -0
  71. package/dist/workers/editor/common/eolCounter.js +44 -0
  72. package/dist/workers/editor/common/findSectionHeaders.js +128 -0
  73. package/dist/workers/editor/common/fixBrackets.js +67 -0
  74. package/dist/workers/editor/common/fixedArray.js +70 -0
  75. package/dist/workers/editor/common/fontInfo.js +172 -0
  76. package/dist/workers/editor/common/fontInfoFromSettings.js +29 -0
  77. package/dist/workers/editor/common/getIconClasses.js +106 -0
  78. package/dist/workers/editor/common/getPositionOffsetTransformerFromTextModel.js +24 -0
  79. package/dist/workers/editor/common/glyphLanesModel.js +61 -0
  80. package/dist/workers/editor/common/guidesTextModelPart.js +405 -0
  81. package/dist/workers/editor/common/heuristicSequenceOptimizations.js +374 -0
  82. package/dist/workers/editor/common/indentRules.js +63 -0
  83. package/dist/workers/editor/common/indentation.js +39 -0
  84. package/dist/workers/editor/common/indentationGuesser.js +178 -0
  85. package/dist/workers/editor/common/indentationLineProcessor.js +193 -0
  86. package/dist/workers/editor/common/inlineDecorations.js +26 -0
  87. package/dist/workers/editor/common/inplaceReplaceSupport.js +87 -0
  88. package/dist/workers/editor/common/inputMode.js +22 -0
  89. package/dist/workers/editor/common/intervalTree.js +1002 -0
  90. package/dist/workers/editor/common/language.js +9 -0
  91. package/dist/workers/editor/common/languageBracketsConfiguration.js +133 -0
  92. package/dist/workers/editor/common/languageConfiguration.js +138 -0
  93. package/dist/workers/editor/common/languageConfigurationRegistry.js +361 -0
  94. package/dist/workers/editor/common/languageFeatureDebounce.js +137 -0
  95. package/dist/workers/editor/common/languageFeatureRegistry.js +180 -0
  96. package/dist/workers/editor/common/languageFeatures.js +9 -0
  97. package/dist/workers/editor/common/languageFeaturesService.js +47 -0
  98. package/dist/workers/editor/common/languageSelector.js +112 -0
  99. package/dist/workers/editor/common/languageService.js +92 -0
  100. package/dist/workers/editor/common/languages.js +522 -0
  101. package/dist/workers/editor/common/languagesAssociations.js +193 -0
  102. package/dist/workers/editor/common/languagesRegistry.js +237 -0
  103. package/dist/workers/editor/common/legacyLinesDiffComputer.js +468 -0
  104. package/dist/workers/editor/common/length.js +129 -0
  105. package/dist/workers/editor/common/lineDecorations.js +208 -0
  106. package/dist/workers/editor/common/lineEdit.js +75 -0
  107. package/dist/workers/editor/common/lineHeights.js +370 -0
  108. package/dist/workers/editor/common/linePart.js +25 -0
  109. package/dist/workers/editor/common/lineRange.js +312 -0
  110. package/dist/workers/editor/common/lineSequence.js +36 -0
  111. package/dist/workers/editor/common/lineTokens.js +405 -0
  112. package/dist/workers/editor/common/linesDiffComputer.js +29 -0
  113. package/dist/workers/editor/common/linesDiffComputers.js +13 -0
  114. package/dist/workers/editor/common/linesLayout.js +765 -0
  115. package/dist/workers/editor/common/linesSliceCharSequence.js +205 -0
  116. package/dist/workers/editor/common/linkComputer.js +269 -0
  117. package/dist/workers/editor/common/markerDecorations.js +9 -0
  118. package/dist/workers/editor/common/markerDecorationsService.js +248 -0
  119. package/dist/workers/editor/common/minimapTokensColorTracker.js +58 -0
  120. package/dist/workers/editor/common/mirrorTextModel.js +117 -0
  121. package/dist/workers/editor/common/model.js +9 -0
  122. package/dist/workers/editor/common/modelLineProjection.js +350 -0
  123. package/dist/workers/editor/common/modelLineProjectionData.js +297 -0
  124. package/dist/workers/editor/common/modelService.js +413 -0
  125. package/dist/workers/editor/common/modesRegistry.js +75 -0
  126. package/dist/workers/editor/common/monospaceLineBreaksComputer.js +473 -0
  127. package/dist/workers/editor/common/myersDiffAlgorithm.js +159 -0
  128. package/dist/workers/editor/common/nodeReader.js +127 -0
  129. package/dist/workers/editor/common/nullTokenize.js +29 -0
  130. package/dist/workers/editor/common/offsetRange.js +225 -0
  131. package/dist/workers/editor/common/onEnter.js +109 -0
  132. package/dist/workers/editor/common/oneCursor.js +117 -0
  133. package/dist/workers/editor/common/overviewZoneManager.js +176 -0
  134. package/dist/workers/editor/common/parser.js +121 -0
  135. package/dist/workers/editor/common/pieceTreeBase.js +1473 -0
  136. package/dist/workers/editor/common/pieceTreeTextBuffer.js +461 -0
  137. package/dist/workers/editor/common/pieceTreeTextBufferBuilder.js +140 -0
  138. package/dist/workers/editor/common/point.js +50 -0
  139. package/dist/workers/editor/common/position.js +142 -0
  140. package/dist/workers/editor/common/positionToOffset.js +17 -0
  141. package/dist/workers/editor/common/positionToOffsetImpl.js +98 -0
  142. package/dist/workers/editor/common/prefixSumComputer.js +226 -0
  143. package/dist/workers/editor/common/range.js +421 -0
  144. package/dist/workers/editor/common/rangeMapping.js +229 -0
  145. package/dist/workers/editor/common/rangeSingleLine.js +17 -0
  146. package/dist/workers/editor/common/rbTreeBase.js +362 -0
  147. package/dist/workers/editor/common/rect.js +163 -0
  148. package/dist/workers/editor/common/replaceCommand.js +158 -0
  149. package/dist/workers/editor/common/resolverService.js +5 -0
  150. package/dist/workers/editor/common/rgba.js +35 -0
  151. package/dist/workers/editor/common/richEditBrackets.js +356 -0
  152. package/dist/workers/editor/common/selection.js +145 -0
  153. package/dist/workers/editor/common/semanticTokensDto.js +82 -0
  154. package/dist/workers/editor/common/semanticTokensProviderStyling.js +263 -0
  155. package/dist/workers/editor/common/semanticTokensStyling.js +9 -0
  156. package/dist/workers/editor/common/semanticTokensStylingService.js +47 -0
  157. package/dist/workers/editor/common/shiftCommand.js +241 -0
  158. package/dist/workers/editor/common/smallImmutableSet.js +108 -0
  159. package/dist/workers/editor/common/sparseMultilineTokens.js +548 -0
  160. package/dist/workers/editor/common/sparseTokensStore.js +210 -0
  161. package/dist/workers/editor/common/standaloneEnums.js +1017 -0
  162. package/dist/workers/editor/common/standaloneStrings.js +42 -0
  163. package/dist/workers/editor/common/stringBuilder.js +122 -0
  164. package/dist/workers/editor/common/stringEdit.js +165 -0
  165. package/dist/workers/editor/common/supports.js +58 -0
  166. package/dist/workers/editor/common/surroundSelectionCommand.js +44 -0
  167. package/dist/workers/editor/common/textChange.js +248 -0
  168. package/dist/workers/editor/common/textEdit.js +269 -0
  169. package/dist/workers/editor/common/textLength.js +87 -0
  170. package/dist/workers/editor/common/textModel.js +2031 -0
  171. package/dist/workers/editor/common/textModelBracketPairs.js +45 -0
  172. package/dist/workers/editor/common/textModelDefaults.js +18 -0
  173. package/dist/workers/editor/common/textModelEditSource.js +166 -0
  174. package/dist/workers/editor/common/textModelEvents.js +216 -0
  175. package/dist/workers/editor/common/textModelGuides.js +40 -0
  176. package/dist/workers/editor/common/textModelPart.js +23 -0
  177. package/dist/workers/editor/common/textModelSearch.js +455 -0
  178. package/dist/workers/editor/common/textModelStringEdit.js +11 -0
  179. package/dist/workers/editor/common/textModelSync.impl.js +307 -0
  180. package/dist/workers/editor/common/textModelText.js +26 -0
  181. package/dist/workers/editor/common/textModelTokens.js +436 -0
  182. package/dist/workers/editor/common/textResourceConfiguration.js +6 -0
  183. package/dist/workers/editor/common/textToHtmlTokenizer.js +139 -0
  184. package/dist/workers/editor/common/tokenStore.js +407 -0
  185. package/dist/workers/editor/common/tokenWithTextArray.js +73 -0
  186. package/dist/workers/editor/common/tokenization.js +287 -0
  187. package/dist/workers/editor/common/tokenizationRegistry.js +123 -0
  188. package/dist/workers/editor/common/tokenizationTextModelPart.js +275 -0
  189. package/dist/workers/editor/common/tokenizer.js +301 -0
  190. package/dist/workers/editor/common/tokenizerSyntaxTokenBackend.js +261 -0
  191. package/dist/workers/editor/common/treeSitterLibraryService.js +9 -0
  192. package/dist/workers/editor/common/treeSitterSyntaxTokenBackend.js +167 -0
  193. package/dist/workers/editor/common/treeSitterThemeService.js +9 -0
  194. package/dist/workers/editor/common/treeSitterTokenizationImpl.js +713 -0
  195. package/dist/workers/editor/common/treeSitterTree.js +395 -0
  196. package/dist/workers/editor/common/treeViewsDnd.js +24 -0
  197. package/dist/workers/editor/common/treeViewsDndService.js +12 -0
  198. package/dist/workers/editor/common/trimTrailingWhitespaceCommand.js +98 -0
  199. package/dist/workers/editor/common/unicodeTextModelHighlighter.js +188 -0
  200. package/dist/workers/editor/common/utils.js +62 -0
  201. package/dist/workers/editor/common/viewContext.js +22 -0
  202. package/dist/workers/editor/common/viewEventHandler.js +186 -0
  203. package/dist/workers/editor/common/viewEvents.js +180 -0
  204. package/dist/workers/editor/common/viewLayout.js +368 -0
  205. package/dist/workers/editor/common/viewLineRenderer.js +948 -0
  206. package/dist/workers/editor/common/viewLinesViewportData.js +30 -0
  207. package/dist/workers/editor/common/viewModel.js +98 -0
  208. package/dist/workers/editor/common/viewModelDecoration.js +55 -0
  209. package/dist/workers/editor/common/viewModelDecorations.js +132 -0
  210. package/dist/workers/editor/common/viewModelEventDispatcher.js +398 -0
  211. package/dist/workers/editor/common/viewModelImpl.js +1163 -0
  212. package/dist/workers/editor/common/viewModelLines.js +938 -0
  213. package/dist/workers/editor/common/wordCharacterClassifier.js +87 -0
  214. package/dist/workers/editor/common/wordHelper.js +127 -0
  215. package/dist/workers/editor/editor.worker.js +11 -0
  216. package/dist/workers/language/css.worker.js +8 -0
  217. package/dist/workers/language/cssMode.js +198 -0
  218. package/dist/workers/language/cssWorker.js +183 -0
  219. package/dist/workers/language/html.worker.js +8 -0
  220. package/dist/workers/language/htmlMode.js +213 -0
  221. package/dist/workers/language/htmlWorker.js +126 -0
  222. package/dist/workers/language/json.worker.js +8 -0
  223. package/dist/workers/language/jsonMode.js +224 -0
  224. package/dist/workers/language/jsonWorker.js +187 -0
  225. package/dist/workers/language/languageFeatures.js +1009 -0
  226. package/dist/workers/language/lib.index.js +103 -0
  227. package/dist/workers/language/lib.js +1107 -0
  228. package/dist/workers/language/lspLanguageFeatures.js +716 -0
  229. package/dist/workers/language/monaco.contribution.js +144 -0
  230. package/dist/workers/language/tokenization.js +189 -0
  231. package/dist/workers/language/ts.worker.js +14 -0
  232. package/dist/workers/language/tsMode.js +212 -0
  233. package/dist/workers/language/tsWorker.js +352 -0
  234. package/dist/workers/language/typescriptServices.js +210154 -0
  235. package/dist/workers/language/typescriptServicesMetadata.js +3 -0
  236. package/dist/workers/language/workerManager.js +65 -0
  237. package/package.json +3 -2
@@ -0,0 +1,176 @@
1
+ /*---------------------------------------------------------------------------------------------
2
+ * Copyright (c) Microsoft Corporation. All rights reserved.
3
+ * Licensed under the MIT License. See License.txt in the project root for license information.
4
+ *--------------------------------------------------------------------------------------------*/
5
+ class ColorZone {
6
+ constructor(from, to, colorId) {
7
+ this._colorZoneBrand = undefined;
8
+ this.from = from | 0;
9
+ this.to = to | 0;
10
+ this.colorId = colorId | 0;
11
+ }
12
+ static compare(a, b) {
13
+ if (a.colorId === b.colorId) {
14
+ if (a.from === b.from) {
15
+ return a.to - b.to;
16
+ }
17
+ return a.from - b.from;
18
+ }
19
+ return a.colorId - b.colorId;
20
+ }
21
+ }
22
+ /**
23
+ * A zone in the overview ruler
24
+ */
25
+ class OverviewRulerZone {
26
+ constructor(startLineNumber, endLineNumber, heightInLines, color) {
27
+ this._overviewRulerZoneBrand = undefined;
28
+ this.startLineNumber = startLineNumber;
29
+ this.endLineNumber = endLineNumber;
30
+ this.heightInLines = heightInLines;
31
+ this.color = color;
32
+ this._colorZone = null;
33
+ }
34
+ static compare(a, b) {
35
+ if (a.color === b.color) {
36
+ if (a.startLineNumber === b.startLineNumber) {
37
+ if (a.heightInLines === b.heightInLines) {
38
+ return a.endLineNumber - b.endLineNumber;
39
+ }
40
+ return a.heightInLines - b.heightInLines;
41
+ }
42
+ return a.startLineNumber - b.startLineNumber;
43
+ }
44
+ return a.color < b.color ? -1 : 1;
45
+ }
46
+ setColorZone(colorZone) {
47
+ this._colorZone = colorZone;
48
+ }
49
+ getColorZones() {
50
+ return this._colorZone;
51
+ }
52
+ }
53
+ class OverviewZoneManager {
54
+ constructor(getVerticalOffsetForLine) {
55
+ this._getVerticalOffsetForLine = getVerticalOffsetForLine;
56
+ this._zones = [];
57
+ this._colorZonesInvalid = false;
58
+ this._lineHeight = 0;
59
+ this._domWidth = 0;
60
+ this._domHeight = 0;
61
+ this._outerHeight = 0;
62
+ this._pixelRatio = 1;
63
+ this._lastAssignedId = 0;
64
+ this._color2Id = Object.create(null);
65
+ this._id2Color = [];
66
+ }
67
+ getId2Color() {
68
+ return this._id2Color;
69
+ }
70
+ setZones(newZones) {
71
+ this._zones = newZones;
72
+ this._zones.sort(OverviewRulerZone.compare);
73
+ }
74
+ setLineHeight(lineHeight) {
75
+ if (this._lineHeight === lineHeight) {
76
+ return false;
77
+ }
78
+ this._lineHeight = lineHeight;
79
+ this._colorZonesInvalid = true;
80
+ return true;
81
+ }
82
+ setPixelRatio(pixelRatio) {
83
+ this._pixelRatio = pixelRatio;
84
+ this._colorZonesInvalid = true;
85
+ }
86
+ getDOMWidth() {
87
+ return this._domWidth;
88
+ }
89
+ getCanvasWidth() {
90
+ return this._domWidth * this._pixelRatio;
91
+ }
92
+ setDOMWidth(width) {
93
+ if (this._domWidth === width) {
94
+ return false;
95
+ }
96
+ this._domWidth = width;
97
+ this._colorZonesInvalid = true;
98
+ return true;
99
+ }
100
+ getDOMHeight() {
101
+ return this._domHeight;
102
+ }
103
+ getCanvasHeight() {
104
+ return this._domHeight * this._pixelRatio;
105
+ }
106
+ setDOMHeight(height) {
107
+ if (this._domHeight === height) {
108
+ return false;
109
+ }
110
+ this._domHeight = height;
111
+ this._colorZonesInvalid = true;
112
+ return true;
113
+ }
114
+ getOuterHeight() {
115
+ return this._outerHeight;
116
+ }
117
+ setOuterHeight(outerHeight) {
118
+ if (this._outerHeight === outerHeight) {
119
+ return false;
120
+ }
121
+ this._outerHeight = outerHeight;
122
+ this._colorZonesInvalid = true;
123
+ return true;
124
+ }
125
+ resolveColorZones() {
126
+ const colorZonesInvalid = this._colorZonesInvalid;
127
+ const lineHeight = Math.floor(this._lineHeight);
128
+ const totalHeight = Math.floor(this.getCanvasHeight());
129
+ const outerHeight = Math.floor(this._outerHeight);
130
+ const heightRatio = totalHeight / outerHeight;
131
+ const halfMinimumHeight = Math.floor(4 /* Constants.MINIMUM_HEIGHT */ * this._pixelRatio / 2);
132
+ const allColorZones = [];
133
+ for (let i = 0, len = this._zones.length; i < len; i++) {
134
+ const zone = this._zones[i];
135
+ if (!colorZonesInvalid) {
136
+ const colorZone = zone.getColorZones();
137
+ if (colorZone) {
138
+ allColorZones.push(colorZone);
139
+ continue;
140
+ }
141
+ }
142
+ const offset1 = this._getVerticalOffsetForLine(zone.startLineNumber);
143
+ const offset2 = (zone.heightInLines === 0
144
+ ? this._getVerticalOffsetForLine(zone.endLineNumber) + lineHeight
145
+ : offset1 + zone.heightInLines * lineHeight);
146
+ const y1 = Math.floor(heightRatio * offset1);
147
+ const y2 = Math.floor(heightRatio * offset2);
148
+ let ycenter = Math.floor((y1 + y2) / 2);
149
+ let halfHeight = (y2 - ycenter);
150
+ if (halfHeight < halfMinimumHeight) {
151
+ halfHeight = halfMinimumHeight;
152
+ }
153
+ if (ycenter - halfHeight < 0) {
154
+ ycenter = halfHeight;
155
+ }
156
+ if (ycenter + halfHeight > totalHeight) {
157
+ ycenter = totalHeight - halfHeight;
158
+ }
159
+ const color = zone.color;
160
+ let colorId = this._color2Id[color];
161
+ if (!colorId) {
162
+ colorId = (++this._lastAssignedId);
163
+ this._color2Id[color] = colorId;
164
+ this._id2Color[colorId] = color;
165
+ }
166
+ const colorZone = new ColorZone(ycenter - halfHeight, ycenter + halfHeight, colorId);
167
+ zone.setColorZone(colorZone);
168
+ allColorZones.push(colorZone);
169
+ }
170
+ this._colorZonesInvalid = false;
171
+ allColorZones.sort(ColorZone.compare);
172
+ return allColorZones;
173
+ }
174
+ }
175
+
176
+ export { ColorZone, OverviewRulerZone, OverviewZoneManager };
@@ -0,0 +1,121 @@
1
+ import { ListAstNode, TextAstNode, PairAstNode, InvalidBracketAstNode } from './ast.js';
2
+ import { BeforeEditPositionMapper } from './beforeEditPositionMapper.js';
3
+ import { SmallImmutableSet } from './smallImmutableSet.js';
4
+ import { lengthIsZero, lengthLessThan } from './length.js';
5
+ import { concat23Trees, concat23TreesOfSameHeight } from './concat23Trees.js';
6
+ import { NodeReader } from './nodeReader.js';
7
+
8
+ /*---------------------------------------------------------------------------------------------
9
+ * Copyright (c) Microsoft Corporation. All rights reserved.
10
+ * Licensed under the MIT License. See License.txt in the project root for license information.
11
+ *--------------------------------------------------------------------------------------------*/
12
+ /**
13
+ * Non incrementally built ASTs are immutable.
14
+ */
15
+ function parseDocument(tokenizer, edits, oldNode, createImmutableLists) {
16
+ const parser = new Parser(tokenizer, edits, oldNode, createImmutableLists);
17
+ return parser.parseDocument();
18
+ }
19
+ /**
20
+ * Non incrementally built ASTs are immutable.
21
+ */
22
+ class Parser {
23
+ constructor(tokenizer, edits, oldNode, createImmutableLists) {
24
+ this.tokenizer = tokenizer;
25
+ this.createImmutableLists = createImmutableLists;
26
+ this._itemsConstructed = 0;
27
+ this._itemsFromCache = 0;
28
+ if (oldNode && createImmutableLists) {
29
+ throw new Error('Not supported');
30
+ }
31
+ this.oldNodeReader = oldNode ? new NodeReader(oldNode) : undefined;
32
+ this.positionMapper = new BeforeEditPositionMapper(edits);
33
+ }
34
+ parseDocument() {
35
+ this._itemsConstructed = 0;
36
+ this._itemsFromCache = 0;
37
+ let result = this.parseList(SmallImmutableSet.getEmpty(), 0);
38
+ if (!result) {
39
+ result = ListAstNode.getEmpty();
40
+ }
41
+ return result;
42
+ }
43
+ parseList(openedBracketIds, level) {
44
+ const items = [];
45
+ while (true) {
46
+ let child = this.tryReadChildFromCache(openedBracketIds);
47
+ if (!child) {
48
+ const token = this.tokenizer.peek();
49
+ if (!token ||
50
+ (token.kind === 2 /* TokenKind.ClosingBracket */ &&
51
+ token.bracketIds.intersects(openedBracketIds))) {
52
+ break;
53
+ }
54
+ child = this.parseChild(openedBracketIds, level + 1);
55
+ }
56
+ if (child.kind === 4 /* AstNodeKind.List */ && child.childrenLength === 0) {
57
+ continue;
58
+ }
59
+ items.push(child);
60
+ }
61
+ // When there is no oldNodeReader, all items are created from scratch and must have the same height.
62
+ const result = this.oldNodeReader ? concat23Trees(items) : concat23TreesOfSameHeight(items, this.createImmutableLists);
63
+ return result;
64
+ }
65
+ tryReadChildFromCache(openedBracketIds) {
66
+ if (this.oldNodeReader) {
67
+ const maxCacheableLength = this.positionMapper.getDistanceToNextChange(this.tokenizer.offset);
68
+ if (maxCacheableLength === null || !lengthIsZero(maxCacheableLength)) {
69
+ const cachedNode = this.oldNodeReader.readLongestNodeAt(this.positionMapper.getOffsetBeforeChange(this.tokenizer.offset), curNode => {
70
+ // The edit could extend the ending token, thus we cannot re-use nodes that touch the edit.
71
+ // If there is no edit anymore, we can re-use the node in any case.
72
+ if (maxCacheableLength !== null && !lengthLessThan(curNode.length, maxCacheableLength)) {
73
+ // Either the node contains edited text or touches edited text.
74
+ // In the latter case, brackets might have been extended (`end` -> `ending`), so even touching nodes cannot be reused.
75
+ return false;
76
+ }
77
+ const canBeReused = curNode.canBeReused(openedBracketIds);
78
+ return canBeReused;
79
+ });
80
+ if (cachedNode) {
81
+ this._itemsFromCache++;
82
+ this.tokenizer.skip(cachedNode.length);
83
+ return cachedNode;
84
+ }
85
+ }
86
+ }
87
+ return undefined;
88
+ }
89
+ parseChild(openedBracketIds, level) {
90
+ this._itemsConstructed++;
91
+ const token = this.tokenizer.read();
92
+ switch (token.kind) {
93
+ case 2 /* TokenKind.ClosingBracket */:
94
+ return new InvalidBracketAstNode(token.bracketIds, token.length);
95
+ case 0 /* TokenKind.Text */:
96
+ return token.astNode;
97
+ case 1 /* TokenKind.OpeningBracket */: {
98
+ if (level > 300) {
99
+ // To prevent stack overflows
100
+ return new TextAstNode(token.length);
101
+ }
102
+ const set = openedBracketIds.merge(token.bracketIds);
103
+ const child = this.parseList(set, level + 1);
104
+ const nextToken = this.tokenizer.peek();
105
+ if (nextToken &&
106
+ nextToken.kind === 2 /* TokenKind.ClosingBracket */ &&
107
+ (nextToken.bracketId === token.bracketId || nextToken.bracketIds.intersects(token.bracketIds))) {
108
+ this.tokenizer.read();
109
+ return PairAstNode.create(token.astNode, child, nextToken.astNode);
110
+ }
111
+ else {
112
+ return PairAstNode.create(token.astNode, child, null);
113
+ }
114
+ }
115
+ default:
116
+ throw new Error('unexpected');
117
+ }
118
+ }
119
+ }
120
+
121
+ export { parseDocument };