@fluidframework/merge-tree 2.0.0-rc.1.0.4 → 2.0.0-rc.2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/{.eslintrc.js → .eslintrc.cjs} +4 -1
- package/{.mocharc.js → .mocharc.cjs} +1 -1
- package/CHANGELOG.md +4 -0
- package/api-extractor-cjs.json +8 -0
- package/api-extractor-lint.json +1 -1
- package/api-extractor.json +1 -9
- package/api-report/merge-tree.api.md +6 -12
- package/dist/MergeTreeTextHelper.d.ts +2 -2
- package/dist/MergeTreeTextHelper.d.ts.map +1 -1
- package/dist/MergeTreeTextHelper.js +3 -3
- package/dist/MergeTreeTextHelper.js.map +1 -1
- package/dist/attributionCollection.d.ts +1 -1
- package/dist/attributionCollection.d.ts.map +1 -1
- package/dist/attributionCollection.js.map +1 -1
- package/dist/attributionPolicy.d.ts +1 -1
- package/dist/attributionPolicy.d.ts.map +1 -1
- package/dist/attributionPolicy.js +15 -15
- package/dist/attributionPolicy.js.map +1 -1
- package/dist/client.d.ts +31 -12
- package/dist/client.d.ts.map +1 -1
- package/dist/client.js +103 -92
- package/dist/client.js.map +1 -1
- package/dist/collections/index.d.ts +2 -2
- package/dist/collections/index.d.ts.map +1 -1
- package/dist/collections/index.js +6 -6
- package/dist/collections/index.js.map +1 -1
- package/dist/endOfTreeSegment.d.ts +3 -3
- package/dist/endOfTreeSegment.d.ts.map +1 -1
- package/dist/endOfTreeSegment.js +8 -8
- package/dist/endOfTreeSegment.js.map +1 -1
- package/dist/index.d.ts +20 -20
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +71 -71
- package/dist/index.js.map +1 -1
- package/dist/localReference.d.ts +9 -39
- package/dist/localReference.d.ts.map +1 -1
- package/dist/localReference.js +29 -24
- package/dist/localReference.js.map +1 -1
- package/dist/merge-tree-alpha.d.ts +28 -450
- package/dist/merge-tree-beta.d.ts +0 -438
- package/dist/merge-tree-public.d.ts +0 -438
- package/dist/merge-tree-untrimmed.d.ts +28 -787
- package/dist/mergeTree.d.ts +11 -19
- package/dist/mergeTree.d.ts.map +1 -1
- package/dist/mergeTree.js +201 -189
- package/dist/mergeTree.js.map +1 -1
- package/dist/mergeTreeDeltaCallback.d.ts +3 -7
- package/dist/mergeTreeDeltaCallback.d.ts.map +1 -1
- package/dist/mergeTreeDeltaCallback.js.map +1 -1
- package/dist/mergeTreeNodeWalk.d.ts +1 -1
- package/dist/mergeTreeNodeWalk.d.ts.map +1 -1
- package/dist/mergeTreeNodeWalk.js.map +1 -1
- package/dist/mergeTreeNodes.d.ts +17 -14
- package/dist/mergeTreeNodes.d.ts.map +1 -1
- package/dist/mergeTreeNodes.js +32 -32
- package/dist/mergeTreeNodes.js.map +1 -1
- package/dist/mergeTreeTracking.d.ts +2 -2
- package/dist/mergeTreeTracking.d.ts.map +1 -1
- package/dist/mergeTreeTracking.js +2 -2
- package/dist/mergeTreeTracking.js.map +1 -1
- package/dist/opBuilder.d.ts +3 -3
- package/dist/opBuilder.d.ts.map +1 -1
- package/dist/opBuilder.js +7 -7
- package/dist/opBuilder.js.map +1 -1
- package/dist/package.json +3 -0
- package/dist/partialLengths.d.ts +5 -5
- package/dist/partialLengths.d.ts.map +1 -1
- package/dist/partialLengths.js +29 -29
- package/dist/partialLengths.js.map +1 -1
- package/dist/referencePositions.d.ts +4 -4
- package/dist/referencePositions.d.ts.map +1 -1
- package/dist/referencePositions.js +2 -2
- package/dist/referencePositions.js.map +1 -1
- package/dist/revertibles.d.ts +7 -7
- package/dist/revertibles.d.ts.map +1 -1
- package/dist/revertibles.js +39 -39
- package/dist/revertibles.js.map +1 -1
- package/dist/segmentGroupCollection.d.ts +1 -1
- package/dist/segmentGroupCollection.d.ts.map +1 -1
- package/dist/segmentGroupCollection.js +3 -3
- package/dist/segmentGroupCollection.js.map +1 -1
- package/dist/segmentPropertiesManager.d.ts +2 -2
- package/dist/segmentPropertiesManager.d.ts.map +1 -1
- package/dist/segmentPropertiesManager.js +8 -8
- package/dist/segmentPropertiesManager.js.map +1 -1
- package/dist/snapshotChunks.d.ts +3 -3
- package/dist/snapshotChunks.d.ts.map +1 -1
- package/dist/snapshotChunks.js +5 -5
- package/dist/snapshotChunks.js.map +1 -1
- package/dist/snapshotLoader.d.ts +3 -3
- package/dist/snapshotLoader.d.ts.map +1 -1
- package/dist/snapshotLoader.js +19 -19
- package/dist/snapshotLoader.js.map +1 -1
- package/dist/snapshotV1.d.ts +3 -3
- package/dist/snapshotV1.d.ts.map +1 -1
- package/dist/snapshotV1.js +35 -18
- package/dist/snapshotV1.js.map +1 -1
- package/dist/snapshotlegacy.d.ts +2 -2
- package/dist/snapshotlegacy.d.ts.map +1 -1
- package/dist/snapshotlegacy.js +22 -10
- package/dist/snapshotlegacy.js.map +1 -1
- package/dist/sortedSegmentSet.d.ts +3 -3
- package/dist/sortedSegmentSet.d.ts.map +1 -1
- package/dist/sortedSegmentSet.js +2 -2
- package/dist/sortedSegmentSet.js.map +1 -1
- package/dist/test/Insertion.perf.spec.js +15 -15
- package/dist/test/Insertion.perf.spec.js.map +1 -1
- package/dist/test/PartialLengths.perf.spec.js +13 -13
- package/dist/test/PartialLengths.perf.spec.js.map +1 -1
- package/dist/test/Removal.perf.spec.js +25 -25
- package/dist/test/Removal.perf.spec.js.map +1 -1
- package/dist/test/Snapshot.perf.spec.js +3 -3
- package/dist/test/Snapshot.perf.spec.js.map +1 -1
- package/dist/test/attributionCollection.perf.spec.js +9 -9
- package/dist/test/attributionCollection.perf.spec.js.map +1 -1
- package/dist/test/attributionCollection.spec.js +46 -46
- package/dist/test/attributionCollection.spec.js.map +1 -1
- package/dist/test/attributionPolicy.spec.js +13 -13
- package/dist/test/attributionPolicy.spec.js.map +1 -1
- package/dist/test/{beastTest.d.ts → beastTest.spec.d.ts} +3 -3
- package/dist/test/beastTest.spec.d.ts.map +1 -0
- package/dist/test/{beastTest.js → beastTest.spec.js} +120 -119
- package/dist/test/beastTest.spec.js.map +1 -0
- package/dist/test/client.annotateMarker.spec.js +13 -13
- package/dist/test/client.annotateMarker.spec.js.map +1 -1
- package/dist/test/{client.apis.d.ts → client.apis.spec.d.ts} +1 -1
- package/dist/test/client.apis.spec.d.ts.map +1 -0
- package/dist/test/{client.apis.js → client.apis.spec.js} +8 -8
- package/dist/test/client.apis.spec.js.map +1 -0
- package/dist/test/client.applyMsg.spec.js +106 -43
- package/dist/test/client.applyMsg.spec.js.map +1 -1
- package/dist/test/client.applyStashedOpFarm.spec.d.ts +1 -1
- package/dist/test/client.applyStashedOpFarm.spec.d.ts.map +1 -1
- package/dist/test/client.applyStashedOpFarm.spec.js +33 -21
- package/dist/test/client.applyStashedOpFarm.spec.js.map +1 -1
- package/dist/test/client.attributionFarm.spec.d.ts +1 -1
- package/dist/test/client.attributionFarm.spec.d.ts.map +1 -1
- package/dist/test/client.attributionFarm.spec.js +13 -13
- package/dist/test/client.attributionFarm.spec.js.map +1 -1
- package/dist/test/client.conflictFarm.spec.d.ts +1 -1
- package/dist/test/client.conflictFarm.spec.d.ts.map +1 -1
- package/dist/test/client.conflictFarm.spec.js +9 -9
- package/dist/test/client.conflictFarm.spec.js.map +1 -1
- package/dist/test/client.getPosition.spec.js +4 -4
- package/dist/test/client.getPosition.spec.js.map +1 -1
- package/dist/test/client.localReference.spec.js +72 -72
- package/dist/test/client.localReference.spec.js.map +1 -1
- package/dist/test/client.localReferenceFarm.spec.js +18 -18
- package/dist/test/client.localReferenceFarm.spec.js.map +1 -1
- package/dist/test/client.rebasePosition.spec.js +2 -2
- package/dist/test/client.rebasePosition.spec.js.map +1 -1
- package/dist/test/client.reconnectFarm.spec.d.ts +1 -1
- package/dist/test/client.reconnectFarm.spec.d.ts.map +1 -1
- package/dist/test/client.reconnectFarm.spec.js +10 -10
- package/dist/test/client.reconnectFarm.spec.js.map +1 -1
- package/dist/test/client.replay.spec.js +11 -11
- package/dist/test/client.replay.spec.js.map +1 -1
- package/dist/test/client.rollback.spec.js +83 -83
- package/dist/test/client.rollback.spec.js.map +1 -1
- package/dist/test/client.rollbackFarm.spec.js +9 -9
- package/dist/test/client.rollbackFarm.spec.js.map +1 -1
- package/dist/test/client.searchForMarker.spec.js +137 -137
- package/dist/test/client.searchForMarker.spec.js.map +1 -1
- package/dist/test/client.walkSegments.spec.js +2 -2
- package/dist/test/client.walkSegments.spec.js.map +1 -1
- package/dist/test/collections.list.spec.js +4 -4
- package/dist/test/collections.list.spec.js.map +1 -1
- package/dist/test/createInsertOnlyAttributionPolicy.spec.js +4 -4
- package/dist/test/createInsertOnlyAttributionPolicy.spec.js.map +1 -1
- package/dist/test/dirname.cjs +16 -0
- package/dist/test/dirname.cjs.map +1 -0
- package/dist/test/dirname.d.cts +6 -0
- package/dist/test/dirname.d.cts.map +1 -0
- package/dist/test/index.d.ts +8 -8
- package/dist/test/index.d.ts.map +1 -1
- package/dist/test/index.js +82 -81
- package/dist/test/index.js.map +1 -1
- package/dist/test/mergeTree.annotate.deltaCallback.spec.js +39 -39
- package/dist/test/mergeTree.annotate.deltaCallback.spec.js.map +1 -1
- package/dist/test/mergeTree.annotate.spec.js +39 -39
- package/dist/test/mergeTree.annotate.spec.js.map +1 -1
- package/dist/test/mergeTree.insert.deltaCallback.spec.js +35 -35
- package/dist/test/mergeTree.insert.deltaCallback.spec.js.map +1 -1
- package/dist/test/mergeTree.insertingWalk.spec.js +77 -77
- package/dist/test/mergeTree.insertingWalk.spec.js.map +1 -1
- package/dist/test/mergeTree.markRangeRemoved.deltaCallback.spec.js +42 -42
- package/dist/test/mergeTree.markRangeRemoved.deltaCallback.spec.js.map +1 -1
- package/dist/test/mergeTree.markRangeRemoved.spec.js +15 -15
- package/dist/test/mergeTree.markRangeRemoved.spec.js.map +1 -1
- package/dist/test/mergeTree.walk.spec.js +14 -14
- package/dist/test/mergeTree.walk.spec.js.map +1 -1
- package/dist/test/mergeTree.zamboni.spec.js +9 -9
- package/dist/test/mergeTree.zamboni.spec.js.map +1 -1
- package/dist/test/mergeTreeOperationRunner.d.ts +4 -4
- package/dist/test/mergeTreeOperationRunner.d.ts.map +1 -1
- package/dist/test/mergeTreeOperationRunner.js +16 -15
- package/dist/test/mergeTreeOperationRunner.js.map +1 -1
- package/dist/test/mergeTreeOperationRunner.spec.js +5 -5
- package/dist/test/mergeTreeOperationRunner.spec.js.map +1 -1
- package/dist/test/obliterate.concurrent.spec.js +85 -88
- package/dist/test/obliterate.concurrent.spec.js.map +1 -1
- package/dist/test/obliterate.deltaCallback.spec.d.ts +6 -0
- package/dist/test/obliterate.deltaCallback.spec.d.ts.map +1 -0
- package/dist/test/obliterate.deltaCallback.spec.js +146 -0
- package/dist/test/obliterate.deltaCallback.spec.js.map +1 -0
- package/dist/test/obliterate.partialLength.spec.js +39 -44
- package/dist/test/obliterate.partialLength.spec.js.map +1 -1
- package/dist/test/obliterate.reconnect.spec.js +15 -18
- package/dist/test/obliterate.reconnect.spec.js.map +1 -1
- package/dist/test/obliterate.spec.js +16 -16
- package/dist/test/obliterate.spec.js.map +1 -1
- package/dist/test/ordinal.spec.js +5 -5
- package/dist/test/ordinal.spec.js.map +1 -1
- package/dist/test/partialLength.spec.js +58 -64
- package/dist/test/partialLength.spec.js.map +1 -1
- package/dist/test/properties.spec.js +15 -15
- package/dist/test/properties.spec.js.map +1 -1
- package/dist/test/reconnectHelper.d.ts +8 -8
- package/dist/test/reconnectHelper.d.ts.map +1 -1
- package/dist/test/reconnectHelper.js +3 -3
- package/dist/test/reconnectHelper.js.map +1 -1
- package/dist/test/resetPendingSegmentsToOp.spec.js +18 -18
- package/dist/test/resetPendingSegmentsToOp.spec.js.map +1 -1
- package/dist/test/revertibleFarm.spec.js +21 -21
- package/dist/test/revertibleFarm.spec.js.map +1 -1
- package/dist/test/revertibles.spec.js +67 -67
- package/dist/test/revertibles.spec.js.map +1 -1
- package/dist/test/segmentGroupCollection.spec.js +3 -3
- package/dist/test/segmentGroupCollection.spec.js.map +1 -1
- package/dist/test/snapshot.spec.js +16 -16
- package/dist/test/snapshot.spec.js.map +1 -1
- package/dist/test/snapshot.utils.d.ts +4 -4
- package/dist/test/snapshot.utils.d.ts.map +1 -1
- package/dist/test/snapshot.utils.js +11 -11
- package/dist/test/snapshot.utils.js.map +1 -1
- package/dist/test/snapshotlegacy.spec.js +22 -22
- package/dist/test/snapshotlegacy.spec.js.map +1 -1
- package/dist/test/sortedSegmentSet.spec.js +9 -9
- package/dist/test/sortedSegmentSet.spec.js.map +1 -1
- package/dist/test/testClient.d.ts +13 -16
- package/dist/test/testClient.d.ts.map +1 -1
- package/dist/test/testClient.js +57 -59
- package/dist/test/testClient.js.map +1 -1
- package/dist/test/testClientLogger.d.ts +3 -3
- package/dist/test/testClientLogger.d.ts.map +1 -1
- package/dist/test/testClientLogger.js +19 -19
- package/dist/test/testClientLogger.js.map +1 -1
- package/dist/test/testServer.d.ts +3 -3
- package/dist/test/testServer.d.ts.map +1 -1
- package/dist/test/testServer.js +8 -8
- package/dist/test/testServer.js.map +1 -1
- package/dist/test/testUtils.d.ts +14 -6
- package/dist/test/testUtils.d.ts.map +1 -1
- package/dist/test/testUtils.js +36 -17
- package/dist/test/testUtils.js.map +1 -1
- package/dist/test/text.d.ts +2 -2
- package/dist/test/text.d.ts.map +1 -1
- package/dist/test/text.js +10 -10
- package/dist/test/text.js.map +1 -1
- package/dist/test/tracking.spec.js +12 -12
- package/dist/test/tracking.spec.js.map +1 -1
- package/dist/test/{wordUnitTests.d.ts → wordUnitTests.spec.d.ts} +1 -1
- package/dist/test/wordUnitTests.spec.d.ts.map +1 -0
- package/dist/test/{wordUnitTests.js → wordUnitTests.spec.js} +16 -15
- package/dist/test/wordUnitTests.spec.js.map +1 -0
- package/dist/textSegment.d.ts +3 -3
- package/dist/textSegment.d.ts.map +1 -1
- package/dist/textSegment.js +2 -2
- package/dist/textSegment.js.map +1 -1
- package/dist/tsdoc-metadata.json +1 -1
- package/dist/zamboni.d.ts +2 -2
- package/dist/zamboni.d.ts.map +1 -1
- package/dist/zamboni.js +19 -19
- package/dist/zamboni.js.map +1 -1
- package/lib/{MergeTreeTextHelper.d.mts → MergeTreeTextHelper.d.ts} +3 -3
- package/lib/MergeTreeTextHelper.d.ts.map +1 -0
- package/lib/{MergeTreeTextHelper.mjs → MergeTreeTextHelper.js} +3 -2
- package/lib/MergeTreeTextHelper.js.map +1 -0
- package/lib/{attributionCollection.d.mts → attributionCollection.d.ts} +2 -2
- package/lib/attributionCollection.d.ts.map +1 -0
- package/lib/{attributionCollection.mjs → attributionCollection.js} +1 -1
- package/lib/attributionCollection.js.map +1 -0
- package/lib/{attributionPolicy.d.mts → attributionPolicy.d.ts} +2 -2
- package/lib/attributionPolicy.d.ts.map +1 -0
- package/lib/{attributionPolicy.mjs → attributionPolicy.js} +4 -4
- package/lib/attributionPolicy.js.map +1 -0
- package/lib/{client.d.mts → client.d.ts} +32 -13
- package/lib/client.d.ts.map +1 -0
- package/lib/{client.mjs → client.js} +42 -31
- package/lib/client.js.map +1 -0
- package/lib/collections/{index.d.mts → index.d.ts} +3 -3
- package/lib/collections/index.d.ts.map +1 -0
- package/lib/collections/index.js +7 -0
- package/lib/collections/index.js.map +1 -0
- package/lib/collections/{list.d.mts → list.d.ts} +1 -1
- package/lib/collections/list.d.ts.map +1 -0
- package/lib/collections/{list.mjs → list.js} +1 -1
- package/lib/collections/list.js.map +1 -0
- package/lib/collections/{rbTree.d.mts → rbTree.d.ts} +1 -1
- package/lib/collections/rbTree.d.ts.map +1 -0
- package/lib/collections/{rbTree.mjs → rbTree.js} +1 -1
- package/lib/collections/rbTree.js.map +1 -0
- package/lib/{constants.d.mts → constants.d.ts} +1 -1
- package/lib/constants.d.ts.map +1 -0
- package/lib/{constants.mjs → constants.js} +1 -1
- package/lib/constants.js.map +1 -0
- package/lib/{endOfTreeSegment.d.mts → endOfTreeSegment.d.ts} +4 -4
- package/lib/endOfTreeSegment.d.ts.map +1 -0
- package/lib/{endOfTreeSegment.mjs → endOfTreeSegment.js} +3 -3
- package/lib/endOfTreeSegment.js.map +1 -0
- package/lib/{index.d.mts → index.d.ts} +21 -21
- package/lib/index.d.ts.map +1 -0
- package/lib/{index.mjs → index.js} +20 -20
- package/lib/index.js.map +1 -0
- package/lib/{localReference.d.mts → localReference.d.ts} +10 -40
- package/lib/localReference.d.ts.map +1 -0
- package/lib/{localReference.mjs → localReference.js} +12 -6
- package/lib/localReference.js.map +1 -0
- package/lib/{merge-tree-alpha.d.mts → merge-tree-alpha.d.ts} +28 -450
- package/lib/merge-tree-beta.d.ts +230 -0
- package/lib/merge-tree-public.d.ts +230 -0
- package/lib/{merge-tree-untrimmed.d.mts → merge-tree-untrimmed.d.ts} +28 -787
- package/lib/{mergeTree.d.mts → mergeTree.d.ts} +12 -20
- package/lib/mergeTree.d.ts.map +1 -0
- package/lib/{mergeTree.mjs → mergeTree.js} +47 -32
- package/lib/mergeTree.js.map +1 -0
- package/lib/{mergeTreeDeltaCallback.d.mts → mergeTreeDeltaCallback.d.ts} +8 -8
- package/lib/mergeTreeDeltaCallback.d.ts.map +1 -0
- package/lib/{mergeTreeDeltaCallback.mjs → mergeTreeDeltaCallback.js} +1 -1
- package/lib/mergeTreeDeltaCallback.js.map +1 -0
- package/lib/{mergeTreeNodeWalk.d.mts → mergeTreeNodeWalk.d.ts} +2 -2
- package/lib/mergeTreeNodeWalk.d.ts.map +1 -0
- package/lib/{mergeTreeNodeWalk.mjs → mergeTreeNodeWalk.js} +1 -1
- package/lib/mergeTreeNodeWalk.js.map +1 -0
- package/lib/{mergeTreeNodes.d.mts → mergeTreeNodes.d.ts} +18 -15
- package/lib/mergeTreeNodes.d.ts.map +1 -0
- package/lib/{mergeTreeNodes.mjs → mergeTreeNodes.js} +12 -10
- package/lib/mergeTreeNodes.js.map +1 -0
- package/lib/{mergeTreeTracking.d.mts → mergeTreeTracking.d.ts} +3 -3
- package/lib/mergeTreeTracking.d.ts.map +1 -0
- package/lib/{mergeTreeTracking.mjs → mergeTreeTracking.js} +3 -2
- package/lib/mergeTreeTracking.js.map +1 -0
- package/lib/{opBuilder.d.mts → opBuilder.d.ts} +4 -4
- package/lib/{opBuilder.d.mts.map → opBuilder.d.ts.map} +1 -1
- package/lib/{opBuilder.mjs → opBuilder.js} +2 -2
- package/lib/opBuilder.js.map +1 -0
- package/lib/{ops.d.mts → ops.d.ts} +1 -1
- package/lib/ops.d.ts.map +1 -0
- package/lib/{ops.mjs → ops.js} +1 -1
- package/lib/ops.js.map +1 -0
- package/lib/{ordinal.d.mts → ordinal.d.ts} +1 -1
- package/lib/ordinal.d.ts.map +1 -0
- package/lib/{ordinal.mjs → ordinal.js} +2 -1
- package/lib/ordinal.js.map +1 -0
- package/lib/{partialLengths.d.mts → partialLengths.d.ts} +6 -6
- package/lib/partialLengths.d.ts.map +1 -0
- package/lib/{partialLengths.mjs → partialLengths.js} +11 -10
- package/lib/partialLengths.js.map +1 -0
- package/lib/{properties.d.mts → properties.d.ts} +1 -1
- package/lib/properties.d.ts.map +1 -0
- package/lib/{properties.mjs → properties.js} +1 -1
- package/lib/properties.js.map +1 -0
- package/lib/{referencePositions.d.mts → referencePositions.d.ts} +5 -5
- package/lib/referencePositions.d.ts.map +1 -0
- package/lib/{referencePositions.mjs → referencePositions.js} +2 -2
- package/lib/referencePositions.js.map +1 -0
- package/lib/{revertibles.d.mts → revertibles.d.ts} +8 -8
- package/lib/revertibles.d.ts.map +1 -0
- package/lib/{revertibles.mjs → revertibles.js} +13 -13
- package/lib/revertibles.js.map +1 -0
- package/lib/{segmentGroupCollection.d.mts → segmentGroupCollection.d.ts} +2 -2
- package/lib/segmentGroupCollection.d.ts.map +1 -0
- package/lib/{segmentGroupCollection.mjs → segmentGroupCollection.js} +2 -2
- package/lib/segmentGroupCollection.js.map +1 -0
- package/lib/{segmentPropertiesManager.d.mts → segmentPropertiesManager.d.ts} +3 -3
- package/lib/segmentPropertiesManager.d.ts.map +1 -0
- package/lib/{segmentPropertiesManager.mjs → segmentPropertiesManager.js} +5 -3
- package/lib/segmentPropertiesManager.js.map +1 -0
- package/lib/{snapshotChunks.d.mts → snapshotChunks.d.ts} +4 -4
- package/lib/snapshotChunks.d.ts.map +1 -0
- package/lib/{snapshotChunks.mjs → snapshotChunks.js} +2 -2
- package/lib/snapshotChunks.js.map +1 -0
- package/lib/{snapshotLoader.d.mts → snapshotLoader.d.ts} +4 -4
- package/lib/snapshotLoader.d.ts.map +1 -0
- package/lib/{snapshotLoader.mjs → snapshotLoader.js} +10 -9
- package/lib/snapshotLoader.js.map +1 -0
- package/lib/{snapshotV1.d.mts → snapshotV1.d.ts} +4 -4
- package/lib/snapshotV1.d.ts.map +1 -0
- package/lib/{snapshotV1.mjs → snapshotV1.js} +24 -7
- package/lib/snapshotV1.js.map +1 -0
- package/lib/{snapshotlegacy.d.mts → snapshotlegacy.d.ts} +3 -3
- package/lib/snapshotlegacy.d.ts.map +1 -0
- package/lib/{snapshotlegacy.mjs → snapshotlegacy.js} +17 -4
- package/lib/snapshotlegacy.js.map +1 -0
- package/lib/{sortedSegmentSet.d.mts → sortedSegmentSet.d.ts} +4 -4
- package/lib/sortedSegmentSet.d.ts.map +1 -0
- package/lib/{sortedSegmentSet.mjs → sortedSegmentSet.js} +3 -2
- package/lib/sortedSegmentSet.js.map +1 -0
- package/lib/{sortedSet.d.mts → sortedSet.d.ts} +1 -1
- package/lib/sortedSet.d.ts.map +1 -0
- package/lib/{sortedSet.mjs → sortedSet.js} +1 -1
- package/lib/sortedSet.js.map +1 -0
- package/lib/test/Insertion.perf.spec.d.ts +6 -0
- package/lib/test/Insertion.perf.spec.d.ts.map +1 -0
- package/lib/test/Insertion.perf.spec.js +111 -0
- package/lib/test/Insertion.perf.spec.js.map +1 -0
- package/lib/test/PartialLengths.perf.spec.d.ts +6 -0
- package/lib/test/PartialLengths.perf.spec.d.ts.map +1 -0
- package/lib/test/PartialLengths.perf.spec.js +65 -0
- package/lib/test/PartialLengths.perf.spec.js.map +1 -0
- package/lib/test/Removal.perf.spec.d.ts +6 -0
- package/lib/test/Removal.perf.spec.d.ts.map +1 -0
- package/lib/test/Removal.perf.spec.js +164 -0
- package/lib/test/Removal.perf.spec.js.map +1 -0
- package/lib/test/Snapshot.perf.spec.d.ts +6 -0
- package/lib/test/Snapshot.perf.spec.d.ts.map +1 -0
- package/lib/test/Snapshot.perf.spec.js +31 -0
- package/lib/test/Snapshot.perf.spec.js.map +1 -0
- package/lib/test/attributionCollection.perf.spec.d.ts +6 -0
- package/lib/test/attributionCollection.perf.spec.d.ts.map +1 -0
- package/lib/test/attributionCollection.perf.spec.js +229 -0
- package/lib/test/attributionCollection.perf.spec.js.map +1 -0
- package/lib/test/attributionCollection.spec.d.ts +6 -0
- package/lib/test/attributionCollection.spec.d.ts.map +1 -0
- package/lib/test/attributionCollection.spec.js +484 -0
- package/lib/test/attributionCollection.spec.js.map +1 -0
- package/lib/test/attributionPolicy.spec.d.ts +6 -0
- package/lib/test/attributionPolicy.spec.d.ts.map +1 -0
- package/lib/test/attributionPolicy.spec.js +187 -0
- package/lib/test/attributionPolicy.spec.js.map +1 -0
- package/lib/test/beastTest.spec.d.ts +54 -0
- package/lib/test/beastTest.spec.d.ts.map +1 -0
- package/lib/test/beastTest.spec.js +1318 -0
- package/lib/test/beastTest.spec.js.map +1 -0
- package/lib/test/client.annotateMarker.spec.d.ts +6 -0
- package/lib/test/client.annotateMarker.spec.d.ts.map +1 -0
- package/lib/test/client.annotateMarker.spec.js +43 -0
- package/lib/test/client.annotateMarker.spec.js.map +1 -0
- package/lib/test/client.apis.spec.d.ts +7 -0
- package/lib/test/client.apis.spec.d.ts.map +1 -0
- package/lib/test/client.apis.spec.js +67 -0
- package/lib/test/client.apis.spec.js.map +1 -0
- package/lib/test/client.applyMsg.spec.d.ts +6 -0
- package/lib/test/client.applyMsg.spec.d.ts.map +1 -0
- package/lib/test/client.applyMsg.spec.js +561 -0
- package/lib/test/client.applyMsg.spec.js.map +1 -0
- package/lib/test/client.applyStashedOpFarm.spec.d.ts +12 -0
- package/lib/test/client.applyStashedOpFarm.spec.d.ts.map +1 -0
- package/lib/test/client.applyStashedOpFarm.spec.js +153 -0
- package/lib/test/client.applyStashedOpFarm.spec.js.map +1 -0
- package/lib/test/client.attributionFarm.spec.d.ts +7 -0
- package/lib/test/client.attributionFarm.spec.d.ts.map +1 -0
- package/lib/test/client.attributionFarm.spec.js +92 -0
- package/lib/test/client.attributionFarm.spec.js.map +1 -0
- package/lib/test/client.conflictFarm.spec.d.ts +15 -0
- package/lib/test/client.conflictFarm.spec.d.ts.map +1 -0
- package/lib/test/client.conflictFarm.spec.js +85 -0
- package/lib/test/client.conflictFarm.spec.js.map +1 -0
- package/lib/test/client.getPosition.spec.d.ts +6 -0
- package/lib/test/client.getPosition.spec.d.ts.map +1 -0
- package/lib/test/client.getPosition.spec.js +52 -0
- package/lib/test/client.getPosition.spec.js.map +1 -0
- package/lib/test/client.localReference.spec.d.ts +6 -0
- package/lib/test/client.localReference.spec.d.ts.map +1 -0
- package/lib/test/client.localReference.spec.js +468 -0
- package/lib/test/client.localReference.spec.js.map +1 -0
- package/lib/test/client.localReferenceFarm.spec.d.ts +6 -0
- package/lib/test/client.localReferenceFarm.spec.d.ts.map +1 -0
- package/lib/test/client.localReferenceFarm.spec.js +86 -0
- package/lib/test/client.localReferenceFarm.spec.js.map +1 -0
- package/lib/test/client.rebasePosition.spec.d.ts +6 -0
- package/lib/test/client.rebasePosition.spec.d.ts.map +1 -0
- package/lib/test/client.rebasePosition.spec.js +100 -0
- package/lib/test/client.rebasePosition.spec.js.map +1 -0
- package/lib/test/client.reconnectFarm.spec.d.ts +12 -0
- package/lib/test/client.reconnectFarm.spec.d.ts.map +1 -0
- package/lib/test/client.reconnectFarm.spec.js +88 -0
- package/lib/test/client.reconnectFarm.spec.js.map +1 -0
- package/lib/test/client.replay.spec.d.ts +6 -0
- package/lib/test/client.replay.spec.d.ts.map +1 -0
- package/lib/test/client.replay.spec.js +57 -0
- package/lib/test/client.replay.spec.js.map +1 -0
- package/lib/test/client.rollback.spec.d.ts +6 -0
- package/lib/test/client.rollback.spec.d.ts.map +1 -0
- package/lib/test/client.rollback.spec.js +451 -0
- package/lib/test/client.rollback.spec.js.map +1 -0
- package/lib/test/client.rollbackFarm.spec.d.ts +6 -0
- package/lib/test/client.rollbackFarm.spec.d.ts.map +1 -0
- package/lib/test/client.rollbackFarm.spec.js +46 -0
- package/lib/test/client.rollbackFarm.spec.js.map +1 -0
- package/lib/test/client.searchForMarker.spec.d.ts +6 -0
- package/lib/test/client.searchForMarker.spec.d.ts.map +1 -0
- package/lib/test/client.searchForMarker.spec.js +495 -0
- package/lib/test/client.searchForMarker.spec.js.map +1 -0
- package/lib/test/client.walkSegments.spec.d.ts +6 -0
- package/lib/test/client.walkSegments.spec.d.ts.map +1 -0
- package/lib/test/client.walkSegments.spec.js +52 -0
- package/lib/test/client.walkSegments.spec.js.map +1 -0
- package/lib/test/collections.list.spec.d.ts +6 -0
- package/lib/test/collections.list.spec.d.ts.map +1 -0
- package/lib/test/collections.list.spec.js +82 -0
- package/lib/test/collections.list.spec.js.map +1 -0
- package/lib/test/createInsertOnlyAttributionPolicy.spec.d.ts +6 -0
- package/lib/test/createInsertOnlyAttributionPolicy.spec.d.ts.map +1 -0
- package/lib/test/createInsertOnlyAttributionPolicy.spec.js +33 -0
- package/lib/test/createInsertOnlyAttributionPolicy.spec.js.map +1 -0
- package/lib/test/dirname.cjs +16 -0
- package/lib/test/dirname.cjs.map +1 -0
- package/lib/test/dirname.d.cts +6 -0
- package/lib/test/dirname.d.cts.map +1 -0
- package/lib/test/index.d.ts +13 -0
- package/lib/test/index.d.ts.map +1 -0
- package/lib/test/index.js +13 -0
- package/lib/test/index.js.map +1 -0
- package/lib/test/mergeTree.annotate.deltaCallback.spec.d.ts +6 -0
- package/lib/test/mergeTree.annotate.deltaCallback.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.annotate.deltaCallback.spec.js +140 -0
- package/lib/test/mergeTree.annotate.deltaCallback.spec.js.map +1 -0
- package/lib/test/mergeTree.annotate.spec.d.ts +6 -0
- package/lib/test/mergeTree.annotate.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.annotate.spec.js +446 -0
- package/lib/test/mergeTree.annotate.spec.js.map +1 -0
- package/lib/test/mergeTree.insert.deltaCallback.spec.d.ts +6 -0
- package/lib/test/mergeTree.insert.deltaCallback.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.insert.deltaCallback.spec.js +124 -0
- package/lib/test/mergeTree.insert.deltaCallback.spec.js.map +1 -0
- package/lib/test/mergeTree.insertingWalk.spec.d.ts +6 -0
- package/lib/test/mergeTree.insertingWalk.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.insertingWalk.spec.js +277 -0
- package/lib/test/mergeTree.insertingWalk.spec.js.map +1 -0
- package/lib/test/mergeTree.markRangeRemoved.deltaCallback.spec.d.ts +6 -0
- package/lib/test/mergeTree.markRangeRemoved.deltaCallback.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.markRangeRemoved.deltaCallback.spec.js +176 -0
- package/lib/test/mergeTree.markRangeRemoved.deltaCallback.spec.js.map +1 -0
- package/lib/test/mergeTree.markRangeRemoved.spec.d.ts +6 -0
- package/lib/test/mergeTree.markRangeRemoved.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.markRangeRemoved.spec.js +128 -0
- package/lib/test/mergeTree.markRangeRemoved.spec.js.map +1 -0
- package/lib/test/mergeTree.walk.spec.d.ts +6 -0
- package/lib/test/mergeTree.walk.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.walk.spec.js +61 -0
- package/lib/test/mergeTree.walk.spec.js.map +1 -0
- package/lib/test/mergeTree.zamboni.spec.d.ts +6 -0
- package/lib/test/mergeTree.zamboni.spec.d.ts.map +1 -0
- package/lib/test/mergeTree.zamboni.spec.js +50 -0
- package/lib/test/mergeTree.zamboni.spec.js.map +1 -0
- package/lib/test/mergeTreeOperationRunner.d.ts +63 -0
- package/lib/test/mergeTreeOperationRunner.d.ts.map +1 -0
- package/lib/test/mergeTreeOperationRunner.js +207 -0
- package/lib/test/mergeTreeOperationRunner.js.map +1 -0
- package/lib/test/mergeTreeOperationRunner.spec.d.ts +6 -0
- package/lib/test/mergeTreeOperationRunner.spec.d.ts.map +1 -0
- package/lib/test/mergeTreeOperationRunner.spec.js +154 -0
- package/lib/test/mergeTreeOperationRunner.spec.js.map +1 -0
- package/lib/test/obliterate.concurrent.spec.d.ts +6 -0
- package/lib/test/obliterate.concurrent.spec.d.ts.map +1 -0
- package/lib/test/obliterate.concurrent.spec.js +1441 -0
- package/lib/test/obliterate.concurrent.spec.js.map +1 -0
- package/lib/test/obliterate.deltaCallback.spec.d.ts +6 -0
- package/lib/test/obliterate.deltaCallback.spec.d.ts.map +1 -0
- package/lib/test/obliterate.deltaCallback.spec.js +144 -0
- package/lib/test/obliterate.deltaCallback.spec.js.map +1 -0
- package/lib/test/obliterate.partialLength.spec.d.ts +6 -0
- package/lib/test/obliterate.partialLength.spec.d.ts.map +1 -0
- package/lib/test/obliterate.partialLength.spec.js +272 -0
- package/lib/test/obliterate.partialLength.spec.js.map +1 -0
- package/lib/test/obliterate.reconnect.spec.d.ts +6 -0
- package/lib/test/obliterate.reconnect.spec.d.ts.map +1 -0
- package/lib/test/obliterate.reconnect.spec.js +159 -0
- package/lib/test/obliterate.reconnect.spec.js.map +1 -0
- package/lib/test/obliterate.spec.d.ts +6 -0
- package/lib/test/obliterate.spec.d.ts.map +1 -0
- package/lib/test/obliterate.spec.js +160 -0
- package/lib/test/obliterate.spec.js.map +1 -0
- package/lib/test/ordinal.spec.d.ts +2 -0
- package/lib/test/ordinal.spec.d.ts.map +1 -0
- package/lib/test/ordinal.spec.js +38 -0
- package/lib/test/ordinal.spec.js.map +1 -0
- package/lib/test/partialLength.spec.d.ts +6 -0
- package/lib/test/partialLength.spec.d.ts.map +1 -0
- package/lib/test/partialLength.spec.js +274 -0
- package/lib/test/partialLength.spec.js.map +1 -0
- package/lib/test/properties.spec.d.ts +6 -0
- package/lib/test/properties.spec.d.ts.map +1 -0
- package/lib/test/properties.spec.js +53 -0
- package/lib/test/properties.spec.js.map +1 -0
- package/lib/test/reconnectHelper.d.ts +48 -0
- package/lib/test/reconnectHelper.d.ts.map +1 -0
- package/lib/test/reconnectHelper.js +82 -0
- package/lib/test/reconnectHelper.js.map +1 -0
- package/lib/test/resetPendingSegmentsToOp.spec.d.ts +6 -0
- package/lib/test/resetPendingSegmentsToOp.spec.d.ts.map +1 -0
- package/lib/test/resetPendingSegmentsToOp.spec.js +235 -0
- package/lib/test/resetPendingSegmentsToOp.spec.js.map +1 -0
- package/lib/test/revertibleFarm.spec.d.ts +6 -0
- package/lib/test/revertibleFarm.spec.d.ts.map +1 -0
- package/lib/test/revertibleFarm.spec.js +119 -0
- package/lib/test/revertibleFarm.spec.js.map +1 -0
- package/lib/test/revertibles.spec.d.ts +17 -0
- package/lib/test/revertibles.spec.d.ts.map +1 -0
- package/lib/test/revertibles.spec.js +381 -0
- package/lib/test/revertibles.spec.js.map +1 -0
- package/lib/test/segmentGroupCollection.spec.d.ts +6 -0
- package/lib/test/segmentGroupCollection.spec.d.ts.map +1 -0
- package/lib/test/segmentGroupCollection.spec.js +58 -0
- package/lib/test/segmentGroupCollection.spec.js.map +1 -0
- package/lib/test/snapshot.spec.d.ts +6 -0
- package/lib/test/snapshot.spec.d.ts.map +1 -0
- package/lib/test/snapshot.spec.js +176 -0
- package/lib/test/snapshot.spec.js.map +1 -0
- package/lib/test/snapshot.utils.d.ts +33 -0
- package/lib/test/snapshot.utils.d.ts.map +1 -0
- package/lib/test/snapshot.utils.js +104 -0
- package/lib/test/snapshot.utils.js.map +1 -0
- package/lib/test/snapshotlegacy.spec.d.ts +6 -0
- package/lib/test/snapshotlegacy.spec.d.ts.map +1 -0
- package/lib/test/snapshotlegacy.spec.js +137 -0
- package/lib/test/snapshotlegacy.spec.js.map +1 -0
- package/lib/test/sortedSegmentSet.spec.d.ts +6 -0
- package/lib/test/sortedSegmentSet.spec.d.ts.map +1 -0
- package/lib/test/sortedSegmentSet.spec.js +93 -0
- package/lib/test/sortedSegmentSet.spec.js.map +1 -0
- package/lib/test/testClient.d.ts +116 -0
- package/lib/test/testClient.d.ts.map +1 -0
- package/lib/test/testClient.js +430 -0
- package/lib/test/testClient.js.map +1 -0
- package/lib/test/testClientLogger.d.ts +44 -0
- package/lib/test/testClientLogger.d.ts.map +1 -0
- package/lib/test/testClientLogger.js +282 -0
- package/lib/test/testClientLogger.js.map +1 -0
- package/lib/test/testSerializer.d.ts +18 -0
- package/lib/test/testSerializer.d.ts.map +1 -0
- package/lib/test/testSerializer.js +29 -0
- package/lib/test/testSerializer.js.map +1 -0
- package/lib/test/testServer.d.ts +36 -0
- package/lib/test/testServer.d.ts.map +1 -0
- package/lib/test/testServer.js +133 -0
- package/lib/test/testServer.js.map +1 -0
- package/lib/test/testUtils.d.ts +77 -0
- package/lib/test/testUtils.d.ts.map +1 -0
- package/lib/test/testUtils.js +151 -0
- package/lib/test/testUtils.js.map +1 -0
- package/lib/test/text.d.ts +9 -0
- package/lib/test/text.d.ts.map +1 -0
- package/lib/test/text.js +71 -0
- package/lib/test/text.js.map +1 -0
- package/lib/test/tracking.spec.d.ts +6 -0
- package/lib/test/tracking.spec.d.ts.map +1 -0
- package/lib/test/tracking.spec.js +118 -0
- package/lib/test/tracking.spec.js.map +1 -0
- package/lib/test/types/validateMergeTreePrevious.generated.d.ts +2 -0
- package/lib/test/types/validateMergeTreePrevious.generated.d.ts.map +1 -0
- package/lib/test/types/validateMergeTreePrevious.generated.js +228 -0
- package/lib/test/types/validateMergeTreePrevious.generated.js.map +1 -0
- package/lib/test/wordUnitTests.spec.d.ts +6 -0
- package/lib/test/wordUnitTests.spec.d.ts.map +1 -0
- package/lib/test/wordUnitTests.spec.js +166 -0
- package/lib/test/wordUnitTests.spec.js.map +1 -0
- package/lib/{textSegment.d.mts → textSegment.d.ts} +4 -4
- package/lib/textSegment.d.ts.map +1 -0
- package/lib/{textSegment.mjs → textSegment.js} +2 -2
- package/lib/textSegment.js.map +1 -0
- package/lib/{zamboni.d.mts → zamboni.d.ts} +3 -3
- package/lib/zamboni.d.ts.map +1 -0
- package/lib/{zamboni.mjs → zamboni.js} +7 -6
- package/lib/zamboni.js.map +1 -0
- package/package.json +50 -57
- package/src/MergeTreeTextHelper.ts +4 -4
- package/src/attributionCollection.ts +1 -1
- package/src/attributionPolicy.ts +5 -5
- package/src/client.ts +50 -41
- package/src/collections/index.ts +2 -2
- package/src/endOfTreeSegment.ts +5 -5
- package/src/index.ts +20 -20
- package/src/localReference.ts +13 -7
- package/src/mergeTree.ts +53 -44
- package/src/mergeTreeDeltaCallback.ts +3 -8
- package/src/mergeTreeNodeWalk.ts +1 -1
- package/src/mergeTreeNodes.ts +21 -19
- package/src/mergeTreeTracking.ts +3 -3
- package/src/opBuilder.ts +3 -3
- package/src/partialLengths.ts +10 -10
- package/src/referencePositions.ts +4 -4
- package/src/revertibles.ts +14 -18
- package/src/segmentGroupCollection.ts +2 -2
- package/src/segmentPropertiesManager.ts +3 -3
- package/src/snapshotChunks.ts +4 -4
- package/src/snapshotLoader.ts +14 -11
- package/src/snapshotV1.ts +29 -9
- package/src/snapshotlegacy.ts +19 -5
- package/src/sortedSegmentSet.ts +3 -3
- package/src/textSegment.ts +3 -3
- package/src/zamboni.ts +7 -7
- package/tsconfig.cjs.json +7 -0
- package/tsconfig.json +2 -5
- package/api-extractor-esm.json +0 -17
- package/dist/test/beastTest.d.ts.map +0 -1
- package/dist/test/beastTest.js.map +0 -1
- package/dist/test/client.apis.d.ts.map +0 -1
- package/dist/test/client.apis.js.map +0 -1
- package/dist/test/wordUnitTests.d.ts.map +0 -1
- package/dist/test/wordUnitTests.js.map +0 -1
- package/lib/MergeTreeTextHelper.d.mts.map +0 -1
- package/lib/MergeTreeTextHelper.mjs.map +0 -1
- package/lib/attributionCollection.d.mts.map +0 -1
- package/lib/attributionCollection.mjs.map +0 -1
- package/lib/attributionPolicy.d.mts.map +0 -1
- package/lib/attributionPolicy.mjs.map +0 -1
- package/lib/client.d.mts.map +0 -1
- package/lib/client.mjs.map +0 -1
- package/lib/collections/index.d.mts.map +0 -1
- package/lib/collections/index.mjs +0 -7
- package/lib/collections/index.mjs.map +0 -1
- package/lib/collections/list.d.mts.map +0 -1
- package/lib/collections/list.mjs.map +0 -1
- package/lib/collections/rbTree.d.mts.map +0 -1
- package/lib/collections/rbTree.mjs.map +0 -1
- package/lib/constants.d.mts.map +0 -1
- package/lib/constants.mjs.map +0 -1
- package/lib/endOfTreeSegment.d.mts.map +0 -1
- package/lib/endOfTreeSegment.mjs.map +0 -1
- package/lib/index.d.mts.map +0 -1
- package/lib/index.mjs.map +0 -1
- package/lib/localReference.d.mts.map +0 -1
- package/lib/localReference.mjs.map +0 -1
- package/lib/merge-tree-beta.d.mts +0 -668
- package/lib/merge-tree-public.d.mts +0 -668
- package/lib/mergeTree.d.mts.map +0 -1
- package/lib/mergeTree.mjs.map +0 -1
- package/lib/mergeTreeDeltaCallback.d.mts.map +0 -1
- package/lib/mergeTreeDeltaCallback.mjs.map +0 -1
- package/lib/mergeTreeNodeWalk.d.mts.map +0 -1
- package/lib/mergeTreeNodeWalk.mjs.map +0 -1
- package/lib/mergeTreeNodes.d.mts.map +0 -1
- package/lib/mergeTreeNodes.mjs.map +0 -1
- package/lib/mergeTreeTracking.d.mts.map +0 -1
- package/lib/mergeTreeTracking.mjs.map +0 -1
- package/lib/opBuilder.mjs.map +0 -1
- package/lib/ops.d.mts.map +0 -1
- package/lib/ops.mjs.map +0 -1
- package/lib/ordinal.d.mts.map +0 -1
- package/lib/ordinal.mjs.map +0 -1
- package/lib/partialLengths.d.mts.map +0 -1
- package/lib/partialLengths.mjs.map +0 -1
- package/lib/properties.d.mts.map +0 -1
- package/lib/properties.mjs.map +0 -1
- package/lib/referencePositions.d.mts.map +0 -1
- package/lib/referencePositions.mjs.map +0 -1
- package/lib/revertibles.d.mts.map +0 -1
- package/lib/revertibles.mjs.map +0 -1
- package/lib/segmentGroupCollection.d.mts.map +0 -1
- package/lib/segmentGroupCollection.mjs.map +0 -1
- package/lib/segmentPropertiesManager.d.mts.map +0 -1
- package/lib/segmentPropertiesManager.mjs.map +0 -1
- package/lib/snapshotChunks.d.mts.map +0 -1
- package/lib/snapshotChunks.mjs.map +0 -1
- package/lib/snapshotLoader.d.mts.map +0 -1
- package/lib/snapshotLoader.mjs.map +0 -1
- package/lib/snapshotV1.d.mts.map +0 -1
- package/lib/snapshotV1.mjs.map +0 -1
- package/lib/snapshotlegacy.d.mts.map +0 -1
- package/lib/snapshotlegacy.mjs.map +0 -1
- package/lib/sortedSegmentSet.d.mts.map +0 -1
- package/lib/sortedSegmentSet.mjs.map +0 -1
- package/lib/sortedSet.d.mts.map +0 -1
- package/lib/sortedSet.mjs.map +0 -1
- package/lib/textSegment.d.mts.map +0 -1
- package/lib/textSegment.mjs.map +0 -1
- package/lib/zamboni.d.mts.map +0 -1
- package/lib/zamboni.mjs.map +0 -1
|
@@ -33,17 +33,17 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
33
33
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
34
34
|
const fs = __importStar(require("fs"));
|
|
35
35
|
const assert_1 = __importDefault(require("assert"));
|
|
36
|
-
const
|
|
37
|
-
const
|
|
38
|
-
const
|
|
39
|
-
const
|
|
40
|
-
const
|
|
36
|
+
const ops_js_1 = require("../ops.js");
|
|
37
|
+
const opBuilder_js_1 = require("../opBuilder.js");
|
|
38
|
+
const testClient_js_1 = require("./testClient.js");
|
|
39
|
+
const mergeTreeOperationRunner_js_1 = require("./mergeTreeOperationRunner.js");
|
|
40
|
+
const testClientLogger_js_1 = require("./testClientLogger.js");
|
|
41
41
|
describe("MergeTree.Client", () => {
|
|
42
|
-
for (const filePath of fs.readdirSync(
|
|
42
|
+
for (const filePath of fs.readdirSync(mergeTreeOperationRunner_js_1.replayResultsPath)) {
|
|
43
43
|
it(`Replay ${filePath}`, async () => {
|
|
44
|
-
const file = JSON.parse(fs.readFileSync(`${
|
|
44
|
+
const file = JSON.parse(fs.readFileSync(`${mergeTreeOperationRunner_js_1.replayResultsPath}/${filePath}`).toString());
|
|
45
45
|
const msgClients = new Map();
|
|
46
|
-
const originalClient = new
|
|
46
|
+
const originalClient = new testClient_js_1.TestClient();
|
|
47
47
|
msgClients.set("A", { client: originalClient, msgs: [] });
|
|
48
48
|
originalClient.insertTextLocal(0, file[0].initialText);
|
|
49
49
|
originalClient.startOrUpdateCollaboration("A");
|
|
@@ -51,13 +51,13 @@ describe("MergeTree.Client", () => {
|
|
|
51
51
|
for (const msg of group.msgs) {
|
|
52
52
|
(0, assert_1.default)(msg.clientId, "expected clientId to be defined");
|
|
53
53
|
if (!msgClients.has(msg.clientId)) {
|
|
54
|
-
const client = await
|
|
54
|
+
const client = await testClient_js_1.TestClient.createFromClientSnapshot(originalClient, msg.clientId);
|
|
55
55
|
msgClients.set(msg.clientId, { client, msgs: [] });
|
|
56
56
|
}
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
59
|
for (const group of file) {
|
|
60
|
-
const logger = new
|
|
60
|
+
const logger = new testClientLogger_js_1.TestClientLogger([...msgClients.values()].map((mc) => mc.client));
|
|
61
61
|
const initialText = logger.validate();
|
|
62
62
|
assert_1.default.strictEqual(initialText, group.initialText, "Initial text not as expected");
|
|
63
63
|
for (const msg of group.msgs) {
|
|
@@ -67,7 +67,7 @@ describe("MergeTree.Client", () => {
|
|
|
67
67
|
msgClient.client.applyMsg(msgClient.msgs.shift());
|
|
68
68
|
}
|
|
69
69
|
const op = msg.contents;
|
|
70
|
-
msgClient.client.localTransaction(op.type ===
|
|
70
|
+
msgClient.client.localTransaction(op.type === ops_js_1.MergeTreeDeltaType.GROUP ? op : (0, opBuilder_js_1.createGroupOp)(op));
|
|
71
71
|
msgClients.forEach((mc) => mc.msgs.push(msg));
|
|
72
72
|
}
|
|
73
73
|
msgClients.forEach((mc) => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"client.replay.spec.js","sourceRoot":"","sources":["../../src/test/client.replay.spec.ts"],"names":[],"mappings":";AAAA;;;GAGG;AACH,6DAA6D;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAE7D,uCAAyB;AACzB,oDAA4B;AAE5B,
|
|
1
|
+
{"version":3,"file":"client.replay.spec.js","sourceRoot":"","sources":["../../src/test/client.replay.spec.ts"],"names":[],"mappings":";AAAA;;;GAGG;AACH,6DAA6D;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAE7D,uCAAyB;AACzB,oDAA4B;AAE5B,sCAA6D;AAC7D,kDAAgD;AAChD,mDAA6C;AAC7C,+EAA+E;AAC/E,+DAAyD;AAEzD,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IACjC,KAAK,MAAM,QAAQ,IAAI,EAAE,CAAC,WAAW,CAAC,+CAAiB,CAAC,EAAE;QACzD,EAAE,CAAC,UAAU,QAAQ,EAAE,EAAE,KAAK,IAAI,EAAE;YACnC,MAAM,IAAI,GAAkB,IAAI,CAAC,KAAK,CACrC,EAAE,CAAC,YAAY,CAAC,GAAG,+CAAiB,IAAI,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAC9D,CAAC;YACF,MAAM,UAAU,GAAG,IAAI,GAAG,EAGvB,CAAC;YACJ,MAAM,cAAc,GAAG,IAAI,0BAAU,EAAE,CAAC;YACxC,UAAU,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;YAC1D,cAAc,CAAC,eAAe,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;YACvD,cAAc,CAAC,0BAA0B,CAAC,GAAG,CAAC,CAAC;YAC/C,KAAK,MAAM,KAAK,IAAI,IAAI,EAAE;gBACzB,KAAK,MAAM,GAAG,IAAI,KAAK,CAAC,IAAI,EAAE;oBAC7B,IAAA,gBAAM,EAAC,GAAG,CAAC,QAAQ,EAAE,iCAAiC,CAAC,CAAC;oBACxD,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE;wBAClC,MAAM,MAAM,GAAG,MAAM,0BAAU,CAAC,wBAAwB,CACvD,cAAc,EACd,GAAG,CAAC,QAAQ,CACZ,CAAC;wBACF,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,CAAC;qBACnD;iBACD;aACD;YACD,KAAK,MAAM,KAAK,IAAI,IAAI,EAAE;gBACzB,MAAM,MAAM,GAAG,IAAI,sCAAgB,CAClC,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,MAAM,CAAC,CAC/C,CAAC;gBACF,MAAM,WAAW,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACtC,gBAAM,CAAC,WAAW,CAAC,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,8BAA8B,CAAC,CAAC;gBACnF,KAAK,MAAM,GAAG,IAAI,KAAK,CAAC,IAAI,EAAE;oBAC7B,MAAM,SAAS,GAAG,UAAU,CAAC,GAAG,CAAC,GAAG,CAAC,QAAS,CAAE,CAAC;oBACjD,OACC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;wBACzB,GAAG,CAAC,uBAAuB,GAAG,SAAS,CAAC,MAAM,CAAC,aAAa,EAAE,EAC7D;wBACD,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAG,CAAC,CAAC;qBACnD;oBACD,MAAM,EAAE,GAAG,GAAG,CAAC,QAAwB,CAAC;oBACxC,SAAS,CAAC,MAAM,CAAC,gBAAgB,CAChC,EAAE,CAAC,IAAI,KAAK,2BAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAA,4BAAa,EAAC,EAAE,CAAC,CAC7D,CAAC;oBACF,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;iBAC9C;gBAED,UAAU,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE;oBACzB,OAAO,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE;wBAC1B,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,EAAG,CAAC,CAAC;qBACrC;gBACF,CAAC,CAAC,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACjC,gBAAM,CAAC,WAAW,CAAC,MAAM,EAAE,KAAK,CAAC,UAAU,EAAE,6BAA6B,CAAC,CAAC;gBAC5E,MAAM,CAAC,OAAO,EAAE,CAAC;aACjB;QACF,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,GAAG,KAAK,CAAC,CAAC;KACvB;AACF,CAAC,CAAC,CAAC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n/* eslint-disable @typescript-eslint/no-non-null-assertion */\n\nimport * as fs from \"fs\";\nimport assert from \"assert\";\nimport { ISequencedDocumentMessage } from \"@fluidframework/protocol-definitions\";\nimport { IMergeTreeOp, MergeTreeDeltaType } from \"../ops.js\";\nimport { createGroupOp } from \"../opBuilder.js\";\nimport { TestClient } from \"./testClient.js\";\nimport { ReplayGroup, replayResultsPath } from \"./mergeTreeOperationRunner.js\";\nimport { TestClientLogger } from \"./testClientLogger.js\";\n\ndescribe(\"MergeTree.Client\", () => {\n\tfor (const filePath of fs.readdirSync(replayResultsPath)) {\n\t\tit(`Replay ${filePath}`, async () => {\n\t\t\tconst file: ReplayGroup[] = JSON.parse(\n\t\t\t\tfs.readFileSync(`${replayResultsPath}/${filePath}`).toString(),\n\t\t\t);\n\t\t\tconst msgClients = new Map<\n\t\t\t\tstring,\n\t\t\t\t{ client: TestClient; msgs: ISequencedDocumentMessage[] }\n\t\t\t>();\n\t\t\tconst originalClient = new TestClient();\n\t\t\tmsgClients.set(\"A\", { client: originalClient, msgs: [] });\n\t\t\toriginalClient.insertTextLocal(0, file[0].initialText);\n\t\t\toriginalClient.startOrUpdateCollaboration(\"A\");\n\t\t\tfor (const group of file) {\n\t\t\t\tfor (const msg of group.msgs) {\n\t\t\t\t\tassert(msg.clientId, \"expected clientId to be defined\");\n\t\t\t\t\tif (!msgClients.has(msg.clientId)) {\n\t\t\t\t\t\tconst client = await TestClient.createFromClientSnapshot(\n\t\t\t\t\t\t\toriginalClient,\n\t\t\t\t\t\t\tmsg.clientId,\n\t\t\t\t\t\t);\n\t\t\t\t\t\tmsgClients.set(msg.clientId, { client, msgs: [] });\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t}\n\t\t\tfor (const group of file) {\n\t\t\t\tconst logger = new TestClientLogger(\n\t\t\t\t\t[...msgClients.values()].map((mc) => mc.client),\n\t\t\t\t);\n\t\t\t\tconst initialText = logger.validate();\n\t\t\t\tassert.strictEqual(initialText, group.initialText, \"Initial text not as expected\");\n\t\t\t\tfor (const msg of group.msgs) {\n\t\t\t\t\tconst msgClient = msgClients.get(msg.clientId!)!;\n\t\t\t\t\twhile (\n\t\t\t\t\t\tmsgClient.msgs.length > 0 &&\n\t\t\t\t\t\tmsg.referenceSequenceNumber > msgClient.client.getCurrentSeq()\n\t\t\t\t\t) {\n\t\t\t\t\t\tmsgClient.client.applyMsg(msgClient.msgs.shift()!);\n\t\t\t\t\t}\n\t\t\t\t\tconst op = msg.contents as IMergeTreeOp;\n\t\t\t\t\tmsgClient.client.localTransaction(\n\t\t\t\t\t\top.type === MergeTreeDeltaType.GROUP ? op : createGroupOp(op),\n\t\t\t\t\t);\n\t\t\t\t\tmsgClients.forEach((mc) => mc.msgs.push(msg));\n\t\t\t\t}\n\n\t\t\t\tmsgClients.forEach((mc) => {\n\t\t\t\t\twhile (mc.msgs.length > 0) {\n\t\t\t\t\t\tmc.client.applyMsg(mc.msgs.shift()!);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t\tconst result = logger.validate();\n\t\t\t\tassert.strictEqual(result, group.resultText, \"Result text not as expected\");\n\t\t\t\tlogger.dispose();\n\t\t\t}\n\t\t}).timeout(30 * 10000);\n\t}\n});\n"]}
|
|
@@ -6,40 +6,40 @@
|
|
|
6
6
|
/* eslint-disable @typescript-eslint/no-non-null-assertion */
|
|
7
7
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
8
|
const assert_1 = require("assert");
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const
|
|
13
|
-
const
|
|
14
|
-
const
|
|
15
|
-
const
|
|
9
|
+
const constants_js_1 = require("../constants.js");
|
|
10
|
+
const mergeTreeNodes_js_1 = require("../mergeTreeNodes.js");
|
|
11
|
+
const ops_js_1 = require("../ops.js");
|
|
12
|
+
const textSegment_js_1 = require("../textSegment.js");
|
|
13
|
+
const testClient_js_1 = require("./testClient.js");
|
|
14
|
+
const testClientLogger_js_1 = require("./testClientLogger.js");
|
|
15
|
+
const testUtils_js_1 = require("./testUtils.js");
|
|
16
16
|
describe("client.rollback", () => {
|
|
17
17
|
const localUserLongId = "localUser";
|
|
18
18
|
let client;
|
|
19
19
|
beforeEach(() => {
|
|
20
|
-
client = new
|
|
21
|
-
(0,
|
|
20
|
+
client = new testClient_js_1.TestClient();
|
|
21
|
+
(0, testUtils_js_1.insertSegments)({
|
|
22
22
|
mergeTree: client.mergeTree,
|
|
23
23
|
pos: 0,
|
|
24
|
-
segments: [
|
|
25
|
-
refSeq:
|
|
24
|
+
segments: [textSegment_js_1.TextSegment.make("")],
|
|
25
|
+
refSeq: constants_js_1.UniversalSequenceNumber,
|
|
26
26
|
clientId: client.getClientId(),
|
|
27
|
-
seq:
|
|
27
|
+
seq: constants_js_1.UniversalSequenceNumber,
|
|
28
28
|
opArgs: undefined,
|
|
29
29
|
});
|
|
30
30
|
client.startOrUpdateCollaboration(localUserLongId);
|
|
31
31
|
});
|
|
32
32
|
it("Should rollback insert on empty string", () => {
|
|
33
33
|
client.insertTextLocal(0, "abcd");
|
|
34
|
-
client.rollback?.({ type:
|
|
34
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
35
35
|
assert_1.strict.equal(client.getText(), "");
|
|
36
36
|
});
|
|
37
37
|
it("Should rollback insert marker", () => {
|
|
38
38
|
client.insertTextLocal(0, "abc");
|
|
39
|
-
client.insertMarkerLocal(1,
|
|
40
|
-
[
|
|
39
|
+
client.insertMarkerLocal(1, ops_js_1.ReferenceType.Simple, {
|
|
40
|
+
[mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId",
|
|
41
41
|
});
|
|
42
|
-
client.rollback?.({ type:
|
|
42
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
43
43
|
assert_1.strict.equal(client.getText(), "abc");
|
|
44
44
|
const marker = client.getMarkerFromId("markerId");
|
|
45
45
|
assert_1.strict.equal(marker, undefined);
|
|
@@ -48,28 +48,28 @@ describe("client.rollback", () => {
|
|
|
48
48
|
client.insertTextLocal(0, "ghi");
|
|
49
49
|
client.insertTextLocal(0, "def");
|
|
50
50
|
client.insertTextLocal(0, "abc");
|
|
51
|
-
client.rollback?.({ type:
|
|
51
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
52
52
|
assert_1.strict.equal(client.getText(), "defghi");
|
|
53
|
-
(0,
|
|
54
|
-
client.rollback?.({ type:
|
|
53
|
+
(0, testUtils_js_1.validatePartialLengths)(client.getClientId(), client.mergeTree);
|
|
54
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
55
55
|
assert_1.strict.equal(client.getText(), "ghi");
|
|
56
|
-
(0,
|
|
56
|
+
(0, testUtils_js_1.validatePartialLengths)(client.getClientId(), client.mergeTree);
|
|
57
57
|
});
|
|
58
58
|
it("Should rollback multiple inserts with split segments", () => {
|
|
59
59
|
client.insertTextLocal(0, "aefg");
|
|
60
60
|
client.insertTextLocal(1, "bd");
|
|
61
61
|
client.insertTextLocal(2, "c");
|
|
62
|
-
client.rollback?.({ type:
|
|
63
|
-
client.rollback?.({ type:
|
|
62
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
63
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
64
64
|
assert_1.strict.equal(client.getText(), "aefg");
|
|
65
|
-
(0,
|
|
65
|
+
(0, testUtils_js_1.validatePartialLengths)(client.getClientId(), client.mergeTree);
|
|
66
66
|
});
|
|
67
67
|
it("Should zamboni rolled back insert", () => {
|
|
68
68
|
client.insertTextLocal(0, "aefg");
|
|
69
69
|
client.insertTextLocal(1, "bcd");
|
|
70
70
|
const segmentGroup = client.peekPendingSegmentGroups();
|
|
71
71
|
const segment = segmentGroup.segments[0];
|
|
72
|
-
client.rollback?.({ type:
|
|
72
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, segmentGroup);
|
|
73
73
|
// do some work and move the client's min seq forward, so zamboni runs
|
|
74
74
|
for (const c of "hello world") {
|
|
75
75
|
client.applyMsg(client.makeOpMessage(client.insertTextLocal(client.getLength(), c), client.getCurrentSeq() + 1, client.getCurrentSeq(), undefined, client.getCurrentSeq()));
|
|
@@ -77,57 +77,57 @@ describe("client.rollback", () => {
|
|
|
77
77
|
assert_1.strict.equal(segment.parent, undefined);
|
|
78
78
|
});
|
|
79
79
|
it("Should rollback annotate marker", () => {
|
|
80
|
-
client.insertMarkerLocal(0,
|
|
81
|
-
[
|
|
80
|
+
client.insertMarkerLocal(0, ops_js_1.ReferenceType.Simple, {
|
|
81
|
+
[mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId",
|
|
82
82
|
});
|
|
83
83
|
const marker = client.getMarkerFromId("markerId");
|
|
84
84
|
client.annotateMarker(marker, { foo: "bar" });
|
|
85
|
-
client.rollback?.({ type:
|
|
85
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
86
86
|
const properties = marker.getProperties();
|
|
87
87
|
assert_1.strict.equal(properties?.foo, undefined);
|
|
88
88
|
});
|
|
89
89
|
it("Should rollback annotate marker overwriting property", () => {
|
|
90
|
-
client.insertMarkerLocal(0,
|
|
91
|
-
[
|
|
90
|
+
client.insertMarkerLocal(0, ops_js_1.ReferenceType.Simple, {
|
|
91
|
+
[mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId",
|
|
92
92
|
foo: "bar",
|
|
93
93
|
});
|
|
94
94
|
const marker = client.getMarkerFromId("markerId");
|
|
95
95
|
client.annotateMarker(marker, { foo: "baz" });
|
|
96
|
-
client.rollback?.({ type:
|
|
96
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
97
97
|
const properties = marker.getProperties();
|
|
98
98
|
assert_1.strict.equal(properties?.foo, "bar");
|
|
99
99
|
});
|
|
100
100
|
it("Should rollback annotate marker removing property", () => {
|
|
101
|
-
client.insertMarkerLocal(0,
|
|
102
|
-
[
|
|
101
|
+
client.insertMarkerLocal(0, ops_js_1.ReferenceType.Simple, {
|
|
102
|
+
[mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId",
|
|
103
103
|
foo: "bar",
|
|
104
104
|
});
|
|
105
105
|
const marker = client.getMarkerFromId("markerId");
|
|
106
106
|
client.annotateMarker(marker, { foo: null });
|
|
107
|
-
client.rollback?.({ type:
|
|
107
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
108
108
|
const properties = marker.getProperties();
|
|
109
109
|
assert_1.strict.equal(properties?.foo, "bar");
|
|
110
110
|
});
|
|
111
111
|
it("Should rollback annotate marker rewrite", () => {
|
|
112
|
-
client.insertMarkerLocal(0,
|
|
113
|
-
[
|
|
112
|
+
client.insertMarkerLocal(0, ops_js_1.ReferenceType.Simple, {
|
|
113
|
+
[mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId",
|
|
114
114
|
foo: "bar",
|
|
115
115
|
});
|
|
116
116
|
const marker = client.getMarkerFromId("markerId");
|
|
117
|
-
client.annotateMarker(marker, { [
|
|
118
|
-
client.rollback?.({ type:
|
|
117
|
+
client.annotateMarker(marker, { [mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId", abc: "def" });
|
|
118
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
119
119
|
const properties = marker.getProperties();
|
|
120
120
|
assert_1.strict.equal(properties?.foo, "bar");
|
|
121
121
|
assert_1.strict.equal(properties?.abc, undefined);
|
|
122
122
|
});
|
|
123
123
|
it("Should rollback annotate rewrite with explicit null", () => {
|
|
124
|
-
client.insertMarkerLocal(0,
|
|
125
|
-
[
|
|
124
|
+
client.insertMarkerLocal(0, ops_js_1.ReferenceType.Simple, {
|
|
125
|
+
[mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId",
|
|
126
126
|
foo: "bar",
|
|
127
127
|
});
|
|
128
128
|
const marker = client.getMarkerFromId("markerId");
|
|
129
|
-
client.annotateMarker(marker, { [
|
|
130
|
-
client.rollback?.({ type:
|
|
129
|
+
client.annotateMarker(marker, { [mergeTreeNodes_js_1.reservedMarkerIdKey]: "markerId", abc: "def", foo: null });
|
|
130
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
131
131
|
const properties = marker.getProperties();
|
|
132
132
|
assert_1.strict.equal(properties?.foo, "bar");
|
|
133
133
|
assert_1.strict.equal(properties?.abc, undefined);
|
|
@@ -135,7 +135,7 @@ describe("client.rollback", () => {
|
|
|
135
135
|
it("Should rollback annotate causes split string", () => {
|
|
136
136
|
client.insertTextLocal(0, "abcdefg");
|
|
137
137
|
client.annotateRangeLocal(1, 3, { foo: "bar" });
|
|
138
|
-
client.rollback?.({ type:
|
|
138
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
139
139
|
for (let i = 0; i < 4; i++) {
|
|
140
140
|
const props = client.getPropertiesAtPosition(i);
|
|
141
141
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
@@ -145,7 +145,7 @@ describe("client.rollback", () => {
|
|
|
145
145
|
client.insertTextLocal(0, "abfg");
|
|
146
146
|
client.insertTextLocal(1, "cde");
|
|
147
147
|
client.annotateRangeLocal(1, 6, { foo: "bar" });
|
|
148
|
-
client.rollback?.({ type:
|
|
148
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
149
149
|
for (let i = 0; i < 7; i++) {
|
|
150
150
|
const props = client.getPropertiesAtPosition(i);
|
|
151
151
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
@@ -155,8 +155,8 @@ describe("client.rollback", () => {
|
|
|
155
155
|
client.insertTextLocal(0, "abfg");
|
|
156
156
|
client.annotateRangeLocal(0, 4, { foo: "bar" });
|
|
157
157
|
client.insertTextLocal(1, "cde");
|
|
158
|
-
client.rollback?.({ type:
|
|
159
|
-
client.rollback?.({ type:
|
|
158
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
159
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
160
160
|
assert_1.strict.equal(client.getText(), "abfg");
|
|
161
161
|
for (let i = 0; i < 4; i++) {
|
|
162
162
|
const props = client.getPropertiesAtPosition(i);
|
|
@@ -169,14 +169,14 @@ describe("client.rollback", () => {
|
|
|
169
169
|
client.annotateRangeLocal(2, 4, { foo: "two" });
|
|
170
170
|
client.annotateRangeLocal(0, 3, { foo: "three" });
|
|
171
171
|
client.insertTextLocal(1, "b");
|
|
172
|
-
client.rollback?.({ type:
|
|
172
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
173
173
|
let props = client.getPropertiesAtPosition(3);
|
|
174
174
|
(0, assert_1.strict)(props !== undefined && props.foo === "two");
|
|
175
175
|
for (let i = 0; i < 3; i++) {
|
|
176
176
|
props = client.getPropertiesAtPosition(i);
|
|
177
177
|
(0, assert_1.strict)(props !== undefined && props.foo === "three");
|
|
178
178
|
}
|
|
179
|
-
client.rollback?.({ type:
|
|
179
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
180
180
|
for (let i = 0; i < 2; i++) {
|
|
181
181
|
props = client.getPropertiesAtPosition(i);
|
|
182
182
|
(0, assert_1.strict)(props !== undefined && props.foo === "one");
|
|
@@ -185,14 +185,14 @@ describe("client.rollback", () => {
|
|
|
185
185
|
props = client.getPropertiesAtPosition(i);
|
|
186
186
|
(0, assert_1.strict)(props !== undefined && props.foo === "two");
|
|
187
187
|
}
|
|
188
|
-
client.rollback?.({ type:
|
|
188
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
189
189
|
props = client.getPropertiesAtPosition(3);
|
|
190
190
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
191
191
|
for (let i = 0; i < 3; i++) {
|
|
192
192
|
props = client.getPropertiesAtPosition(i);
|
|
193
193
|
(0, assert_1.strict)(props !== undefined && props.foo === "one");
|
|
194
194
|
}
|
|
195
|
-
client.rollback?.({ type:
|
|
195
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
196
196
|
assert_1.strict.equal(client.getText(), "acde");
|
|
197
197
|
for (let i = 0; i < 4; i++) {
|
|
198
198
|
props = client.getPropertiesAtPosition(i);
|
|
@@ -203,7 +203,7 @@ describe("client.rollback", () => {
|
|
|
203
203
|
client.insertTextLocal(0, "abcde");
|
|
204
204
|
client.annotateRangeLocal(2, 3, { foo: "bar" });
|
|
205
205
|
client.annotateRangeLocal(1, 4, { foo: "bar" });
|
|
206
|
-
client.rollback?.({ type:
|
|
206
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
207
207
|
for (let i = 0; i < 5; i++) {
|
|
208
208
|
const props = client.getPropertiesAtPosition(i);
|
|
209
209
|
if (i === 2) {
|
|
@@ -219,7 +219,7 @@ describe("client.rollback", () => {
|
|
|
219
219
|
client.annotateRangeLocal(2, 3, { foo: "bar" });
|
|
220
220
|
const segmentGroup = client.peekPendingSegmentGroups();
|
|
221
221
|
const segment = segmentGroup.segments[0];
|
|
222
|
-
client.rollback?.({ type:
|
|
222
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, segmentGroup);
|
|
223
223
|
// do some work and move the client's min seq forward, so zamboni runs
|
|
224
224
|
for (const c of "hello world") {
|
|
225
225
|
client.applyMsg(client.makeOpMessage(client.insertTextLocal(client.getLength(), c), client.getCurrentSeq() + 1, client.getCurrentSeq(), undefined, client.getCurrentSeq()));
|
|
@@ -229,20 +229,20 @@ describe("client.rollback", () => {
|
|
|
229
229
|
it("Should rollback delete on single segment", () => {
|
|
230
230
|
client.insertTextLocal(0, "abcd");
|
|
231
231
|
client.removeRangeLocal(0, 4);
|
|
232
|
-
client.rollback?.({ type:
|
|
232
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
233
233
|
assert_1.strict.equal(client.getText(), "abcd");
|
|
234
234
|
});
|
|
235
235
|
it("Should rollback delete which causes split segments", () => {
|
|
236
236
|
client.insertTextLocal(0, "abcde");
|
|
237
237
|
client.removeRangeLocal(1, 4);
|
|
238
|
-
client.rollback?.({ type:
|
|
238
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
239
239
|
assert_1.strict.equal(client.getText(), "abcde");
|
|
240
240
|
});
|
|
241
241
|
it("Should rollback delete across split segments", () => {
|
|
242
242
|
client.insertTextLocal(0, "abcde");
|
|
243
243
|
client.annotateRangeLocal(2, 3, { foo: "bar" });
|
|
244
244
|
client.removeRangeLocal(1, 4);
|
|
245
|
-
client.rollback?.({ type:
|
|
245
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
246
246
|
assert_1.strict.equal(client.getText(), "abcde");
|
|
247
247
|
});
|
|
248
248
|
it("Should rollback delete and update blocks", () => {
|
|
@@ -251,7 +251,7 @@ describe("client.rollback", () => {
|
|
|
251
251
|
client.insertTextLocal(client.getLength(), c);
|
|
252
252
|
}
|
|
253
253
|
client.removeRangeLocal(1, 4);
|
|
254
|
-
client.rollback?.({ type:
|
|
254
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
255
255
|
// The insertion position calculation will be wrong if the blocks aren't updated correctly
|
|
256
256
|
client.insertTextLocal(text.length - 1, "+");
|
|
257
257
|
const expectedText = `${text.substring(0, text.length - 1)}+${text[text.length - 1]}`;
|
|
@@ -263,12 +263,12 @@ describe("client.rollback", () => {
|
|
|
263
263
|
client.insertTextLocal(0, "abc");
|
|
264
264
|
const segInfo1 = client.getContainingSegment(2);
|
|
265
265
|
const segInfo3 = client.getContainingSegment(5);
|
|
266
|
-
const ref1 = client.createLocalReferencePosition(segInfo1.segment, 0,
|
|
267
|
-
const refSlide = client.createLocalReferencePosition(segInfo1.segment, 2,
|
|
268
|
-
const ref2 = client.createLocalReferencePosition(segInfo3.segment, 1,
|
|
269
|
-
const refStay = client.createLocalReferencePosition(segInfo3.segment, 1,
|
|
266
|
+
const ref1 = client.createLocalReferencePosition(segInfo1.segment, 0, ops_js_1.ReferenceType.Simple, undefined);
|
|
267
|
+
const refSlide = client.createLocalReferencePosition(segInfo1.segment, 2, ops_js_1.ReferenceType.SlideOnRemove, undefined);
|
|
268
|
+
const ref2 = client.createLocalReferencePosition(segInfo3.segment, 1, ops_js_1.ReferenceType.Simple, undefined);
|
|
269
|
+
const refStay = client.createLocalReferencePosition(segInfo3.segment, 1, ops_js_1.ReferenceType.StayOnRemove, undefined);
|
|
270
270
|
client.removeRangeLocal(0, 7);
|
|
271
|
-
client.rollback?.({ type:
|
|
271
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
272
272
|
assert_1.strict.equal(client.getText(), "abcdefg");
|
|
273
273
|
const segInfo1After = client.getContainingSegment(2);
|
|
274
274
|
assert_1.strict.notEqual(segInfo1After, undefined);
|
|
@@ -286,7 +286,7 @@ describe("client.rollback", () => {
|
|
|
286
286
|
client.removeRangeLocal(1, 4);
|
|
287
287
|
const segmentGroup = client.peekPendingSegmentGroups();
|
|
288
288
|
const segment = segmentGroup.segments[0];
|
|
289
|
-
client.rollback?.({ type:
|
|
289
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, segmentGroup);
|
|
290
290
|
// do some work and move the client's min seq forward, so zamboni runs
|
|
291
291
|
for (const c of "hello world") {
|
|
292
292
|
client.applyMsg(client.makeOpMessage(client.insertTextLocal(client.getLength(), c), client.getCurrentSeq() + 1, client.getCurrentSeq(), undefined, client.getCurrentSeq()));
|
|
@@ -298,7 +298,7 @@ describe("client.rollback", () => {
|
|
|
298
298
|
client.insertTextLocal(3, "123");
|
|
299
299
|
client.annotateRangeLocal(2, 5, { foo: "bar" });
|
|
300
300
|
client.removeRangeLocal(3, 7);
|
|
301
|
-
client.rollback?.({ type:
|
|
301
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
302
302
|
assert_1.strict.equal(client.getText(), "abc123defg");
|
|
303
303
|
for (let i = 0; i < client.getText().length; i++) {
|
|
304
304
|
const props = client.getPropertiesAtPosition(i);
|
|
@@ -309,14 +309,14 @@ describe("client.rollback", () => {
|
|
|
309
309
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
310
310
|
}
|
|
311
311
|
}
|
|
312
|
-
client.rollback?.({ type:
|
|
312
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
313
313
|
for (let i = 0; i < client.getText().length; i++) {
|
|
314
314
|
const props = client.getPropertiesAtPosition(i);
|
|
315
315
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
316
316
|
}
|
|
317
|
-
client.rollback?.({ type:
|
|
317
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
318
318
|
assert_1.strict.equal(client.getText(), "abcdefg");
|
|
319
|
-
client.rollback?.({ type:
|
|
319
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
320
320
|
assert_1.strict.equal(client.getText(), "");
|
|
321
321
|
});
|
|
322
322
|
it("Should rollback multiple removes across split segments", () => {
|
|
@@ -326,24 +326,24 @@ describe("client.rollback", () => {
|
|
|
326
326
|
client.removeRangeLocal(2, 5);
|
|
327
327
|
client.removeRangeLocal(3, 7);
|
|
328
328
|
client.removeRangeLocal(2, 4);
|
|
329
|
-
client.rollback?.({ type:
|
|
329
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
330
330
|
assert_1.strict.equal(client.getText(), "abye");
|
|
331
|
-
client.rollback?.({ type:
|
|
331
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
332
332
|
assert_1.strict.equal(client.getText(), "abyz23de");
|
|
333
|
-
client.rollback?.({ type:
|
|
333
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
334
334
|
assert_1.strict.equal(client.getText(), "abc1xyz23de");
|
|
335
|
-
client.rollback?.({ type:
|
|
335
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
336
336
|
assert_1.strict.equal(client.getText(), "abc123de");
|
|
337
|
-
client.rollback?.({ type:
|
|
337
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
338
338
|
assert_1.strict.equal(client.getText(), "abcde");
|
|
339
|
-
client.rollback?.({ type:
|
|
339
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
340
340
|
assert_1.strict.equal(client.getText(), "");
|
|
341
341
|
});
|
|
342
342
|
it("Should annotate a previously removed range", () => {
|
|
343
343
|
client.insertTextLocal(0, "abcdefg");
|
|
344
344
|
client.insertTextLocal(3, "123");
|
|
345
345
|
client.removeRangeLocal(2, 8);
|
|
346
|
-
client.rollback?.({ type:
|
|
346
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
347
347
|
assert_1.strict.equal(client.getText(), "abc123defg");
|
|
348
348
|
client.annotateRangeLocal(2, 8, { foo: "bar" });
|
|
349
349
|
for (let i = 0; i < client.getText().length; i++) {
|
|
@@ -355,14 +355,14 @@ describe("client.rollback", () => {
|
|
|
355
355
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
356
356
|
}
|
|
357
357
|
}
|
|
358
|
-
client.rollback?.({ type:
|
|
358
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
359
359
|
for (let i = 0; i < client.getText().length; i++) {
|
|
360
360
|
const props = client.getPropertiesAtPosition(i);
|
|
361
361
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
362
362
|
}
|
|
363
|
-
client.rollback?.({ type:
|
|
363
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
364
364
|
assert_1.strict.equal(client.getText(), "abcdefg");
|
|
365
|
-
client.rollback?.({ type:
|
|
365
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
366
366
|
assert_1.strict.equal(client.getText(), "");
|
|
367
367
|
});
|
|
368
368
|
it("Should rollback overlapping annotates and remove", () => {
|
|
@@ -370,10 +370,10 @@ describe("client.rollback", () => {
|
|
|
370
370
|
client.annotateRangeLocal(0, 6, { foo: "one" });
|
|
371
371
|
client.annotateRangeLocal(5, 10, { foo: "two" });
|
|
372
372
|
client.removeRangeLocal(4, 8);
|
|
373
|
-
client.rollback?.({ type:
|
|
373
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
374
374
|
assert_1.strict.equal(client.getPropertiesAtPosition(4)?.foo, "one");
|
|
375
375
|
assert_1.strict.equal(client.getPropertiesAtPosition(5)?.foo, "two");
|
|
376
|
-
client.rollback?.({ type:
|
|
376
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
377
377
|
for (let i = 0; i < client.getText().length; i++) {
|
|
378
378
|
const props = client.getPropertiesAtPosition(i);
|
|
379
379
|
if (i >= 0 && i < 6) {
|
|
@@ -383,18 +383,18 @@ describe("client.rollback", () => {
|
|
|
383
383
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
384
384
|
}
|
|
385
385
|
}
|
|
386
|
-
client.rollback?.({ type:
|
|
386
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.ANNOTATE }, client.peekPendingSegmentGroups());
|
|
387
387
|
for (let i = 0; i < client.getText().length; i++) {
|
|
388
388
|
const props = client.getPropertiesAtPosition(i);
|
|
389
389
|
(0, assert_1.strict)(props === undefined || props.foo === undefined);
|
|
390
390
|
}
|
|
391
|
-
client.rollback?.({ type:
|
|
391
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.INSERT }, client.peekPendingSegmentGroups());
|
|
392
392
|
assert_1.strict.equal(client.getText(), "");
|
|
393
393
|
});
|
|
394
394
|
it("Should function properly after rollback with local ops", () => {
|
|
395
395
|
client.insertTextLocal(0, "abcdefg");
|
|
396
396
|
client.removeRangeLocal(1, 5);
|
|
397
|
-
client.rollback?.({ type:
|
|
397
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
398
398
|
client.removeRangeLocal(2, 4);
|
|
399
399
|
assert_1.strict.equal(client.getText(), "abefg");
|
|
400
400
|
client.annotateRangeLocal(2, 5, { foo: "bar" });
|
|
@@ -411,17 +411,17 @@ describe("client.rollback", () => {
|
|
|
411
411
|
assert_1.strict.equal(client.getText(), "a123befg");
|
|
412
412
|
});
|
|
413
413
|
it("Should function properly after rollback with external ops", () => {
|
|
414
|
-
const remoteClient = new
|
|
414
|
+
const remoteClient = new testClient_js_1.TestClient();
|
|
415
415
|
remoteClient.insertTextLocal(0, client.getText());
|
|
416
416
|
remoteClient.startOrUpdateCollaboration("remoteUser");
|
|
417
417
|
const clients = [client, remoteClient];
|
|
418
418
|
let seq = 0;
|
|
419
|
-
const logger = new
|
|
419
|
+
const logger = new testClientLogger_js_1.TestClientLogger(clients);
|
|
420
420
|
let msg = remoteClient.makeOpMessage(remoteClient.insertTextLocal(0, "12345"), ++seq);
|
|
421
421
|
clients.forEach((c) => c.applyMsg(msg));
|
|
422
422
|
logger.validate({ baseText: "12345" });
|
|
423
423
|
client.removeRangeLocal(1, 4);
|
|
424
|
-
client.rollback?.({ type:
|
|
424
|
+
client.rollback?.({ type: ops_js_1.MergeTreeDeltaType.REMOVE }, client.peekPendingSegmentGroups());
|
|
425
425
|
msg = remoteClient.makeOpMessage(remoteClient.removeRangeLocal(2, 3), ++seq);
|
|
426
426
|
clients.forEach((c) => {
|
|
427
427
|
c.applyMsg(msg);
|