monaco-editor11 1.1.0 → 1.1.2

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 (1068) hide show
  1. package/dist/index.d.ts +1 -8
  2. package/dist/monaco-editor11.es.js +1 -49
  3. package/dist/monaco-editor11.umd.js +1 -1
  4. package/dist/workers/_.contribution.js +120 -0
  5. package/dist/workers/abap.contribution.js +8 -0
  6. package/dist/workers/abap.js +1397 -0
  7. package/dist/workers/abstractCodeEditorService.js +129 -0
  8. package/dist/workers/abstractKeybindingService.js +286 -0
  9. package/dist/workers/abstractScrollbar.js +214 -0
  10. package/dist/workers/abstractSyntaxTokenBackend.js +128 -0
  11. package/dist/workers/abstractText.js +89 -0
  12. package/dist/workers/abstractTree.js +2027 -0
  13. package/dist/workers/accessibility.js +11 -0
  14. package/dist/workers/accessibilityService.js +111 -0
  15. package/dist/workers/accessibilitySignalService.js +331 -0
  16. package/dist/workers/accessibleDiffViewer.js +588 -0
  17. package/dist/workers/accessibleViewRegistry.js +25 -0
  18. package/dist/workers/action.js +15 -0
  19. package/dist/workers/actionCommonCategories.js +16 -0
  20. package/dist/workers/actionList.js +344 -0
  21. package/dist/workers/actionViewItemService.js +29 -0
  22. package/dist/workers/actionViewItems.js +376 -0
  23. package/dist/workers/actionWidget.js +236 -0
  24. package/dist/workers/actionbar.js +462 -0
  25. package/dist/workers/actions.js +483 -0
  26. package/dist/workers/anchorSelect.js +160 -0
  27. package/dist/workers/animation.js +74 -0
  28. package/dist/workers/apex.contribution.js +9 -0
  29. package/dist/workers/apex.js +329 -0
  30. package/dist/workers/aria.js +84 -0
  31. package/dist/workers/arrays.js +529 -0
  32. package/dist/workers/arraysFind.js +177 -0
  33. package/dist/workers/assert.js +79 -0
  34. package/dist/workers/ast.js +485 -0
  35. package/dist/workers/async.js +938 -0
  36. package/dist/workers/asyncDataTree.js +946 -0
  37. package/dist/workers/autoIndent.js +390 -0
  38. package/dist/workers/autorun.js +89 -0
  39. package/dist/workers/autorunImpl.js +215 -0
  40. package/dist/workers/azcli.contribution.js +8 -0
  41. package/dist/workers/azcli.js +67 -0
  42. package/dist/workers/bannerController.js +118 -0
  43. package/dist/workers/base.js +19 -0
  44. package/dist/workers/baseColors.js +31 -0
  45. package/dist/workers/baseObservable.js +106 -0
  46. package/dist/workers/baseRenderStrategy.js +19 -0
  47. package/dist/workers/baseResolvedKeybinding.js +56 -0
  48. package/dist/workers/bat.contribution.js +8 -0
  49. package/dist/workers/bat.js +99 -0
  50. package/dist/workers/beforeEditPositionMapper.js +110 -0
  51. package/dist/workers/bicep.contribution.js +8 -0
  52. package/dist/workers/bicep.js +108 -0
  53. package/dist/workers/blockCommentCommand.js +149 -0
  54. package/dist/workers/blockDecorations.js +97 -0
  55. package/dist/workers/bracketMatching.js +359 -0
  56. package/dist/workers/bracketPairsImpl.js +717 -0
  57. package/dist/workers/bracketPairsTree.js +343 -0
  58. package/dist/workers/bracketSelections.js +149 -0
  59. package/dist/workers/brackets.js +108 -0
  60. package/dist/workers/browser.js +57 -0
  61. package/dist/workers/buffer.js +81 -0
  62. package/dist/workers/bufferDirtyTracker.js +45 -0
  63. package/dist/workers/bulkEditService.js +76 -0
  64. package/dist/workers/button.js +226 -0
  65. package/dist/workers/cache.js +61 -0
  66. package/dist/workers/cameligo.contribution.js +8 -0
  67. package/dist/workers/cameligo.js +173 -0
  68. package/dist/workers/canIUse.js +23 -0
  69. package/dist/workers/cancellation.js +116 -0
  70. package/dist/workers/caretOperations.js +48 -0
  71. package/dist/workers/changeRecorder.js +78 -0
  72. package/dist/workers/changeTracker.js +80 -0
  73. package/dist/workers/charWidthReader.js +104 -0
  74. package/dist/workers/characterClassifier.js +59 -0
  75. package/dist/workers/characterPair.js +40 -0
  76. package/dist/workers/chartsColors.js +18 -0
  77. package/dist/workers/clickLinkGesture.js +161 -0
  78. package/dist/workers/clipboard.js +308 -0
  79. package/dist/workers/clipboardService.js +9 -0
  80. package/dist/workers/clipboardUtils.js +85 -0
  81. package/dist/workers/clojure.contribution.js +8 -0
  82. package/dist/workers/clojure.js +760 -0
  83. package/dist/workers/codeAction.js +306 -0
  84. package/dist/workers/codeActionCommands.js +230 -0
  85. package/dist/workers/codeActionContributions.js +55 -0
  86. package/dist/workers/codeActionController.js +372 -0
  87. package/dist/workers/codeActionKeybindingResolver.js +90 -0
  88. package/dist/workers/codeActionMenu.js +68 -0
  89. package/dist/workers/codeActionModel.js +334 -0
  90. package/dist/workers/codeEditorContributions.js +132 -0
  91. package/dist/workers/codeEditorService.js +9 -0
  92. package/dist/workers/codeEditorWidget.js +1856 -0
  93. package/dist/workers/codeLensCache.js +112 -0
  94. package/dist/workers/codelens.js +114 -0
  95. package/dist/workers/codelensController.js +469 -0
  96. package/dist/workers/codelensWidget.js +265 -0
  97. package/dist/workers/codicons.js +50 -0
  98. package/dist/workers/codiconsLibrary.js +642 -0
  99. package/dist/workers/codiconsUtil.js +22 -0
  100. package/dist/workers/coffee.contribution.js +9 -0
  101. package/dist/workers/coffee.js +231 -0
  102. package/dist/workers/collections.js +98 -0
  103. package/dist/workers/color.js +94 -0
  104. package/dist/workers/colorDetector.js +245 -0
  105. package/dist/workers/colorPickerBody.js +71 -0
  106. package/dist/workers/colorPickerCloseButton.js +34 -0
  107. package/dist/workers/colorPickerContribution.js +50 -0
  108. package/dist/workers/colorPickerHeader.js +79 -0
  109. package/dist/workers/colorPickerInsertButton.js +27 -0
  110. package/dist/workers/colorPickerModel.js +74 -0
  111. package/dist/workers/colorPickerParticipantUtils.js +52 -0
  112. package/dist/workers/colorPickerSaturationBox.js +106 -0
  113. package/dist/workers/colorPickerStrip.js +98 -0
  114. package/dist/workers/colorPickerWidget.js +32 -0
  115. package/dist/workers/colorUtils.js +199 -0
  116. package/dist/workers/colorizedBracketPairsDecorationProvider.js +97 -0
  117. package/dist/workers/colorizer.js +120 -0
  118. package/dist/workers/colors.js +20 -0
  119. package/dist/workers/columnRange.js +35 -0
  120. package/dist/workers/combineTextEditInfos.js +124 -0
  121. package/dist/workers/commandIds.js +12 -0
  122. package/dist/workers/commands.js +329 -0
  123. package/dist/workers/commandsQuickAccess.js +40 -0
  124. package/dist/workers/comment.js +147 -0
  125. package/dist/workers/common.js +20 -0
  126. package/dist/workers/comparers.js +87 -0
  127. package/dist/workers/completionModel.js +227 -0
  128. package/dist/workers/compressedObjectTreeModel.js +385 -0
  129. package/dist/workers/computeGhostText.js +182 -0
  130. package/dist/workers/computeMovedLines.js +249 -0
  131. package/dist/workers/concat23Trees.js +192 -0
  132. package/dist/workers/configuration.js +92 -0
  133. package/dist/workers/configurationModels.js +614 -0
  134. package/dist/workers/configurationRegistry.js +400 -0
  135. package/dist/workers/configurations.js +46 -0
  136. package/dist/workers/consoleObservableLogger.js +83 -0
  137. package/dist/workers/constObservable.js +35 -0
  138. package/dist/workers/contentHoverComputer.js +71 -0
  139. package/dist/workers/contentHoverController.js +320 -0
  140. package/dist/workers/contentHoverRendered.js +336 -0
  141. package/dist/workers/contentHoverStatusBar.js +52 -0
  142. package/dist/workers/contentHoverTypes.js +29 -0
  143. package/dist/workers/contentHoverWidget.js +394 -0
  144. package/dist/workers/contentHoverWidgetWrapper.js +362 -0
  145. package/dist/workers/contentSegmenter.js +52 -0
  146. package/dist/workers/contentWidgets.js +495 -0
  147. package/dist/workers/contextKeyService.js +468 -0
  148. package/dist/workers/contextMenuHandler.js +126 -0
  149. package/dist/workers/contextMenuService.js +103 -0
  150. package/dist/workers/contextScopedHistoryWidget.js +106 -0
  151. package/dist/workers/contextViewService.js +73 -0
  152. package/dist/workers/contextkey.js +1551 -0
  153. package/dist/workers/contextkeys.js +21 -0
  154. package/dist/workers/contextmenu.js +334 -0
  155. package/dist/workers/contextview.js +298 -0
  156. package/dist/workers/contiguousMultilineTokens.js +32 -0
  157. package/dist/workers/contiguousMultilineTokensBuilder.js +23 -0
  158. package/dist/workers/contiguousTokensEditing.js +128 -0
  159. package/dist/workers/contiguousTokensStore.js +207 -0
  160. package/dist/workers/contribution.js +36 -0
  161. package/dist/workers/coordinatesConverter.js +51 -0
  162. package/dist/workers/copyLinesCommand.js +73 -0
  163. package/dist/workers/copyPasteContribution.js +114 -0
  164. package/dist/workers/copyPasteController.js +585 -0
  165. package/dist/workers/copySelection.js +47 -0
  166. package/dist/workers/coreCommands.js +1731 -0
  167. package/dist/workers/countBadge.js +52 -0
  168. package/dist/workers/cpp.contribution.js +14 -0
  169. package/dist/workers/cpp.js +388 -0
  170. package/dist/workers/csharp.contribution.js +8 -0
  171. package/dist/workers/csharp.js +325 -0
  172. package/dist/workers/csp.contribution.js +8 -0
  173. package/dist/workers/csp.js +52 -0
  174. package/dist/workers/css.contribution.js +9 -0
  175. package/dist/workers/css.js +184 -0
  176. package/dist/workers/cssMode.js +198 -0
  177. package/dist/workers/cssValue.js +69 -0
  178. package/dist/workers/cssWorker.js +183 -0
  179. package/dist/workers/currentLineHighlight.js +205 -0
  180. package/dist/workers/cursor.js +899 -0
  181. package/dist/workers/cursorAtomicMoveOperations.js +145 -0
  182. package/dist/workers/cursorCollection.js +194 -0
  183. package/dist/workers/cursorColumnSelection.js +93 -0
  184. package/dist/workers/cursorColumns.js +112 -0
  185. package/dist/workers/cursorCommon.js +250 -0
  186. package/dist/workers/cursorContext.js +15 -0
  187. package/dist/workers/cursorDeleteOperations.js +231 -0
  188. package/dist/workers/cursorMoveCommands.js +676 -0
  189. package/dist/workers/cursorMoveOperations.js +290 -0
  190. package/dist/workers/cursorTypeEditOperations.js +968 -0
  191. package/dist/workers/cursorTypeOperations.js +173 -0
  192. package/dist/workers/cursorUndo.js +133 -0
  193. package/dist/workers/cursorUtils.js +75 -0
  194. package/dist/workers/cursorWordOperations.js +720 -0
  195. package/dist/workers/cypher.contribution.js +8 -0
  196. package/dist/workers/cypher.js +262 -0
  197. package/dist/workers/dart.contribution.js +9 -0
  198. package/dist/workers/dart.js +280 -0
  199. package/dist/workers/dataChannel.js +12 -0
  200. package/dist/workers/dataTransfer.js +80 -0
  201. package/dist/workers/dataTree.js +20 -0
  202. package/dist/workers/date.js +57 -0
  203. package/dist/workers/debugLocation.js +66 -0
  204. package/dist/workers/debugName.js +110 -0
  205. package/dist/workers/debuggerRpc.js +67 -0
  206. package/dist/workers/decorationCssRuleExtractor.js +73 -0
  207. package/dist/workers/decorationStyleCache.js +40 -0
  208. package/dist/workers/decorations.js +196 -0
  209. package/dist/workers/decorationsOverviewRuler.js +416 -0
  210. package/dist/workers/decorators.js +33 -0
  211. package/dist/workers/defaultDocumentColorProvider.js +55 -0
  212. package/dist/workers/defaultDocumentColorsComputer.js +138 -0
  213. package/dist/workers/defaultLinesDiffComputer.js +188 -0
  214. package/dist/workers/defaultProviders.js +230 -0
  215. package/dist/workers/defaultStyles.js +194 -0
  216. package/dist/workers/delegatingEditorImpl.js +111 -0
  217. package/dist/workers/derived.js +80 -0
  218. package/dist/workers/derivedImpl.js +353 -0
  219. package/dist/workers/descriptors.js +13 -0
  220. package/dist/workers/devToolsLogger.js +442 -0
  221. package/dist/workers/dialogs.js +5 -0
  222. package/dist/workers/diff.js +902 -0
  223. package/dist/workers/diffAlgorithm.js +139 -0
  224. package/dist/workers/diffChange.js +34 -0
  225. package/dist/workers/diffEditor.contribution.js +83 -0
  226. package/dist/workers/diffEditor.js +38 -0
  227. package/dist/workers/diffEditorDecorations.js +115 -0
  228. package/dist/workers/diffEditorEditors.js +190 -0
  229. package/dist/workers/diffEditorItemTemplate.js +272 -0
  230. package/dist/workers/diffEditorOptions.js +152 -0
  231. package/dist/workers/diffEditorSash.js +86 -0
  232. package/dist/workers/diffEditorViewModel.js +608 -0
  233. package/dist/workers/diffEditorViewZones.js +525 -0
  234. package/dist/workers/diffEditorWidget.js +590 -0
  235. package/dist/workers/diffProviderFactoryService.js +142 -0
  236. package/dist/workers/dnd.js +198 -0
  237. package/dist/workers/dockerfile.contribution.js +9 -0
  238. package/dist/workers/dockerfile.js +129 -0
  239. package/dist/workers/documentSemanticTokens.js +362 -0
  240. package/dist/workers/documentSymbols.js +24 -0
  241. package/dist/workers/dom.js +1454 -0
  242. package/dist/workers/domFontInfo.js +28 -0
  243. package/dist/workers/domLineBreaksComputer.js +301 -0
  244. package/dist/workers/domReadingContext.js +43 -0
  245. package/dist/workers/domSanitize.js +312 -0
  246. package/dist/workers/domStylesheets.js +145 -0
  247. package/dist/workers/dompurify.js +1347 -0
  248. package/dist/workers/dragAndDropCommand.js +65 -0
  249. package/dist/workers/dragScrolling.js +174 -0
  250. package/dist/workers/dropIntoEditorContribution.js +41 -0
  251. package/dist/workers/dropIntoEditorController.js +173 -0
  252. package/dist/workers/dropdown.js +141 -0
  253. package/dist/workers/dropdownActionViewItem.js +109 -0
  254. package/dist/workers/dynamicProgrammingDiffing.js +101 -0
  255. package/dist/workers/dynamicViewOverlay.js +10 -0
  256. package/dist/workers/ecl.contribution.js +8 -0
  257. package/dist/workers/ecl.js +455 -0
  258. package/dist/workers/edcore.main.js +74 -0
  259. package/dist/workers/edit.js +83 -0
  260. package/dist/workers/editContext.js +10 -0
  261. package/dist/workers/editContextFactory.js +16 -0
  262. package/dist/workers/editOperation.js +36 -0
  263. package/dist/workers/editStack.js +363 -0
  264. package/dist/workers/editor.all.js +65 -0
  265. package/dist/workers/editor.api.js +2 -0
  266. package/dist/workers/editor.api2.js +60 -0
  267. package/dist/workers/editor.js +15 -0
  268. package/dist/workers/editor.main.js +170 -0
  269. package/dist/workers/editor.worker.start.js +44 -0
  270. package/dist/workers/editorAction.js +26 -0
  271. package/dist/workers/editorBaseApi.js +43 -0
  272. package/dist/workers/editorBrowser.js +53 -0
  273. package/dist/workers/editorColorRegistry.js +102 -0
  274. package/dist/workers/editorColors.js +128 -0
  275. package/dist/workers/editorCommon.js +13 -0
  276. package/dist/workers/editorConfiguration.js +292 -0
  277. package/dist/workers/editorConfigurationSchema.js +338 -0
  278. package/dist/workers/editorContextKeys.js +84 -0
  279. package/dist/workers/editorDom.js +299 -0
  280. package/dist/workers/editorExtensions.js +489 -0
  281. package/dist/workers/editorFeatures.js +17 -0
  282. package/dist/workers/editorGutter.js +117 -0
  283. package/dist/workers/editorMarkdownCodeBlockRenderer.js +85 -0
  284. package/dist/workers/editorNavigationQuickAccess.js +152 -0
  285. package/dist/workers/editorOptions.js +3440 -0
  286. package/dist/workers/editorScrollbar.js +151 -0
  287. package/dist/workers/editorState.js +115 -0
  288. package/dist/workers/editorTheme.js +23 -0
  289. package/dist/workers/editorWebWorker.js +299 -0
  290. package/dist/workers/editorWorker.js +9 -0
  291. package/dist/workers/editorWorkerHost.js +15 -0
  292. package/dist/workers/editorWorkerService.js +366 -0
  293. package/dist/workers/editorZoom.js +26 -0
  294. package/dist/workers/electricCharacter.js +55 -0
  295. package/dist/workers/elementSizeObserver.js +107 -0
  296. package/dist/workers/elixir.contribution.js +8 -0
  297. package/dist/workers/elixir.js +568 -0
  298. package/dist/workers/embeddedCodeEditorWidget.js +66 -0
  299. package/dist/workers/encodedTokenAttributes.js +79 -0
  300. package/dist/workers/enterAction.js +53 -0
  301. package/dist/workers/environment.js +5 -0
  302. package/dist/workers/eolCounter.js +44 -0
  303. package/dist/workers/equals.js +84 -0
  304. package/dist/workers/errorMessage.js +71 -0
  305. package/dist/workers/errors.js +163 -0
  306. package/dist/workers/event.js +1197 -0
  307. package/dist/workers/extensions.js +18 -0
  308. package/dist/workers/extpath.js +147 -0
  309. package/dist/workers/fastDomNode.js +255 -0
  310. package/dist/workers/files.js +19 -0
  311. package/dist/workers/filters.js +742 -0
  312. package/dist/workers/findController.js +970 -0
  313. package/dist/workers/findDecorations.js +311 -0
  314. package/dist/workers/findInput.js +294 -0
  315. package/dist/workers/findInputToggles.js +52 -0
  316. package/dist/workers/findModel.js +497 -0
  317. package/dist/workers/findOptionsWidget.js +155 -0
  318. package/dist/workers/findSectionHeaders.js +128 -0
  319. package/dist/workers/findState.js +244 -0
  320. package/dist/workers/findWidget.js +1168 -0
  321. package/dist/workers/findWidgetSearchHistory.js +85 -0
  322. package/dist/workers/fixBrackets.js +67 -0
  323. package/dist/workers/fixedArray.js +70 -0
  324. package/dist/workers/floatingMenu.contribution.js +9 -0
  325. package/dist/workers/floatingMenu.js +94 -0
  326. package/dist/workers/flow9.contribution.js +8 -0
  327. package/dist/workers/flow9.js +141 -0
  328. package/dist/workers/folding.js +1136 -0
  329. package/dist/workers/foldingDecorations.js +158 -0
  330. package/dist/workers/foldingModel.js +532 -0
  331. package/dist/workers/foldingRanges.js +354 -0
  332. package/dist/workers/fontInfo.js +172 -0
  333. package/dist/workers/fontInfoFromSettings.js +29 -0
  334. package/dist/workers/fontMeasurements.js +206 -0
  335. package/dist/workers/fontZoom.js +47 -0
  336. package/dist/workers/fonts.js +17 -0
  337. package/dist/workers/format.js +367 -0
  338. package/dist/workers/formatActions.js +263 -0
  339. package/dist/workers/formattedTextRenderer.js +160 -0
  340. package/dist/workers/formattingEdit.js +57 -0
  341. package/dist/workers/forwardingTelemetryService.js +60 -0
  342. package/dist/workers/freemarker2.contribution.js +52 -0
  343. package/dist/workers/freemarker2.js +1062 -0
  344. package/dist/workers/fsharp.contribution.js +8 -0
  345. package/dist/workers/fsharp.js +216 -0
  346. package/dist/workers/fullFileRenderStrategy.js +414 -0
  347. package/dist/workers/fullFileRenderStrategy.wgsl.js +93 -0
  348. package/dist/workers/functional.js +24 -0
  349. package/dist/workers/fuzzyScorer.js +143 -0
  350. package/dist/workers/getHover.js +56 -0
  351. package/dist/workers/getIconClasses.js +106 -0
  352. package/dist/workers/getLinks.js +157 -0
  353. package/dist/workers/getPositionOffsetTransformerFromTextModel.js +24 -0
  354. package/dist/workers/getSemanticTokens.js +211 -0
  355. package/dist/workers/ghostText.js +111 -0
  356. package/dist/workers/ghostTextView.js +449 -0
  357. package/dist/workers/glob.js +581 -0
  358. package/dist/workers/globalPointerMoveMonitor.js +83 -0
  359. package/dist/workers/glyphHoverComputer.js +40 -0
  360. package/dist/workers/glyphHoverController.js +171 -0
  361. package/dist/workers/glyphHoverWidget.js +184 -0
  362. package/dist/workers/glyphLanesModel.js +61 -0
  363. package/dist/workers/glyphMargin.js +403 -0
  364. package/dist/workers/glyphRasterizer.js +276 -0
  365. package/dist/workers/go.contribution.js +8 -0
  366. package/dist/workers/go.js +217 -0
  367. package/dist/workers/goToCommands.js +694 -0
  368. package/dist/workers/goToDefinitionAtPosition.js +267 -0
  369. package/dist/workers/goToSymbol.js +128 -0
  370. package/dist/workers/gotoError.js +272 -0
  371. package/dist/workers/gotoErrorWidget.js +352 -0
  372. package/dist/workers/gotoLineQuickAccess.js +183 -0
  373. package/dist/workers/gotoSymbolQuickAccess.js +395 -0
  374. package/dist/workers/gpuActions.js +126 -0
  375. package/dist/workers/gpuDisposable.js +48 -0
  376. package/dist/workers/gpuMark.js +80 -0
  377. package/dist/workers/gpuUtils.js +58 -0
  378. package/dist/workers/graph.js +74 -0
  379. package/dist/workers/graphql.contribution.js +9 -0
  380. package/dist/workers/graphql.js +150 -0
  381. package/dist/workers/guidesTextModelPart.js +405 -0
  382. package/dist/workers/gutterFeature.js +238 -0
  383. package/dist/workers/gutterIndicatorMenu.js +252 -0
  384. package/dist/workers/gutterIndicatorView.js +456 -0
  385. package/dist/workers/handlebars.contribution.js +9 -0
  386. package/dist/workers/handlebars.js +485 -0
  387. package/dist/workers/hash.js +256 -0
  388. package/dist/workers/hcl.contribution.js +8 -0
  389. package/dist/workers/hcl.js +182 -0
  390. package/dist/workers/helpQuickAccess.js +77 -0
  391. package/dist/workers/heuristicSequenceOptimizations.js +374 -0
  392. package/dist/workers/hiddenRangeModel.js +126 -0
  393. package/dist/workers/hideUnchangedRegionsFeature.js +433 -0
  394. package/dist/workers/hierarchicalKind.js +26 -0
  395. package/dist/workers/highlightDecorations.js +111 -0
  396. package/dist/workers/highlightedLabel.js +129 -0
  397. package/dist/workers/history.js +85 -0
  398. package/dist/workers/historyWidgetKeybindingHint.js +9 -0
  399. package/dist/workers/horizontalScrollbar.js +91 -0
  400. package/dist/workers/hotReloadHelpers.js +17 -0
  401. package/dist/workers/hover.js +11 -0
  402. package/dist/workers/hoverAccessibleViews.js +8 -0
  403. package/dist/workers/hoverActionIds.js +23 -0
  404. package/dist/workers/hoverActions.js +424 -0
  405. package/dist/workers/hoverColorPicker.js +14 -0
  406. package/dist/workers/hoverColorPickerContribution.js +44 -0
  407. package/dist/workers/hoverColorPickerParticipant.js +151 -0
  408. package/dist/workers/hoverContribution.js +56 -0
  409. package/dist/workers/hoverCopyButton.js +54 -0
  410. package/dist/workers/hoverDelegate2.js +39 -0
  411. package/dist/workers/hoverDelegateFactory.js +34 -0
  412. package/dist/workers/hoverOperation.js +168 -0
  413. package/dist/workers/hoverParticipant.js +161 -0
  414. package/dist/workers/hoverService.js +542 -0
  415. package/dist/workers/hoverTypes.js +64 -0
  416. package/dist/workers/hoverUtils.js +18 -0
  417. package/dist/workers/hoverWidget.js +93 -0
  418. package/dist/workers/html.contribution.js +9 -0
  419. package/dist/workers/html.js +374 -0
  420. package/dist/workers/htmlContent.js +164 -0
  421. package/dist/workers/htmlMode.js +213 -0
  422. package/dist/workers/htmlWorker.js +126 -0
  423. package/dist/workers/iPadShowKeyboard.js +74 -0
  424. package/dist/workers/iconLabel.js +291 -0
  425. package/dist/workers/iconLabels.js +33 -0
  426. package/dist/workers/iconRegistry.js +183 -0
  427. package/dist/workers/iconsStyleSheet.js +75 -0
  428. package/dist/workers/idGenerator.js +16 -0
  429. package/dist/workers/iframe.js +87 -0
  430. package/dist/workers/ime.js +33 -0
  431. package/dist/workers/inPlaceReplace.js +151 -0
  432. package/dist/workers/inPlaceReplaceCommand.js +27 -0
  433. package/dist/workers/indentGuides.js +254 -0
  434. package/dist/workers/indentRangeProvider.js +166 -0
  435. package/dist/workers/indentRules.js +63 -0
  436. package/dist/workers/indentUtils.js +33 -0
  437. package/dist/workers/indentation.js +100 -0
  438. package/dist/workers/indentationGuesser.js +178 -0
  439. package/dist/workers/indentationLineProcessor.js +193 -0
  440. package/dist/workers/index.js +21 -0
  441. package/dist/workers/indexTreeModel.js +538 -0
  442. package/dist/workers/ini.contribution.js +9 -0
  443. package/dist/workers/ini.js +70 -0
  444. package/dist/workers/initialize.js +11 -0
  445. package/dist/workers/inlayHints.js +147 -0
  446. package/dist/workers/inlayHintsContribution.js +11 -0
  447. package/dist/workers/inlayHintsController.js +686 -0
  448. package/dist/workers/inlayHintsHover.js +162 -0
  449. package/dist/workers/inlayHintsLocations.js +96 -0
  450. package/dist/workers/inlineCompletionContextKeys.js +23 -0
  451. package/dist/workers/inlineCompletions.contribution.js +31 -0
  452. package/dist/workers/inlineCompletionsAccessibleView.js +4 -0
  453. package/dist/workers/inlineCompletionsController.js +427 -0
  454. package/dist/workers/inlineCompletionsHintsWidget.js +356 -0
  455. package/dist/workers/inlineCompletionsModel.js +1048 -0
  456. package/dist/workers/inlineCompletionsService.js +170 -0
  457. package/dist/workers/inlineCompletionsSource.js +548 -0
  458. package/dist/workers/inlineCompletionsView.js +86 -0
  459. package/dist/workers/inlineDecorations.js +26 -0
  460. package/dist/workers/inlineDiffDeletedCodeMargin.js +138 -0
  461. package/dist/workers/inlineEdit.js +17 -0
  462. package/dist/workers/inlineEditWithChanges.js +30 -0
  463. package/dist/workers/inlineEditsCollapsedView.js +132 -0
  464. package/dist/workers/inlineEditsCustomView.js +256 -0
  465. package/dist/workers/inlineEditsDeletionView.js +178 -0
  466. package/dist/workers/inlineEditsInsertionView.js +267 -0
  467. package/dist/workers/inlineEditsLineReplacementView.js +329 -0
  468. package/dist/workers/inlineEditsModel.js +59 -0
  469. package/dist/workers/inlineEditsNewUsers.js +174 -0
  470. package/dist/workers/inlineEditsSideBySideView.js +517 -0
  471. package/dist/workers/inlineEditsView.js +561 -0
  472. package/dist/workers/inlineEditsViewInterface.js +21 -0
  473. package/dist/workers/inlineEditsViewProducer.js +119 -0
  474. package/dist/workers/inlineEditsWordReplacementView.js +211 -0
  475. package/dist/workers/inlineProgress.js +139 -0
  476. package/dist/workers/inlineSuggestionItem.js +497 -0
  477. package/dist/workers/inplaceReplaceSupport.js +87 -0
  478. package/dist/workers/inputBox.js +510 -0
  479. package/dist/workers/inputColors.js +66 -0
  480. package/dist/workers/inputMode.js +22 -0
  481. package/dist/workers/insertFinalNewLine.js +32 -0
  482. package/dist/workers/insertFinalNewLineCommand.js +39 -0
  483. package/dist/workers/inspectTokens.js +240 -0
  484. package/dist/workers/instantiation.js +44 -0
  485. package/dist/workers/instantiationService.js +403 -0
  486. package/dist/workers/intervalTree.js +1002 -0
  487. package/dist/workers/iterator.js +186 -0
  488. package/dist/workers/java.contribution.js +9 -0
  489. package/dist/workers/java.js +231 -0
  490. package/dist/workers/javascript.contribution.js +11 -0
  491. package/dist/workers/javascript.js +70 -0
  492. package/dist/workers/jsonContributionRegistry.js +42 -0
  493. package/dist/workers/jsonMode.js +224 -0
  494. package/dist/workers/jsonWorker.js +187 -0
  495. package/dist/workers/julia.contribution.js +8 -0
  496. package/dist/workers/julia.js +510 -0
  497. package/dist/workers/keyCodes.js +351 -0
  498. package/dist/workers/keybinding.js +9 -0
  499. package/dist/workers/keybindingCancellation.js +81 -0
  500. package/dist/workers/keybindingLabel.js +122 -0
  501. package/dist/workers/keybindingLabels.js +139 -0
  502. package/dist/workers/keybindingResolver.js +304 -0
  503. package/dist/workers/keybindings.js +104 -0
  504. package/dist/workers/keybindingsRegistry.js +111 -0
  505. package/dist/workers/keyboardEvent.js +125 -0
  506. package/dist/workers/korean.js +321 -0
  507. package/dist/workers/kotlin.contribution.js +9 -0
  508. package/dist/workers/kotlin.js +251 -0
  509. package/dist/workers/label.js +5 -0
  510. package/dist/workers/labels.js +15 -0
  511. package/dist/workers/language.js +9 -0
  512. package/dist/workers/languageBracketsConfiguration.js +133 -0
  513. package/dist/workers/languageConfiguration.js +138 -0
  514. package/dist/workers/languageConfigurationRegistry.js +361 -0
  515. package/dist/workers/languageFeatureDebounce.js +137 -0
  516. package/dist/workers/languageFeatureRegistry.js +180 -0
  517. package/dist/workers/languageFeatures.js +9 -0
  518. package/dist/workers/languageFeaturesService.js +47 -0
  519. package/dist/workers/languageSelector.js +112 -0
  520. package/dist/workers/languageService.js +92 -0
  521. package/dist/workers/languages.js +522 -0
  522. package/dist/workers/languagesAssociations.js +193 -0
  523. package/dist/workers/languagesRegistry.js +237 -0
  524. package/dist/workers/layoutService.js +9 -0
  525. package/dist/workers/lazy.js +49 -0
  526. package/dist/workers/lazyObservableValue.js +125 -0
  527. package/dist/workers/legacyLinesDiffComputer.js +468 -0
  528. package/dist/workers/length.js +129 -0
  529. package/dist/workers/less.contribution.js +9 -0
  530. package/dist/workers/less.js +160 -0
  531. package/dist/workers/lexon.contribution.js +8 -0
  532. package/dist/workers/lexon.js +156 -0
  533. package/dist/workers/lib.index.js +103 -0
  534. package/dist/workers/lib.js +1107 -0
  535. package/dist/workers/lifecycle.js +311 -0
  536. package/dist/workers/lightBulbWidget.js +427 -0
  537. package/dist/workers/lineCommentCommand.js +328 -0
  538. package/dist/workers/lineDecorations.js +208 -0
  539. package/dist/workers/lineEdit.js +75 -0
  540. package/dist/workers/lineHeights.js +370 -0
  541. package/dist/workers/lineNumbers.js +184 -0
  542. package/dist/workers/linePart.js +25 -0
  543. package/dist/workers/lineRange.js +312 -0
  544. package/dist/workers/lineSelection.js +36 -0
  545. package/dist/workers/lineSequence.js +36 -0
  546. package/dist/workers/lineTokens.js +405 -0
  547. package/dist/workers/linesDecorations.js +104 -0
  548. package/dist/workers/linesDiffComputer.js +29 -0
  549. package/dist/workers/linesDiffComputers.js +13 -0
  550. package/dist/workers/linesLayout.js +765 -0
  551. package/dist/workers/linesOperations.js +1187 -0
  552. package/dist/workers/linesSliceCharSequence.js +205 -0
  553. package/dist/workers/link.js +95 -0
  554. package/dist/workers/linkComputer.js +269 -0
  555. package/dist/workers/linkedEditing.js +381 -0
  556. package/dist/workers/linkedList.js +126 -0
  557. package/dist/workers/linkedText.js +48 -0
  558. package/dist/workers/links.js +376 -0
  559. package/dist/workers/liquid.contribution.js +9 -0
  560. package/dist/workers/liquid.js +306 -0
  561. package/dist/workers/list.js +11 -0
  562. package/dist/workers/listColors.js +51 -0
  563. package/dist/workers/listPaging.js +128 -0
  564. package/dist/workers/listService.js +1025 -0
  565. package/dist/workers/listView.js +1173 -0
  566. package/dist/workers/listWidget.js +1535 -0
  567. package/dist/workers/log.js +271 -0
  568. package/dist/workers/logService.js +40 -0
  569. package/dist/workers/logging.js +86 -0
  570. package/dist/workers/longLinesHelper.js +23 -0
  571. package/dist/workers/lspLanguageFeatures.js +716 -0
  572. package/dist/workers/lua.contribution.js +8 -0
  573. package/dist/workers/lua.js +161 -0
  574. package/dist/workers/m3.contribution.js +8 -0
  575. package/dist/workers/m3.js +209 -0
  576. package/dist/workers/map.js +670 -0
  577. package/dist/workers/margin.js +71 -0
  578. package/dist/workers/marginDecorations.js +84 -0
  579. package/dist/workers/markdown.contribution.js +8 -0
  580. package/dist/workers/markdown.js +228 -0
  581. package/dist/workers/markdownHoverParticipant.js +419 -0
  582. package/dist/workers/markdownRenderer.js +73 -0
  583. package/dist/workers/marked.js +2478 -0
  584. package/dist/workers/markerDecorations.js +9 -0
  585. package/dist/workers/markerDecorationsService.js +248 -0
  586. package/dist/workers/markerHoverParticipant.js +270 -0
  587. package/dist/workers/markerNavigationService.js +223 -0
  588. package/dist/workers/markerService.js +330 -0
  589. package/dist/workers/markers.js +127 -0
  590. package/dist/workers/marshalling.js +62 -0
  591. package/dist/workers/mdx.contribution.js +8 -0
  592. package/dist/workers/mdx.js +230 -0
  593. package/dist/workers/menu.js +1147 -0
  594. package/dist/workers/menuColors.js +19 -0
  595. package/dist/workers/menuEntryActionViewItem.js +519 -0
  596. package/dist/workers/menuService.js +436 -0
  597. package/dist/workers/messageController.js +186 -0
  598. package/dist/workers/middleScroll.contribution.js +8 -0
  599. package/dist/workers/middleScrollController.js +128 -0
  600. package/dist/workers/migrateOptions.js +220 -0
  601. package/dist/workers/mime.js +11 -0
  602. package/dist/workers/minimap.js +1662 -0
  603. package/dist/workers/minimapCharRenderer.js +90 -0
  604. package/dist/workers/minimapCharRendererFactory.js +136 -0
  605. package/dist/workers/minimapCharSheet.js +25 -0
  606. package/dist/workers/minimapColors.js +23 -0
  607. package/dist/workers/minimapPreBaked.js +52 -0
  608. package/dist/workers/minimapTokensColorTracker.js +58 -0
  609. package/dist/workers/mips.contribution.js +9 -0
  610. package/dist/workers/mips.js +197 -0
  611. package/dist/workers/mirrorTextModel.js +117 -0
  612. package/dist/workers/miscColors.js +32 -0
  613. package/dist/workers/model.js +9 -0
  614. package/dist/workers/modelLineProjection.js +350 -0
  615. package/dist/workers/modelLineProjectionData.js +297 -0
  616. package/dist/workers/modelService.js +413 -0
  617. package/dist/workers/modesRegistry.js +75 -0
  618. package/dist/workers/monaco.contribution.js +302 -0
  619. package/dist/workers/monarchCommon.js +147 -0
  620. package/dist/workers/monarchCompile.js +546 -0
  621. package/dist/workers/monarchLexer.js +764 -0
  622. package/dist/workers/monospaceLineBreaksComputer.js +473 -0
  623. package/dist/workers/mouseCursor.js +9 -0
  624. package/dist/workers/mouseEvent.js +153 -0
  625. package/dist/workers/mouseHandler.js +539 -0
  626. package/dist/workers/mouseTarget.js +978 -0
  627. package/dist/workers/moveCaretCommand.js +49 -0
  628. package/dist/workers/moveLinesCommand.js +394 -0
  629. package/dist/workers/movedBlocksLinesFeature.js +277 -0
  630. package/dist/workers/msdax.contribution.js +8 -0
  631. package/dist/workers/msdax.js +374 -0
  632. package/dist/workers/multiDiffEditorWidget.js +43 -0
  633. package/dist/workers/multiDiffEditorWidgetImpl.js +427 -0
  634. package/dist/workers/multicursor.js +1004 -0
  635. package/dist/workers/myersDiffAlgorithm.js +159 -0
  636. package/dist/workers/mysql.contribution.js +8 -0
  637. package/dist/workers/mysql.js +877 -0
  638. package/dist/workers/nativeEditContext.js +518 -0
  639. package/dist/workers/nativeEditContextRegistry.js +23 -0
  640. package/dist/workers/nativeEditContextUtils.js +85 -0
  641. package/dist/workers/navigator.js +36 -0
  642. package/dist/workers/network.js +267 -0
  643. package/dist/workers/nls.js +76 -0
  644. package/dist/workers/nls.messages.js +18 -0
  645. package/dist/workers/nodeReader.js +127 -0
  646. package/dist/workers/normalization.js +41 -0
  647. package/dist/workers/notification.js +9 -0
  648. package/dist/workers/nullTokenize.js +29 -0
  649. package/dist/workers/numbers.js +45 -0
  650. package/dist/workers/objectCollectionBuffer.js +102 -0
  651. package/dist/workers/objectPool.js +47 -0
  652. package/dist/workers/objectTree.js +204 -0
  653. package/dist/workers/objectTreeModel.js +220 -0
  654. package/dist/workers/objective-c.contribution.js +8 -0
  655. package/dist/workers/objective-c.js +182 -0
  656. package/dist/workers/objects.js +152 -0
  657. package/dist/workers/observableCodeEditor.js +373 -0
  658. package/dist/workers/observableFromEvent.js +123 -0
  659. package/dist/workers/observableSignal.js +47 -0
  660. package/dist/workers/observableSignalFromEvent.js +41 -0
  661. package/dist/workers/observableValue.js +105 -0
  662. package/dist/workers/observableValueOpts.js +20 -0
  663. package/dist/workers/offsetRange.js +225 -0
  664. package/dist/workers/onEnter.js +109 -0
  665. package/dist/workers/oneCursor.js +117 -0
  666. package/dist/workers/opener.js +43 -0
  667. package/dist/workers/openerService.js +222 -0
  668. package/dist/workers/originalEditorInlineDiffView.js +215 -0
  669. package/dist/workers/outlineModel.js +265 -0
  670. package/dist/workers/overlayWidgets.js +181 -0
  671. package/dist/workers/overviewRuler.js +134 -0
  672. package/dist/workers/overviewRulerFeature.js +168 -0
  673. package/dist/workers/overviewZoneManager.js +176 -0
  674. package/dist/workers/parameterHints.js +126 -0
  675. package/dist/workers/parameterHintsModel.js +258 -0
  676. package/dist/workers/parameterHintsWidget.js +318 -0
  677. package/dist/workers/parser.js +121 -0
  678. package/dist/workers/pascal.contribution.js +9 -0
  679. package/dist/workers/pascal.js +250 -0
  680. package/dist/workers/pascaligo.contribution.js +8 -0
  681. package/dist/workers/pascaligo.js +163 -0
  682. package/dist/workers/path.js +1451 -0
  683. package/dist/workers/peekView.js +246 -0
  684. package/dist/workers/performance.js +222 -0
  685. package/dist/workers/perl.contribution.js +8 -0
  686. package/dist/workers/perl.js +625 -0
  687. package/dist/workers/pgsql.contribution.js +8 -0
  688. package/dist/workers/pgsql.js +850 -0
  689. package/dist/workers/php.contribution.js +9 -0
  690. package/dist/workers/php.js +499 -0
  691. package/dist/workers/pickerQuickAccess.js +271 -0
  692. package/dist/workers/pieceTreeBase.js +1473 -0
  693. package/dist/workers/pieceTreeTextBuffer.js +461 -0
  694. package/dist/workers/pieceTreeTextBufferBuilder.js +140 -0
  695. package/dist/workers/pixelRatio.js +88 -0
  696. package/dist/workers/pla.contribution.js +7 -0
  697. package/dist/workers/pla.js +136 -0
  698. package/dist/workers/placeholderText.contribution.js +14 -0
  699. package/dist/workers/placeholderTextContribution.js +77 -0
  700. package/dist/workers/platform.js +32 -0
  701. package/dist/workers/platformObservableUtils.js +31 -0
  702. package/dist/workers/point.js +50 -0
  703. package/dist/workers/pointerHandler.js +132 -0
  704. package/dist/workers/position.js +142 -0
  705. package/dist/workers/positionToOffset.js +17 -0
  706. package/dist/workers/positionToOffsetImpl.js +98 -0
  707. package/dist/workers/postEditWidget.js +220 -0
  708. package/dist/workers/postiats.contribution.js +8 -0
  709. package/dist/workers/postiats.js +906 -0
  710. package/dist/workers/powerquery.contribution.js +8 -0
  711. package/dist/workers/powerquery.js +889 -0
  712. package/dist/workers/powershell.contribution.js +8 -0
  713. package/dist/workers/powershell.js +238 -0
  714. package/dist/workers/prefixSumComputer.js +226 -0
  715. package/dist/workers/process.js +61 -0
  716. package/dist/workers/product.js +70 -0
  717. package/dist/workers/productService.js +9 -0
  718. package/dist/workers/progress.js +16 -0
  719. package/dist/workers/progressbar.js +105 -0
  720. package/dist/workers/promise.js +56 -0
  721. package/dist/workers/protobuf.contribution.js +8 -0
  722. package/dist/workers/protobuf.js +419 -0
  723. package/dist/workers/provideInlineCompletions.js +372 -0
  724. package/dist/workers/provideSignatureHelp.js +59 -0
  725. package/dist/workers/pug.contribution.js +8 -0
  726. package/dist/workers/pug.js +401 -0
  727. package/dist/workers/python.contribution.js +9 -0
  728. package/dist/workers/python.js +366 -0
  729. package/dist/workers/qsharp.contribution.js +8 -0
  730. package/dist/workers/qsharp.js +300 -0
  731. package/dist/workers/quickAccess.js +56 -0
  732. package/dist/workers/quickInput.js +108 -0
  733. package/dist/workers/quickInputActions.js +189 -0
  734. package/dist/workers/quickInputBox.js +104 -0
  735. package/dist/workers/quickInputController.js +901 -0
  736. package/dist/workers/quickInputDelegate.js +19 -0
  737. package/dist/workers/quickInputList.js +1391 -0
  738. package/dist/workers/quickInputService.js +197 -0
  739. package/dist/workers/quickInputTree.js +37 -0
  740. package/dist/workers/quickInputTreeAccessibilityProvider.js +39 -0
  741. package/dist/workers/quickInputTreeController.js +181 -0
  742. package/dist/workers/quickInputTreeFilter.js +42 -0
  743. package/dist/workers/quickInputTreeRenderer.js +141 -0
  744. package/dist/workers/quickInputTreeSorter.js +48 -0
  745. package/dist/workers/quickInputUtils.js +89 -0
  746. package/dist/workers/quickpickColors.js +21 -0
  747. package/dist/workers/r.contribution.js +8 -0
  748. package/dist/workers/r.js +242 -0
  749. package/dist/workers/range.js +421 -0
  750. package/dist/workers/rangeMap.js +161 -0
  751. package/dist/workers/rangeMapping.js +229 -0
  752. package/dist/workers/rangeSingleLine.js +17 -0
  753. package/dist/workers/rangeUtil.js +117 -0
  754. package/dist/workers/razor.contribution.js +9 -0
  755. package/dist/workers/razor.js +616 -0
  756. package/dist/workers/rbTreeBase.js +362 -0
  757. package/dist/workers/rect.js +163 -0
  758. package/dist/workers/rectangleRenderer.js +214 -0
  759. package/dist/workers/rectangleRenderer.wgsl.js +68 -0
  760. package/dist/workers/redis.contribution.js +8 -0
  761. package/dist/workers/redis.js +301 -0
  762. package/dist/workers/redshift.contribution.js +8 -0
  763. package/dist/workers/redshift.js +808 -0
  764. package/dist/workers/reducer.js +46 -0
  765. package/dist/workers/referencesController.js +382 -0
  766. package/dist/workers/referencesModel.js +241 -0
  767. package/dist/workers/referencesTree.js +200 -0
  768. package/dist/workers/referencesWidget.js +525 -0
  769. package/dist/workers/registrations.contribution.js +82 -0
  770. package/dist/workers/rename.js +458 -0
  771. package/dist/workers/renameWidget.js +741 -0
  772. package/dist/workers/renderLines.js +185 -0
  773. package/dist/workers/renderingContext.js +118 -0
  774. package/dist/workers/replaceAllCommand.js +54 -0
  775. package/dist/workers/replaceCommand.js +158 -0
  776. package/dist/workers/replaceInput.js +176 -0
  777. package/dist/workers/replacePattern.js +289 -0
  778. package/dist/workers/replaceWidgetHistory.js +85 -0
  779. package/dist/workers/resizable.js +150 -0
  780. package/dist/workers/resizableContentWidget.js +92 -0
  781. package/dist/workers/resolvedKeybindingItem.js +35 -0
  782. package/dist/workers/resolverService.js +5 -0
  783. package/dist/workers/resources.js +231 -0
  784. package/dist/workers/restructuredtext.contribution.js +8 -0
  785. package/dist/workers/restructuredtext.js +173 -0
  786. package/dist/workers/revertButtonsFeature.js +149 -0
  787. package/dist/workers/rgba.js +35 -0
  788. package/dist/workers/richEditBrackets.js +356 -0
  789. package/dist/workers/rowCache.js +110 -0
  790. package/dist/workers/rpc.js +57 -0
  791. package/dist/workers/ruby.contribution.js +9 -0
  792. package/dist/workers/ruby.js +510 -0
  793. package/dist/workers/rulers.js +82 -0
  794. package/dist/workers/rulersGpu.js +66 -0
  795. package/dist/workers/runOnChange.js +61 -0
  796. package/dist/workers/rust.contribution.js +8 -0
  797. package/dist/workers/rust.js +342 -0
  798. package/dist/workers/sash.js +451 -0
  799. package/dist/workers/sb.contribution.js +8 -0
  800. package/dist/workers/sb.js +114 -0
  801. package/dist/workers/scala.contribution.js +9 -0
  802. package/dist/workers/scala.js +369 -0
  803. package/dist/workers/scanner.js +287 -0
  804. package/dist/workers/scheme.contribution.js +8 -0
  805. package/dist/workers/scheme.js +107 -0
  806. package/dist/workers/screenReaderContentRich.js +337 -0
  807. package/dist/workers/screenReaderContentSimple.js +194 -0
  808. package/dist/workers/screenReaderSupport.js +175 -0
  809. package/dist/workers/screenReaderUtils.js +111 -0
  810. package/dist/workers/scrollDecoration.js +70 -0
  811. package/dist/workers/scrollable.js +323 -0
  812. package/dist/workers/scrollableElement.js +603 -0
  813. package/dist/workers/scrollbarArrow.js +78 -0
  814. package/dist/workers/scrollbarState.js +163 -0
  815. package/dist/workers/scrollbarVisibilityController.js +93 -0
  816. package/dist/workers/scss.contribution.js +9 -0
  817. package/dist/workers/scss.js +259 -0
  818. package/dist/workers/search.js +52 -0
  819. package/dist/workers/searchColors.js +13 -0
  820. package/dist/workers/sectionHeaders.js +179 -0
  821. package/dist/workers/selectBox.js +47 -0
  822. package/dist/workers/selectBoxCustom.js +858 -0
  823. package/dist/workers/selectBoxNative.js +142 -0
  824. package/dist/workers/selection.js +145 -0
  825. package/dist/workers/selections.js +338 -0
  826. package/dist/workers/semanticTokensConfig.js +14 -0
  827. package/dist/workers/semanticTokensDto.js +82 -0
  828. package/dist/workers/semanticTokensProviderStyling.js +263 -0
  829. package/dist/workers/semanticTokensStyling.js +9 -0
  830. package/dist/workers/semanticTokensStylingService.js +47 -0
  831. package/dist/workers/serviceCollection.js +22 -0
  832. package/dist/workers/severity.js +52 -0
  833. package/dist/workers/severityIcon.js +29 -0
  834. package/dist/workers/shell.contribution.js +8 -0
  835. package/dist/workers/shell.js +220 -0
  836. package/dist/workers/shiftCommand.js +241 -0
  837. package/dist/workers/singleTextEditHelpers.js +32 -0
  838. package/dist/workers/smallImmutableSet.js +108 -0
  839. package/dist/workers/smartSelect.js +281 -0
  840. package/dist/workers/snippetController2.js +297 -0
  841. package/dist/workers/snippetParser.js +890 -0
  842. package/dist/workers/snippetSession.js +650 -0
  843. package/dist/workers/snippetVariables.js +323 -0
  844. package/dist/workers/solidity.contribution.js +8 -0
  845. package/dist/workers/solidity.js +1366 -0
  846. package/dist/workers/sophia.contribution.js +8 -0
  847. package/dist/workers/sophia.js +198 -0
  848. package/dist/workers/sortLinesCommand.js +81 -0
  849. package/dist/workers/sparql.contribution.js +8 -0
  850. package/dist/workers/sparql.js +200 -0
  851. package/dist/workers/sparseMultilineTokens.js +548 -0
  852. package/dist/workers/sparseTokensStore.js +210 -0
  853. package/dist/workers/splice.js +14 -0
  854. package/dist/workers/splitview.js +829 -0
  855. package/dist/workers/sql.contribution.js +8 -0
  856. package/dist/workers/sql.js +852 -0
  857. package/dist/workers/st.contribution.js +8 -0
  858. package/dist/workers/st.js +415 -0
  859. package/dist/workers/stableEditorScroll.js +52 -0
  860. package/dist/workers/standaloneCodeEditor.js +335 -0
  861. package/dist/workers/standaloneCodeEditorService.js +96 -0
  862. package/dist/workers/standaloneColorPickerActions.js +81 -0
  863. package/dist/workers/standaloneColorPickerController.js +62 -0
  864. package/dist/workers/standaloneColorPickerParticipant.js +117 -0
  865. package/dist/workers/standaloneColorPickerWidget.js +215 -0
  866. package/dist/workers/standaloneCommandsQuickAccess.js +82 -0
  867. package/dist/workers/standaloneEditor.js +519 -0
  868. package/dist/workers/standaloneEnums.js +1017 -0
  869. package/dist/workers/standaloneGotoLineQuickAccess.js +67 -0
  870. package/dist/workers/standaloneGotoSymbolQuickAccess.js +77 -0
  871. package/dist/workers/standaloneHelpQuickAccess.js +14 -0
  872. package/dist/workers/standaloneLanguages.js +621 -0
  873. package/dist/workers/standaloneLayoutService.js +74 -0
  874. package/dist/workers/standaloneQuickInputService.js +150 -0
  875. package/dist/workers/standaloneReferenceSearch.js +38 -0
  876. package/dist/workers/standaloneServices.js +787 -0
  877. package/dist/workers/standaloneStrings.js +42 -0
  878. package/dist/workers/standaloneTheme.js +9 -0
  879. package/dist/workers/standaloneThemeService.js +367 -0
  880. package/dist/workers/standaloneTreeSitterLibraryService.js +23 -0
  881. package/dist/workers/standaloneWebWorker.js +55 -0
  882. package/dist/workers/stickyScrollActions.js +132 -0
  883. package/dist/workers/stickyScrollContribution.js +16 -0
  884. package/dist/workers/stickyScrollController.js +566 -0
  885. package/dist/workers/stickyScrollElement.js +39 -0
  886. package/dist/workers/stickyScrollModelProvider.js +338 -0
  887. package/dist/workers/stickyScrollProvider.js +197 -0
  888. package/dist/workers/stickyScrollWidget.js +474 -0
  889. package/dist/workers/stopwatch.js +30 -0
  890. package/dist/workers/storage.js +200 -0
  891. package/dist/workers/stringBuilder.js +122 -0
  892. package/dist/workers/stringEdit.js +165 -0
  893. package/dist/workers/strings.js +834 -0
  894. package/dist/workers/structuredLogger.js +56 -0
  895. package/dist/workers/suggest.js +322 -0
  896. package/dist/workers/suggestAlternatives.js +95 -0
  897. package/dist/workers/suggestCommitCharacters.js +59 -0
  898. package/dist/workers/suggestController.js +941 -0
  899. package/dist/workers/suggestInlineCompletions.js +193 -0
  900. package/dist/workers/suggestMemory.js +254 -0
  901. package/dist/workers/suggestModel.js +667 -0
  902. package/dist/workers/suggestOvertypingCapturer.js +62 -0
  903. package/dist/workers/suggestWidget.js +890 -0
  904. package/dist/workers/suggestWidgetAdapter.js +210 -0
  905. package/dist/workers/suggestWidgetDetails.js +393 -0
  906. package/dist/workers/suggestWidgetRenderer.js +208 -0
  907. package/dist/workers/suggestWidgetStatus.js +74 -0
  908. package/dist/workers/supports.js +58 -0
  909. package/dist/workers/surroundSelectionCommand.js +44 -0
  910. package/dist/workers/swift.contribution.js +9 -0
  911. package/dist/workers/swift.js +311 -0
  912. package/dist/workers/symbolIcons.js +101 -0
  913. package/dist/workers/symbolNavigation.js +178 -0
  914. package/dist/workers/symbols.js +10 -0
  915. package/dist/workers/syntaxRangeProvider.js +177 -0
  916. package/dist/workers/systemverilog.contribution.js +14 -0
  917. package/dist/workers/systemverilog.js +575 -0
  918. package/dist/workers/tabFocus.js +29 -0
  919. package/dist/workers/tableWidget.js +181 -0
  920. package/dist/workers/taskQueue.js +116 -0
  921. package/dist/workers/tcl.contribution.js +8 -0
  922. package/dist/workers/tcl.js +231 -0
  923. package/dist/workers/telemetry.js +9 -0
  924. package/dist/workers/ternarySearchTree.js +674 -0
  925. package/dist/workers/textAreaEditContext.js +720 -0
  926. package/dist/workers/textAreaEditContextInput.js +588 -0
  927. package/dist/workers/textAreaEditContextState.js +160 -0
  928. package/dist/workers/textChange.js +248 -0
  929. package/dist/workers/textEdit.js +269 -0
  930. package/dist/workers/textLength.js +87 -0
  931. package/dist/workers/textModel.js +2031 -0
  932. package/dist/workers/textModelBracketPairs.js +45 -0
  933. package/dist/workers/textModelDefaults.js +18 -0
  934. package/dist/workers/textModelEditSource.js +166 -0
  935. package/dist/workers/textModelEvents.js +216 -0
  936. package/dist/workers/textModelGuides.js +40 -0
  937. package/dist/workers/textModelPart.js +23 -0
  938. package/dist/workers/textModelSearch.js +455 -0
  939. package/dist/workers/textModelStringEdit.js +11 -0
  940. package/dist/workers/textModelSync.impl.js +307 -0
  941. package/dist/workers/textModelText.js +26 -0
  942. package/dist/workers/textModelTokens.js +436 -0
  943. package/dist/workers/textResourceConfiguration.js +6 -0
  944. package/dist/workers/textToHtmlTokenizer.js +139 -0
  945. package/dist/workers/textualHighlightProvider.js +78 -0
  946. package/dist/workers/textureAtlas.js +179 -0
  947. package/dist/workers/textureAtlasPage.js +110 -0
  948. package/dist/workers/textureAtlasShelfAllocator.js +129 -0
  949. package/dist/workers/textureAtlasSlabAllocator.js +346 -0
  950. package/dist/workers/tfIdf.js +179 -0
  951. package/dist/workers/themables.js +100 -0
  952. package/dist/workers/theme.js +110 -0
  953. package/dist/workers/themeService.js +67 -0
  954. package/dist/workers/themes.js +242 -0
  955. package/dist/workers/toggle.js +242 -0
  956. package/dist/workers/toggleHighContrast.js +35 -0
  957. package/dist/workers/toggleTabFocusMode.js +42 -0
  958. package/dist/workers/tokenStore.js +407 -0
  959. package/dist/workers/tokenWithTextArray.js +73 -0
  960. package/dist/workers/tokenization.js +29 -0
  961. package/dist/workers/tokenizationRegistry.js +123 -0
  962. package/dist/workers/tokenizationTextModelPart.js +275 -0
  963. package/dist/workers/tokenizer.js +301 -0
  964. package/dist/workers/tokenizerSyntaxTokenBackend.js +261 -0
  965. package/dist/workers/toolbar.js +244 -0
  966. package/dist/workers/touch.js +270 -0
  967. package/dist/workers/transaction.js +109 -0
  968. package/dist/workers/transpose.js +65 -0
  969. package/dist/workers/tree.js +45 -0
  970. package/dist/workers/treeSitterLibraryService.js +9 -0
  971. package/dist/workers/treeSitterSyntaxTokenBackend.js +167 -0
  972. package/dist/workers/treeSitterThemeService.js +9 -0
  973. package/dist/workers/treeSitterTokenizationImpl.js +713 -0
  974. package/dist/workers/treeSitterTree.js +395 -0
  975. package/dist/workers/treeViewsDnd.js +24 -0
  976. package/dist/workers/treeViewsDndService.js +12 -0
  977. package/dist/workers/triggerInlineEditCommandsRegistry.js +18 -0
  978. package/dist/workers/trimTrailingWhitespaceCommand.js +98 -0
  979. package/dist/workers/trustedTypes.js +29 -0
  980. package/dist/workers/tsMode.js +212 -0
  981. package/dist/workers/tsWorker.js +352 -0
  982. package/dist/workers/twig.contribution.js +9 -0
  983. package/dist/workers/twig.js +391 -0
  984. package/dist/workers/types.js +144 -0
  985. package/dist/workers/typescript.contribution.js +11 -0
  986. package/dist/workers/typescript.js +408 -0
  987. package/dist/workers/typescriptServices.js +210154 -0
  988. package/dist/workers/typescriptServicesMetadata.js +3 -0
  989. package/dist/workers/typespec.contribution.js +8 -0
  990. package/dist/workers/typespec.js +126 -0
  991. package/dist/workers/typingSpeed.js +165 -0
  992. package/dist/workers/uint.js +24 -0
  993. package/dist/workers/undoRedo.js +43 -0
  994. package/dist/workers/undoRedoService.js +1076 -0
  995. package/dist/workers/unicodeHighlighter.js +673 -0
  996. package/dist/workers/unicodeTextModelHighlighter.js +188 -0
  997. package/dist/workers/unusualLineTerminators.js +113 -0
  998. package/dist/workers/updatableHoverWidget.js +107 -0
  999. package/dist/workers/uri.js +606 -0
  1000. package/dist/workers/usLayoutResolvedKeybinding.js +175 -0
  1001. package/dist/workers/utils.js +209 -0
  1002. package/dist/workers/utilsCancellation.js +63 -0
  1003. package/dist/workers/uuid.js +53 -0
  1004. package/dist/workers/validation.js +159 -0
  1005. package/dist/workers/vb.contribution.js +8 -0
  1006. package/dist/workers/vb.js +371 -0
  1007. package/dist/workers/verticalScrollbar.js +94 -0
  1008. package/dist/workers/view.js +720 -0
  1009. package/dist/workers/viewContext.js +22 -0
  1010. package/dist/workers/viewController.js +274 -0
  1011. package/dist/workers/viewCursor.js +218 -0
  1012. package/dist/workers/viewCursors.js +339 -0
  1013. package/dist/workers/viewEventHandler.js +186 -0
  1014. package/dist/workers/viewEvents.js +180 -0
  1015. package/dist/workers/viewGpuContext.js +241 -0
  1016. package/dist/workers/viewLayer.js +478 -0
  1017. package/dist/workers/viewLayout.js +368 -0
  1018. package/dist/workers/viewLine.js +544 -0
  1019. package/dist/workers/viewLineOptions.js +43 -0
  1020. package/dist/workers/viewLineRenderer.js +948 -0
  1021. package/dist/workers/viewLines.js +721 -0
  1022. package/dist/workers/viewLinesGpu.js +571 -0
  1023. package/dist/workers/viewLinesViewportData.js +30 -0
  1024. package/dist/workers/viewModel.js +98 -0
  1025. package/dist/workers/viewModelDecoration.js +55 -0
  1026. package/dist/workers/viewModelDecorations.js +132 -0
  1027. package/dist/workers/viewModelEventDispatcher.js +398 -0
  1028. package/dist/workers/viewModelImpl.js +1163 -0
  1029. package/dist/workers/viewModelLines.js +938 -0
  1030. package/dist/workers/viewOverlays.js +204 -0
  1031. package/dist/workers/viewPart.js +49 -0
  1032. package/dist/workers/viewUserInputEvents.js +91 -0
  1033. package/dist/workers/viewZones.js +335 -0
  1034. package/dist/workers/viewportRenderStrategy.js +316 -0
  1035. package/dist/workers/viewportSemanticTokens.js +166 -0
  1036. package/dist/workers/webWorker.js +396 -0
  1037. package/dist/workers/webWorkerBootstrap.js +20 -0
  1038. package/dist/workers/webWorkerFactory.js +171 -0
  1039. package/dist/workers/wgsl.contribution.js +8 -0
  1040. package/dist/workers/wgsl.js +452 -0
  1041. package/dist/workers/whitespace.js +277 -0
  1042. package/dist/workers/widget.js +44 -0
  1043. package/dist/workers/window.js +60 -0
  1044. package/dist/workers/wordCharacterClassifier.js +87 -0
  1045. package/dist/workers/wordContextKey.js +69 -0
  1046. package/dist/workers/wordDistance.js +64 -0
  1047. package/dist/workers/wordHelper.js +127 -0
  1048. package/dist/workers/wordHighlighter.js +796 -0
  1049. package/dist/workers/wordOperations.js +442 -0
  1050. package/dist/workers/wordPartOperations.js +145 -0
  1051. package/dist/workers/wordSelections.js +82 -0
  1052. package/dist/workers/workerManager.js +147 -0
  1053. package/dist/workers/workers.js +141 -0
  1054. package/dist/workers/workspace.js +84 -0
  1055. package/dist/workers/workspaceTrust.js +9 -0
  1056. package/dist/workers/wrapInHotClass.js +41 -0
  1057. package/dist/workers/wrapInReloadableClass.js +35 -0
  1058. package/dist/workers/xml.contribution.js +28 -0
  1059. package/dist/workers/xml.js +160 -0
  1060. package/dist/workers/yaml.contribution.js +9 -0
  1061. package/dist/workers/yaml.js +271 -0
  1062. package/dist/workers/zoneWidget.js +406 -0
  1063. package/package.json +2 -2
  1064. package/dist/assets/css.worker-C7FogG4G.js +0 -93
  1065. package/dist/assets/editor.worker-iXcRX1Tq.js +0 -26
  1066. package/dist/assets/html.worker-C8VxctEJ.js +0 -470
  1067. package/dist/assets/json.worker-CMC9kgPL.js +0 -58
  1068. package/dist/assets/ts.worker-CtTJ3hNN.js +0 -67731
@@ -0,0 +1,1473 @@
1
+ import { Position } from '../../core/position.js';
2
+ import { Range } from '../../core/range.js';
3
+ import { FindMatch } from '../../model.js';
4
+ import { SENTINEL, rbDelete, updateTreeMetadata, TreeNode, leftest, fixInsert, righttest } from './rbTreeBase.js';
5
+ import { createFindMatch, Searcher, isValidMatch } from '../textModelSearch.js';
6
+
7
+ /*---------------------------------------------------------------------------------------------
8
+ * Copyright (c) Microsoft Corporation. All rights reserved.
9
+ * Licensed under the MIT License. See License.txt in the project root for license information.
10
+ *--------------------------------------------------------------------------------------------*/
11
+ // const lfRegex = new RegExp(/\r\n|\r|\n/g);
12
+ const AverageBufferSize = 65535;
13
+ function createUintArray(arr) {
14
+ let r;
15
+ if (arr[arr.length - 1] < 65536) {
16
+ r = new Uint16Array(arr.length);
17
+ }
18
+ else {
19
+ r = new Uint32Array(arr.length);
20
+ }
21
+ r.set(arr, 0);
22
+ return r;
23
+ }
24
+ class LineStarts {
25
+ constructor(lineStarts, cr, lf, crlf, isBasicASCII) {
26
+ this.lineStarts = lineStarts;
27
+ this.cr = cr;
28
+ this.lf = lf;
29
+ this.crlf = crlf;
30
+ this.isBasicASCII = isBasicASCII;
31
+ }
32
+ }
33
+ function createLineStartsFast(str, readonly = true) {
34
+ const r = [0];
35
+ let rLength = 1;
36
+ for (let i = 0, len = str.length; i < len; i++) {
37
+ const chr = str.charCodeAt(i);
38
+ if (chr === 13 /* CharCode.CarriageReturn */) {
39
+ if (i + 1 < len && str.charCodeAt(i + 1) === 10 /* CharCode.LineFeed */) {
40
+ // \r\n... case
41
+ r[rLength++] = i + 2;
42
+ i++; // skip \n
43
+ }
44
+ else {
45
+ // \r... case
46
+ r[rLength++] = i + 1;
47
+ }
48
+ }
49
+ else if (chr === 10 /* CharCode.LineFeed */) {
50
+ r[rLength++] = i + 1;
51
+ }
52
+ }
53
+ if (readonly) {
54
+ return createUintArray(r);
55
+ }
56
+ else {
57
+ return r;
58
+ }
59
+ }
60
+ function createLineStarts(r, str) {
61
+ r.length = 0;
62
+ r[0] = 0;
63
+ let rLength = 1;
64
+ let cr = 0, lf = 0, crlf = 0;
65
+ let isBasicASCII = true;
66
+ for (let i = 0, len = str.length; i < len; i++) {
67
+ const chr = str.charCodeAt(i);
68
+ if (chr === 13 /* CharCode.CarriageReturn */) {
69
+ if (i + 1 < len && str.charCodeAt(i + 1) === 10 /* CharCode.LineFeed */) {
70
+ // \r\n... case
71
+ crlf++;
72
+ r[rLength++] = i + 2;
73
+ i++; // skip \n
74
+ }
75
+ else {
76
+ cr++;
77
+ // \r... case
78
+ r[rLength++] = i + 1;
79
+ }
80
+ }
81
+ else if (chr === 10 /* CharCode.LineFeed */) {
82
+ lf++;
83
+ r[rLength++] = i + 1;
84
+ }
85
+ else {
86
+ if (isBasicASCII) {
87
+ if (chr !== 9 /* CharCode.Tab */ && (chr < 32 || chr > 126)) {
88
+ isBasicASCII = false;
89
+ }
90
+ }
91
+ }
92
+ }
93
+ const result = new LineStarts(createUintArray(r), cr, lf, crlf, isBasicASCII);
94
+ r.length = 0;
95
+ return result;
96
+ }
97
+ class Piece {
98
+ constructor(bufferIndex, start, end, lineFeedCnt, length) {
99
+ this.bufferIndex = bufferIndex;
100
+ this.start = start;
101
+ this.end = end;
102
+ this.lineFeedCnt = lineFeedCnt;
103
+ this.length = length;
104
+ }
105
+ }
106
+ class StringBuffer {
107
+ constructor(buffer, lineStarts) {
108
+ this.buffer = buffer;
109
+ this.lineStarts = lineStarts;
110
+ }
111
+ }
112
+ /**
113
+ * Readonly snapshot for piece tree.
114
+ * In a real multiple thread environment, to make snapshot reading always work correctly, we need to
115
+ * 1. Make TreeNode.piece immutable, then reading and writing can run in parallel.
116
+ * 2. TreeNode/Buffers normalization should not happen during snapshot reading.
117
+ */
118
+ class PieceTreeSnapshot {
119
+ constructor(tree, BOM) {
120
+ this._pieces = [];
121
+ this._tree = tree;
122
+ this._BOM = BOM;
123
+ this._index = 0;
124
+ if (tree.root !== SENTINEL) {
125
+ tree.iterate(tree.root, node => {
126
+ if (node !== SENTINEL) {
127
+ this._pieces.push(node.piece);
128
+ }
129
+ return true;
130
+ });
131
+ }
132
+ }
133
+ read() {
134
+ if (this._pieces.length === 0) {
135
+ if (this._index === 0) {
136
+ this._index++;
137
+ return this._BOM;
138
+ }
139
+ else {
140
+ return null;
141
+ }
142
+ }
143
+ if (this._index > this._pieces.length - 1) {
144
+ return null;
145
+ }
146
+ if (this._index === 0) {
147
+ return this._BOM + this._tree.getPieceContent(this._pieces[this._index++]);
148
+ }
149
+ return this._tree.getPieceContent(this._pieces[this._index++]);
150
+ }
151
+ }
152
+ class PieceTreeSearchCache {
153
+ constructor(limit) {
154
+ this._limit = limit;
155
+ this._cache = [];
156
+ }
157
+ get(offset) {
158
+ for (let i = this._cache.length - 1; i >= 0; i--) {
159
+ const nodePos = this._cache[i];
160
+ if (nodePos.nodeStartOffset <= offset && nodePos.nodeStartOffset + nodePos.node.piece.length >= offset) {
161
+ return nodePos;
162
+ }
163
+ }
164
+ return null;
165
+ }
166
+ get2(lineNumber) {
167
+ for (let i = this._cache.length - 1; i >= 0; i--) {
168
+ const nodePos = this._cache[i];
169
+ if (nodePos.nodeStartLineNumber && nodePos.nodeStartLineNumber < lineNumber && nodePos.nodeStartLineNumber + nodePos.node.piece.lineFeedCnt >= lineNumber) {
170
+ return nodePos;
171
+ }
172
+ }
173
+ return null;
174
+ }
175
+ set(nodePosition) {
176
+ if (this._cache.length >= this._limit) {
177
+ this._cache.shift();
178
+ }
179
+ this._cache.push(nodePosition);
180
+ }
181
+ validate(offset) {
182
+ let hasInvalidVal = false;
183
+ const tmp = this._cache;
184
+ for (let i = 0; i < tmp.length; i++) {
185
+ const nodePos = tmp[i];
186
+ if (nodePos.node.parent === null || nodePos.nodeStartOffset >= offset) {
187
+ tmp[i] = null;
188
+ hasInvalidVal = true;
189
+ continue;
190
+ }
191
+ }
192
+ if (hasInvalidVal) {
193
+ const newArr = [];
194
+ for (const entry of tmp) {
195
+ if (entry !== null) {
196
+ newArr.push(entry);
197
+ }
198
+ }
199
+ this._cache = newArr;
200
+ }
201
+ }
202
+ }
203
+ class PieceTreeBase {
204
+ constructor(chunks, eol, eolNormalized) {
205
+ this.create(chunks, eol, eolNormalized);
206
+ }
207
+ create(chunks, eol, eolNormalized) {
208
+ this._buffers = [
209
+ new StringBuffer('', [0])
210
+ ];
211
+ this._lastChangeBufferPos = { line: 0, column: 0 };
212
+ this.root = SENTINEL;
213
+ this._lineCnt = 1;
214
+ this._length = 0;
215
+ this._EOL = eol;
216
+ this._EOLLength = eol.length;
217
+ this._EOLNormalized = eolNormalized;
218
+ let lastNode = null;
219
+ for (let i = 0, len = chunks.length; i < len; i++) {
220
+ if (chunks[i].buffer.length > 0) {
221
+ if (!chunks[i].lineStarts) {
222
+ chunks[i].lineStarts = createLineStartsFast(chunks[i].buffer);
223
+ }
224
+ const piece = new Piece(i + 1, { line: 0, column: 0 }, { line: chunks[i].lineStarts.length - 1, column: chunks[i].buffer.length - chunks[i].lineStarts[chunks[i].lineStarts.length - 1] }, chunks[i].lineStarts.length - 1, chunks[i].buffer.length);
225
+ this._buffers.push(chunks[i]);
226
+ lastNode = this.rbInsertRight(lastNode, piece);
227
+ }
228
+ }
229
+ this._searchCache = new PieceTreeSearchCache(1);
230
+ this._lastVisitedLine = { lineNumber: 0, value: '' };
231
+ this.computeBufferMetadata();
232
+ }
233
+ normalizeEOL(eol) {
234
+ const averageBufferSize = AverageBufferSize;
235
+ const min = averageBufferSize - Math.floor(averageBufferSize / 3);
236
+ const max = min * 2;
237
+ let tempChunk = '';
238
+ let tempChunkLen = 0;
239
+ const chunks = [];
240
+ this.iterate(this.root, node => {
241
+ const str = this.getNodeContent(node);
242
+ const len = str.length;
243
+ if (tempChunkLen <= min || tempChunkLen + len < max) {
244
+ tempChunk += str;
245
+ tempChunkLen += len;
246
+ return true;
247
+ }
248
+ // flush anyways
249
+ const text = tempChunk.replace(/\r\n|\r|\n/g, eol);
250
+ chunks.push(new StringBuffer(text, createLineStartsFast(text)));
251
+ tempChunk = str;
252
+ tempChunkLen = len;
253
+ return true;
254
+ });
255
+ if (tempChunkLen > 0) {
256
+ const text = tempChunk.replace(/\r\n|\r|\n/g, eol);
257
+ chunks.push(new StringBuffer(text, createLineStartsFast(text)));
258
+ }
259
+ this.create(chunks, eol, true);
260
+ }
261
+ // #region Buffer API
262
+ getEOL() {
263
+ return this._EOL;
264
+ }
265
+ setEOL(newEOL) {
266
+ this._EOL = newEOL;
267
+ this._EOLLength = this._EOL.length;
268
+ this.normalizeEOL(newEOL);
269
+ }
270
+ createSnapshot(BOM) {
271
+ return new PieceTreeSnapshot(this, BOM);
272
+ }
273
+ getOffsetAt(lineNumber, column) {
274
+ let leftLen = 0; // inorder
275
+ let x = this.root;
276
+ while (x !== SENTINEL) {
277
+ if (x.left !== SENTINEL && x.lf_left + 1 >= lineNumber) {
278
+ x = x.left;
279
+ }
280
+ else if (x.lf_left + x.piece.lineFeedCnt + 1 >= lineNumber) {
281
+ leftLen += x.size_left;
282
+ // lineNumber >= 2
283
+ const accumualtedValInCurrentIndex = this.getAccumulatedValue(x, lineNumber - x.lf_left - 2);
284
+ return leftLen += accumualtedValInCurrentIndex + column - 1;
285
+ }
286
+ else {
287
+ lineNumber -= x.lf_left + x.piece.lineFeedCnt;
288
+ leftLen += x.size_left + x.piece.length;
289
+ x = x.right;
290
+ }
291
+ }
292
+ return leftLen;
293
+ }
294
+ getPositionAt(offset) {
295
+ offset = Math.floor(offset);
296
+ offset = Math.max(0, offset);
297
+ let x = this.root;
298
+ let lfCnt = 0;
299
+ const originalOffset = offset;
300
+ while (x !== SENTINEL) {
301
+ if (x.size_left !== 0 && x.size_left >= offset) {
302
+ x = x.left;
303
+ }
304
+ else if (x.size_left + x.piece.length >= offset) {
305
+ const out = this.getIndexOf(x, offset - x.size_left);
306
+ lfCnt += x.lf_left + out.index;
307
+ if (out.index === 0) {
308
+ const lineStartOffset = this.getOffsetAt(lfCnt + 1, 1);
309
+ const column = originalOffset - lineStartOffset;
310
+ return new Position(lfCnt + 1, column + 1);
311
+ }
312
+ return new Position(lfCnt + 1, out.remainder + 1);
313
+ }
314
+ else {
315
+ offset -= x.size_left + x.piece.length;
316
+ lfCnt += x.lf_left + x.piece.lineFeedCnt;
317
+ if (x.right === SENTINEL) {
318
+ // last node
319
+ const lineStartOffset = this.getOffsetAt(lfCnt + 1, 1);
320
+ const column = originalOffset - offset - lineStartOffset;
321
+ return new Position(lfCnt + 1, column + 1);
322
+ }
323
+ else {
324
+ x = x.right;
325
+ }
326
+ }
327
+ }
328
+ return new Position(1, 1);
329
+ }
330
+ getValueInRange(range, eol) {
331
+ if (range.startLineNumber === range.endLineNumber && range.startColumn === range.endColumn) {
332
+ return '';
333
+ }
334
+ const startPosition = this.nodeAt2(range.startLineNumber, range.startColumn);
335
+ const endPosition = this.nodeAt2(range.endLineNumber, range.endColumn);
336
+ const value = this.getValueInRange2(startPosition, endPosition);
337
+ if (eol) {
338
+ if (eol !== this._EOL || !this._EOLNormalized) {
339
+ return value.replace(/\r\n|\r|\n/g, eol);
340
+ }
341
+ if (eol === this.getEOL() && this._EOLNormalized) {
342
+ return value;
343
+ }
344
+ return value.replace(/\r\n|\r|\n/g, eol);
345
+ }
346
+ return value;
347
+ }
348
+ getValueInRange2(startPosition, endPosition) {
349
+ if (startPosition.node === endPosition.node) {
350
+ const node = startPosition.node;
351
+ const buffer = this._buffers[node.piece.bufferIndex].buffer;
352
+ const startOffset = this.offsetInBuffer(node.piece.bufferIndex, node.piece.start);
353
+ return buffer.substring(startOffset + startPosition.remainder, startOffset + endPosition.remainder);
354
+ }
355
+ let x = startPosition.node;
356
+ const buffer = this._buffers[x.piece.bufferIndex].buffer;
357
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
358
+ let ret = buffer.substring(startOffset + startPosition.remainder, startOffset + x.piece.length);
359
+ x = x.next();
360
+ while (x !== SENTINEL) {
361
+ const buffer = this._buffers[x.piece.bufferIndex].buffer;
362
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
363
+ if (x === endPosition.node) {
364
+ ret += buffer.substring(startOffset, startOffset + endPosition.remainder);
365
+ break;
366
+ }
367
+ else {
368
+ ret += buffer.substr(startOffset, x.piece.length);
369
+ }
370
+ x = x.next();
371
+ }
372
+ return ret;
373
+ }
374
+ getLinesContent() {
375
+ const lines = [];
376
+ let linesLength = 0;
377
+ let currentLine = '';
378
+ let danglingCR = false;
379
+ this.iterate(this.root, node => {
380
+ if (node === SENTINEL) {
381
+ return true;
382
+ }
383
+ const piece = node.piece;
384
+ let pieceLength = piece.length;
385
+ if (pieceLength === 0) {
386
+ return true;
387
+ }
388
+ const buffer = this._buffers[piece.bufferIndex].buffer;
389
+ const lineStarts = this._buffers[piece.bufferIndex].lineStarts;
390
+ const pieceStartLine = piece.start.line;
391
+ const pieceEndLine = piece.end.line;
392
+ let pieceStartOffset = lineStarts[pieceStartLine] + piece.start.column;
393
+ if (danglingCR) {
394
+ if (buffer.charCodeAt(pieceStartOffset) === 10 /* CharCode.LineFeed */) {
395
+ // pretend the \n was in the previous piece..
396
+ pieceStartOffset++;
397
+ pieceLength--;
398
+ }
399
+ lines[linesLength++] = currentLine;
400
+ currentLine = '';
401
+ danglingCR = false;
402
+ if (pieceLength === 0) {
403
+ return true;
404
+ }
405
+ }
406
+ if (pieceStartLine === pieceEndLine) {
407
+ // this piece has no new lines
408
+ if (!this._EOLNormalized && buffer.charCodeAt(pieceStartOffset + pieceLength - 1) === 13 /* CharCode.CarriageReturn */) {
409
+ danglingCR = true;
410
+ currentLine += buffer.substr(pieceStartOffset, pieceLength - 1);
411
+ }
412
+ else {
413
+ currentLine += buffer.substr(pieceStartOffset, pieceLength);
414
+ }
415
+ return true;
416
+ }
417
+ // add the text before the first line start in this piece
418
+ currentLine += (this._EOLNormalized
419
+ ? buffer.substring(pieceStartOffset, Math.max(pieceStartOffset, lineStarts[pieceStartLine + 1] - this._EOLLength))
420
+ : buffer.substring(pieceStartOffset, lineStarts[pieceStartLine + 1]).replace(/(\r\n|\r|\n)$/, ''));
421
+ lines[linesLength++] = currentLine;
422
+ for (let line = pieceStartLine + 1; line < pieceEndLine; line++) {
423
+ currentLine = (this._EOLNormalized
424
+ ? buffer.substring(lineStarts[line], lineStarts[line + 1] - this._EOLLength)
425
+ : buffer.substring(lineStarts[line], lineStarts[line + 1]).replace(/(\r\n|\r|\n)$/, ''));
426
+ lines[linesLength++] = currentLine;
427
+ }
428
+ if (!this._EOLNormalized && buffer.charCodeAt(lineStarts[pieceEndLine] + piece.end.column - 1) === 13 /* CharCode.CarriageReturn */) {
429
+ danglingCR = true;
430
+ if (piece.end.column === 0) {
431
+ // The last line ended with a \r, let's undo the push, it will be pushed by next iteration
432
+ linesLength--;
433
+ }
434
+ else {
435
+ currentLine = buffer.substr(lineStarts[pieceEndLine], piece.end.column - 1);
436
+ }
437
+ }
438
+ else {
439
+ currentLine = buffer.substr(lineStarts[pieceEndLine], piece.end.column);
440
+ }
441
+ return true;
442
+ });
443
+ if (danglingCR) {
444
+ lines[linesLength++] = currentLine;
445
+ currentLine = '';
446
+ }
447
+ lines[linesLength++] = currentLine;
448
+ return lines;
449
+ }
450
+ getLength() {
451
+ return this._length;
452
+ }
453
+ getLineCount() {
454
+ return this._lineCnt;
455
+ }
456
+ getLineContent(lineNumber) {
457
+ if (this._lastVisitedLine.lineNumber === lineNumber) {
458
+ return this._lastVisitedLine.value;
459
+ }
460
+ this._lastVisitedLine.lineNumber = lineNumber;
461
+ if (lineNumber === this._lineCnt) {
462
+ this._lastVisitedLine.value = this.getLineRawContent(lineNumber);
463
+ }
464
+ else if (this._EOLNormalized) {
465
+ this._lastVisitedLine.value = this.getLineRawContent(lineNumber, this._EOLLength);
466
+ }
467
+ else {
468
+ this._lastVisitedLine.value = this.getLineRawContent(lineNumber).replace(/(\r\n|\r|\n)$/, '');
469
+ }
470
+ return this._lastVisitedLine.value;
471
+ }
472
+ _getCharCode(nodePos) {
473
+ if (nodePos.remainder === nodePos.node.piece.length) {
474
+ // the char we want to fetch is at the head of next node.
475
+ const matchingNode = nodePos.node.next();
476
+ if (!matchingNode) {
477
+ return 0;
478
+ }
479
+ const buffer = this._buffers[matchingNode.piece.bufferIndex];
480
+ const startOffset = this.offsetInBuffer(matchingNode.piece.bufferIndex, matchingNode.piece.start);
481
+ return buffer.buffer.charCodeAt(startOffset);
482
+ }
483
+ else {
484
+ const buffer = this._buffers[nodePos.node.piece.bufferIndex];
485
+ const startOffset = this.offsetInBuffer(nodePos.node.piece.bufferIndex, nodePos.node.piece.start);
486
+ const targetOffset = startOffset + nodePos.remainder;
487
+ return buffer.buffer.charCodeAt(targetOffset);
488
+ }
489
+ }
490
+ getLineCharCode(lineNumber, index) {
491
+ const nodePos = this.nodeAt2(lineNumber, index + 1);
492
+ return this._getCharCode(nodePos);
493
+ }
494
+ getLineLength(lineNumber) {
495
+ if (lineNumber === this.getLineCount()) {
496
+ const startOffset = this.getOffsetAt(lineNumber, 1);
497
+ return this.getLength() - startOffset;
498
+ }
499
+ return this.getOffsetAt(lineNumber + 1, 1) - this.getOffsetAt(lineNumber, 1) - this._EOLLength;
500
+ }
501
+ getNearestChunk(offset) {
502
+ const nodePos = this.nodeAt(offset);
503
+ if (nodePos.remainder === nodePos.node.piece.length) {
504
+ // the offset is at the head of next node.
505
+ const matchingNode = nodePos.node.next();
506
+ if (!matchingNode || matchingNode === SENTINEL) {
507
+ return '';
508
+ }
509
+ const buffer = this._buffers[matchingNode.piece.bufferIndex];
510
+ const startOffset = this.offsetInBuffer(matchingNode.piece.bufferIndex, matchingNode.piece.start);
511
+ return buffer.buffer.substring(startOffset, startOffset + matchingNode.piece.length);
512
+ }
513
+ else {
514
+ const buffer = this._buffers[nodePos.node.piece.bufferIndex];
515
+ const startOffset = this.offsetInBuffer(nodePos.node.piece.bufferIndex, nodePos.node.piece.start);
516
+ const targetOffset = startOffset + nodePos.remainder;
517
+ const targetEnd = startOffset + nodePos.node.piece.length;
518
+ return buffer.buffer.substring(targetOffset, targetEnd);
519
+ }
520
+ }
521
+ findMatchesInNode(node, searcher, startLineNumber, startColumn, startCursor, endCursor, searchData, captureMatches, limitResultCount, resultLen, result) {
522
+ const buffer = this._buffers[node.piece.bufferIndex];
523
+ const startOffsetInBuffer = this.offsetInBuffer(node.piece.bufferIndex, node.piece.start);
524
+ const start = this.offsetInBuffer(node.piece.bufferIndex, startCursor);
525
+ const end = this.offsetInBuffer(node.piece.bufferIndex, endCursor);
526
+ let m;
527
+ // Reset regex to search from the beginning
528
+ const ret = { line: 0, column: 0 };
529
+ let searchText;
530
+ let offsetInBuffer;
531
+ if (searcher._wordSeparators) {
532
+ searchText = buffer.buffer.substring(start, end);
533
+ offsetInBuffer = (offset) => offset + start;
534
+ searcher.reset(0);
535
+ }
536
+ else {
537
+ searchText = buffer.buffer;
538
+ offsetInBuffer = (offset) => offset;
539
+ searcher.reset(start);
540
+ }
541
+ do {
542
+ m = searcher.next(searchText);
543
+ if (m) {
544
+ if (offsetInBuffer(m.index) >= end) {
545
+ return resultLen;
546
+ }
547
+ this.positionInBuffer(node, offsetInBuffer(m.index) - startOffsetInBuffer, ret);
548
+ const lineFeedCnt = this.getLineFeedCnt(node.piece.bufferIndex, startCursor, ret);
549
+ const retStartColumn = ret.line === startCursor.line ? ret.column - startCursor.column + startColumn : ret.column + 1;
550
+ const retEndColumn = retStartColumn + m[0].length;
551
+ result[resultLen++] = createFindMatch(new Range(startLineNumber + lineFeedCnt, retStartColumn, startLineNumber + lineFeedCnt, retEndColumn), m, captureMatches);
552
+ if (offsetInBuffer(m.index) + m[0].length >= end) {
553
+ return resultLen;
554
+ }
555
+ if (resultLen >= limitResultCount) {
556
+ return resultLen;
557
+ }
558
+ }
559
+ } while (m);
560
+ return resultLen;
561
+ }
562
+ findMatchesLineByLine(searchRange, searchData, captureMatches, limitResultCount) {
563
+ const result = [];
564
+ let resultLen = 0;
565
+ const searcher = new Searcher(searchData.wordSeparators, searchData.regex);
566
+ let startPosition = this.nodeAt2(searchRange.startLineNumber, searchRange.startColumn);
567
+ if (startPosition === null) {
568
+ return [];
569
+ }
570
+ const endPosition = this.nodeAt2(searchRange.endLineNumber, searchRange.endColumn);
571
+ if (endPosition === null) {
572
+ return [];
573
+ }
574
+ let start = this.positionInBuffer(startPosition.node, startPosition.remainder);
575
+ const end = this.positionInBuffer(endPosition.node, endPosition.remainder);
576
+ if (startPosition.node === endPosition.node) {
577
+ this.findMatchesInNode(startPosition.node, searcher, searchRange.startLineNumber, searchRange.startColumn, start, end, searchData, captureMatches, limitResultCount, resultLen, result);
578
+ return result;
579
+ }
580
+ let startLineNumber = searchRange.startLineNumber;
581
+ let currentNode = startPosition.node;
582
+ while (currentNode !== endPosition.node) {
583
+ const lineBreakCnt = this.getLineFeedCnt(currentNode.piece.bufferIndex, start, currentNode.piece.end);
584
+ if (lineBreakCnt >= 1) {
585
+ // last line break position
586
+ const lineStarts = this._buffers[currentNode.piece.bufferIndex].lineStarts;
587
+ const startOffsetInBuffer = this.offsetInBuffer(currentNode.piece.bufferIndex, currentNode.piece.start);
588
+ const nextLineStartOffset = lineStarts[start.line + lineBreakCnt];
589
+ const startColumn = startLineNumber === searchRange.startLineNumber ? searchRange.startColumn : 1;
590
+ resultLen = this.findMatchesInNode(currentNode, searcher, startLineNumber, startColumn, start, this.positionInBuffer(currentNode, nextLineStartOffset - startOffsetInBuffer), searchData, captureMatches, limitResultCount, resultLen, result);
591
+ if (resultLen >= limitResultCount) {
592
+ return result;
593
+ }
594
+ startLineNumber += lineBreakCnt;
595
+ }
596
+ const startColumn = startLineNumber === searchRange.startLineNumber ? searchRange.startColumn - 1 : 0;
597
+ // search for the remaining content
598
+ if (startLineNumber === searchRange.endLineNumber) {
599
+ const text = this.getLineContent(startLineNumber).substring(startColumn, searchRange.endColumn - 1);
600
+ resultLen = this._findMatchesInLine(searchData, searcher, text, searchRange.endLineNumber, startColumn, resultLen, result, captureMatches, limitResultCount);
601
+ return result;
602
+ }
603
+ resultLen = this._findMatchesInLine(searchData, searcher, this.getLineContent(startLineNumber).substr(startColumn), startLineNumber, startColumn, resultLen, result, captureMatches, limitResultCount);
604
+ if (resultLen >= limitResultCount) {
605
+ return result;
606
+ }
607
+ startLineNumber++;
608
+ startPosition = this.nodeAt2(startLineNumber, 1);
609
+ currentNode = startPosition.node;
610
+ start = this.positionInBuffer(startPosition.node, startPosition.remainder);
611
+ }
612
+ if (startLineNumber === searchRange.endLineNumber) {
613
+ const startColumn = startLineNumber === searchRange.startLineNumber ? searchRange.startColumn - 1 : 0;
614
+ const text = this.getLineContent(startLineNumber).substring(startColumn, searchRange.endColumn - 1);
615
+ resultLen = this._findMatchesInLine(searchData, searcher, text, searchRange.endLineNumber, startColumn, resultLen, result, captureMatches, limitResultCount);
616
+ return result;
617
+ }
618
+ const startColumn = startLineNumber === searchRange.startLineNumber ? searchRange.startColumn : 1;
619
+ resultLen = this.findMatchesInNode(endPosition.node, searcher, startLineNumber, startColumn, start, end, searchData, captureMatches, limitResultCount, resultLen, result);
620
+ return result;
621
+ }
622
+ _findMatchesInLine(searchData, searcher, text, lineNumber, deltaOffset, resultLen, result, captureMatches, limitResultCount) {
623
+ const wordSeparators = searchData.wordSeparators;
624
+ if (!captureMatches && searchData.simpleSearch) {
625
+ const searchString = searchData.simpleSearch;
626
+ const searchStringLen = searchString.length;
627
+ const textLength = text.length;
628
+ let lastMatchIndex = -searchStringLen;
629
+ while ((lastMatchIndex = text.indexOf(searchString, lastMatchIndex + searchStringLen)) !== -1) {
630
+ if (!wordSeparators || isValidMatch(wordSeparators, text, textLength, lastMatchIndex, searchStringLen)) {
631
+ result[resultLen++] = new FindMatch(new Range(lineNumber, lastMatchIndex + 1 + deltaOffset, lineNumber, lastMatchIndex + 1 + searchStringLen + deltaOffset), null);
632
+ if (resultLen >= limitResultCount) {
633
+ return resultLen;
634
+ }
635
+ }
636
+ }
637
+ return resultLen;
638
+ }
639
+ let m;
640
+ // Reset regex to search from the beginning
641
+ searcher.reset(0);
642
+ do {
643
+ m = searcher.next(text);
644
+ if (m) {
645
+ result[resultLen++] = createFindMatch(new Range(lineNumber, m.index + 1 + deltaOffset, lineNumber, m.index + 1 + m[0].length + deltaOffset), m, captureMatches);
646
+ if (resultLen >= limitResultCount) {
647
+ return resultLen;
648
+ }
649
+ }
650
+ } while (m);
651
+ return resultLen;
652
+ }
653
+ // #endregion
654
+ // #region Piece Table
655
+ insert(offset, value, eolNormalized = false) {
656
+ this._EOLNormalized = this._EOLNormalized && eolNormalized;
657
+ this._lastVisitedLine.lineNumber = 0;
658
+ this._lastVisitedLine.value = '';
659
+ if (this.root !== SENTINEL) {
660
+ const { node, remainder, nodeStartOffset } = this.nodeAt(offset);
661
+ const piece = node.piece;
662
+ const bufferIndex = piece.bufferIndex;
663
+ const insertPosInBuffer = this.positionInBuffer(node, remainder);
664
+ if (node.piece.bufferIndex === 0 &&
665
+ piece.end.line === this._lastChangeBufferPos.line &&
666
+ piece.end.column === this._lastChangeBufferPos.column &&
667
+ (nodeStartOffset + piece.length === offset) &&
668
+ value.length < AverageBufferSize) {
669
+ // changed buffer
670
+ this.appendToNode(node, value);
671
+ this.computeBufferMetadata();
672
+ return;
673
+ }
674
+ if (nodeStartOffset === offset) {
675
+ this.insertContentToNodeLeft(value, node);
676
+ this._searchCache.validate(offset);
677
+ }
678
+ else if (nodeStartOffset + node.piece.length > offset) {
679
+ // we are inserting into the middle of a node.
680
+ const nodesToDel = [];
681
+ let newRightPiece = new Piece(piece.bufferIndex, insertPosInBuffer, piece.end, this.getLineFeedCnt(piece.bufferIndex, insertPosInBuffer, piece.end), this.offsetInBuffer(bufferIndex, piece.end) - this.offsetInBuffer(bufferIndex, insertPosInBuffer));
682
+ if (this.shouldCheckCRLF() && this.endWithCR(value)) {
683
+ const headOfRight = this.nodeCharCodeAt(node, remainder);
684
+ if (headOfRight === 10 /** \n */) {
685
+ const newStart = { line: newRightPiece.start.line + 1, column: 0 };
686
+ newRightPiece = new Piece(newRightPiece.bufferIndex, newStart, newRightPiece.end, this.getLineFeedCnt(newRightPiece.bufferIndex, newStart, newRightPiece.end), newRightPiece.length - 1);
687
+ value += '\n';
688
+ }
689
+ }
690
+ // reuse node for content before insertion point.
691
+ if (this.shouldCheckCRLF() && this.startWithLF(value)) {
692
+ const tailOfLeft = this.nodeCharCodeAt(node, remainder - 1);
693
+ if (tailOfLeft === 13 /** \r */) {
694
+ const previousPos = this.positionInBuffer(node, remainder - 1);
695
+ this.deleteNodeTail(node, previousPos);
696
+ value = '\r' + value;
697
+ if (node.piece.length === 0) {
698
+ nodesToDel.push(node);
699
+ }
700
+ }
701
+ else {
702
+ this.deleteNodeTail(node, insertPosInBuffer);
703
+ }
704
+ }
705
+ else {
706
+ this.deleteNodeTail(node, insertPosInBuffer);
707
+ }
708
+ const newPieces = this.createNewPieces(value);
709
+ if (newRightPiece.length > 0) {
710
+ this.rbInsertRight(node, newRightPiece);
711
+ }
712
+ let tmpNode = node;
713
+ for (let k = 0; k < newPieces.length; k++) {
714
+ tmpNode = this.rbInsertRight(tmpNode, newPieces[k]);
715
+ }
716
+ this.deleteNodes(nodesToDel);
717
+ }
718
+ else {
719
+ this.insertContentToNodeRight(value, node);
720
+ }
721
+ }
722
+ else {
723
+ // insert new node
724
+ const pieces = this.createNewPieces(value);
725
+ let node = this.rbInsertLeft(null, pieces[0]);
726
+ for (let k = 1; k < pieces.length; k++) {
727
+ node = this.rbInsertRight(node, pieces[k]);
728
+ }
729
+ }
730
+ // todo, this is too brutal. Total line feed count should be updated the same way as lf_left.
731
+ this.computeBufferMetadata();
732
+ }
733
+ delete(offset, cnt) {
734
+ this._lastVisitedLine.lineNumber = 0;
735
+ this._lastVisitedLine.value = '';
736
+ if (cnt <= 0 || this.root === SENTINEL) {
737
+ return;
738
+ }
739
+ const startPosition = this.nodeAt(offset);
740
+ const endPosition = this.nodeAt(offset + cnt);
741
+ const startNode = startPosition.node;
742
+ const endNode = endPosition.node;
743
+ if (startNode === endNode) {
744
+ const startSplitPosInBuffer = this.positionInBuffer(startNode, startPosition.remainder);
745
+ const endSplitPosInBuffer = this.positionInBuffer(startNode, endPosition.remainder);
746
+ if (startPosition.nodeStartOffset === offset) {
747
+ if (cnt === startNode.piece.length) { // delete node
748
+ const next = startNode.next();
749
+ rbDelete(this, startNode);
750
+ this.validateCRLFWithPrevNode(next);
751
+ this.computeBufferMetadata();
752
+ return;
753
+ }
754
+ this.deleteNodeHead(startNode, endSplitPosInBuffer);
755
+ this._searchCache.validate(offset);
756
+ this.validateCRLFWithPrevNode(startNode);
757
+ this.computeBufferMetadata();
758
+ return;
759
+ }
760
+ if (startPosition.nodeStartOffset + startNode.piece.length === offset + cnt) {
761
+ this.deleteNodeTail(startNode, startSplitPosInBuffer);
762
+ this.validateCRLFWithNextNode(startNode);
763
+ this.computeBufferMetadata();
764
+ return;
765
+ }
766
+ // delete content in the middle, this node will be splitted to nodes
767
+ this.shrinkNode(startNode, startSplitPosInBuffer, endSplitPosInBuffer);
768
+ this.computeBufferMetadata();
769
+ return;
770
+ }
771
+ const nodesToDel = [];
772
+ const startSplitPosInBuffer = this.positionInBuffer(startNode, startPosition.remainder);
773
+ this.deleteNodeTail(startNode, startSplitPosInBuffer);
774
+ this._searchCache.validate(offset);
775
+ if (startNode.piece.length === 0) {
776
+ nodesToDel.push(startNode);
777
+ }
778
+ // update last touched node
779
+ const endSplitPosInBuffer = this.positionInBuffer(endNode, endPosition.remainder);
780
+ this.deleteNodeHead(endNode, endSplitPosInBuffer);
781
+ if (endNode.piece.length === 0) {
782
+ nodesToDel.push(endNode);
783
+ }
784
+ // delete nodes in between
785
+ const secondNode = startNode.next();
786
+ for (let node = secondNode; node !== SENTINEL && node !== endNode; node = node.next()) {
787
+ nodesToDel.push(node);
788
+ }
789
+ const prev = startNode.piece.length === 0 ? startNode.prev() : startNode;
790
+ this.deleteNodes(nodesToDel);
791
+ this.validateCRLFWithNextNode(prev);
792
+ this.computeBufferMetadata();
793
+ }
794
+ insertContentToNodeLeft(value, node) {
795
+ // we are inserting content to the beginning of node
796
+ const nodesToDel = [];
797
+ if (this.shouldCheckCRLF() && this.endWithCR(value) && this.startWithLF(node)) {
798
+ // move `\n` to new node.
799
+ const piece = node.piece;
800
+ const newStart = { line: piece.start.line + 1, column: 0 };
801
+ const nPiece = new Piece(piece.bufferIndex, newStart, piece.end, this.getLineFeedCnt(piece.bufferIndex, newStart, piece.end), piece.length - 1);
802
+ node.piece = nPiece;
803
+ value += '\n';
804
+ updateTreeMetadata(this, node, -1, -1);
805
+ if (node.piece.length === 0) {
806
+ nodesToDel.push(node);
807
+ }
808
+ }
809
+ const newPieces = this.createNewPieces(value);
810
+ let newNode = this.rbInsertLeft(node, newPieces[newPieces.length - 1]);
811
+ for (let k = newPieces.length - 2; k >= 0; k--) {
812
+ newNode = this.rbInsertLeft(newNode, newPieces[k]);
813
+ }
814
+ this.validateCRLFWithPrevNode(newNode);
815
+ this.deleteNodes(nodesToDel);
816
+ }
817
+ insertContentToNodeRight(value, node) {
818
+ // we are inserting to the right of this node.
819
+ if (this.adjustCarriageReturnFromNext(value, node)) {
820
+ // move \n to the new node.
821
+ value += '\n';
822
+ }
823
+ const newPieces = this.createNewPieces(value);
824
+ const newNode = this.rbInsertRight(node, newPieces[0]);
825
+ let tmpNode = newNode;
826
+ for (let k = 1; k < newPieces.length; k++) {
827
+ tmpNode = this.rbInsertRight(tmpNode, newPieces[k]);
828
+ }
829
+ this.validateCRLFWithPrevNode(newNode);
830
+ }
831
+ positionInBuffer(node, remainder, ret) {
832
+ const piece = node.piece;
833
+ const bufferIndex = node.piece.bufferIndex;
834
+ const lineStarts = this._buffers[bufferIndex].lineStarts;
835
+ const startOffset = lineStarts[piece.start.line] + piece.start.column;
836
+ const offset = startOffset + remainder;
837
+ // binary search offset between startOffset and endOffset
838
+ let low = piece.start.line;
839
+ let high = piece.end.line;
840
+ let mid = 0;
841
+ let midStop = 0;
842
+ let midStart = 0;
843
+ while (low <= high) {
844
+ mid = low + ((high - low) / 2) | 0;
845
+ midStart = lineStarts[mid];
846
+ if (mid === high) {
847
+ break;
848
+ }
849
+ midStop = lineStarts[mid + 1];
850
+ if (offset < midStart) {
851
+ high = mid - 1;
852
+ }
853
+ else if (offset >= midStop) {
854
+ low = mid + 1;
855
+ }
856
+ else {
857
+ break;
858
+ }
859
+ }
860
+ if (ret) {
861
+ ret.line = mid;
862
+ ret.column = offset - midStart;
863
+ return null;
864
+ }
865
+ return {
866
+ line: mid,
867
+ column: offset - midStart
868
+ };
869
+ }
870
+ getLineFeedCnt(bufferIndex, start, end) {
871
+ // we don't need to worry about start: abc\r|\n, or abc|\r, or abc|\n, or abc|\r\n doesn't change the fact that, there is one line break after start.
872
+ // now let's take care of end: abc\r|\n, if end is in between \r and \n, we need to add line feed count by 1
873
+ if (end.column === 0) {
874
+ return end.line - start.line;
875
+ }
876
+ const lineStarts = this._buffers[bufferIndex].lineStarts;
877
+ if (end.line === lineStarts.length - 1) { // it means, there is no \n after end, otherwise, there will be one more lineStart.
878
+ return end.line - start.line;
879
+ }
880
+ const nextLineStartOffset = lineStarts[end.line + 1];
881
+ const endOffset = lineStarts[end.line] + end.column;
882
+ if (nextLineStartOffset > endOffset + 1) { // there are more than 1 character after end, which means it can't be \n
883
+ return end.line - start.line;
884
+ }
885
+ // endOffset + 1 === nextLineStartOffset
886
+ // character at endOffset is \n, so we check the character before first
887
+ // if character at endOffset is \r, end.column is 0 and we can't get here.
888
+ const previousCharOffset = endOffset - 1; // end.column > 0 so it's okay.
889
+ const buffer = this._buffers[bufferIndex].buffer;
890
+ if (buffer.charCodeAt(previousCharOffset) === 13) {
891
+ return end.line - start.line + 1;
892
+ }
893
+ else {
894
+ return end.line - start.line;
895
+ }
896
+ }
897
+ offsetInBuffer(bufferIndex, cursor) {
898
+ const lineStarts = this._buffers[bufferIndex].lineStarts;
899
+ return lineStarts[cursor.line] + cursor.column;
900
+ }
901
+ deleteNodes(nodes) {
902
+ for (let i = 0; i < nodes.length; i++) {
903
+ rbDelete(this, nodes[i]);
904
+ }
905
+ }
906
+ createNewPieces(text) {
907
+ if (text.length > AverageBufferSize) {
908
+ // the content is large, operations like substring, charCode becomes slow
909
+ // so here we split it into smaller chunks, just like what we did for CR/LF normalization
910
+ const newPieces = [];
911
+ while (text.length > AverageBufferSize) {
912
+ const lastChar = text.charCodeAt(AverageBufferSize - 1);
913
+ let splitText;
914
+ if (lastChar === 13 /* CharCode.CarriageReturn */ || (lastChar >= 0xD800 && lastChar <= 0xDBFF)) {
915
+ // last character is \r or a high surrogate => keep it back
916
+ splitText = text.substring(0, AverageBufferSize - 1);
917
+ text = text.substring(AverageBufferSize - 1);
918
+ }
919
+ else {
920
+ splitText = text.substring(0, AverageBufferSize);
921
+ text = text.substring(AverageBufferSize);
922
+ }
923
+ const lineStarts = createLineStartsFast(splitText);
924
+ newPieces.push(new Piece(this._buffers.length, /* buffer index */ { line: 0, column: 0 }, { line: lineStarts.length - 1, column: splitText.length - lineStarts[lineStarts.length - 1] }, lineStarts.length - 1, splitText.length));
925
+ this._buffers.push(new StringBuffer(splitText, lineStarts));
926
+ }
927
+ const lineStarts = createLineStartsFast(text);
928
+ newPieces.push(new Piece(this._buffers.length, /* buffer index */ { line: 0, column: 0 }, { line: lineStarts.length - 1, column: text.length - lineStarts[lineStarts.length - 1] }, lineStarts.length - 1, text.length));
929
+ this._buffers.push(new StringBuffer(text, lineStarts));
930
+ return newPieces;
931
+ }
932
+ let startOffset = this._buffers[0].buffer.length;
933
+ const lineStarts = createLineStartsFast(text, false);
934
+ let start = this._lastChangeBufferPos;
935
+ if (this._buffers[0].lineStarts[this._buffers[0].lineStarts.length - 1] === startOffset
936
+ && startOffset !== 0
937
+ && this.startWithLF(text)
938
+ && this.endWithCR(this._buffers[0].buffer) // todo, we can check this._lastChangeBufferPos's column as it's the last one
939
+ ) {
940
+ this._lastChangeBufferPos = { line: this._lastChangeBufferPos.line, column: this._lastChangeBufferPos.column + 1 };
941
+ start = this._lastChangeBufferPos;
942
+ for (let i = 0; i < lineStarts.length; i++) {
943
+ lineStarts[i] += startOffset + 1;
944
+ }
945
+ this._buffers[0].lineStarts = this._buffers[0].lineStarts.concat(lineStarts.slice(1));
946
+ this._buffers[0].buffer += '_' + text;
947
+ startOffset += 1;
948
+ }
949
+ else {
950
+ if (startOffset !== 0) {
951
+ for (let i = 0; i < lineStarts.length; i++) {
952
+ lineStarts[i] += startOffset;
953
+ }
954
+ }
955
+ this._buffers[0].lineStarts = this._buffers[0].lineStarts.concat(lineStarts.slice(1));
956
+ this._buffers[0].buffer += text;
957
+ }
958
+ const endOffset = this._buffers[0].buffer.length;
959
+ const endIndex = this._buffers[0].lineStarts.length - 1;
960
+ const endColumn = endOffset - this._buffers[0].lineStarts[endIndex];
961
+ const endPos = { line: endIndex, column: endColumn };
962
+ const newPiece = new Piece(0, /** todo@peng */ start, endPos, this.getLineFeedCnt(0, start, endPos), endOffset - startOffset);
963
+ this._lastChangeBufferPos = endPos;
964
+ return [newPiece];
965
+ }
966
+ getLineRawContent(lineNumber, endOffset = 0) {
967
+ let x = this.root;
968
+ let ret = '';
969
+ const cache = this._searchCache.get2(lineNumber);
970
+ if (cache) {
971
+ x = cache.node;
972
+ const prevAccumulatedValue = this.getAccumulatedValue(x, lineNumber - cache.nodeStartLineNumber - 1);
973
+ const buffer = this._buffers[x.piece.bufferIndex].buffer;
974
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
975
+ if (cache.nodeStartLineNumber + x.piece.lineFeedCnt === lineNumber) {
976
+ ret = buffer.substring(startOffset + prevAccumulatedValue, startOffset + x.piece.length);
977
+ }
978
+ else {
979
+ const accumulatedValue = this.getAccumulatedValue(x, lineNumber - cache.nodeStartLineNumber);
980
+ return buffer.substring(startOffset + prevAccumulatedValue, startOffset + accumulatedValue - endOffset);
981
+ }
982
+ }
983
+ else {
984
+ let nodeStartOffset = 0;
985
+ const originalLineNumber = lineNumber;
986
+ while (x !== SENTINEL) {
987
+ if (x.left !== SENTINEL && x.lf_left >= lineNumber - 1) {
988
+ x = x.left;
989
+ }
990
+ else if (x.lf_left + x.piece.lineFeedCnt > lineNumber - 1) {
991
+ const prevAccumulatedValue = this.getAccumulatedValue(x, lineNumber - x.lf_left - 2);
992
+ const accumulatedValue = this.getAccumulatedValue(x, lineNumber - x.lf_left - 1);
993
+ const buffer = this._buffers[x.piece.bufferIndex].buffer;
994
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
995
+ nodeStartOffset += x.size_left;
996
+ this._searchCache.set({
997
+ node: x,
998
+ nodeStartOffset,
999
+ nodeStartLineNumber: originalLineNumber - (lineNumber - 1 - x.lf_left)
1000
+ });
1001
+ return buffer.substring(startOffset + prevAccumulatedValue, startOffset + accumulatedValue - endOffset);
1002
+ }
1003
+ else if (x.lf_left + x.piece.lineFeedCnt === lineNumber - 1) {
1004
+ const prevAccumulatedValue = this.getAccumulatedValue(x, lineNumber - x.lf_left - 2);
1005
+ const buffer = this._buffers[x.piece.bufferIndex].buffer;
1006
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
1007
+ ret = buffer.substring(startOffset + prevAccumulatedValue, startOffset + x.piece.length);
1008
+ break;
1009
+ }
1010
+ else {
1011
+ lineNumber -= x.lf_left + x.piece.lineFeedCnt;
1012
+ nodeStartOffset += x.size_left + x.piece.length;
1013
+ x = x.right;
1014
+ }
1015
+ }
1016
+ }
1017
+ // search in order, to find the node contains end column
1018
+ x = x.next();
1019
+ while (x !== SENTINEL) {
1020
+ const buffer = this._buffers[x.piece.bufferIndex].buffer;
1021
+ if (x.piece.lineFeedCnt > 0) {
1022
+ const accumulatedValue = this.getAccumulatedValue(x, 0);
1023
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
1024
+ ret += buffer.substring(startOffset, startOffset + accumulatedValue - endOffset);
1025
+ return ret;
1026
+ }
1027
+ else {
1028
+ const startOffset = this.offsetInBuffer(x.piece.bufferIndex, x.piece.start);
1029
+ ret += buffer.substr(startOffset, x.piece.length);
1030
+ }
1031
+ x = x.next();
1032
+ }
1033
+ return ret;
1034
+ }
1035
+ computeBufferMetadata() {
1036
+ let x = this.root;
1037
+ let lfCnt = 1;
1038
+ let len = 0;
1039
+ while (x !== SENTINEL) {
1040
+ lfCnt += x.lf_left + x.piece.lineFeedCnt;
1041
+ len += x.size_left + x.piece.length;
1042
+ x = x.right;
1043
+ }
1044
+ this._lineCnt = lfCnt;
1045
+ this._length = len;
1046
+ this._searchCache.validate(this._length);
1047
+ }
1048
+ // #region node operations
1049
+ getIndexOf(node, accumulatedValue) {
1050
+ const piece = node.piece;
1051
+ const pos = this.positionInBuffer(node, accumulatedValue);
1052
+ const lineCnt = pos.line - piece.start.line;
1053
+ if (this.offsetInBuffer(piece.bufferIndex, piece.end) - this.offsetInBuffer(piece.bufferIndex, piece.start) === accumulatedValue) {
1054
+ // we are checking the end of this node, so a CRLF check is necessary.
1055
+ const realLineCnt = this.getLineFeedCnt(node.piece.bufferIndex, piece.start, pos);
1056
+ if (realLineCnt !== lineCnt) {
1057
+ // aha yes, CRLF
1058
+ return { index: realLineCnt, remainder: 0 };
1059
+ }
1060
+ }
1061
+ return { index: lineCnt, remainder: pos.column };
1062
+ }
1063
+ getAccumulatedValue(node, index) {
1064
+ if (index < 0) {
1065
+ return 0;
1066
+ }
1067
+ const piece = node.piece;
1068
+ const lineStarts = this._buffers[piece.bufferIndex].lineStarts;
1069
+ const expectedLineStartIndex = piece.start.line + index + 1;
1070
+ if (expectedLineStartIndex > piece.end.line) {
1071
+ return lineStarts[piece.end.line] + piece.end.column - lineStarts[piece.start.line] - piece.start.column;
1072
+ }
1073
+ else {
1074
+ return lineStarts[expectedLineStartIndex] - lineStarts[piece.start.line] - piece.start.column;
1075
+ }
1076
+ }
1077
+ deleteNodeTail(node, pos) {
1078
+ const piece = node.piece;
1079
+ const originalLFCnt = piece.lineFeedCnt;
1080
+ const originalEndOffset = this.offsetInBuffer(piece.bufferIndex, piece.end);
1081
+ const newEnd = pos;
1082
+ const newEndOffset = this.offsetInBuffer(piece.bufferIndex, newEnd);
1083
+ const newLineFeedCnt = this.getLineFeedCnt(piece.bufferIndex, piece.start, newEnd);
1084
+ const lf_delta = newLineFeedCnt - originalLFCnt;
1085
+ const size_delta = newEndOffset - originalEndOffset;
1086
+ const newLength = piece.length + size_delta;
1087
+ node.piece = new Piece(piece.bufferIndex, piece.start, newEnd, newLineFeedCnt, newLength);
1088
+ updateTreeMetadata(this, node, size_delta, lf_delta);
1089
+ }
1090
+ deleteNodeHead(node, pos) {
1091
+ const piece = node.piece;
1092
+ const originalLFCnt = piece.lineFeedCnt;
1093
+ const originalStartOffset = this.offsetInBuffer(piece.bufferIndex, piece.start);
1094
+ const newStart = pos;
1095
+ const newLineFeedCnt = this.getLineFeedCnt(piece.bufferIndex, newStart, piece.end);
1096
+ const newStartOffset = this.offsetInBuffer(piece.bufferIndex, newStart);
1097
+ const lf_delta = newLineFeedCnt - originalLFCnt;
1098
+ const size_delta = originalStartOffset - newStartOffset;
1099
+ const newLength = piece.length + size_delta;
1100
+ node.piece = new Piece(piece.bufferIndex, newStart, piece.end, newLineFeedCnt, newLength);
1101
+ updateTreeMetadata(this, node, size_delta, lf_delta);
1102
+ }
1103
+ shrinkNode(node, start, end) {
1104
+ const piece = node.piece;
1105
+ const originalStartPos = piece.start;
1106
+ const originalEndPos = piece.end;
1107
+ // old piece, originalStartPos, start
1108
+ const oldLength = piece.length;
1109
+ const oldLFCnt = piece.lineFeedCnt;
1110
+ const newEnd = start;
1111
+ const newLineFeedCnt = this.getLineFeedCnt(piece.bufferIndex, piece.start, newEnd);
1112
+ const newLength = this.offsetInBuffer(piece.bufferIndex, start) - this.offsetInBuffer(piece.bufferIndex, originalStartPos);
1113
+ node.piece = new Piece(piece.bufferIndex, piece.start, newEnd, newLineFeedCnt, newLength);
1114
+ updateTreeMetadata(this, node, newLength - oldLength, newLineFeedCnt - oldLFCnt);
1115
+ // new right piece, end, originalEndPos
1116
+ const newPiece = new Piece(piece.bufferIndex, end, originalEndPos, this.getLineFeedCnt(piece.bufferIndex, end, originalEndPos), this.offsetInBuffer(piece.bufferIndex, originalEndPos) - this.offsetInBuffer(piece.bufferIndex, end));
1117
+ const newNode = this.rbInsertRight(node, newPiece);
1118
+ this.validateCRLFWithPrevNode(newNode);
1119
+ }
1120
+ appendToNode(node, value) {
1121
+ if (this.adjustCarriageReturnFromNext(value, node)) {
1122
+ value += '\n';
1123
+ }
1124
+ const hitCRLF = this.shouldCheckCRLF() && this.startWithLF(value) && this.endWithCR(node);
1125
+ const startOffset = this._buffers[0].buffer.length;
1126
+ this._buffers[0].buffer += value;
1127
+ const lineStarts = createLineStartsFast(value, false);
1128
+ for (let i = 0; i < lineStarts.length; i++) {
1129
+ lineStarts[i] += startOffset;
1130
+ }
1131
+ if (hitCRLF) {
1132
+ const prevStartOffset = this._buffers[0].lineStarts[this._buffers[0].lineStarts.length - 2];
1133
+ this._buffers[0].lineStarts.pop();
1134
+ // _lastChangeBufferPos is already wrong
1135
+ this._lastChangeBufferPos = { line: this._lastChangeBufferPos.line - 1, column: startOffset - prevStartOffset };
1136
+ }
1137
+ this._buffers[0].lineStarts = this._buffers[0].lineStarts.concat(lineStarts.slice(1));
1138
+ const endIndex = this._buffers[0].lineStarts.length - 1;
1139
+ const endColumn = this._buffers[0].buffer.length - this._buffers[0].lineStarts[endIndex];
1140
+ const newEnd = { line: endIndex, column: endColumn };
1141
+ const newLength = node.piece.length + value.length;
1142
+ const oldLineFeedCnt = node.piece.lineFeedCnt;
1143
+ const newLineFeedCnt = this.getLineFeedCnt(0, node.piece.start, newEnd);
1144
+ const lf_delta = newLineFeedCnt - oldLineFeedCnt;
1145
+ node.piece = new Piece(node.piece.bufferIndex, node.piece.start, newEnd, newLineFeedCnt, newLength);
1146
+ this._lastChangeBufferPos = newEnd;
1147
+ updateTreeMetadata(this, node, value.length, lf_delta);
1148
+ }
1149
+ nodeAt(offset) {
1150
+ let x = this.root;
1151
+ const cache = this._searchCache.get(offset);
1152
+ if (cache) {
1153
+ return {
1154
+ node: cache.node,
1155
+ nodeStartOffset: cache.nodeStartOffset,
1156
+ remainder: offset - cache.nodeStartOffset
1157
+ };
1158
+ }
1159
+ let nodeStartOffset = 0;
1160
+ while (x !== SENTINEL) {
1161
+ if (x.size_left > offset) {
1162
+ x = x.left;
1163
+ }
1164
+ else if (x.size_left + x.piece.length >= offset) {
1165
+ nodeStartOffset += x.size_left;
1166
+ const ret = {
1167
+ node: x,
1168
+ remainder: offset - x.size_left,
1169
+ nodeStartOffset
1170
+ };
1171
+ this._searchCache.set(ret);
1172
+ return ret;
1173
+ }
1174
+ else {
1175
+ offset -= x.size_left + x.piece.length;
1176
+ nodeStartOffset += x.size_left + x.piece.length;
1177
+ x = x.right;
1178
+ }
1179
+ }
1180
+ return null;
1181
+ }
1182
+ nodeAt2(lineNumber, column) {
1183
+ let x = this.root;
1184
+ let nodeStartOffset = 0;
1185
+ while (x !== SENTINEL) {
1186
+ if (x.left !== SENTINEL && x.lf_left >= lineNumber - 1) {
1187
+ x = x.left;
1188
+ }
1189
+ else if (x.lf_left + x.piece.lineFeedCnt > lineNumber - 1) {
1190
+ const prevAccumualtedValue = this.getAccumulatedValue(x, lineNumber - x.lf_left - 2);
1191
+ const accumulatedValue = this.getAccumulatedValue(x, lineNumber - x.lf_left - 1);
1192
+ nodeStartOffset += x.size_left;
1193
+ return {
1194
+ node: x,
1195
+ remainder: Math.min(prevAccumualtedValue + column - 1, accumulatedValue),
1196
+ nodeStartOffset
1197
+ };
1198
+ }
1199
+ else if (x.lf_left + x.piece.lineFeedCnt === lineNumber - 1) {
1200
+ const prevAccumualtedValue = this.getAccumulatedValue(x, lineNumber - x.lf_left - 2);
1201
+ if (prevAccumualtedValue + column - 1 <= x.piece.length) {
1202
+ return {
1203
+ node: x,
1204
+ remainder: prevAccumualtedValue + column - 1,
1205
+ nodeStartOffset
1206
+ };
1207
+ }
1208
+ else {
1209
+ column -= x.piece.length - prevAccumualtedValue;
1210
+ break;
1211
+ }
1212
+ }
1213
+ else {
1214
+ lineNumber -= x.lf_left + x.piece.lineFeedCnt;
1215
+ nodeStartOffset += x.size_left + x.piece.length;
1216
+ x = x.right;
1217
+ }
1218
+ }
1219
+ // search in order, to find the node contains position.column
1220
+ x = x.next();
1221
+ while (x !== SENTINEL) {
1222
+ if (x.piece.lineFeedCnt > 0) {
1223
+ const accumulatedValue = this.getAccumulatedValue(x, 0);
1224
+ const nodeStartOffset = this.offsetOfNode(x);
1225
+ return {
1226
+ node: x,
1227
+ remainder: Math.min(column - 1, accumulatedValue),
1228
+ nodeStartOffset
1229
+ };
1230
+ }
1231
+ else {
1232
+ if (x.piece.length >= column - 1) {
1233
+ const nodeStartOffset = this.offsetOfNode(x);
1234
+ return {
1235
+ node: x,
1236
+ remainder: column - 1,
1237
+ nodeStartOffset
1238
+ };
1239
+ }
1240
+ else {
1241
+ column -= x.piece.length;
1242
+ }
1243
+ }
1244
+ x = x.next();
1245
+ }
1246
+ return null;
1247
+ }
1248
+ nodeCharCodeAt(node, offset) {
1249
+ if (node.piece.lineFeedCnt < 1) {
1250
+ return -1;
1251
+ }
1252
+ const buffer = this._buffers[node.piece.bufferIndex];
1253
+ const newOffset = this.offsetInBuffer(node.piece.bufferIndex, node.piece.start) + offset;
1254
+ return buffer.buffer.charCodeAt(newOffset);
1255
+ }
1256
+ offsetOfNode(node) {
1257
+ if (!node) {
1258
+ return 0;
1259
+ }
1260
+ let pos = node.size_left;
1261
+ while (node !== this.root) {
1262
+ if (node.parent.right === node) {
1263
+ pos += node.parent.size_left + node.parent.piece.length;
1264
+ }
1265
+ node = node.parent;
1266
+ }
1267
+ return pos;
1268
+ }
1269
+ // #endregion
1270
+ // #region CRLF
1271
+ shouldCheckCRLF() {
1272
+ return !(this._EOLNormalized && this._EOL === '\n');
1273
+ }
1274
+ startWithLF(val) {
1275
+ if (typeof val === 'string') {
1276
+ return val.charCodeAt(0) === 10;
1277
+ }
1278
+ if (val === SENTINEL || val.piece.lineFeedCnt === 0) {
1279
+ return false;
1280
+ }
1281
+ const piece = val.piece;
1282
+ const lineStarts = this._buffers[piece.bufferIndex].lineStarts;
1283
+ const line = piece.start.line;
1284
+ const startOffset = lineStarts[line] + piece.start.column;
1285
+ if (line === lineStarts.length - 1) {
1286
+ // last line, so there is no line feed at the end of this line
1287
+ return false;
1288
+ }
1289
+ const nextLineOffset = lineStarts[line + 1];
1290
+ if (nextLineOffset > startOffset + 1) {
1291
+ return false;
1292
+ }
1293
+ return this._buffers[piece.bufferIndex].buffer.charCodeAt(startOffset) === 10;
1294
+ }
1295
+ endWithCR(val) {
1296
+ if (typeof val === 'string') {
1297
+ return val.charCodeAt(val.length - 1) === 13;
1298
+ }
1299
+ if (val === SENTINEL || val.piece.lineFeedCnt === 0) {
1300
+ return false;
1301
+ }
1302
+ return this.nodeCharCodeAt(val, val.piece.length - 1) === 13;
1303
+ }
1304
+ validateCRLFWithPrevNode(nextNode) {
1305
+ if (this.shouldCheckCRLF() && this.startWithLF(nextNode)) {
1306
+ const node = nextNode.prev();
1307
+ if (this.endWithCR(node)) {
1308
+ this.fixCRLF(node, nextNode);
1309
+ }
1310
+ }
1311
+ }
1312
+ validateCRLFWithNextNode(node) {
1313
+ if (this.shouldCheckCRLF() && this.endWithCR(node)) {
1314
+ const nextNode = node.next();
1315
+ if (this.startWithLF(nextNode)) {
1316
+ this.fixCRLF(node, nextNode);
1317
+ }
1318
+ }
1319
+ }
1320
+ fixCRLF(prev, next) {
1321
+ const nodesToDel = [];
1322
+ // update node
1323
+ const lineStarts = this._buffers[prev.piece.bufferIndex].lineStarts;
1324
+ let newEnd;
1325
+ if (prev.piece.end.column === 0) {
1326
+ // it means, last line ends with \r, not \r\n
1327
+ newEnd = { line: prev.piece.end.line - 1, column: lineStarts[prev.piece.end.line] - lineStarts[prev.piece.end.line - 1] - 1 };
1328
+ }
1329
+ else {
1330
+ // \r\n
1331
+ newEnd = { line: prev.piece.end.line, column: prev.piece.end.column - 1 };
1332
+ }
1333
+ const prevNewLength = prev.piece.length - 1;
1334
+ const prevNewLFCnt = prev.piece.lineFeedCnt - 1;
1335
+ prev.piece = new Piece(prev.piece.bufferIndex, prev.piece.start, newEnd, prevNewLFCnt, prevNewLength);
1336
+ updateTreeMetadata(this, prev, -1, -1);
1337
+ if (prev.piece.length === 0) {
1338
+ nodesToDel.push(prev);
1339
+ }
1340
+ // update nextNode
1341
+ const newStart = { line: next.piece.start.line + 1, column: 0 };
1342
+ const newLength = next.piece.length - 1;
1343
+ const newLineFeedCnt = this.getLineFeedCnt(next.piece.bufferIndex, newStart, next.piece.end);
1344
+ next.piece = new Piece(next.piece.bufferIndex, newStart, next.piece.end, newLineFeedCnt, newLength);
1345
+ updateTreeMetadata(this, next, -1, -1);
1346
+ if (next.piece.length === 0) {
1347
+ nodesToDel.push(next);
1348
+ }
1349
+ // create new piece which contains \r\n
1350
+ const pieces = this.createNewPieces('\r\n');
1351
+ this.rbInsertRight(prev, pieces[0]);
1352
+ // delete empty nodes
1353
+ for (let i = 0; i < nodesToDel.length; i++) {
1354
+ rbDelete(this, nodesToDel[i]);
1355
+ }
1356
+ }
1357
+ adjustCarriageReturnFromNext(value, node) {
1358
+ if (this.shouldCheckCRLF() && this.endWithCR(value)) {
1359
+ const nextNode = node.next();
1360
+ if (this.startWithLF(nextNode)) {
1361
+ // move `\n` forward
1362
+ value += '\n';
1363
+ if (nextNode.piece.length === 1) {
1364
+ rbDelete(this, nextNode);
1365
+ }
1366
+ else {
1367
+ const piece = nextNode.piece;
1368
+ const newStart = { line: piece.start.line + 1, column: 0 };
1369
+ const newLength = piece.length - 1;
1370
+ const newLineFeedCnt = this.getLineFeedCnt(piece.bufferIndex, newStart, piece.end);
1371
+ nextNode.piece = new Piece(piece.bufferIndex, newStart, piece.end, newLineFeedCnt, newLength);
1372
+ updateTreeMetadata(this, nextNode, -1, -1);
1373
+ }
1374
+ return true;
1375
+ }
1376
+ }
1377
+ return false;
1378
+ }
1379
+ // #endregion
1380
+ // #endregion
1381
+ // #region Tree operations
1382
+ iterate(node, callback) {
1383
+ if (node === SENTINEL) {
1384
+ return callback(SENTINEL);
1385
+ }
1386
+ const leftRet = this.iterate(node.left, callback);
1387
+ if (!leftRet) {
1388
+ return leftRet;
1389
+ }
1390
+ return callback(node) && this.iterate(node.right, callback);
1391
+ }
1392
+ getNodeContent(node) {
1393
+ if (node === SENTINEL) {
1394
+ return '';
1395
+ }
1396
+ const buffer = this._buffers[node.piece.bufferIndex];
1397
+ const piece = node.piece;
1398
+ const startOffset = this.offsetInBuffer(piece.bufferIndex, piece.start);
1399
+ const endOffset = this.offsetInBuffer(piece.bufferIndex, piece.end);
1400
+ const currentContent = buffer.buffer.substring(startOffset, endOffset);
1401
+ return currentContent;
1402
+ }
1403
+ getPieceContent(piece) {
1404
+ const buffer = this._buffers[piece.bufferIndex];
1405
+ const startOffset = this.offsetInBuffer(piece.bufferIndex, piece.start);
1406
+ const endOffset = this.offsetInBuffer(piece.bufferIndex, piece.end);
1407
+ const currentContent = buffer.buffer.substring(startOffset, endOffset);
1408
+ return currentContent;
1409
+ }
1410
+ /**
1411
+ * node node
1412
+ * / \ / \
1413
+ * a b <---- a b
1414
+ * /
1415
+ * z
1416
+ */
1417
+ rbInsertRight(node, p) {
1418
+ const z = new TreeNode(p, 1 /* NodeColor.Red */);
1419
+ z.left = SENTINEL;
1420
+ z.right = SENTINEL;
1421
+ z.parent = SENTINEL;
1422
+ z.size_left = 0;
1423
+ z.lf_left = 0;
1424
+ const x = this.root;
1425
+ if (x === SENTINEL) {
1426
+ this.root = z;
1427
+ z.color = 0 /* NodeColor.Black */;
1428
+ }
1429
+ else if (node.right === SENTINEL) {
1430
+ node.right = z;
1431
+ z.parent = node;
1432
+ }
1433
+ else {
1434
+ const nextNode = leftest(node.right);
1435
+ nextNode.left = z;
1436
+ z.parent = nextNode;
1437
+ }
1438
+ fixInsert(this, z);
1439
+ return z;
1440
+ }
1441
+ /**
1442
+ * node node
1443
+ * / \ / \
1444
+ * a b ----> a b
1445
+ * \
1446
+ * z
1447
+ */
1448
+ rbInsertLeft(node, p) {
1449
+ const z = new TreeNode(p, 1 /* NodeColor.Red */);
1450
+ z.left = SENTINEL;
1451
+ z.right = SENTINEL;
1452
+ z.parent = SENTINEL;
1453
+ z.size_left = 0;
1454
+ z.lf_left = 0;
1455
+ if (this.root === SENTINEL) {
1456
+ this.root = z;
1457
+ z.color = 0 /* NodeColor.Black */;
1458
+ }
1459
+ else if (node.left === SENTINEL) {
1460
+ node.left = z;
1461
+ z.parent = node;
1462
+ }
1463
+ else {
1464
+ const prevNode = righttest(node.left); // a
1465
+ prevNode.right = z;
1466
+ z.parent = prevNode;
1467
+ }
1468
+ fixInsert(this, z);
1469
+ return z;
1470
+ }
1471
+ }
1472
+
1473
+ export { Piece, PieceTreeBase, StringBuffer, createLineStarts, createLineStartsFast };