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.
- package/dist/index.d.ts +1 -8
- package/dist/monaco-editor11.es.js +1 -49
- package/dist/monaco-editor11.umd.js +1 -1
- package/dist/workers/_.contribution.js +120 -0
- package/dist/workers/abap.contribution.js +8 -0
- package/dist/workers/abap.js +1397 -0
- package/dist/workers/abstractCodeEditorService.js +129 -0
- package/dist/workers/abstractKeybindingService.js +286 -0
- package/dist/workers/abstractScrollbar.js +214 -0
- package/dist/workers/abstractSyntaxTokenBackend.js +128 -0
- package/dist/workers/abstractText.js +89 -0
- package/dist/workers/abstractTree.js +2027 -0
- package/dist/workers/accessibility.js +11 -0
- package/dist/workers/accessibilityService.js +111 -0
- package/dist/workers/accessibilitySignalService.js +331 -0
- package/dist/workers/accessibleDiffViewer.js +588 -0
- package/dist/workers/accessibleViewRegistry.js +25 -0
- package/dist/workers/action.js +15 -0
- package/dist/workers/actionCommonCategories.js +16 -0
- package/dist/workers/actionList.js +344 -0
- package/dist/workers/actionViewItemService.js +29 -0
- package/dist/workers/actionViewItems.js +376 -0
- package/dist/workers/actionWidget.js +236 -0
- package/dist/workers/actionbar.js +462 -0
- package/dist/workers/actions.js +483 -0
- package/dist/workers/anchorSelect.js +160 -0
- package/dist/workers/animation.js +74 -0
- package/dist/workers/apex.contribution.js +9 -0
- package/dist/workers/apex.js +329 -0
- package/dist/workers/aria.js +84 -0
- package/dist/workers/arrays.js +529 -0
- package/dist/workers/arraysFind.js +177 -0
- package/dist/workers/assert.js +79 -0
- package/dist/workers/ast.js +485 -0
- package/dist/workers/async.js +938 -0
- package/dist/workers/asyncDataTree.js +946 -0
- package/dist/workers/autoIndent.js +390 -0
- package/dist/workers/autorun.js +89 -0
- package/dist/workers/autorunImpl.js +215 -0
- package/dist/workers/azcli.contribution.js +8 -0
- package/dist/workers/azcli.js +67 -0
- package/dist/workers/bannerController.js +118 -0
- package/dist/workers/base.js +19 -0
- package/dist/workers/baseColors.js +31 -0
- package/dist/workers/baseObservable.js +106 -0
- package/dist/workers/baseRenderStrategy.js +19 -0
- package/dist/workers/baseResolvedKeybinding.js +56 -0
- package/dist/workers/bat.contribution.js +8 -0
- package/dist/workers/bat.js +99 -0
- package/dist/workers/beforeEditPositionMapper.js +110 -0
- package/dist/workers/bicep.contribution.js +8 -0
- package/dist/workers/bicep.js +108 -0
- package/dist/workers/blockCommentCommand.js +149 -0
- package/dist/workers/blockDecorations.js +97 -0
- package/dist/workers/bracketMatching.js +359 -0
- package/dist/workers/bracketPairsImpl.js +717 -0
- package/dist/workers/bracketPairsTree.js +343 -0
- package/dist/workers/bracketSelections.js +149 -0
- package/dist/workers/brackets.js +108 -0
- package/dist/workers/browser.js +57 -0
- package/dist/workers/buffer.js +81 -0
- package/dist/workers/bufferDirtyTracker.js +45 -0
- package/dist/workers/bulkEditService.js +76 -0
- package/dist/workers/button.js +226 -0
- package/dist/workers/cache.js +61 -0
- package/dist/workers/cameligo.contribution.js +8 -0
- package/dist/workers/cameligo.js +173 -0
- package/dist/workers/canIUse.js +23 -0
- package/dist/workers/cancellation.js +116 -0
- package/dist/workers/caretOperations.js +48 -0
- package/dist/workers/changeRecorder.js +78 -0
- package/dist/workers/changeTracker.js +80 -0
- package/dist/workers/charWidthReader.js +104 -0
- package/dist/workers/characterClassifier.js +59 -0
- package/dist/workers/characterPair.js +40 -0
- package/dist/workers/chartsColors.js +18 -0
- package/dist/workers/clickLinkGesture.js +161 -0
- package/dist/workers/clipboard.js +308 -0
- package/dist/workers/clipboardService.js +9 -0
- package/dist/workers/clipboardUtils.js +85 -0
- package/dist/workers/clojure.contribution.js +8 -0
- package/dist/workers/clojure.js +760 -0
- package/dist/workers/codeAction.js +306 -0
- package/dist/workers/codeActionCommands.js +230 -0
- package/dist/workers/codeActionContributions.js +55 -0
- package/dist/workers/codeActionController.js +372 -0
- package/dist/workers/codeActionKeybindingResolver.js +90 -0
- package/dist/workers/codeActionMenu.js +68 -0
- package/dist/workers/codeActionModel.js +334 -0
- package/dist/workers/codeEditorContributions.js +132 -0
- package/dist/workers/codeEditorService.js +9 -0
- package/dist/workers/codeEditorWidget.js +1856 -0
- package/dist/workers/codeLensCache.js +112 -0
- package/dist/workers/codelens.js +114 -0
- package/dist/workers/codelensController.js +469 -0
- package/dist/workers/codelensWidget.js +265 -0
- package/dist/workers/codicons.js +50 -0
- package/dist/workers/codiconsLibrary.js +642 -0
- package/dist/workers/codiconsUtil.js +22 -0
- package/dist/workers/coffee.contribution.js +9 -0
- package/dist/workers/coffee.js +231 -0
- package/dist/workers/collections.js +98 -0
- package/dist/workers/color.js +94 -0
- package/dist/workers/colorDetector.js +245 -0
- package/dist/workers/colorPickerBody.js +71 -0
- package/dist/workers/colorPickerCloseButton.js +34 -0
- package/dist/workers/colorPickerContribution.js +50 -0
- package/dist/workers/colorPickerHeader.js +79 -0
- package/dist/workers/colorPickerInsertButton.js +27 -0
- package/dist/workers/colorPickerModel.js +74 -0
- package/dist/workers/colorPickerParticipantUtils.js +52 -0
- package/dist/workers/colorPickerSaturationBox.js +106 -0
- package/dist/workers/colorPickerStrip.js +98 -0
- package/dist/workers/colorPickerWidget.js +32 -0
- package/dist/workers/colorUtils.js +199 -0
- package/dist/workers/colorizedBracketPairsDecorationProvider.js +97 -0
- package/dist/workers/colorizer.js +120 -0
- package/dist/workers/colors.js +20 -0
- package/dist/workers/columnRange.js +35 -0
- package/dist/workers/combineTextEditInfos.js +124 -0
- package/dist/workers/commandIds.js +12 -0
- package/dist/workers/commands.js +329 -0
- package/dist/workers/commandsQuickAccess.js +40 -0
- package/dist/workers/comment.js +147 -0
- package/dist/workers/common.js +20 -0
- package/dist/workers/comparers.js +87 -0
- package/dist/workers/completionModel.js +227 -0
- package/dist/workers/compressedObjectTreeModel.js +385 -0
- package/dist/workers/computeGhostText.js +182 -0
- package/dist/workers/computeMovedLines.js +249 -0
- package/dist/workers/concat23Trees.js +192 -0
- package/dist/workers/configuration.js +92 -0
- package/dist/workers/configurationModels.js +614 -0
- package/dist/workers/configurationRegistry.js +400 -0
- package/dist/workers/configurations.js +46 -0
- package/dist/workers/consoleObservableLogger.js +83 -0
- package/dist/workers/constObservable.js +35 -0
- package/dist/workers/contentHoverComputer.js +71 -0
- package/dist/workers/contentHoverController.js +320 -0
- package/dist/workers/contentHoverRendered.js +336 -0
- package/dist/workers/contentHoverStatusBar.js +52 -0
- package/dist/workers/contentHoverTypes.js +29 -0
- package/dist/workers/contentHoverWidget.js +394 -0
- package/dist/workers/contentHoverWidgetWrapper.js +362 -0
- package/dist/workers/contentSegmenter.js +52 -0
- package/dist/workers/contentWidgets.js +495 -0
- package/dist/workers/contextKeyService.js +468 -0
- package/dist/workers/contextMenuHandler.js +126 -0
- package/dist/workers/contextMenuService.js +103 -0
- package/dist/workers/contextScopedHistoryWidget.js +106 -0
- package/dist/workers/contextViewService.js +73 -0
- package/dist/workers/contextkey.js +1551 -0
- package/dist/workers/contextkeys.js +21 -0
- package/dist/workers/contextmenu.js +334 -0
- package/dist/workers/contextview.js +298 -0
- package/dist/workers/contiguousMultilineTokens.js +32 -0
- package/dist/workers/contiguousMultilineTokensBuilder.js +23 -0
- package/dist/workers/contiguousTokensEditing.js +128 -0
- package/dist/workers/contiguousTokensStore.js +207 -0
- package/dist/workers/contribution.js +36 -0
- package/dist/workers/coordinatesConverter.js +51 -0
- package/dist/workers/copyLinesCommand.js +73 -0
- package/dist/workers/copyPasteContribution.js +114 -0
- package/dist/workers/copyPasteController.js +585 -0
- package/dist/workers/copySelection.js +47 -0
- package/dist/workers/coreCommands.js +1731 -0
- package/dist/workers/countBadge.js +52 -0
- package/dist/workers/cpp.contribution.js +14 -0
- package/dist/workers/cpp.js +388 -0
- package/dist/workers/csharp.contribution.js +8 -0
- package/dist/workers/csharp.js +325 -0
- package/dist/workers/csp.contribution.js +8 -0
- package/dist/workers/csp.js +52 -0
- package/dist/workers/css.contribution.js +9 -0
- package/dist/workers/css.js +184 -0
- package/dist/workers/cssMode.js +198 -0
- package/dist/workers/cssValue.js +69 -0
- package/dist/workers/cssWorker.js +183 -0
- package/dist/workers/currentLineHighlight.js +205 -0
- package/dist/workers/cursor.js +899 -0
- package/dist/workers/cursorAtomicMoveOperations.js +145 -0
- package/dist/workers/cursorCollection.js +194 -0
- package/dist/workers/cursorColumnSelection.js +93 -0
- package/dist/workers/cursorColumns.js +112 -0
- package/dist/workers/cursorCommon.js +250 -0
- package/dist/workers/cursorContext.js +15 -0
- package/dist/workers/cursorDeleteOperations.js +231 -0
- package/dist/workers/cursorMoveCommands.js +676 -0
- package/dist/workers/cursorMoveOperations.js +290 -0
- package/dist/workers/cursorTypeEditOperations.js +968 -0
- package/dist/workers/cursorTypeOperations.js +173 -0
- package/dist/workers/cursorUndo.js +133 -0
- package/dist/workers/cursorUtils.js +75 -0
- package/dist/workers/cursorWordOperations.js +720 -0
- package/dist/workers/cypher.contribution.js +8 -0
- package/dist/workers/cypher.js +262 -0
- package/dist/workers/dart.contribution.js +9 -0
- package/dist/workers/dart.js +280 -0
- package/dist/workers/dataChannel.js +12 -0
- package/dist/workers/dataTransfer.js +80 -0
- package/dist/workers/dataTree.js +20 -0
- package/dist/workers/date.js +57 -0
- package/dist/workers/debugLocation.js +66 -0
- package/dist/workers/debugName.js +110 -0
- package/dist/workers/debuggerRpc.js +67 -0
- package/dist/workers/decorationCssRuleExtractor.js +73 -0
- package/dist/workers/decorationStyleCache.js +40 -0
- package/dist/workers/decorations.js +196 -0
- package/dist/workers/decorationsOverviewRuler.js +416 -0
- package/dist/workers/decorators.js +33 -0
- package/dist/workers/defaultDocumentColorProvider.js +55 -0
- package/dist/workers/defaultDocumentColorsComputer.js +138 -0
- package/dist/workers/defaultLinesDiffComputer.js +188 -0
- package/dist/workers/defaultProviders.js +230 -0
- package/dist/workers/defaultStyles.js +194 -0
- package/dist/workers/delegatingEditorImpl.js +111 -0
- package/dist/workers/derived.js +80 -0
- package/dist/workers/derivedImpl.js +353 -0
- package/dist/workers/descriptors.js +13 -0
- package/dist/workers/devToolsLogger.js +442 -0
- package/dist/workers/dialogs.js +5 -0
- package/dist/workers/diff.js +902 -0
- package/dist/workers/diffAlgorithm.js +139 -0
- package/dist/workers/diffChange.js +34 -0
- package/dist/workers/diffEditor.contribution.js +83 -0
- package/dist/workers/diffEditor.js +38 -0
- package/dist/workers/diffEditorDecorations.js +115 -0
- package/dist/workers/diffEditorEditors.js +190 -0
- package/dist/workers/diffEditorItemTemplate.js +272 -0
- package/dist/workers/diffEditorOptions.js +152 -0
- package/dist/workers/diffEditorSash.js +86 -0
- package/dist/workers/diffEditorViewModel.js +608 -0
- package/dist/workers/diffEditorViewZones.js +525 -0
- package/dist/workers/diffEditorWidget.js +590 -0
- package/dist/workers/diffProviderFactoryService.js +142 -0
- package/dist/workers/dnd.js +198 -0
- package/dist/workers/dockerfile.contribution.js +9 -0
- package/dist/workers/dockerfile.js +129 -0
- package/dist/workers/documentSemanticTokens.js +362 -0
- package/dist/workers/documentSymbols.js +24 -0
- package/dist/workers/dom.js +1454 -0
- package/dist/workers/domFontInfo.js +28 -0
- package/dist/workers/domLineBreaksComputer.js +301 -0
- package/dist/workers/domReadingContext.js +43 -0
- package/dist/workers/domSanitize.js +312 -0
- package/dist/workers/domStylesheets.js +145 -0
- package/dist/workers/dompurify.js +1347 -0
- package/dist/workers/dragAndDropCommand.js +65 -0
- package/dist/workers/dragScrolling.js +174 -0
- package/dist/workers/dropIntoEditorContribution.js +41 -0
- package/dist/workers/dropIntoEditorController.js +173 -0
- package/dist/workers/dropdown.js +141 -0
- package/dist/workers/dropdownActionViewItem.js +109 -0
- package/dist/workers/dynamicProgrammingDiffing.js +101 -0
- package/dist/workers/dynamicViewOverlay.js +10 -0
- package/dist/workers/ecl.contribution.js +8 -0
- package/dist/workers/ecl.js +455 -0
- package/dist/workers/edcore.main.js +74 -0
- package/dist/workers/edit.js +83 -0
- package/dist/workers/editContext.js +10 -0
- package/dist/workers/editContextFactory.js +16 -0
- package/dist/workers/editOperation.js +36 -0
- package/dist/workers/editStack.js +363 -0
- package/dist/workers/editor.all.js +65 -0
- package/dist/workers/editor.api.js +2 -0
- package/dist/workers/editor.api2.js +60 -0
- package/dist/workers/editor.js +15 -0
- package/dist/workers/editor.main.js +170 -0
- package/dist/workers/editor.worker.start.js +44 -0
- package/dist/workers/editorAction.js +26 -0
- package/dist/workers/editorBaseApi.js +43 -0
- package/dist/workers/editorBrowser.js +53 -0
- package/dist/workers/editorColorRegistry.js +102 -0
- package/dist/workers/editorColors.js +128 -0
- package/dist/workers/editorCommon.js +13 -0
- package/dist/workers/editorConfiguration.js +292 -0
- package/dist/workers/editorConfigurationSchema.js +338 -0
- package/dist/workers/editorContextKeys.js +84 -0
- package/dist/workers/editorDom.js +299 -0
- package/dist/workers/editorExtensions.js +489 -0
- package/dist/workers/editorFeatures.js +17 -0
- package/dist/workers/editorGutter.js +117 -0
- package/dist/workers/editorMarkdownCodeBlockRenderer.js +85 -0
- package/dist/workers/editorNavigationQuickAccess.js +152 -0
- package/dist/workers/editorOptions.js +3440 -0
- package/dist/workers/editorScrollbar.js +151 -0
- package/dist/workers/editorState.js +115 -0
- package/dist/workers/editorTheme.js +23 -0
- package/dist/workers/editorWebWorker.js +299 -0
- package/dist/workers/editorWorker.js +9 -0
- package/dist/workers/editorWorkerHost.js +15 -0
- package/dist/workers/editorWorkerService.js +366 -0
- package/dist/workers/editorZoom.js +26 -0
- package/dist/workers/electricCharacter.js +55 -0
- package/dist/workers/elementSizeObserver.js +107 -0
- package/dist/workers/elixir.contribution.js +8 -0
- package/dist/workers/elixir.js +568 -0
- package/dist/workers/embeddedCodeEditorWidget.js +66 -0
- package/dist/workers/encodedTokenAttributes.js +79 -0
- package/dist/workers/enterAction.js +53 -0
- package/dist/workers/environment.js +5 -0
- package/dist/workers/eolCounter.js +44 -0
- package/dist/workers/equals.js +84 -0
- package/dist/workers/errorMessage.js +71 -0
- package/dist/workers/errors.js +163 -0
- package/dist/workers/event.js +1197 -0
- package/dist/workers/extensions.js +18 -0
- package/dist/workers/extpath.js +147 -0
- package/dist/workers/fastDomNode.js +255 -0
- package/dist/workers/files.js +19 -0
- package/dist/workers/filters.js +742 -0
- package/dist/workers/findController.js +970 -0
- package/dist/workers/findDecorations.js +311 -0
- package/dist/workers/findInput.js +294 -0
- package/dist/workers/findInputToggles.js +52 -0
- package/dist/workers/findModel.js +497 -0
- package/dist/workers/findOptionsWidget.js +155 -0
- package/dist/workers/findSectionHeaders.js +128 -0
- package/dist/workers/findState.js +244 -0
- package/dist/workers/findWidget.js +1168 -0
- package/dist/workers/findWidgetSearchHistory.js +85 -0
- package/dist/workers/fixBrackets.js +67 -0
- package/dist/workers/fixedArray.js +70 -0
- package/dist/workers/floatingMenu.contribution.js +9 -0
- package/dist/workers/floatingMenu.js +94 -0
- package/dist/workers/flow9.contribution.js +8 -0
- package/dist/workers/flow9.js +141 -0
- package/dist/workers/folding.js +1136 -0
- package/dist/workers/foldingDecorations.js +158 -0
- package/dist/workers/foldingModel.js +532 -0
- package/dist/workers/foldingRanges.js +354 -0
- package/dist/workers/fontInfo.js +172 -0
- package/dist/workers/fontInfoFromSettings.js +29 -0
- package/dist/workers/fontMeasurements.js +206 -0
- package/dist/workers/fontZoom.js +47 -0
- package/dist/workers/fonts.js +17 -0
- package/dist/workers/format.js +367 -0
- package/dist/workers/formatActions.js +263 -0
- package/dist/workers/formattedTextRenderer.js +160 -0
- package/dist/workers/formattingEdit.js +57 -0
- package/dist/workers/forwardingTelemetryService.js +60 -0
- package/dist/workers/freemarker2.contribution.js +52 -0
- package/dist/workers/freemarker2.js +1062 -0
- package/dist/workers/fsharp.contribution.js +8 -0
- package/dist/workers/fsharp.js +216 -0
- package/dist/workers/fullFileRenderStrategy.js +414 -0
- package/dist/workers/fullFileRenderStrategy.wgsl.js +93 -0
- package/dist/workers/functional.js +24 -0
- package/dist/workers/fuzzyScorer.js +143 -0
- package/dist/workers/getHover.js +56 -0
- package/dist/workers/getIconClasses.js +106 -0
- package/dist/workers/getLinks.js +157 -0
- package/dist/workers/getPositionOffsetTransformerFromTextModel.js +24 -0
- package/dist/workers/getSemanticTokens.js +211 -0
- package/dist/workers/ghostText.js +111 -0
- package/dist/workers/ghostTextView.js +449 -0
- package/dist/workers/glob.js +581 -0
- package/dist/workers/globalPointerMoveMonitor.js +83 -0
- package/dist/workers/glyphHoverComputer.js +40 -0
- package/dist/workers/glyphHoverController.js +171 -0
- package/dist/workers/glyphHoverWidget.js +184 -0
- package/dist/workers/glyphLanesModel.js +61 -0
- package/dist/workers/glyphMargin.js +403 -0
- package/dist/workers/glyphRasterizer.js +276 -0
- package/dist/workers/go.contribution.js +8 -0
- package/dist/workers/go.js +217 -0
- package/dist/workers/goToCommands.js +694 -0
- package/dist/workers/goToDefinitionAtPosition.js +267 -0
- package/dist/workers/goToSymbol.js +128 -0
- package/dist/workers/gotoError.js +272 -0
- package/dist/workers/gotoErrorWidget.js +352 -0
- package/dist/workers/gotoLineQuickAccess.js +183 -0
- package/dist/workers/gotoSymbolQuickAccess.js +395 -0
- package/dist/workers/gpuActions.js +126 -0
- package/dist/workers/gpuDisposable.js +48 -0
- package/dist/workers/gpuMark.js +80 -0
- package/dist/workers/gpuUtils.js +58 -0
- package/dist/workers/graph.js +74 -0
- package/dist/workers/graphql.contribution.js +9 -0
- package/dist/workers/graphql.js +150 -0
- package/dist/workers/guidesTextModelPart.js +405 -0
- package/dist/workers/gutterFeature.js +238 -0
- package/dist/workers/gutterIndicatorMenu.js +252 -0
- package/dist/workers/gutterIndicatorView.js +456 -0
- package/dist/workers/handlebars.contribution.js +9 -0
- package/dist/workers/handlebars.js +485 -0
- package/dist/workers/hash.js +256 -0
- package/dist/workers/hcl.contribution.js +8 -0
- package/dist/workers/hcl.js +182 -0
- package/dist/workers/helpQuickAccess.js +77 -0
- package/dist/workers/heuristicSequenceOptimizations.js +374 -0
- package/dist/workers/hiddenRangeModel.js +126 -0
- package/dist/workers/hideUnchangedRegionsFeature.js +433 -0
- package/dist/workers/hierarchicalKind.js +26 -0
- package/dist/workers/highlightDecorations.js +111 -0
- package/dist/workers/highlightedLabel.js +129 -0
- package/dist/workers/history.js +85 -0
- package/dist/workers/historyWidgetKeybindingHint.js +9 -0
- package/dist/workers/horizontalScrollbar.js +91 -0
- package/dist/workers/hotReloadHelpers.js +17 -0
- package/dist/workers/hover.js +11 -0
- package/dist/workers/hoverAccessibleViews.js +8 -0
- package/dist/workers/hoverActionIds.js +23 -0
- package/dist/workers/hoverActions.js +424 -0
- package/dist/workers/hoverColorPicker.js +14 -0
- package/dist/workers/hoverColorPickerContribution.js +44 -0
- package/dist/workers/hoverColorPickerParticipant.js +151 -0
- package/dist/workers/hoverContribution.js +56 -0
- package/dist/workers/hoverCopyButton.js +54 -0
- package/dist/workers/hoverDelegate2.js +39 -0
- package/dist/workers/hoverDelegateFactory.js +34 -0
- package/dist/workers/hoverOperation.js +168 -0
- package/dist/workers/hoverParticipant.js +161 -0
- package/dist/workers/hoverService.js +542 -0
- package/dist/workers/hoverTypes.js +64 -0
- package/dist/workers/hoverUtils.js +18 -0
- package/dist/workers/hoverWidget.js +93 -0
- package/dist/workers/html.contribution.js +9 -0
- package/dist/workers/html.js +374 -0
- package/dist/workers/htmlContent.js +164 -0
- package/dist/workers/htmlMode.js +213 -0
- package/dist/workers/htmlWorker.js +126 -0
- package/dist/workers/iPadShowKeyboard.js +74 -0
- package/dist/workers/iconLabel.js +291 -0
- package/dist/workers/iconLabels.js +33 -0
- package/dist/workers/iconRegistry.js +183 -0
- package/dist/workers/iconsStyleSheet.js +75 -0
- package/dist/workers/idGenerator.js +16 -0
- package/dist/workers/iframe.js +87 -0
- package/dist/workers/ime.js +33 -0
- package/dist/workers/inPlaceReplace.js +151 -0
- package/dist/workers/inPlaceReplaceCommand.js +27 -0
- package/dist/workers/indentGuides.js +254 -0
- package/dist/workers/indentRangeProvider.js +166 -0
- package/dist/workers/indentRules.js +63 -0
- package/dist/workers/indentUtils.js +33 -0
- package/dist/workers/indentation.js +100 -0
- package/dist/workers/indentationGuesser.js +178 -0
- package/dist/workers/indentationLineProcessor.js +193 -0
- package/dist/workers/index.js +21 -0
- package/dist/workers/indexTreeModel.js +538 -0
- package/dist/workers/ini.contribution.js +9 -0
- package/dist/workers/ini.js +70 -0
- package/dist/workers/initialize.js +11 -0
- package/dist/workers/inlayHints.js +147 -0
- package/dist/workers/inlayHintsContribution.js +11 -0
- package/dist/workers/inlayHintsController.js +686 -0
- package/dist/workers/inlayHintsHover.js +162 -0
- package/dist/workers/inlayHintsLocations.js +96 -0
- package/dist/workers/inlineCompletionContextKeys.js +23 -0
- package/dist/workers/inlineCompletions.contribution.js +31 -0
- package/dist/workers/inlineCompletionsAccessibleView.js +4 -0
- package/dist/workers/inlineCompletionsController.js +427 -0
- package/dist/workers/inlineCompletionsHintsWidget.js +356 -0
- package/dist/workers/inlineCompletionsModel.js +1048 -0
- package/dist/workers/inlineCompletionsService.js +170 -0
- package/dist/workers/inlineCompletionsSource.js +548 -0
- package/dist/workers/inlineCompletionsView.js +86 -0
- package/dist/workers/inlineDecorations.js +26 -0
- package/dist/workers/inlineDiffDeletedCodeMargin.js +138 -0
- package/dist/workers/inlineEdit.js +17 -0
- package/dist/workers/inlineEditWithChanges.js +30 -0
- package/dist/workers/inlineEditsCollapsedView.js +132 -0
- package/dist/workers/inlineEditsCustomView.js +256 -0
- package/dist/workers/inlineEditsDeletionView.js +178 -0
- package/dist/workers/inlineEditsInsertionView.js +267 -0
- package/dist/workers/inlineEditsLineReplacementView.js +329 -0
- package/dist/workers/inlineEditsModel.js +59 -0
- package/dist/workers/inlineEditsNewUsers.js +174 -0
- package/dist/workers/inlineEditsSideBySideView.js +517 -0
- package/dist/workers/inlineEditsView.js +561 -0
- package/dist/workers/inlineEditsViewInterface.js +21 -0
- package/dist/workers/inlineEditsViewProducer.js +119 -0
- package/dist/workers/inlineEditsWordReplacementView.js +211 -0
- package/dist/workers/inlineProgress.js +139 -0
- package/dist/workers/inlineSuggestionItem.js +497 -0
- package/dist/workers/inplaceReplaceSupport.js +87 -0
- package/dist/workers/inputBox.js +510 -0
- package/dist/workers/inputColors.js +66 -0
- package/dist/workers/inputMode.js +22 -0
- package/dist/workers/insertFinalNewLine.js +32 -0
- package/dist/workers/insertFinalNewLineCommand.js +39 -0
- package/dist/workers/inspectTokens.js +240 -0
- package/dist/workers/instantiation.js +44 -0
- package/dist/workers/instantiationService.js +403 -0
- package/dist/workers/intervalTree.js +1002 -0
- package/dist/workers/iterator.js +186 -0
- package/dist/workers/java.contribution.js +9 -0
- package/dist/workers/java.js +231 -0
- package/dist/workers/javascript.contribution.js +11 -0
- package/dist/workers/javascript.js +70 -0
- package/dist/workers/jsonContributionRegistry.js +42 -0
- package/dist/workers/jsonMode.js +224 -0
- package/dist/workers/jsonWorker.js +187 -0
- package/dist/workers/julia.contribution.js +8 -0
- package/dist/workers/julia.js +510 -0
- package/dist/workers/keyCodes.js +351 -0
- package/dist/workers/keybinding.js +9 -0
- package/dist/workers/keybindingCancellation.js +81 -0
- package/dist/workers/keybindingLabel.js +122 -0
- package/dist/workers/keybindingLabels.js +139 -0
- package/dist/workers/keybindingResolver.js +304 -0
- package/dist/workers/keybindings.js +104 -0
- package/dist/workers/keybindingsRegistry.js +111 -0
- package/dist/workers/keyboardEvent.js +125 -0
- package/dist/workers/korean.js +321 -0
- package/dist/workers/kotlin.contribution.js +9 -0
- package/dist/workers/kotlin.js +251 -0
- package/dist/workers/label.js +5 -0
- package/dist/workers/labels.js +15 -0
- package/dist/workers/language.js +9 -0
- package/dist/workers/languageBracketsConfiguration.js +133 -0
- package/dist/workers/languageConfiguration.js +138 -0
- package/dist/workers/languageConfigurationRegistry.js +361 -0
- package/dist/workers/languageFeatureDebounce.js +137 -0
- package/dist/workers/languageFeatureRegistry.js +180 -0
- package/dist/workers/languageFeatures.js +9 -0
- package/dist/workers/languageFeaturesService.js +47 -0
- package/dist/workers/languageSelector.js +112 -0
- package/dist/workers/languageService.js +92 -0
- package/dist/workers/languages.js +522 -0
- package/dist/workers/languagesAssociations.js +193 -0
- package/dist/workers/languagesRegistry.js +237 -0
- package/dist/workers/layoutService.js +9 -0
- package/dist/workers/lazy.js +49 -0
- package/dist/workers/lazyObservableValue.js +125 -0
- package/dist/workers/legacyLinesDiffComputer.js +468 -0
- package/dist/workers/length.js +129 -0
- package/dist/workers/less.contribution.js +9 -0
- package/dist/workers/less.js +160 -0
- package/dist/workers/lexon.contribution.js +8 -0
- package/dist/workers/lexon.js +156 -0
- package/dist/workers/lib.index.js +103 -0
- package/dist/workers/lib.js +1107 -0
- package/dist/workers/lifecycle.js +311 -0
- package/dist/workers/lightBulbWidget.js +427 -0
- package/dist/workers/lineCommentCommand.js +328 -0
- package/dist/workers/lineDecorations.js +208 -0
- package/dist/workers/lineEdit.js +75 -0
- package/dist/workers/lineHeights.js +370 -0
- package/dist/workers/lineNumbers.js +184 -0
- package/dist/workers/linePart.js +25 -0
- package/dist/workers/lineRange.js +312 -0
- package/dist/workers/lineSelection.js +36 -0
- package/dist/workers/lineSequence.js +36 -0
- package/dist/workers/lineTokens.js +405 -0
- package/dist/workers/linesDecorations.js +104 -0
- package/dist/workers/linesDiffComputer.js +29 -0
- package/dist/workers/linesDiffComputers.js +13 -0
- package/dist/workers/linesLayout.js +765 -0
- package/dist/workers/linesOperations.js +1187 -0
- package/dist/workers/linesSliceCharSequence.js +205 -0
- package/dist/workers/link.js +95 -0
- package/dist/workers/linkComputer.js +269 -0
- package/dist/workers/linkedEditing.js +381 -0
- package/dist/workers/linkedList.js +126 -0
- package/dist/workers/linkedText.js +48 -0
- package/dist/workers/links.js +376 -0
- package/dist/workers/liquid.contribution.js +9 -0
- package/dist/workers/liquid.js +306 -0
- package/dist/workers/list.js +11 -0
- package/dist/workers/listColors.js +51 -0
- package/dist/workers/listPaging.js +128 -0
- package/dist/workers/listService.js +1025 -0
- package/dist/workers/listView.js +1173 -0
- package/dist/workers/listWidget.js +1535 -0
- package/dist/workers/log.js +271 -0
- package/dist/workers/logService.js +40 -0
- package/dist/workers/logging.js +86 -0
- package/dist/workers/longLinesHelper.js +23 -0
- package/dist/workers/lspLanguageFeatures.js +716 -0
- package/dist/workers/lua.contribution.js +8 -0
- package/dist/workers/lua.js +161 -0
- package/dist/workers/m3.contribution.js +8 -0
- package/dist/workers/m3.js +209 -0
- package/dist/workers/map.js +670 -0
- package/dist/workers/margin.js +71 -0
- package/dist/workers/marginDecorations.js +84 -0
- package/dist/workers/markdown.contribution.js +8 -0
- package/dist/workers/markdown.js +228 -0
- package/dist/workers/markdownHoverParticipant.js +419 -0
- package/dist/workers/markdownRenderer.js +73 -0
- package/dist/workers/marked.js +2478 -0
- package/dist/workers/markerDecorations.js +9 -0
- package/dist/workers/markerDecorationsService.js +248 -0
- package/dist/workers/markerHoverParticipant.js +270 -0
- package/dist/workers/markerNavigationService.js +223 -0
- package/dist/workers/markerService.js +330 -0
- package/dist/workers/markers.js +127 -0
- package/dist/workers/marshalling.js +62 -0
- package/dist/workers/mdx.contribution.js +8 -0
- package/dist/workers/mdx.js +230 -0
- package/dist/workers/menu.js +1147 -0
- package/dist/workers/menuColors.js +19 -0
- package/dist/workers/menuEntryActionViewItem.js +519 -0
- package/dist/workers/menuService.js +436 -0
- package/dist/workers/messageController.js +186 -0
- package/dist/workers/middleScroll.contribution.js +8 -0
- package/dist/workers/middleScrollController.js +128 -0
- package/dist/workers/migrateOptions.js +220 -0
- package/dist/workers/mime.js +11 -0
- package/dist/workers/minimap.js +1662 -0
- package/dist/workers/minimapCharRenderer.js +90 -0
- package/dist/workers/minimapCharRendererFactory.js +136 -0
- package/dist/workers/minimapCharSheet.js +25 -0
- package/dist/workers/minimapColors.js +23 -0
- package/dist/workers/minimapPreBaked.js +52 -0
- package/dist/workers/minimapTokensColorTracker.js +58 -0
- package/dist/workers/mips.contribution.js +9 -0
- package/dist/workers/mips.js +197 -0
- package/dist/workers/mirrorTextModel.js +117 -0
- package/dist/workers/miscColors.js +32 -0
- package/dist/workers/model.js +9 -0
- package/dist/workers/modelLineProjection.js +350 -0
- package/dist/workers/modelLineProjectionData.js +297 -0
- package/dist/workers/modelService.js +413 -0
- package/dist/workers/modesRegistry.js +75 -0
- package/dist/workers/monaco.contribution.js +302 -0
- package/dist/workers/monarchCommon.js +147 -0
- package/dist/workers/monarchCompile.js +546 -0
- package/dist/workers/monarchLexer.js +764 -0
- package/dist/workers/monospaceLineBreaksComputer.js +473 -0
- package/dist/workers/mouseCursor.js +9 -0
- package/dist/workers/mouseEvent.js +153 -0
- package/dist/workers/mouseHandler.js +539 -0
- package/dist/workers/mouseTarget.js +978 -0
- package/dist/workers/moveCaretCommand.js +49 -0
- package/dist/workers/moveLinesCommand.js +394 -0
- package/dist/workers/movedBlocksLinesFeature.js +277 -0
- package/dist/workers/msdax.contribution.js +8 -0
- package/dist/workers/msdax.js +374 -0
- package/dist/workers/multiDiffEditorWidget.js +43 -0
- package/dist/workers/multiDiffEditorWidgetImpl.js +427 -0
- package/dist/workers/multicursor.js +1004 -0
- package/dist/workers/myersDiffAlgorithm.js +159 -0
- package/dist/workers/mysql.contribution.js +8 -0
- package/dist/workers/mysql.js +877 -0
- package/dist/workers/nativeEditContext.js +518 -0
- package/dist/workers/nativeEditContextRegistry.js +23 -0
- package/dist/workers/nativeEditContextUtils.js +85 -0
- package/dist/workers/navigator.js +36 -0
- package/dist/workers/network.js +267 -0
- package/dist/workers/nls.js +76 -0
- package/dist/workers/nls.messages.js +18 -0
- package/dist/workers/nodeReader.js +127 -0
- package/dist/workers/normalization.js +41 -0
- package/dist/workers/notification.js +9 -0
- package/dist/workers/nullTokenize.js +29 -0
- package/dist/workers/numbers.js +45 -0
- package/dist/workers/objectCollectionBuffer.js +102 -0
- package/dist/workers/objectPool.js +47 -0
- package/dist/workers/objectTree.js +204 -0
- package/dist/workers/objectTreeModel.js +220 -0
- package/dist/workers/objective-c.contribution.js +8 -0
- package/dist/workers/objective-c.js +182 -0
- package/dist/workers/objects.js +152 -0
- package/dist/workers/observableCodeEditor.js +373 -0
- package/dist/workers/observableFromEvent.js +123 -0
- package/dist/workers/observableSignal.js +47 -0
- package/dist/workers/observableSignalFromEvent.js +41 -0
- package/dist/workers/observableValue.js +105 -0
- package/dist/workers/observableValueOpts.js +20 -0
- package/dist/workers/offsetRange.js +225 -0
- package/dist/workers/onEnter.js +109 -0
- package/dist/workers/oneCursor.js +117 -0
- package/dist/workers/opener.js +43 -0
- package/dist/workers/openerService.js +222 -0
- package/dist/workers/originalEditorInlineDiffView.js +215 -0
- package/dist/workers/outlineModel.js +265 -0
- package/dist/workers/overlayWidgets.js +181 -0
- package/dist/workers/overviewRuler.js +134 -0
- package/dist/workers/overviewRulerFeature.js +168 -0
- package/dist/workers/overviewZoneManager.js +176 -0
- package/dist/workers/parameterHints.js +126 -0
- package/dist/workers/parameterHintsModel.js +258 -0
- package/dist/workers/parameterHintsWidget.js +318 -0
- package/dist/workers/parser.js +121 -0
- package/dist/workers/pascal.contribution.js +9 -0
- package/dist/workers/pascal.js +250 -0
- package/dist/workers/pascaligo.contribution.js +8 -0
- package/dist/workers/pascaligo.js +163 -0
- package/dist/workers/path.js +1451 -0
- package/dist/workers/peekView.js +246 -0
- package/dist/workers/performance.js +222 -0
- package/dist/workers/perl.contribution.js +8 -0
- package/dist/workers/perl.js +625 -0
- package/dist/workers/pgsql.contribution.js +8 -0
- package/dist/workers/pgsql.js +850 -0
- package/dist/workers/php.contribution.js +9 -0
- package/dist/workers/php.js +499 -0
- package/dist/workers/pickerQuickAccess.js +271 -0
- package/dist/workers/pieceTreeBase.js +1473 -0
- package/dist/workers/pieceTreeTextBuffer.js +461 -0
- package/dist/workers/pieceTreeTextBufferBuilder.js +140 -0
- package/dist/workers/pixelRatio.js +88 -0
- package/dist/workers/pla.contribution.js +7 -0
- package/dist/workers/pla.js +136 -0
- package/dist/workers/placeholderText.contribution.js +14 -0
- package/dist/workers/placeholderTextContribution.js +77 -0
- package/dist/workers/platform.js +32 -0
- package/dist/workers/platformObservableUtils.js +31 -0
- package/dist/workers/point.js +50 -0
- package/dist/workers/pointerHandler.js +132 -0
- package/dist/workers/position.js +142 -0
- package/dist/workers/positionToOffset.js +17 -0
- package/dist/workers/positionToOffsetImpl.js +98 -0
- package/dist/workers/postEditWidget.js +220 -0
- package/dist/workers/postiats.contribution.js +8 -0
- package/dist/workers/postiats.js +906 -0
- package/dist/workers/powerquery.contribution.js +8 -0
- package/dist/workers/powerquery.js +889 -0
- package/dist/workers/powershell.contribution.js +8 -0
- package/dist/workers/powershell.js +238 -0
- package/dist/workers/prefixSumComputer.js +226 -0
- package/dist/workers/process.js +61 -0
- package/dist/workers/product.js +70 -0
- package/dist/workers/productService.js +9 -0
- package/dist/workers/progress.js +16 -0
- package/dist/workers/progressbar.js +105 -0
- package/dist/workers/promise.js +56 -0
- package/dist/workers/protobuf.contribution.js +8 -0
- package/dist/workers/protobuf.js +419 -0
- package/dist/workers/provideInlineCompletions.js +372 -0
- package/dist/workers/provideSignatureHelp.js +59 -0
- package/dist/workers/pug.contribution.js +8 -0
- package/dist/workers/pug.js +401 -0
- package/dist/workers/python.contribution.js +9 -0
- package/dist/workers/python.js +366 -0
- package/dist/workers/qsharp.contribution.js +8 -0
- package/dist/workers/qsharp.js +300 -0
- package/dist/workers/quickAccess.js +56 -0
- package/dist/workers/quickInput.js +108 -0
- package/dist/workers/quickInputActions.js +189 -0
- package/dist/workers/quickInputBox.js +104 -0
- package/dist/workers/quickInputController.js +901 -0
- package/dist/workers/quickInputDelegate.js +19 -0
- package/dist/workers/quickInputList.js +1391 -0
- package/dist/workers/quickInputService.js +197 -0
- package/dist/workers/quickInputTree.js +37 -0
- package/dist/workers/quickInputTreeAccessibilityProvider.js +39 -0
- package/dist/workers/quickInputTreeController.js +181 -0
- package/dist/workers/quickInputTreeFilter.js +42 -0
- package/dist/workers/quickInputTreeRenderer.js +141 -0
- package/dist/workers/quickInputTreeSorter.js +48 -0
- package/dist/workers/quickInputUtils.js +89 -0
- package/dist/workers/quickpickColors.js +21 -0
- package/dist/workers/r.contribution.js +8 -0
- package/dist/workers/r.js +242 -0
- package/dist/workers/range.js +421 -0
- package/dist/workers/rangeMap.js +161 -0
- package/dist/workers/rangeMapping.js +229 -0
- package/dist/workers/rangeSingleLine.js +17 -0
- package/dist/workers/rangeUtil.js +117 -0
- package/dist/workers/razor.contribution.js +9 -0
- package/dist/workers/razor.js +616 -0
- package/dist/workers/rbTreeBase.js +362 -0
- package/dist/workers/rect.js +163 -0
- package/dist/workers/rectangleRenderer.js +214 -0
- package/dist/workers/rectangleRenderer.wgsl.js +68 -0
- package/dist/workers/redis.contribution.js +8 -0
- package/dist/workers/redis.js +301 -0
- package/dist/workers/redshift.contribution.js +8 -0
- package/dist/workers/redshift.js +808 -0
- package/dist/workers/reducer.js +46 -0
- package/dist/workers/referencesController.js +382 -0
- package/dist/workers/referencesModel.js +241 -0
- package/dist/workers/referencesTree.js +200 -0
- package/dist/workers/referencesWidget.js +525 -0
- package/dist/workers/registrations.contribution.js +82 -0
- package/dist/workers/rename.js +458 -0
- package/dist/workers/renameWidget.js +741 -0
- package/dist/workers/renderLines.js +185 -0
- package/dist/workers/renderingContext.js +118 -0
- package/dist/workers/replaceAllCommand.js +54 -0
- package/dist/workers/replaceCommand.js +158 -0
- package/dist/workers/replaceInput.js +176 -0
- package/dist/workers/replacePattern.js +289 -0
- package/dist/workers/replaceWidgetHistory.js +85 -0
- package/dist/workers/resizable.js +150 -0
- package/dist/workers/resizableContentWidget.js +92 -0
- package/dist/workers/resolvedKeybindingItem.js +35 -0
- package/dist/workers/resolverService.js +5 -0
- package/dist/workers/resources.js +231 -0
- package/dist/workers/restructuredtext.contribution.js +8 -0
- package/dist/workers/restructuredtext.js +173 -0
- package/dist/workers/revertButtonsFeature.js +149 -0
- package/dist/workers/rgba.js +35 -0
- package/dist/workers/richEditBrackets.js +356 -0
- package/dist/workers/rowCache.js +110 -0
- package/dist/workers/rpc.js +57 -0
- package/dist/workers/ruby.contribution.js +9 -0
- package/dist/workers/ruby.js +510 -0
- package/dist/workers/rulers.js +82 -0
- package/dist/workers/rulersGpu.js +66 -0
- package/dist/workers/runOnChange.js +61 -0
- package/dist/workers/rust.contribution.js +8 -0
- package/dist/workers/rust.js +342 -0
- package/dist/workers/sash.js +451 -0
- package/dist/workers/sb.contribution.js +8 -0
- package/dist/workers/sb.js +114 -0
- package/dist/workers/scala.contribution.js +9 -0
- package/dist/workers/scala.js +369 -0
- package/dist/workers/scanner.js +287 -0
- package/dist/workers/scheme.contribution.js +8 -0
- package/dist/workers/scheme.js +107 -0
- package/dist/workers/screenReaderContentRich.js +337 -0
- package/dist/workers/screenReaderContentSimple.js +194 -0
- package/dist/workers/screenReaderSupport.js +175 -0
- package/dist/workers/screenReaderUtils.js +111 -0
- package/dist/workers/scrollDecoration.js +70 -0
- package/dist/workers/scrollable.js +323 -0
- package/dist/workers/scrollableElement.js +603 -0
- package/dist/workers/scrollbarArrow.js +78 -0
- package/dist/workers/scrollbarState.js +163 -0
- package/dist/workers/scrollbarVisibilityController.js +93 -0
- package/dist/workers/scss.contribution.js +9 -0
- package/dist/workers/scss.js +259 -0
- package/dist/workers/search.js +52 -0
- package/dist/workers/searchColors.js +13 -0
- package/dist/workers/sectionHeaders.js +179 -0
- package/dist/workers/selectBox.js +47 -0
- package/dist/workers/selectBoxCustom.js +858 -0
- package/dist/workers/selectBoxNative.js +142 -0
- package/dist/workers/selection.js +145 -0
- package/dist/workers/selections.js +338 -0
- package/dist/workers/semanticTokensConfig.js +14 -0
- package/dist/workers/semanticTokensDto.js +82 -0
- package/dist/workers/semanticTokensProviderStyling.js +263 -0
- package/dist/workers/semanticTokensStyling.js +9 -0
- package/dist/workers/semanticTokensStylingService.js +47 -0
- package/dist/workers/serviceCollection.js +22 -0
- package/dist/workers/severity.js +52 -0
- package/dist/workers/severityIcon.js +29 -0
- package/dist/workers/shell.contribution.js +8 -0
- package/dist/workers/shell.js +220 -0
- package/dist/workers/shiftCommand.js +241 -0
- package/dist/workers/singleTextEditHelpers.js +32 -0
- package/dist/workers/smallImmutableSet.js +108 -0
- package/dist/workers/smartSelect.js +281 -0
- package/dist/workers/snippetController2.js +297 -0
- package/dist/workers/snippetParser.js +890 -0
- package/dist/workers/snippetSession.js +650 -0
- package/dist/workers/snippetVariables.js +323 -0
- package/dist/workers/solidity.contribution.js +8 -0
- package/dist/workers/solidity.js +1366 -0
- package/dist/workers/sophia.contribution.js +8 -0
- package/dist/workers/sophia.js +198 -0
- package/dist/workers/sortLinesCommand.js +81 -0
- package/dist/workers/sparql.contribution.js +8 -0
- package/dist/workers/sparql.js +200 -0
- package/dist/workers/sparseMultilineTokens.js +548 -0
- package/dist/workers/sparseTokensStore.js +210 -0
- package/dist/workers/splice.js +14 -0
- package/dist/workers/splitview.js +829 -0
- package/dist/workers/sql.contribution.js +8 -0
- package/dist/workers/sql.js +852 -0
- package/dist/workers/st.contribution.js +8 -0
- package/dist/workers/st.js +415 -0
- package/dist/workers/stableEditorScroll.js +52 -0
- package/dist/workers/standaloneCodeEditor.js +335 -0
- package/dist/workers/standaloneCodeEditorService.js +96 -0
- package/dist/workers/standaloneColorPickerActions.js +81 -0
- package/dist/workers/standaloneColorPickerController.js +62 -0
- package/dist/workers/standaloneColorPickerParticipant.js +117 -0
- package/dist/workers/standaloneColorPickerWidget.js +215 -0
- package/dist/workers/standaloneCommandsQuickAccess.js +82 -0
- package/dist/workers/standaloneEditor.js +519 -0
- package/dist/workers/standaloneEnums.js +1017 -0
- package/dist/workers/standaloneGotoLineQuickAccess.js +67 -0
- package/dist/workers/standaloneGotoSymbolQuickAccess.js +77 -0
- package/dist/workers/standaloneHelpQuickAccess.js +14 -0
- package/dist/workers/standaloneLanguages.js +621 -0
- package/dist/workers/standaloneLayoutService.js +74 -0
- package/dist/workers/standaloneQuickInputService.js +150 -0
- package/dist/workers/standaloneReferenceSearch.js +38 -0
- package/dist/workers/standaloneServices.js +787 -0
- package/dist/workers/standaloneStrings.js +42 -0
- package/dist/workers/standaloneTheme.js +9 -0
- package/dist/workers/standaloneThemeService.js +367 -0
- package/dist/workers/standaloneTreeSitterLibraryService.js +23 -0
- package/dist/workers/standaloneWebWorker.js +55 -0
- package/dist/workers/stickyScrollActions.js +132 -0
- package/dist/workers/stickyScrollContribution.js +16 -0
- package/dist/workers/stickyScrollController.js +566 -0
- package/dist/workers/stickyScrollElement.js +39 -0
- package/dist/workers/stickyScrollModelProvider.js +338 -0
- package/dist/workers/stickyScrollProvider.js +197 -0
- package/dist/workers/stickyScrollWidget.js +474 -0
- package/dist/workers/stopwatch.js +30 -0
- package/dist/workers/storage.js +200 -0
- package/dist/workers/stringBuilder.js +122 -0
- package/dist/workers/stringEdit.js +165 -0
- package/dist/workers/strings.js +834 -0
- package/dist/workers/structuredLogger.js +56 -0
- package/dist/workers/suggest.js +322 -0
- package/dist/workers/suggestAlternatives.js +95 -0
- package/dist/workers/suggestCommitCharacters.js +59 -0
- package/dist/workers/suggestController.js +941 -0
- package/dist/workers/suggestInlineCompletions.js +193 -0
- package/dist/workers/suggestMemory.js +254 -0
- package/dist/workers/suggestModel.js +667 -0
- package/dist/workers/suggestOvertypingCapturer.js +62 -0
- package/dist/workers/suggestWidget.js +890 -0
- package/dist/workers/suggestWidgetAdapter.js +210 -0
- package/dist/workers/suggestWidgetDetails.js +393 -0
- package/dist/workers/suggestWidgetRenderer.js +208 -0
- package/dist/workers/suggestWidgetStatus.js +74 -0
- package/dist/workers/supports.js +58 -0
- package/dist/workers/surroundSelectionCommand.js +44 -0
- package/dist/workers/swift.contribution.js +9 -0
- package/dist/workers/swift.js +311 -0
- package/dist/workers/symbolIcons.js +101 -0
- package/dist/workers/symbolNavigation.js +178 -0
- package/dist/workers/symbols.js +10 -0
- package/dist/workers/syntaxRangeProvider.js +177 -0
- package/dist/workers/systemverilog.contribution.js +14 -0
- package/dist/workers/systemverilog.js +575 -0
- package/dist/workers/tabFocus.js +29 -0
- package/dist/workers/tableWidget.js +181 -0
- package/dist/workers/taskQueue.js +116 -0
- package/dist/workers/tcl.contribution.js +8 -0
- package/dist/workers/tcl.js +231 -0
- package/dist/workers/telemetry.js +9 -0
- package/dist/workers/ternarySearchTree.js +674 -0
- package/dist/workers/textAreaEditContext.js +720 -0
- package/dist/workers/textAreaEditContextInput.js +588 -0
- package/dist/workers/textAreaEditContextState.js +160 -0
- package/dist/workers/textChange.js +248 -0
- package/dist/workers/textEdit.js +269 -0
- package/dist/workers/textLength.js +87 -0
- package/dist/workers/textModel.js +2031 -0
- package/dist/workers/textModelBracketPairs.js +45 -0
- package/dist/workers/textModelDefaults.js +18 -0
- package/dist/workers/textModelEditSource.js +166 -0
- package/dist/workers/textModelEvents.js +216 -0
- package/dist/workers/textModelGuides.js +40 -0
- package/dist/workers/textModelPart.js +23 -0
- package/dist/workers/textModelSearch.js +455 -0
- package/dist/workers/textModelStringEdit.js +11 -0
- package/dist/workers/textModelSync.impl.js +307 -0
- package/dist/workers/textModelText.js +26 -0
- package/dist/workers/textModelTokens.js +436 -0
- package/dist/workers/textResourceConfiguration.js +6 -0
- package/dist/workers/textToHtmlTokenizer.js +139 -0
- package/dist/workers/textualHighlightProvider.js +78 -0
- package/dist/workers/textureAtlas.js +179 -0
- package/dist/workers/textureAtlasPage.js +110 -0
- package/dist/workers/textureAtlasShelfAllocator.js +129 -0
- package/dist/workers/textureAtlasSlabAllocator.js +346 -0
- package/dist/workers/tfIdf.js +179 -0
- package/dist/workers/themables.js +100 -0
- package/dist/workers/theme.js +110 -0
- package/dist/workers/themeService.js +67 -0
- package/dist/workers/themes.js +242 -0
- package/dist/workers/toggle.js +242 -0
- package/dist/workers/toggleHighContrast.js +35 -0
- package/dist/workers/toggleTabFocusMode.js +42 -0
- package/dist/workers/tokenStore.js +407 -0
- package/dist/workers/tokenWithTextArray.js +73 -0
- package/dist/workers/tokenization.js +29 -0
- package/dist/workers/tokenizationRegistry.js +123 -0
- package/dist/workers/tokenizationTextModelPart.js +275 -0
- package/dist/workers/tokenizer.js +301 -0
- package/dist/workers/tokenizerSyntaxTokenBackend.js +261 -0
- package/dist/workers/toolbar.js +244 -0
- package/dist/workers/touch.js +270 -0
- package/dist/workers/transaction.js +109 -0
- package/dist/workers/transpose.js +65 -0
- package/dist/workers/tree.js +45 -0
- package/dist/workers/treeSitterLibraryService.js +9 -0
- package/dist/workers/treeSitterSyntaxTokenBackend.js +167 -0
- package/dist/workers/treeSitterThemeService.js +9 -0
- package/dist/workers/treeSitterTokenizationImpl.js +713 -0
- package/dist/workers/treeSitterTree.js +395 -0
- package/dist/workers/treeViewsDnd.js +24 -0
- package/dist/workers/treeViewsDndService.js +12 -0
- package/dist/workers/triggerInlineEditCommandsRegistry.js +18 -0
- package/dist/workers/trimTrailingWhitespaceCommand.js +98 -0
- package/dist/workers/trustedTypes.js +29 -0
- package/dist/workers/tsMode.js +212 -0
- package/dist/workers/tsWorker.js +352 -0
- package/dist/workers/twig.contribution.js +9 -0
- package/dist/workers/twig.js +391 -0
- package/dist/workers/types.js +144 -0
- package/dist/workers/typescript.contribution.js +11 -0
- package/dist/workers/typescript.js +408 -0
- package/dist/workers/typescriptServices.js +210154 -0
- package/dist/workers/typescriptServicesMetadata.js +3 -0
- package/dist/workers/typespec.contribution.js +8 -0
- package/dist/workers/typespec.js +126 -0
- package/dist/workers/typingSpeed.js +165 -0
- package/dist/workers/uint.js +24 -0
- package/dist/workers/undoRedo.js +43 -0
- package/dist/workers/undoRedoService.js +1076 -0
- package/dist/workers/unicodeHighlighter.js +673 -0
- package/dist/workers/unicodeTextModelHighlighter.js +188 -0
- package/dist/workers/unusualLineTerminators.js +113 -0
- package/dist/workers/updatableHoverWidget.js +107 -0
- package/dist/workers/uri.js +606 -0
- package/dist/workers/usLayoutResolvedKeybinding.js +175 -0
- package/dist/workers/utils.js +209 -0
- package/dist/workers/utilsCancellation.js +63 -0
- package/dist/workers/uuid.js +53 -0
- package/dist/workers/validation.js +159 -0
- package/dist/workers/vb.contribution.js +8 -0
- package/dist/workers/vb.js +371 -0
- package/dist/workers/verticalScrollbar.js +94 -0
- package/dist/workers/view.js +720 -0
- package/dist/workers/viewContext.js +22 -0
- package/dist/workers/viewController.js +274 -0
- package/dist/workers/viewCursor.js +218 -0
- package/dist/workers/viewCursors.js +339 -0
- package/dist/workers/viewEventHandler.js +186 -0
- package/dist/workers/viewEvents.js +180 -0
- package/dist/workers/viewGpuContext.js +241 -0
- package/dist/workers/viewLayer.js +478 -0
- package/dist/workers/viewLayout.js +368 -0
- package/dist/workers/viewLine.js +544 -0
- package/dist/workers/viewLineOptions.js +43 -0
- package/dist/workers/viewLineRenderer.js +948 -0
- package/dist/workers/viewLines.js +721 -0
- package/dist/workers/viewLinesGpu.js +571 -0
- package/dist/workers/viewLinesViewportData.js +30 -0
- package/dist/workers/viewModel.js +98 -0
- package/dist/workers/viewModelDecoration.js +55 -0
- package/dist/workers/viewModelDecorations.js +132 -0
- package/dist/workers/viewModelEventDispatcher.js +398 -0
- package/dist/workers/viewModelImpl.js +1163 -0
- package/dist/workers/viewModelLines.js +938 -0
- package/dist/workers/viewOverlays.js +204 -0
- package/dist/workers/viewPart.js +49 -0
- package/dist/workers/viewUserInputEvents.js +91 -0
- package/dist/workers/viewZones.js +335 -0
- package/dist/workers/viewportRenderStrategy.js +316 -0
- package/dist/workers/viewportSemanticTokens.js +166 -0
- package/dist/workers/webWorker.js +396 -0
- package/dist/workers/webWorkerBootstrap.js +20 -0
- package/dist/workers/webWorkerFactory.js +171 -0
- package/dist/workers/wgsl.contribution.js +8 -0
- package/dist/workers/wgsl.js +452 -0
- package/dist/workers/whitespace.js +277 -0
- package/dist/workers/widget.js +44 -0
- package/dist/workers/window.js +60 -0
- package/dist/workers/wordCharacterClassifier.js +87 -0
- package/dist/workers/wordContextKey.js +69 -0
- package/dist/workers/wordDistance.js +64 -0
- package/dist/workers/wordHelper.js +127 -0
- package/dist/workers/wordHighlighter.js +796 -0
- package/dist/workers/wordOperations.js +442 -0
- package/dist/workers/wordPartOperations.js +145 -0
- package/dist/workers/wordSelections.js +82 -0
- package/dist/workers/workerManager.js +147 -0
- package/dist/workers/workers.js +141 -0
- package/dist/workers/workspace.js +84 -0
- package/dist/workers/workspaceTrust.js +9 -0
- package/dist/workers/wrapInHotClass.js +41 -0
- package/dist/workers/wrapInReloadableClass.js +35 -0
- package/dist/workers/xml.contribution.js +28 -0
- package/dist/workers/xml.js +160 -0
- package/dist/workers/yaml.contribution.js +9 -0
- package/dist/workers/yaml.js +271 -0
- package/dist/workers/zoneWidget.js +406 -0
- package/package.json +2 -2
- package/dist/assets/css.worker-C7FogG4G.js +0 -93
- package/dist/assets/editor.worker-iXcRX1Tq.js +0 -26
- package/dist/assets/html.worker-C8VxctEJ.js +0 -470
- package/dist/assets/json.worker-CMC9kgPL.js +0 -58
- package/dist/assets/ts.worker-CtTJ3hNN.js +0 -67731
|
@@ -0,0 +1,902 @@
|
|
|
1
|
+
import { DiffChange } from './diffChange.js';
|
|
2
|
+
import { stringHash } from '../hash.js';
|
|
3
|
+
|
|
4
|
+
/*---------------------------------------------------------------------------------------------
|
|
5
|
+
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
6
|
+
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
7
|
+
*--------------------------------------------------------------------------------------------*/
|
|
8
|
+
class StringDiffSequence {
|
|
9
|
+
constructor(source) {
|
|
10
|
+
this.source = source;
|
|
11
|
+
}
|
|
12
|
+
getElements() {
|
|
13
|
+
const source = this.source;
|
|
14
|
+
const characters = new Int32Array(source.length);
|
|
15
|
+
for (let i = 0, len = source.length; i < len; i++) {
|
|
16
|
+
characters[i] = source.charCodeAt(i);
|
|
17
|
+
}
|
|
18
|
+
return characters;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function stringDiff(original, modified, pretty) {
|
|
22
|
+
return new LcsDiff(new StringDiffSequence(original), new StringDiffSequence(modified)).ComputeDiff(pretty).changes;
|
|
23
|
+
}
|
|
24
|
+
//
|
|
25
|
+
// The code below has been ported from a C# implementation in VS
|
|
26
|
+
//
|
|
27
|
+
class Debug {
|
|
28
|
+
static Assert(condition, message) {
|
|
29
|
+
if (!condition) {
|
|
30
|
+
throw new Error(message);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
class MyArray {
|
|
35
|
+
/**
|
|
36
|
+
* Copies a range of elements from an Array starting at the specified source index and pastes
|
|
37
|
+
* them to another Array starting at the specified destination index. The length and the indexes
|
|
38
|
+
* are specified as 64-bit integers.
|
|
39
|
+
* sourceArray:
|
|
40
|
+
* The Array that contains the data to copy.
|
|
41
|
+
* sourceIndex:
|
|
42
|
+
* A 64-bit integer that represents the index in the sourceArray at which copying begins.
|
|
43
|
+
* destinationArray:
|
|
44
|
+
* The Array that receives the data.
|
|
45
|
+
* destinationIndex:
|
|
46
|
+
* A 64-bit integer that represents the index in the destinationArray at which storing begins.
|
|
47
|
+
* length:
|
|
48
|
+
* A 64-bit integer that represents the number of elements to copy.
|
|
49
|
+
*/
|
|
50
|
+
static Copy(sourceArray, sourceIndex, destinationArray, destinationIndex, length) {
|
|
51
|
+
for (let i = 0; i < length; i++) {
|
|
52
|
+
destinationArray[destinationIndex + i] = sourceArray[sourceIndex + i];
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
static Copy2(sourceArray, sourceIndex, destinationArray, destinationIndex, length) {
|
|
56
|
+
for (let i = 0; i < length; i++) {
|
|
57
|
+
destinationArray[destinationIndex + i] = sourceArray[sourceIndex + i];
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* A utility class which helps to create the set of DiffChanges from
|
|
63
|
+
* a difference operation. This class accepts original DiffElements and
|
|
64
|
+
* modified DiffElements that are involved in a particular change. The
|
|
65
|
+
* MarkNextChange() method can be called to mark the separation between
|
|
66
|
+
* distinct changes. At the end, the Changes property can be called to retrieve
|
|
67
|
+
* the constructed changes.
|
|
68
|
+
*/
|
|
69
|
+
class DiffChangeHelper {
|
|
70
|
+
/**
|
|
71
|
+
* Constructs a new DiffChangeHelper for the given DiffSequences.
|
|
72
|
+
*/
|
|
73
|
+
constructor() {
|
|
74
|
+
this.m_changes = [];
|
|
75
|
+
this.m_originalStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;
|
|
76
|
+
this.m_modifiedStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;
|
|
77
|
+
this.m_originalCount = 0;
|
|
78
|
+
this.m_modifiedCount = 0;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Marks the beginning of the next change in the set of differences.
|
|
82
|
+
*/
|
|
83
|
+
MarkNextChange() {
|
|
84
|
+
// Only add to the list if there is something to add
|
|
85
|
+
if (this.m_originalCount > 0 || this.m_modifiedCount > 0) {
|
|
86
|
+
// Add the new change to our list
|
|
87
|
+
this.m_changes.push(new DiffChange(this.m_originalStart, this.m_originalCount, this.m_modifiedStart, this.m_modifiedCount));
|
|
88
|
+
}
|
|
89
|
+
// Reset for the next change
|
|
90
|
+
this.m_originalCount = 0;
|
|
91
|
+
this.m_modifiedCount = 0;
|
|
92
|
+
this.m_originalStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;
|
|
93
|
+
this.m_modifiedStart = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Adds the original element at the given position to the elements
|
|
97
|
+
* affected by the current change. The modified index gives context
|
|
98
|
+
* to the change position with respect to the original sequence.
|
|
99
|
+
* @param originalIndex The index of the original element to add.
|
|
100
|
+
* @param modifiedIndex The index of the modified element that provides corresponding position in the modified sequence.
|
|
101
|
+
*/
|
|
102
|
+
AddOriginalElement(originalIndex, modifiedIndex) {
|
|
103
|
+
// The 'true' start index is the smallest of the ones we've seen
|
|
104
|
+
this.m_originalStart = Math.min(this.m_originalStart, originalIndex);
|
|
105
|
+
this.m_modifiedStart = Math.min(this.m_modifiedStart, modifiedIndex);
|
|
106
|
+
this.m_originalCount++;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Adds the modified element at the given position to the elements
|
|
110
|
+
* affected by the current change. The original index gives context
|
|
111
|
+
* to the change position with respect to the modified sequence.
|
|
112
|
+
* @param originalIndex The index of the original element that provides corresponding position in the original sequence.
|
|
113
|
+
* @param modifiedIndex The index of the modified element to add.
|
|
114
|
+
*/
|
|
115
|
+
AddModifiedElement(originalIndex, modifiedIndex) {
|
|
116
|
+
// The 'true' start index is the smallest of the ones we've seen
|
|
117
|
+
this.m_originalStart = Math.min(this.m_originalStart, originalIndex);
|
|
118
|
+
this.m_modifiedStart = Math.min(this.m_modifiedStart, modifiedIndex);
|
|
119
|
+
this.m_modifiedCount++;
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Retrieves all of the changes marked by the class.
|
|
123
|
+
*/
|
|
124
|
+
getChanges() {
|
|
125
|
+
if (this.m_originalCount > 0 || this.m_modifiedCount > 0) {
|
|
126
|
+
// Finish up on whatever is left
|
|
127
|
+
this.MarkNextChange();
|
|
128
|
+
}
|
|
129
|
+
return this.m_changes;
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Retrieves all of the changes marked by the class in the reverse order
|
|
133
|
+
*/
|
|
134
|
+
getReverseChanges() {
|
|
135
|
+
if (this.m_originalCount > 0 || this.m_modifiedCount > 0) {
|
|
136
|
+
// Finish up on whatever is left
|
|
137
|
+
this.MarkNextChange();
|
|
138
|
+
}
|
|
139
|
+
this.m_changes.reverse();
|
|
140
|
+
return this.m_changes;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* An implementation of the difference algorithm described in
|
|
145
|
+
* "An O(ND) Difference Algorithm and its variations" by Eugene W. Myers
|
|
146
|
+
*/
|
|
147
|
+
class LcsDiff {
|
|
148
|
+
/**
|
|
149
|
+
* Constructs the DiffFinder
|
|
150
|
+
*/
|
|
151
|
+
constructor(originalSequence, modifiedSequence, continueProcessingPredicate = null) {
|
|
152
|
+
this.ContinueProcessingPredicate = continueProcessingPredicate;
|
|
153
|
+
this._originalSequence = originalSequence;
|
|
154
|
+
this._modifiedSequence = modifiedSequence;
|
|
155
|
+
const [originalStringElements, originalElementsOrHash, originalHasStrings] = LcsDiff._getElements(originalSequence);
|
|
156
|
+
const [modifiedStringElements, modifiedElementsOrHash, modifiedHasStrings] = LcsDiff._getElements(modifiedSequence);
|
|
157
|
+
this._hasStrings = (originalHasStrings && modifiedHasStrings);
|
|
158
|
+
this._originalStringElements = originalStringElements;
|
|
159
|
+
this._originalElementsOrHash = originalElementsOrHash;
|
|
160
|
+
this._modifiedStringElements = modifiedStringElements;
|
|
161
|
+
this._modifiedElementsOrHash = modifiedElementsOrHash;
|
|
162
|
+
this.m_forwardHistory = [];
|
|
163
|
+
this.m_reverseHistory = [];
|
|
164
|
+
}
|
|
165
|
+
static _isStringArray(arr) {
|
|
166
|
+
return (arr.length > 0 && typeof arr[0] === 'string');
|
|
167
|
+
}
|
|
168
|
+
static _getElements(sequence) {
|
|
169
|
+
const elements = sequence.getElements();
|
|
170
|
+
if (LcsDiff._isStringArray(elements)) {
|
|
171
|
+
const hashes = new Int32Array(elements.length);
|
|
172
|
+
for (let i = 0, len = elements.length; i < len; i++) {
|
|
173
|
+
hashes[i] = stringHash(elements[i], 0);
|
|
174
|
+
}
|
|
175
|
+
return [elements, hashes, true];
|
|
176
|
+
}
|
|
177
|
+
if (elements instanceof Int32Array) {
|
|
178
|
+
return [[], elements, false];
|
|
179
|
+
}
|
|
180
|
+
return [[], new Int32Array(elements), false];
|
|
181
|
+
}
|
|
182
|
+
ElementsAreEqual(originalIndex, newIndex) {
|
|
183
|
+
if (this._originalElementsOrHash[originalIndex] !== this._modifiedElementsOrHash[newIndex]) {
|
|
184
|
+
return false;
|
|
185
|
+
}
|
|
186
|
+
return (this._hasStrings ? this._originalStringElements[originalIndex] === this._modifiedStringElements[newIndex] : true);
|
|
187
|
+
}
|
|
188
|
+
ElementsAreStrictEqual(originalIndex, newIndex) {
|
|
189
|
+
if (!this.ElementsAreEqual(originalIndex, newIndex)) {
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
192
|
+
const originalElement = LcsDiff._getStrictElement(this._originalSequence, originalIndex);
|
|
193
|
+
const modifiedElement = LcsDiff._getStrictElement(this._modifiedSequence, newIndex);
|
|
194
|
+
return (originalElement === modifiedElement);
|
|
195
|
+
}
|
|
196
|
+
static _getStrictElement(sequence, index) {
|
|
197
|
+
if (typeof sequence.getStrictElement === 'function') {
|
|
198
|
+
return sequence.getStrictElement(index);
|
|
199
|
+
}
|
|
200
|
+
return null;
|
|
201
|
+
}
|
|
202
|
+
OriginalElementsAreEqual(index1, index2) {
|
|
203
|
+
if (this._originalElementsOrHash[index1] !== this._originalElementsOrHash[index2]) {
|
|
204
|
+
return false;
|
|
205
|
+
}
|
|
206
|
+
return (this._hasStrings ? this._originalStringElements[index1] === this._originalStringElements[index2] : true);
|
|
207
|
+
}
|
|
208
|
+
ModifiedElementsAreEqual(index1, index2) {
|
|
209
|
+
if (this._modifiedElementsOrHash[index1] !== this._modifiedElementsOrHash[index2]) {
|
|
210
|
+
return false;
|
|
211
|
+
}
|
|
212
|
+
return (this._hasStrings ? this._modifiedStringElements[index1] === this._modifiedStringElements[index2] : true);
|
|
213
|
+
}
|
|
214
|
+
ComputeDiff(pretty) {
|
|
215
|
+
return this._ComputeDiff(0, this._originalElementsOrHash.length - 1, 0, this._modifiedElementsOrHash.length - 1, pretty);
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Computes the differences between the original and modified input
|
|
219
|
+
* sequences on the bounded range.
|
|
220
|
+
* @returns An array of the differences between the two input sequences.
|
|
221
|
+
*/
|
|
222
|
+
_ComputeDiff(originalStart, originalEnd, modifiedStart, modifiedEnd, pretty) {
|
|
223
|
+
const quitEarlyArr = [false];
|
|
224
|
+
let changes = this.ComputeDiffRecursive(originalStart, originalEnd, modifiedStart, modifiedEnd, quitEarlyArr);
|
|
225
|
+
if (pretty) {
|
|
226
|
+
// We have to clean up the computed diff to be more intuitive
|
|
227
|
+
// but it turns out this cannot be done correctly until the entire set
|
|
228
|
+
// of diffs have been computed
|
|
229
|
+
changes = this.PrettifyChanges(changes);
|
|
230
|
+
}
|
|
231
|
+
return {
|
|
232
|
+
quitEarly: quitEarlyArr[0],
|
|
233
|
+
changes: changes
|
|
234
|
+
};
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Private helper method which computes the differences on the bounded range
|
|
238
|
+
* recursively.
|
|
239
|
+
* @returns An array of the differences between the two input sequences.
|
|
240
|
+
*/
|
|
241
|
+
ComputeDiffRecursive(originalStart, originalEnd, modifiedStart, modifiedEnd, quitEarlyArr) {
|
|
242
|
+
quitEarlyArr[0] = false;
|
|
243
|
+
// Find the start of the differences
|
|
244
|
+
while (originalStart <= originalEnd && modifiedStart <= modifiedEnd && this.ElementsAreEqual(originalStart, modifiedStart)) {
|
|
245
|
+
originalStart++;
|
|
246
|
+
modifiedStart++;
|
|
247
|
+
}
|
|
248
|
+
// Find the end of the differences
|
|
249
|
+
while (originalEnd >= originalStart && modifiedEnd >= modifiedStart && this.ElementsAreEqual(originalEnd, modifiedEnd)) {
|
|
250
|
+
originalEnd--;
|
|
251
|
+
modifiedEnd--;
|
|
252
|
+
}
|
|
253
|
+
// In the special case where we either have all insertions or all deletions or the sequences are identical
|
|
254
|
+
if (originalStart > originalEnd || modifiedStart > modifiedEnd) {
|
|
255
|
+
let changes;
|
|
256
|
+
if (modifiedStart <= modifiedEnd) {
|
|
257
|
+
Debug.Assert(originalStart === originalEnd + 1, 'originalStart should only be one more than originalEnd');
|
|
258
|
+
// All insertions
|
|
259
|
+
changes = [
|
|
260
|
+
new DiffChange(originalStart, 0, modifiedStart, modifiedEnd - modifiedStart + 1)
|
|
261
|
+
];
|
|
262
|
+
}
|
|
263
|
+
else if (originalStart <= originalEnd) {
|
|
264
|
+
Debug.Assert(modifiedStart === modifiedEnd + 1, 'modifiedStart should only be one more than modifiedEnd');
|
|
265
|
+
// All deletions
|
|
266
|
+
changes = [
|
|
267
|
+
new DiffChange(originalStart, originalEnd - originalStart + 1, modifiedStart, 0)
|
|
268
|
+
];
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
Debug.Assert(originalStart === originalEnd + 1, 'originalStart should only be one more than originalEnd');
|
|
272
|
+
Debug.Assert(modifiedStart === modifiedEnd + 1, 'modifiedStart should only be one more than modifiedEnd');
|
|
273
|
+
// Identical sequences - No differences
|
|
274
|
+
changes = [];
|
|
275
|
+
}
|
|
276
|
+
return changes;
|
|
277
|
+
}
|
|
278
|
+
// This problem can be solved using the Divide-And-Conquer technique.
|
|
279
|
+
const midOriginalArr = [0];
|
|
280
|
+
const midModifiedArr = [0];
|
|
281
|
+
const result = this.ComputeRecursionPoint(originalStart, originalEnd, modifiedStart, modifiedEnd, midOriginalArr, midModifiedArr, quitEarlyArr);
|
|
282
|
+
const midOriginal = midOriginalArr[0];
|
|
283
|
+
const midModified = midModifiedArr[0];
|
|
284
|
+
if (result !== null) {
|
|
285
|
+
// Result is not-null when there was enough memory to compute the changes while
|
|
286
|
+
// searching for the recursion point
|
|
287
|
+
return result;
|
|
288
|
+
}
|
|
289
|
+
else if (!quitEarlyArr[0]) {
|
|
290
|
+
// We can break the problem down recursively by finding the changes in the
|
|
291
|
+
// First Half: (originalStart, modifiedStart) to (midOriginal, midModified)
|
|
292
|
+
// Second Half: (midOriginal + 1, minModified + 1) to (originalEnd, modifiedEnd)
|
|
293
|
+
// NOTE: ComputeDiff() is inclusive, therefore the second range starts on the next point
|
|
294
|
+
const leftChanges = this.ComputeDiffRecursive(originalStart, midOriginal, modifiedStart, midModified, quitEarlyArr);
|
|
295
|
+
let rightChanges = [];
|
|
296
|
+
if (!quitEarlyArr[0]) {
|
|
297
|
+
rightChanges = this.ComputeDiffRecursive(midOriginal + 1, originalEnd, midModified + 1, modifiedEnd, quitEarlyArr);
|
|
298
|
+
}
|
|
299
|
+
else {
|
|
300
|
+
// We didn't have time to finish the first half, so we don't have time to compute this half.
|
|
301
|
+
// Consider the entire rest of the sequence different.
|
|
302
|
+
rightChanges = [
|
|
303
|
+
new DiffChange(midOriginal + 1, originalEnd - (midOriginal + 1) + 1, midModified + 1, modifiedEnd - (midModified + 1) + 1)
|
|
304
|
+
];
|
|
305
|
+
}
|
|
306
|
+
return this.ConcatenateChanges(leftChanges, rightChanges);
|
|
307
|
+
}
|
|
308
|
+
// If we hit here, we quit early, and so can't return anything meaningful
|
|
309
|
+
return [
|
|
310
|
+
new DiffChange(originalStart, originalEnd - originalStart + 1, modifiedStart, modifiedEnd - modifiedStart + 1)
|
|
311
|
+
];
|
|
312
|
+
}
|
|
313
|
+
WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr) {
|
|
314
|
+
let forwardChanges = null;
|
|
315
|
+
let reverseChanges = null;
|
|
316
|
+
// First, walk backward through the forward diagonals history
|
|
317
|
+
let changeHelper = new DiffChangeHelper();
|
|
318
|
+
let diagonalMin = diagonalForwardStart;
|
|
319
|
+
let diagonalMax = diagonalForwardEnd;
|
|
320
|
+
let diagonalRelative = (midOriginalArr[0] - midModifiedArr[0]) - diagonalForwardOffset;
|
|
321
|
+
let lastOriginalIndex = -1073741824 /* Constants.MIN_SAFE_SMALL_INTEGER */;
|
|
322
|
+
let historyIndex = this.m_forwardHistory.length - 1;
|
|
323
|
+
do {
|
|
324
|
+
// Get the diagonal index from the relative diagonal number
|
|
325
|
+
const diagonal = diagonalRelative + diagonalForwardBase;
|
|
326
|
+
// Figure out where we came from
|
|
327
|
+
if (diagonal === diagonalMin || (diagonal < diagonalMax && forwardPoints[diagonal - 1] < forwardPoints[diagonal + 1])) {
|
|
328
|
+
// Vertical line (the element is an insert)
|
|
329
|
+
originalIndex = forwardPoints[diagonal + 1];
|
|
330
|
+
modifiedIndex = originalIndex - diagonalRelative - diagonalForwardOffset;
|
|
331
|
+
if (originalIndex < lastOriginalIndex) {
|
|
332
|
+
changeHelper.MarkNextChange();
|
|
333
|
+
}
|
|
334
|
+
lastOriginalIndex = originalIndex;
|
|
335
|
+
changeHelper.AddModifiedElement(originalIndex + 1, modifiedIndex);
|
|
336
|
+
diagonalRelative = (diagonal + 1) - diagonalForwardBase; //Setup for the next iteration
|
|
337
|
+
}
|
|
338
|
+
else {
|
|
339
|
+
// Horizontal line (the element is a deletion)
|
|
340
|
+
originalIndex = forwardPoints[diagonal - 1] + 1;
|
|
341
|
+
modifiedIndex = originalIndex - diagonalRelative - diagonalForwardOffset;
|
|
342
|
+
if (originalIndex < lastOriginalIndex) {
|
|
343
|
+
changeHelper.MarkNextChange();
|
|
344
|
+
}
|
|
345
|
+
lastOriginalIndex = originalIndex - 1;
|
|
346
|
+
changeHelper.AddOriginalElement(originalIndex, modifiedIndex + 1);
|
|
347
|
+
diagonalRelative = (diagonal - 1) - diagonalForwardBase; //Setup for the next iteration
|
|
348
|
+
}
|
|
349
|
+
if (historyIndex >= 0) {
|
|
350
|
+
forwardPoints = this.m_forwardHistory[historyIndex];
|
|
351
|
+
diagonalForwardBase = forwardPoints[0]; //We stored this in the first spot
|
|
352
|
+
diagonalMin = 1;
|
|
353
|
+
diagonalMax = forwardPoints.length - 1;
|
|
354
|
+
}
|
|
355
|
+
} while (--historyIndex >= -1);
|
|
356
|
+
// Ironically, we get the forward changes as the reverse of the
|
|
357
|
+
// order we added them since we technically added them backwards
|
|
358
|
+
forwardChanges = changeHelper.getReverseChanges();
|
|
359
|
+
if (quitEarlyArr[0]) {
|
|
360
|
+
// TODO: Calculate a partial from the reverse diagonals.
|
|
361
|
+
// For now, just assume everything after the midOriginal/midModified point is a diff
|
|
362
|
+
let originalStartPoint = midOriginalArr[0] + 1;
|
|
363
|
+
let modifiedStartPoint = midModifiedArr[0] + 1;
|
|
364
|
+
if (forwardChanges !== null && forwardChanges.length > 0) {
|
|
365
|
+
const lastForwardChange = forwardChanges[forwardChanges.length - 1];
|
|
366
|
+
originalStartPoint = Math.max(originalStartPoint, lastForwardChange.getOriginalEnd());
|
|
367
|
+
modifiedStartPoint = Math.max(modifiedStartPoint, lastForwardChange.getModifiedEnd());
|
|
368
|
+
}
|
|
369
|
+
reverseChanges = [
|
|
370
|
+
new DiffChange(originalStartPoint, originalEnd - originalStartPoint + 1, modifiedStartPoint, modifiedEnd - modifiedStartPoint + 1)
|
|
371
|
+
];
|
|
372
|
+
}
|
|
373
|
+
else {
|
|
374
|
+
// Now walk backward through the reverse diagonals history
|
|
375
|
+
changeHelper = new DiffChangeHelper();
|
|
376
|
+
diagonalMin = diagonalReverseStart;
|
|
377
|
+
diagonalMax = diagonalReverseEnd;
|
|
378
|
+
diagonalRelative = (midOriginalArr[0] - midModifiedArr[0]) - diagonalReverseOffset;
|
|
379
|
+
lastOriginalIndex = 1073741824 /* Constants.MAX_SAFE_SMALL_INTEGER */;
|
|
380
|
+
historyIndex = (deltaIsEven) ? this.m_reverseHistory.length - 1 : this.m_reverseHistory.length - 2;
|
|
381
|
+
do {
|
|
382
|
+
// Get the diagonal index from the relative diagonal number
|
|
383
|
+
const diagonal = diagonalRelative + diagonalReverseBase;
|
|
384
|
+
// Figure out where we came from
|
|
385
|
+
if (diagonal === diagonalMin || (diagonal < diagonalMax && reversePoints[diagonal - 1] >= reversePoints[diagonal + 1])) {
|
|
386
|
+
// Horizontal line (the element is a deletion))
|
|
387
|
+
originalIndex = reversePoints[diagonal + 1] - 1;
|
|
388
|
+
modifiedIndex = originalIndex - diagonalRelative - diagonalReverseOffset;
|
|
389
|
+
if (originalIndex > lastOriginalIndex) {
|
|
390
|
+
changeHelper.MarkNextChange();
|
|
391
|
+
}
|
|
392
|
+
lastOriginalIndex = originalIndex + 1;
|
|
393
|
+
changeHelper.AddOriginalElement(originalIndex + 1, modifiedIndex + 1);
|
|
394
|
+
diagonalRelative = (diagonal + 1) - diagonalReverseBase; //Setup for the next iteration
|
|
395
|
+
}
|
|
396
|
+
else {
|
|
397
|
+
// Vertical line (the element is an insertion)
|
|
398
|
+
originalIndex = reversePoints[diagonal - 1];
|
|
399
|
+
modifiedIndex = originalIndex - diagonalRelative - diagonalReverseOffset;
|
|
400
|
+
if (originalIndex > lastOriginalIndex) {
|
|
401
|
+
changeHelper.MarkNextChange();
|
|
402
|
+
}
|
|
403
|
+
lastOriginalIndex = originalIndex;
|
|
404
|
+
changeHelper.AddModifiedElement(originalIndex + 1, modifiedIndex + 1);
|
|
405
|
+
diagonalRelative = (diagonal - 1) - diagonalReverseBase; //Setup for the next iteration
|
|
406
|
+
}
|
|
407
|
+
if (historyIndex >= 0) {
|
|
408
|
+
reversePoints = this.m_reverseHistory[historyIndex];
|
|
409
|
+
diagonalReverseBase = reversePoints[0]; //We stored this in the first spot
|
|
410
|
+
diagonalMin = 1;
|
|
411
|
+
diagonalMax = reversePoints.length - 1;
|
|
412
|
+
}
|
|
413
|
+
} while (--historyIndex >= -1);
|
|
414
|
+
// There are cases where the reverse history will find diffs that
|
|
415
|
+
// are correct, but not intuitive, so we need shift them.
|
|
416
|
+
reverseChanges = changeHelper.getChanges();
|
|
417
|
+
}
|
|
418
|
+
return this.ConcatenateChanges(forwardChanges, reverseChanges);
|
|
419
|
+
}
|
|
420
|
+
/**
|
|
421
|
+
* Given the range to compute the diff on, this method finds the point:
|
|
422
|
+
* (midOriginal, midModified)
|
|
423
|
+
* that exists in the middle of the LCS of the two sequences and
|
|
424
|
+
* is the point at which the LCS problem may be broken down recursively.
|
|
425
|
+
* This method will try to keep the LCS trace in memory. If the LCS recursion
|
|
426
|
+
* point is calculated and the full trace is available in memory, then this method
|
|
427
|
+
* will return the change list.
|
|
428
|
+
* @param originalStart The start bound of the original sequence range
|
|
429
|
+
* @param originalEnd The end bound of the original sequence range
|
|
430
|
+
* @param modifiedStart The start bound of the modified sequence range
|
|
431
|
+
* @param modifiedEnd The end bound of the modified sequence range
|
|
432
|
+
* @param midOriginal The middle point of the original sequence range
|
|
433
|
+
* @param midModified The middle point of the modified sequence range
|
|
434
|
+
* @returns The diff changes, if available, otherwise null
|
|
435
|
+
*/
|
|
436
|
+
ComputeRecursionPoint(originalStart, originalEnd, modifiedStart, modifiedEnd, midOriginalArr, midModifiedArr, quitEarlyArr) {
|
|
437
|
+
let originalIndex = 0, modifiedIndex = 0;
|
|
438
|
+
let diagonalForwardStart = 0, diagonalForwardEnd = 0;
|
|
439
|
+
let diagonalReverseStart = 0, diagonalReverseEnd = 0;
|
|
440
|
+
// To traverse the edit graph and produce the proper LCS, our actual
|
|
441
|
+
// start position is just outside the given boundary
|
|
442
|
+
originalStart--;
|
|
443
|
+
modifiedStart--;
|
|
444
|
+
// We set these up to make the compiler happy, but they will
|
|
445
|
+
// be replaced before we return with the actual recursion point
|
|
446
|
+
midOriginalArr[0] = 0;
|
|
447
|
+
midModifiedArr[0] = 0;
|
|
448
|
+
// Clear out the history
|
|
449
|
+
this.m_forwardHistory = [];
|
|
450
|
+
this.m_reverseHistory = [];
|
|
451
|
+
// Each cell in the two arrays corresponds to a diagonal in the edit graph.
|
|
452
|
+
// The integer value in the cell represents the originalIndex of the furthest
|
|
453
|
+
// reaching point found so far that ends in that diagonal.
|
|
454
|
+
// The modifiedIndex can be computed mathematically from the originalIndex and the diagonal number.
|
|
455
|
+
const maxDifferences = (originalEnd - originalStart) + (modifiedEnd - modifiedStart);
|
|
456
|
+
const numDiagonals = maxDifferences + 1;
|
|
457
|
+
const forwardPoints = new Int32Array(numDiagonals);
|
|
458
|
+
const reversePoints = new Int32Array(numDiagonals);
|
|
459
|
+
// diagonalForwardBase: Index into forwardPoints of the diagonal which passes through (originalStart, modifiedStart)
|
|
460
|
+
// diagonalReverseBase: Index into reversePoints of the diagonal which passes through (originalEnd, modifiedEnd)
|
|
461
|
+
const diagonalForwardBase = (modifiedEnd - modifiedStart);
|
|
462
|
+
const diagonalReverseBase = (originalEnd - originalStart);
|
|
463
|
+
// diagonalForwardOffset: Geometric offset which allows modifiedIndex to be computed from originalIndex and the
|
|
464
|
+
// diagonal number (relative to diagonalForwardBase)
|
|
465
|
+
// diagonalReverseOffset: Geometric offset which allows modifiedIndex to be computed from originalIndex and the
|
|
466
|
+
// diagonal number (relative to diagonalReverseBase)
|
|
467
|
+
const diagonalForwardOffset = (originalStart - modifiedStart);
|
|
468
|
+
const diagonalReverseOffset = (originalEnd - modifiedEnd);
|
|
469
|
+
// delta: The difference between the end diagonal and the start diagonal. This is used to relate diagonal numbers
|
|
470
|
+
// relative to the start diagonal with diagonal numbers relative to the end diagonal.
|
|
471
|
+
// The Even/Oddn-ness of this delta is important for determining when we should check for overlap
|
|
472
|
+
const delta = diagonalReverseBase - diagonalForwardBase;
|
|
473
|
+
const deltaIsEven = (delta % 2 === 0);
|
|
474
|
+
// Here we set up the start and end points as the furthest points found so far
|
|
475
|
+
// in both the forward and reverse directions, respectively
|
|
476
|
+
forwardPoints[diagonalForwardBase] = originalStart;
|
|
477
|
+
reversePoints[diagonalReverseBase] = originalEnd;
|
|
478
|
+
// Remember if we quit early, and thus need to do a best-effort result instead of a real result.
|
|
479
|
+
quitEarlyArr[0] = false;
|
|
480
|
+
// A couple of points:
|
|
481
|
+
// --With this method, we iterate on the number of differences between the two sequences.
|
|
482
|
+
// The more differences there actually are, the longer this will take.
|
|
483
|
+
// --Also, as the number of differences increases, we have to search on diagonals further
|
|
484
|
+
// away from the reference diagonal (which is diagonalForwardBase for forward, diagonalReverseBase for reverse).
|
|
485
|
+
// --We extend on even diagonals (relative to the reference diagonal) only when numDifferences
|
|
486
|
+
// is even and odd diagonals only when numDifferences is odd.
|
|
487
|
+
for (let numDifferences = 1; numDifferences <= (maxDifferences / 2) + 1; numDifferences++) {
|
|
488
|
+
let furthestOriginalIndex = 0;
|
|
489
|
+
let furthestModifiedIndex = 0;
|
|
490
|
+
// Run the algorithm in the forward direction
|
|
491
|
+
diagonalForwardStart = this.ClipDiagonalBound(diagonalForwardBase - numDifferences, numDifferences, diagonalForwardBase, numDiagonals);
|
|
492
|
+
diagonalForwardEnd = this.ClipDiagonalBound(diagonalForwardBase + numDifferences, numDifferences, diagonalForwardBase, numDiagonals);
|
|
493
|
+
for (let diagonal = diagonalForwardStart; diagonal <= diagonalForwardEnd; diagonal += 2) {
|
|
494
|
+
// STEP 1: We extend the furthest reaching point in the present diagonal
|
|
495
|
+
// by looking at the diagonals above and below and picking the one whose point
|
|
496
|
+
// is further away from the start point (originalStart, modifiedStart)
|
|
497
|
+
if (diagonal === diagonalForwardStart || (diagonal < diagonalForwardEnd && forwardPoints[diagonal - 1] < forwardPoints[diagonal + 1])) {
|
|
498
|
+
originalIndex = forwardPoints[diagonal + 1];
|
|
499
|
+
}
|
|
500
|
+
else {
|
|
501
|
+
originalIndex = forwardPoints[diagonal - 1] + 1;
|
|
502
|
+
}
|
|
503
|
+
modifiedIndex = originalIndex - (diagonal - diagonalForwardBase) - diagonalForwardOffset;
|
|
504
|
+
// Save the current originalIndex so we can test for false overlap in step 3
|
|
505
|
+
const tempOriginalIndex = originalIndex;
|
|
506
|
+
// STEP 2: We can continue to extend the furthest reaching point in the present diagonal
|
|
507
|
+
// so long as the elements are equal.
|
|
508
|
+
while (originalIndex < originalEnd && modifiedIndex < modifiedEnd && this.ElementsAreEqual(originalIndex + 1, modifiedIndex + 1)) {
|
|
509
|
+
originalIndex++;
|
|
510
|
+
modifiedIndex++;
|
|
511
|
+
}
|
|
512
|
+
forwardPoints[diagonal] = originalIndex;
|
|
513
|
+
if (originalIndex + modifiedIndex > furthestOriginalIndex + furthestModifiedIndex) {
|
|
514
|
+
furthestOriginalIndex = originalIndex;
|
|
515
|
+
furthestModifiedIndex = modifiedIndex;
|
|
516
|
+
}
|
|
517
|
+
// STEP 3: If delta is odd (overlap first happens on forward when delta is odd)
|
|
518
|
+
// and diagonal is in the range of reverse diagonals computed for numDifferences-1
|
|
519
|
+
// (the previous iteration; we haven't computed reverse diagonals for numDifferences yet)
|
|
520
|
+
// then check for overlap.
|
|
521
|
+
if (!deltaIsEven && Math.abs(diagonal - diagonalReverseBase) <= (numDifferences - 1)) {
|
|
522
|
+
if (originalIndex >= reversePoints[diagonal]) {
|
|
523
|
+
midOriginalArr[0] = originalIndex;
|
|
524
|
+
midModifiedArr[0] = modifiedIndex;
|
|
525
|
+
if (tempOriginalIndex <= reversePoints[diagonal] && 1447 /* LocalConstants.MaxDifferencesHistory */ > 0 && numDifferences <= (1447 /* LocalConstants.MaxDifferencesHistory */ + 1)) {
|
|
526
|
+
// BINGO! We overlapped, and we have the full trace in memory!
|
|
527
|
+
return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);
|
|
528
|
+
}
|
|
529
|
+
else {
|
|
530
|
+
// Either false overlap, or we didn't have enough memory for the full trace
|
|
531
|
+
// Just return the recursion point
|
|
532
|
+
return null;
|
|
533
|
+
}
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
}
|
|
537
|
+
// Check to see if we should be quitting early, before moving on to the next iteration.
|
|
538
|
+
const matchLengthOfLongest = ((furthestOriginalIndex - originalStart) + (furthestModifiedIndex - modifiedStart) - numDifferences) / 2;
|
|
539
|
+
if (this.ContinueProcessingPredicate !== null && !this.ContinueProcessingPredicate(furthestOriginalIndex, matchLengthOfLongest)) {
|
|
540
|
+
// We can't finish, so skip ahead to generating a result from what we have.
|
|
541
|
+
quitEarlyArr[0] = true;
|
|
542
|
+
// Use the furthest distance we got in the forward direction.
|
|
543
|
+
midOriginalArr[0] = furthestOriginalIndex;
|
|
544
|
+
midModifiedArr[0] = furthestModifiedIndex;
|
|
545
|
+
if (matchLengthOfLongest > 0 && 1447 /* LocalConstants.MaxDifferencesHistory */ > 0 && numDifferences <= (1447 /* LocalConstants.MaxDifferencesHistory */ + 1)) {
|
|
546
|
+
// Enough of the history is in memory to walk it backwards
|
|
547
|
+
return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);
|
|
548
|
+
}
|
|
549
|
+
else {
|
|
550
|
+
// We didn't actually remember enough of the history.
|
|
551
|
+
//Since we are quitting the diff early, we need to shift back the originalStart and modified start
|
|
552
|
+
//back into the boundary limits since we decremented their value above beyond the boundary limit.
|
|
553
|
+
originalStart++;
|
|
554
|
+
modifiedStart++;
|
|
555
|
+
return [
|
|
556
|
+
new DiffChange(originalStart, originalEnd - originalStart + 1, modifiedStart, modifiedEnd - modifiedStart + 1)
|
|
557
|
+
];
|
|
558
|
+
}
|
|
559
|
+
}
|
|
560
|
+
// Run the algorithm in the reverse direction
|
|
561
|
+
diagonalReverseStart = this.ClipDiagonalBound(diagonalReverseBase - numDifferences, numDifferences, diagonalReverseBase, numDiagonals);
|
|
562
|
+
diagonalReverseEnd = this.ClipDiagonalBound(diagonalReverseBase + numDifferences, numDifferences, diagonalReverseBase, numDiagonals);
|
|
563
|
+
for (let diagonal = diagonalReverseStart; diagonal <= diagonalReverseEnd; diagonal += 2) {
|
|
564
|
+
// STEP 1: We extend the furthest reaching point in the present diagonal
|
|
565
|
+
// by looking at the diagonals above and below and picking the one whose point
|
|
566
|
+
// is further away from the start point (originalEnd, modifiedEnd)
|
|
567
|
+
if (diagonal === diagonalReverseStart || (diagonal < diagonalReverseEnd && reversePoints[diagonal - 1] >= reversePoints[diagonal + 1])) {
|
|
568
|
+
originalIndex = reversePoints[diagonal + 1] - 1;
|
|
569
|
+
}
|
|
570
|
+
else {
|
|
571
|
+
originalIndex = reversePoints[diagonal - 1];
|
|
572
|
+
}
|
|
573
|
+
modifiedIndex = originalIndex - (diagonal - diagonalReverseBase) - diagonalReverseOffset;
|
|
574
|
+
// Save the current originalIndex so we can test for false overlap
|
|
575
|
+
const tempOriginalIndex = originalIndex;
|
|
576
|
+
// STEP 2: We can continue to extend the furthest reaching point in the present diagonal
|
|
577
|
+
// as long as the elements are equal.
|
|
578
|
+
while (originalIndex > originalStart && modifiedIndex > modifiedStart && this.ElementsAreEqual(originalIndex, modifiedIndex)) {
|
|
579
|
+
originalIndex--;
|
|
580
|
+
modifiedIndex--;
|
|
581
|
+
}
|
|
582
|
+
reversePoints[diagonal] = originalIndex;
|
|
583
|
+
// STEP 4: If delta is even (overlap first happens on reverse when delta is even)
|
|
584
|
+
// and diagonal is in the range of forward diagonals computed for numDifferences
|
|
585
|
+
// then check for overlap.
|
|
586
|
+
if (deltaIsEven && Math.abs(diagonal - diagonalForwardBase) <= numDifferences) {
|
|
587
|
+
if (originalIndex <= forwardPoints[diagonal]) {
|
|
588
|
+
midOriginalArr[0] = originalIndex;
|
|
589
|
+
midModifiedArr[0] = modifiedIndex;
|
|
590
|
+
if (tempOriginalIndex >= forwardPoints[diagonal] && 1447 /* LocalConstants.MaxDifferencesHistory */ > 0 && numDifferences <= (1447 /* LocalConstants.MaxDifferencesHistory */ + 1)) {
|
|
591
|
+
// BINGO! We overlapped, and we have the full trace in memory!
|
|
592
|
+
return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);
|
|
593
|
+
}
|
|
594
|
+
else {
|
|
595
|
+
// Either false overlap, or we didn't have enough memory for the full trace
|
|
596
|
+
// Just return the recursion point
|
|
597
|
+
return null;
|
|
598
|
+
}
|
|
599
|
+
}
|
|
600
|
+
}
|
|
601
|
+
}
|
|
602
|
+
// Save current vectors to history before the next iteration
|
|
603
|
+
if (numDifferences <= 1447 /* LocalConstants.MaxDifferencesHistory */) {
|
|
604
|
+
// We are allocating space for one extra int, which we fill with
|
|
605
|
+
// the index of the diagonal base index
|
|
606
|
+
let temp = new Int32Array(diagonalForwardEnd - diagonalForwardStart + 2);
|
|
607
|
+
temp[0] = diagonalForwardBase - diagonalForwardStart + 1;
|
|
608
|
+
MyArray.Copy2(forwardPoints, diagonalForwardStart, temp, 1, diagonalForwardEnd - diagonalForwardStart + 1);
|
|
609
|
+
this.m_forwardHistory.push(temp);
|
|
610
|
+
temp = new Int32Array(diagonalReverseEnd - diagonalReverseStart + 2);
|
|
611
|
+
temp[0] = diagonalReverseBase - diagonalReverseStart + 1;
|
|
612
|
+
MyArray.Copy2(reversePoints, diagonalReverseStart, temp, 1, diagonalReverseEnd - diagonalReverseStart + 1);
|
|
613
|
+
this.m_reverseHistory.push(temp);
|
|
614
|
+
}
|
|
615
|
+
}
|
|
616
|
+
// If we got here, then we have the full trace in history. We just have to convert it to a change list
|
|
617
|
+
// NOTE: This part is a bit messy
|
|
618
|
+
return this.WALKTRACE(diagonalForwardBase, diagonalForwardStart, diagonalForwardEnd, diagonalForwardOffset, diagonalReverseBase, diagonalReverseStart, diagonalReverseEnd, diagonalReverseOffset, forwardPoints, reversePoints, originalIndex, originalEnd, midOriginalArr, modifiedIndex, modifiedEnd, midModifiedArr, deltaIsEven, quitEarlyArr);
|
|
619
|
+
}
|
|
620
|
+
/**
|
|
621
|
+
* Shifts the given changes to provide a more intuitive diff.
|
|
622
|
+
* While the first element in a diff matches the first element after the diff,
|
|
623
|
+
* we shift the diff down.
|
|
624
|
+
*
|
|
625
|
+
* @param changes The list of changes to shift
|
|
626
|
+
* @returns The shifted changes
|
|
627
|
+
*/
|
|
628
|
+
PrettifyChanges(changes) {
|
|
629
|
+
// Shift all the changes down first
|
|
630
|
+
for (let i = 0; i < changes.length; i++) {
|
|
631
|
+
const change = changes[i];
|
|
632
|
+
const originalStop = (i < changes.length - 1) ? changes[i + 1].originalStart : this._originalElementsOrHash.length;
|
|
633
|
+
const modifiedStop = (i < changes.length - 1) ? changes[i + 1].modifiedStart : this._modifiedElementsOrHash.length;
|
|
634
|
+
const checkOriginal = change.originalLength > 0;
|
|
635
|
+
const checkModified = change.modifiedLength > 0;
|
|
636
|
+
while (change.originalStart + change.originalLength < originalStop
|
|
637
|
+
&& change.modifiedStart + change.modifiedLength < modifiedStop
|
|
638
|
+
&& (!checkOriginal || this.OriginalElementsAreEqual(change.originalStart, change.originalStart + change.originalLength))
|
|
639
|
+
&& (!checkModified || this.ModifiedElementsAreEqual(change.modifiedStart, change.modifiedStart + change.modifiedLength))) {
|
|
640
|
+
const startStrictEqual = this.ElementsAreStrictEqual(change.originalStart, change.modifiedStart);
|
|
641
|
+
const endStrictEqual = this.ElementsAreStrictEqual(change.originalStart + change.originalLength, change.modifiedStart + change.modifiedLength);
|
|
642
|
+
if (endStrictEqual && !startStrictEqual) {
|
|
643
|
+
// moving the change down would create an equal change, but the elements are not strict equal
|
|
644
|
+
break;
|
|
645
|
+
}
|
|
646
|
+
change.originalStart++;
|
|
647
|
+
change.modifiedStart++;
|
|
648
|
+
}
|
|
649
|
+
const mergedChangeArr = [null];
|
|
650
|
+
if (i < changes.length - 1 && this.ChangesOverlap(changes[i], changes[i + 1], mergedChangeArr)) {
|
|
651
|
+
changes[i] = mergedChangeArr[0];
|
|
652
|
+
changes.splice(i + 1, 1);
|
|
653
|
+
i--;
|
|
654
|
+
continue;
|
|
655
|
+
}
|
|
656
|
+
}
|
|
657
|
+
// Shift changes back up until we hit empty or whitespace-only lines
|
|
658
|
+
for (let i = changes.length - 1; i >= 0; i--) {
|
|
659
|
+
const change = changes[i];
|
|
660
|
+
let originalStop = 0;
|
|
661
|
+
let modifiedStop = 0;
|
|
662
|
+
if (i > 0) {
|
|
663
|
+
const prevChange = changes[i - 1];
|
|
664
|
+
originalStop = prevChange.originalStart + prevChange.originalLength;
|
|
665
|
+
modifiedStop = prevChange.modifiedStart + prevChange.modifiedLength;
|
|
666
|
+
}
|
|
667
|
+
const checkOriginal = change.originalLength > 0;
|
|
668
|
+
const checkModified = change.modifiedLength > 0;
|
|
669
|
+
let bestDelta = 0;
|
|
670
|
+
let bestScore = this._boundaryScore(change.originalStart, change.originalLength, change.modifiedStart, change.modifiedLength);
|
|
671
|
+
for (let delta = 1;; delta++) {
|
|
672
|
+
const originalStart = change.originalStart - delta;
|
|
673
|
+
const modifiedStart = change.modifiedStart - delta;
|
|
674
|
+
if (originalStart < originalStop || modifiedStart < modifiedStop) {
|
|
675
|
+
break;
|
|
676
|
+
}
|
|
677
|
+
if (checkOriginal && !this.OriginalElementsAreEqual(originalStart, originalStart + change.originalLength)) {
|
|
678
|
+
break;
|
|
679
|
+
}
|
|
680
|
+
if (checkModified && !this.ModifiedElementsAreEqual(modifiedStart, modifiedStart + change.modifiedLength)) {
|
|
681
|
+
break;
|
|
682
|
+
}
|
|
683
|
+
const touchingPreviousChange = (originalStart === originalStop && modifiedStart === modifiedStop);
|
|
684
|
+
const score = ((touchingPreviousChange ? 5 : 0)
|
|
685
|
+
+ this._boundaryScore(originalStart, change.originalLength, modifiedStart, change.modifiedLength));
|
|
686
|
+
if (score > bestScore) {
|
|
687
|
+
bestScore = score;
|
|
688
|
+
bestDelta = delta;
|
|
689
|
+
}
|
|
690
|
+
}
|
|
691
|
+
change.originalStart -= bestDelta;
|
|
692
|
+
change.modifiedStart -= bestDelta;
|
|
693
|
+
const mergedChangeArr = [null];
|
|
694
|
+
if (i > 0 && this.ChangesOverlap(changes[i - 1], changes[i], mergedChangeArr)) {
|
|
695
|
+
changes[i - 1] = mergedChangeArr[0];
|
|
696
|
+
changes.splice(i, 1);
|
|
697
|
+
i++;
|
|
698
|
+
continue;
|
|
699
|
+
}
|
|
700
|
+
}
|
|
701
|
+
// There could be multiple longest common substrings.
|
|
702
|
+
// Give preference to the ones containing longer lines
|
|
703
|
+
if (this._hasStrings) {
|
|
704
|
+
for (let i = 1, len = changes.length; i < len; i++) {
|
|
705
|
+
const aChange = changes[i - 1];
|
|
706
|
+
const bChange = changes[i];
|
|
707
|
+
const matchedLength = bChange.originalStart - aChange.originalStart - aChange.originalLength;
|
|
708
|
+
const aOriginalStart = aChange.originalStart;
|
|
709
|
+
const bOriginalEnd = bChange.originalStart + bChange.originalLength;
|
|
710
|
+
const abOriginalLength = bOriginalEnd - aOriginalStart;
|
|
711
|
+
const aModifiedStart = aChange.modifiedStart;
|
|
712
|
+
const bModifiedEnd = bChange.modifiedStart + bChange.modifiedLength;
|
|
713
|
+
const abModifiedLength = bModifiedEnd - aModifiedStart;
|
|
714
|
+
// Avoid wasting a lot of time with these searches
|
|
715
|
+
if (matchedLength < 5 && abOriginalLength < 20 && abModifiedLength < 20) {
|
|
716
|
+
const t = this._findBetterContiguousSequence(aOriginalStart, abOriginalLength, aModifiedStart, abModifiedLength, matchedLength);
|
|
717
|
+
if (t) {
|
|
718
|
+
const [originalMatchStart, modifiedMatchStart] = t;
|
|
719
|
+
if (originalMatchStart !== aChange.originalStart + aChange.originalLength || modifiedMatchStart !== aChange.modifiedStart + aChange.modifiedLength) {
|
|
720
|
+
// switch to another sequence that has a better score
|
|
721
|
+
aChange.originalLength = originalMatchStart - aChange.originalStart;
|
|
722
|
+
aChange.modifiedLength = modifiedMatchStart - aChange.modifiedStart;
|
|
723
|
+
bChange.originalStart = originalMatchStart + matchedLength;
|
|
724
|
+
bChange.modifiedStart = modifiedMatchStart + matchedLength;
|
|
725
|
+
bChange.originalLength = bOriginalEnd - bChange.originalStart;
|
|
726
|
+
bChange.modifiedLength = bModifiedEnd - bChange.modifiedStart;
|
|
727
|
+
}
|
|
728
|
+
}
|
|
729
|
+
}
|
|
730
|
+
}
|
|
731
|
+
}
|
|
732
|
+
return changes;
|
|
733
|
+
}
|
|
734
|
+
_findBetterContiguousSequence(originalStart, originalLength, modifiedStart, modifiedLength, desiredLength) {
|
|
735
|
+
if (originalLength < desiredLength || modifiedLength < desiredLength) {
|
|
736
|
+
return null;
|
|
737
|
+
}
|
|
738
|
+
const originalMax = originalStart + originalLength - desiredLength + 1;
|
|
739
|
+
const modifiedMax = modifiedStart + modifiedLength - desiredLength + 1;
|
|
740
|
+
let bestScore = 0;
|
|
741
|
+
let bestOriginalStart = 0;
|
|
742
|
+
let bestModifiedStart = 0;
|
|
743
|
+
for (let i = originalStart; i < originalMax; i++) {
|
|
744
|
+
for (let j = modifiedStart; j < modifiedMax; j++) {
|
|
745
|
+
const score = this._contiguousSequenceScore(i, j, desiredLength);
|
|
746
|
+
if (score > 0 && score > bestScore) {
|
|
747
|
+
bestScore = score;
|
|
748
|
+
bestOriginalStart = i;
|
|
749
|
+
bestModifiedStart = j;
|
|
750
|
+
}
|
|
751
|
+
}
|
|
752
|
+
}
|
|
753
|
+
if (bestScore > 0) {
|
|
754
|
+
return [bestOriginalStart, bestModifiedStart];
|
|
755
|
+
}
|
|
756
|
+
return null;
|
|
757
|
+
}
|
|
758
|
+
_contiguousSequenceScore(originalStart, modifiedStart, length) {
|
|
759
|
+
let score = 0;
|
|
760
|
+
for (let l = 0; l < length; l++) {
|
|
761
|
+
if (!this.ElementsAreEqual(originalStart + l, modifiedStart + l)) {
|
|
762
|
+
return 0;
|
|
763
|
+
}
|
|
764
|
+
score += this._originalStringElements[originalStart + l].length;
|
|
765
|
+
}
|
|
766
|
+
return score;
|
|
767
|
+
}
|
|
768
|
+
_OriginalIsBoundary(index) {
|
|
769
|
+
if (index <= 0 || index >= this._originalElementsOrHash.length - 1) {
|
|
770
|
+
return true;
|
|
771
|
+
}
|
|
772
|
+
return (this._hasStrings && /^\s*$/.test(this._originalStringElements[index]));
|
|
773
|
+
}
|
|
774
|
+
_OriginalRegionIsBoundary(originalStart, originalLength) {
|
|
775
|
+
if (this._OriginalIsBoundary(originalStart) || this._OriginalIsBoundary(originalStart - 1)) {
|
|
776
|
+
return true;
|
|
777
|
+
}
|
|
778
|
+
if (originalLength > 0) {
|
|
779
|
+
const originalEnd = originalStart + originalLength;
|
|
780
|
+
if (this._OriginalIsBoundary(originalEnd - 1) || this._OriginalIsBoundary(originalEnd)) {
|
|
781
|
+
return true;
|
|
782
|
+
}
|
|
783
|
+
}
|
|
784
|
+
return false;
|
|
785
|
+
}
|
|
786
|
+
_ModifiedIsBoundary(index) {
|
|
787
|
+
if (index <= 0 || index >= this._modifiedElementsOrHash.length - 1) {
|
|
788
|
+
return true;
|
|
789
|
+
}
|
|
790
|
+
return (this._hasStrings && /^\s*$/.test(this._modifiedStringElements[index]));
|
|
791
|
+
}
|
|
792
|
+
_ModifiedRegionIsBoundary(modifiedStart, modifiedLength) {
|
|
793
|
+
if (this._ModifiedIsBoundary(modifiedStart) || this._ModifiedIsBoundary(modifiedStart - 1)) {
|
|
794
|
+
return true;
|
|
795
|
+
}
|
|
796
|
+
if (modifiedLength > 0) {
|
|
797
|
+
const modifiedEnd = modifiedStart + modifiedLength;
|
|
798
|
+
if (this._ModifiedIsBoundary(modifiedEnd - 1) || this._ModifiedIsBoundary(modifiedEnd)) {
|
|
799
|
+
return true;
|
|
800
|
+
}
|
|
801
|
+
}
|
|
802
|
+
return false;
|
|
803
|
+
}
|
|
804
|
+
_boundaryScore(originalStart, originalLength, modifiedStart, modifiedLength) {
|
|
805
|
+
const originalScore = (this._OriginalRegionIsBoundary(originalStart, originalLength) ? 1 : 0);
|
|
806
|
+
const modifiedScore = (this._ModifiedRegionIsBoundary(modifiedStart, modifiedLength) ? 1 : 0);
|
|
807
|
+
return (originalScore + modifiedScore);
|
|
808
|
+
}
|
|
809
|
+
/**
|
|
810
|
+
* Concatenates the two input DiffChange lists and returns the resulting
|
|
811
|
+
* list.
|
|
812
|
+
* @param The left changes
|
|
813
|
+
* @param The right changes
|
|
814
|
+
* @returns The concatenated list
|
|
815
|
+
*/
|
|
816
|
+
ConcatenateChanges(left, right) {
|
|
817
|
+
const mergedChangeArr = [];
|
|
818
|
+
if (left.length === 0 || right.length === 0) {
|
|
819
|
+
return (right.length > 0) ? right : left;
|
|
820
|
+
}
|
|
821
|
+
else if (this.ChangesOverlap(left[left.length - 1], right[0], mergedChangeArr)) {
|
|
822
|
+
// Since we break the problem down recursively, it is possible that we
|
|
823
|
+
// might recurse in the middle of a change thereby splitting it into
|
|
824
|
+
// two changes. Here in the combining stage, we detect and fuse those
|
|
825
|
+
// changes back together
|
|
826
|
+
const result = new Array(left.length + right.length - 1);
|
|
827
|
+
MyArray.Copy(left, 0, result, 0, left.length - 1);
|
|
828
|
+
result[left.length - 1] = mergedChangeArr[0];
|
|
829
|
+
MyArray.Copy(right, 1, result, left.length, right.length - 1);
|
|
830
|
+
return result;
|
|
831
|
+
}
|
|
832
|
+
else {
|
|
833
|
+
const result = new Array(left.length + right.length);
|
|
834
|
+
MyArray.Copy(left, 0, result, 0, left.length);
|
|
835
|
+
MyArray.Copy(right, 0, result, left.length, right.length);
|
|
836
|
+
return result;
|
|
837
|
+
}
|
|
838
|
+
}
|
|
839
|
+
/**
|
|
840
|
+
* Returns true if the two changes overlap and can be merged into a single
|
|
841
|
+
* change
|
|
842
|
+
* @param left The left change
|
|
843
|
+
* @param right The right change
|
|
844
|
+
* @param mergedChange The merged change if the two overlap, null otherwise
|
|
845
|
+
* @returns True if the two changes overlap
|
|
846
|
+
*/
|
|
847
|
+
ChangesOverlap(left, right, mergedChangeArr) {
|
|
848
|
+
Debug.Assert(left.originalStart <= right.originalStart, 'Left change is not less than or equal to right change');
|
|
849
|
+
Debug.Assert(left.modifiedStart <= right.modifiedStart, 'Left change is not less than or equal to right change');
|
|
850
|
+
if (left.originalStart + left.originalLength >= right.originalStart || left.modifiedStart + left.modifiedLength >= right.modifiedStart) {
|
|
851
|
+
const originalStart = left.originalStart;
|
|
852
|
+
let originalLength = left.originalLength;
|
|
853
|
+
const modifiedStart = left.modifiedStart;
|
|
854
|
+
let modifiedLength = left.modifiedLength;
|
|
855
|
+
if (left.originalStart + left.originalLength >= right.originalStart) {
|
|
856
|
+
originalLength = right.originalStart + right.originalLength - left.originalStart;
|
|
857
|
+
}
|
|
858
|
+
if (left.modifiedStart + left.modifiedLength >= right.modifiedStart) {
|
|
859
|
+
modifiedLength = right.modifiedStart + right.modifiedLength - left.modifiedStart;
|
|
860
|
+
}
|
|
861
|
+
mergedChangeArr[0] = new DiffChange(originalStart, originalLength, modifiedStart, modifiedLength);
|
|
862
|
+
return true;
|
|
863
|
+
}
|
|
864
|
+
else {
|
|
865
|
+
mergedChangeArr[0] = null;
|
|
866
|
+
return false;
|
|
867
|
+
}
|
|
868
|
+
}
|
|
869
|
+
/**
|
|
870
|
+
* Helper method used to clip a diagonal index to the range of valid
|
|
871
|
+
* diagonals. This also decides whether or not the diagonal index,
|
|
872
|
+
* if it exceeds the boundary, should be clipped to the boundary or clipped
|
|
873
|
+
* one inside the boundary depending on the Even/Odd status of the boundary
|
|
874
|
+
* and numDifferences.
|
|
875
|
+
* @param diagonal The index of the diagonal to clip.
|
|
876
|
+
* @param numDifferences The current number of differences being iterated upon.
|
|
877
|
+
* @param diagonalBaseIndex The base reference diagonal.
|
|
878
|
+
* @param numDiagonals The total number of diagonals.
|
|
879
|
+
* @returns The clipped diagonal index.
|
|
880
|
+
*/
|
|
881
|
+
ClipDiagonalBound(diagonal, numDifferences, diagonalBaseIndex, numDiagonals) {
|
|
882
|
+
if (diagonal >= 0 && diagonal < numDiagonals) {
|
|
883
|
+
// Nothing to clip, its in range
|
|
884
|
+
return diagonal;
|
|
885
|
+
}
|
|
886
|
+
// diagonalsBelow: The number of diagonals below the reference diagonal
|
|
887
|
+
// diagonalsAbove: The number of diagonals above the reference diagonal
|
|
888
|
+
const diagonalsBelow = diagonalBaseIndex;
|
|
889
|
+
const diagonalsAbove = numDiagonals - diagonalBaseIndex - 1;
|
|
890
|
+
const diffEven = (numDifferences % 2 === 0);
|
|
891
|
+
if (diagonal < 0) {
|
|
892
|
+
const lowerBoundEven = (diagonalsBelow % 2 === 0);
|
|
893
|
+
return (diffEven === lowerBoundEven) ? 0 : 1;
|
|
894
|
+
}
|
|
895
|
+
else {
|
|
896
|
+
const upperBoundEven = (diagonalsAbove % 2 === 0);
|
|
897
|
+
return (diffEven === upperBoundEven) ? numDiagonals - 1 : numDiagonals - 2;
|
|
898
|
+
}
|
|
899
|
+
}
|
|
900
|
+
}
|
|
901
|
+
|
|
902
|
+
export { LcsDiff, StringDiffSequence, stringDiff };
|