@fluid-experimental/tree 0.58.2002 → 0.59.1000
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/README.md +159 -46
- package/dist/ChangeCompression.d.ts +39 -0
- package/dist/ChangeCompression.d.ts.map +1 -0
- package/dist/ChangeCompression.js +117 -0
- package/dist/ChangeCompression.js.map +1 -0
- package/{lib/default-edits/PersistedTypes.d.ts → dist/ChangeTypes.d.ts} +58 -105
- package/dist/ChangeTypes.d.ts.map +1 -0
- package/dist/{default-edits/PersistedTypes.js → ChangeTypes.js} +21 -76
- package/dist/ChangeTypes.js.map +1 -0
- package/dist/Checkout.d.ts +39 -27
- package/dist/Checkout.d.ts.map +1 -1
- package/dist/Checkout.js +61 -32
- package/dist/Checkout.js.map +1 -1
- package/dist/Common.d.ts +175 -38
- package/dist/Common.d.ts.map +1 -1
- package/dist/Common.js +240 -103
- package/dist/Common.js.map +1 -1
- package/dist/EagerCheckout.d.ts +24 -0
- package/dist/EagerCheckout.d.ts.map +1 -0
- package/dist/{BasicCheckout.js → EagerCheckout.js} +9 -6
- package/dist/EagerCheckout.js.map +1 -0
- package/dist/EditLog.d.ts +77 -63
- package/dist/EditLog.d.ts.map +1 -1
- package/dist/EditLog.js +85 -48
- package/dist/EditLog.js.map +1 -1
- package/dist/EditUtilities.d.ts +168 -0
- package/dist/EditUtilities.d.ts.map +1 -0
- package/dist/EditUtilities.js +373 -0
- package/dist/EditUtilities.js.map +1 -0
- package/dist/EventTypes.d.ts +73 -0
- package/dist/EventTypes.d.ts.map +1 -0
- package/dist/EventTypes.js +78 -0
- package/dist/EventTypes.js.map +1 -0
- package/dist/Forest.d.ts +29 -7
- package/dist/Forest.d.ts.map +1 -1
- package/dist/Forest.js +60 -36
- package/dist/Forest.js.map +1 -1
- package/dist/HistoryEditFactory.d.ts +20 -0
- package/dist/HistoryEditFactory.d.ts.map +1 -0
- package/dist/HistoryEditFactory.js +226 -0
- package/dist/HistoryEditFactory.js.map +1 -0
- package/dist/IdConversion.d.ts +12 -0
- package/dist/IdConversion.d.ts.map +1 -0
- package/dist/IdConversion.js +98 -0
- package/dist/IdConversion.js.map +1 -0
- package/dist/Identifiers.d.ts +89 -2
- package/dist/Identifiers.d.ts.map +1 -1
- package/dist/Identifiers.js +10 -0
- package/dist/Identifiers.js.map +1 -1
- package/dist/InitialTree.d.ts +2 -2
- package/dist/InitialTree.d.ts.map +1 -1
- package/dist/InitialTree.js +2 -1
- package/dist/InitialTree.js.map +1 -1
- package/dist/LazyCheckout.d.ts +28 -0
- package/dist/LazyCheckout.d.ts.map +1 -0
- package/dist/LazyCheckout.js +44 -0
- package/dist/LazyCheckout.js.map +1 -0
- package/dist/LogViewer.d.ts +129 -85
- package/dist/LogViewer.d.ts.map +1 -1
- package/dist/LogViewer.js +111 -85
- package/dist/LogViewer.js.map +1 -1
- package/dist/MergeHealth.d.ts +221 -0
- package/dist/MergeHealth.d.ts.map +1 -0
- package/dist/MergeHealth.js +263 -0
- package/dist/MergeHealth.js.map +1 -0
- package/dist/NodeIdUtilities.d.ts +105 -0
- package/dist/NodeIdUtilities.d.ts.map +1 -0
- package/dist/NodeIdUtilities.js +60 -0
- package/dist/NodeIdUtilities.js.map +1 -0
- package/dist/PayloadUtilities.d.ts +42 -0
- package/dist/PayloadUtilities.d.ts.map +1 -0
- package/dist/PayloadUtilities.js +114 -0
- package/dist/PayloadUtilities.js.map +1 -0
- package/dist/ReconciliationPath.d.ts +18 -13
- package/dist/ReconciliationPath.d.ts.map +1 -1
- package/dist/ReconciliationPath.js.map +1 -1
- package/dist/RevisionValueCache.d.ts +11 -2
- package/dist/RevisionValueCache.d.ts.map +1 -1
- package/dist/RevisionValueCache.js +2 -3
- package/dist/RevisionValueCache.js.map +1 -1
- package/dist/RevisionView.d.ts +83 -0
- package/dist/RevisionView.d.ts.map +1 -0
- package/dist/RevisionView.js +182 -0
- package/dist/RevisionView.js.map +1 -0
- package/dist/SerializationUtilities.d.ts +36 -0
- package/dist/SerializationUtilities.d.ts.map +1 -0
- package/dist/SerializationUtilities.js +102 -0
- package/dist/SerializationUtilities.js.map +1 -0
- package/dist/SharedTree.d.ts +439 -0
- package/dist/SharedTree.d.ts.map +1 -0
- package/dist/SharedTree.js +1109 -0
- package/dist/SharedTree.js.map +1 -0
- package/dist/SharedTreeEncoder.d.ts +102 -0
- package/dist/SharedTreeEncoder.d.ts.map +1 -0
- package/dist/SharedTreeEncoder.js +313 -0
- package/dist/SharedTreeEncoder.js.map +1 -0
- package/dist/StringInterner.d.ts +46 -0
- package/dist/StringInterner.d.ts.map +1 -0
- package/dist/StringInterner.js +61 -0
- package/dist/StringInterner.js.map +1 -0
- package/dist/Summary.d.ts +40 -0
- package/dist/Summary.d.ts.map +1 -0
- package/dist/Summary.js +23 -0
- package/dist/Summary.js.map +1 -0
- package/dist/SummaryBackCompatibility.d.ts +22 -22
- package/dist/SummaryBackCompatibility.d.ts.map +1 -1
- package/dist/SummaryBackCompatibility.js +30 -33
- package/dist/SummaryBackCompatibility.js.map +1 -1
- package/dist/SummaryTestUtilities.d.ts +31 -0
- package/dist/SummaryTestUtilities.d.ts.map +1 -0
- package/dist/SummaryTestUtilities.js +37 -0
- package/dist/SummaryTestUtilities.js.map +1 -0
- package/dist/Transaction.d.ts +52 -0
- package/dist/Transaction.d.ts.map +1 -0
- package/dist/Transaction.js +72 -0
- package/dist/Transaction.js.map +1 -0
- package/dist/TransactionInternal.d.ts +540 -0
- package/dist/TransactionInternal.d.ts.map +1 -0
- package/dist/TransactionInternal.js +626 -0
- package/dist/TransactionInternal.js.map +1 -0
- package/dist/TreeCompressor.d.ts +36 -0
- package/dist/TreeCompressor.d.ts.map +1 -0
- package/dist/TreeCompressor.js +137 -0
- package/dist/TreeCompressor.js.map +1 -0
- package/dist/TreeNodeHandle.d.ts +12 -18
- package/dist/TreeNodeHandle.d.ts.map +1 -1
- package/dist/TreeNodeHandle.js +13 -23
- package/dist/TreeNodeHandle.js.map +1 -1
- package/dist/TreeView.d.ts +166 -0
- package/dist/TreeView.d.ts.map +1 -0
- package/dist/TreeView.js +218 -0
- package/dist/TreeView.js.map +1 -0
- package/dist/TreeViewUtilities.d.ts +21 -0
- package/dist/TreeViewUtilities.d.ts.map +1 -0
- package/dist/TreeViewUtilities.js +77 -0
- package/dist/TreeViewUtilities.js.map +1 -0
- package/dist/{default-edits/UndoRedoHandler.d.ts → UndoRedoHandler.d.ts} +2 -2
- package/dist/UndoRedoHandler.d.ts.map +1 -0
- package/dist/{default-edits/UndoRedoHandler.js → UndoRedoHandler.js} +5 -9
- package/dist/UndoRedoHandler.js.map +1 -0
- package/dist/id-compressor/AppendOnlySortedMap.d.ts +127 -0
- package/dist/id-compressor/AppendOnlySortedMap.d.ts.map +1 -0
- package/dist/id-compressor/AppendOnlySortedMap.js +283 -0
- package/dist/id-compressor/AppendOnlySortedMap.js.map +1 -0
- package/dist/id-compressor/IdCompressor.d.ts +389 -0
- package/dist/id-compressor/IdCompressor.d.ts.map +1 -0
- package/dist/id-compressor/IdCompressor.js +1353 -0
- package/dist/id-compressor/IdCompressor.js.map +1 -0
- package/dist/id-compressor/IdRange.d.ts +11 -0
- package/dist/id-compressor/IdRange.d.ts.map +1 -0
- package/dist/id-compressor/IdRange.js +29 -0
- package/dist/id-compressor/IdRange.js.map +1 -0
- package/dist/id-compressor/NumericUuid.d.ts +63 -0
- package/dist/id-compressor/NumericUuid.d.ts.map +1 -0
- package/dist/id-compressor/NumericUuid.js +377 -0
- package/dist/id-compressor/NumericUuid.js.map +1 -0
- package/dist/id-compressor/index.d.ts +12 -0
- package/dist/id-compressor/index.d.ts.map +1 -0
- package/dist/id-compressor/index.js +26 -0
- package/dist/id-compressor/index.js.map +1 -0
- package/dist/id-compressor/persisted-types/0.0.1.d.ts +156 -0
- package/dist/id-compressor/persisted-types/0.0.1.d.ts.map +1 -0
- package/dist/id-compressor/persisted-types/0.0.1.js +7 -0
- package/dist/id-compressor/persisted-types/0.0.1.js.map +1 -0
- package/dist/id-compressor/persisted-types/index.d.ts +6 -0
- package/dist/id-compressor/persisted-types/index.d.ts.map +1 -0
- package/dist/id-compressor/persisted-types/index.js +18 -0
- package/dist/id-compressor/persisted-types/index.js.map +1 -0
- package/dist/index.d.ts +29 -9
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +50 -35
- package/dist/index.js.map +1 -1
- package/dist/persisted-types/0.0.2.d.ts +385 -0
- package/dist/persisted-types/0.0.2.d.ts.map +1 -0
- package/dist/persisted-types/0.0.2.js +113 -0
- package/dist/persisted-types/0.0.2.js.map +1 -0
- package/dist/persisted-types/0.1.1.d.ts +314 -0
- package/dist/persisted-types/0.1.1.d.ts.map +1 -0
- package/dist/persisted-types/0.1.1.js +153 -0
- package/dist/persisted-types/0.1.1.js.map +1 -0
- package/dist/persisted-types/index.d.ts +7 -0
- package/dist/persisted-types/index.d.ts.map +1 -0
- package/dist/persisted-types/index.js +20 -0
- package/dist/persisted-types/index.js.map +1 -0
- package/docs/0-1-1-Compression.md +228 -0
- package/docs/Breaking-Change-Migration.md +52 -0
- package/docs/Compression.md +2 -2
- package/docs/Telemetry.md +43 -0
- package/docs/Write-Format.md +19 -0
- package/lib/ChangeCompression.d.ts +39 -0
- package/lib/ChangeCompression.d.ts.map +1 -0
- package/lib/ChangeCompression.js +111 -0
- package/lib/ChangeCompression.js.map +1 -0
- package/{dist/default-edits/PersistedTypes.d.ts → lib/ChangeTypes.d.ts} +58 -105
- package/lib/ChangeTypes.d.ts.map +1 -0
- package/lib/{default-edits/PersistedTypes.js → ChangeTypes.js} +15 -68
- package/lib/ChangeTypes.js.map +1 -0
- package/lib/Checkout.d.ts +39 -27
- package/lib/Checkout.d.ts.map +1 -1
- package/lib/Checkout.js +53 -24
- package/lib/Checkout.js.map +1 -1
- package/lib/Common.d.ts +175 -38
- package/lib/Common.d.ts.map +1 -1
- package/lib/Common.js +226 -101
- package/lib/Common.js.map +1 -1
- package/lib/EagerCheckout.d.ts +24 -0
- package/lib/EagerCheckout.d.ts.map +1 -0
- package/lib/{BasicCheckout.js → EagerCheckout.js} +7 -4
- package/lib/EagerCheckout.js.map +1 -0
- package/lib/EditLog.d.ts +77 -63
- package/lib/EditLog.d.ts.map +1 -1
- package/lib/EditLog.js +83 -47
- package/lib/EditLog.js.map +1 -1
- package/lib/EditUtilities.d.ts +168 -0
- package/lib/EditUtilities.d.ts.map +1 -0
- package/lib/EditUtilities.js +353 -0
- package/lib/EditUtilities.js.map +1 -0
- package/lib/EventTypes.d.ts +73 -0
- package/lib/EventTypes.d.ts.map +1 -0
- package/lib/EventTypes.js +75 -0
- package/lib/EventTypes.js.map +1 -0
- package/lib/Forest.d.ts +29 -7
- package/lib/Forest.d.ts.map +1 -1
- package/lib/Forest.js +58 -35
- package/lib/Forest.js.map +1 -1
- package/lib/HistoryEditFactory.d.ts +20 -0
- package/lib/HistoryEditFactory.d.ts.map +1 -0
- package/lib/{default-edits/HistoryEditFactory.js → HistoryEditFactory.js} +78 -39
- package/lib/HistoryEditFactory.js.map +1 -0
- package/lib/IdConversion.d.ts +12 -0
- package/lib/IdConversion.d.ts.map +1 -0
- package/lib/IdConversion.js +91 -0
- package/lib/IdConversion.js.map +1 -0
- package/lib/Identifiers.d.ts +89 -2
- package/lib/Identifiers.d.ts.map +1 -1
- package/lib/Identifiers.js +8 -1
- package/lib/Identifiers.js.map +1 -1
- package/lib/InitialTree.d.ts +2 -2
- package/lib/InitialTree.d.ts.map +1 -1
- package/lib/InitialTree.js +2 -1
- package/lib/InitialTree.js.map +1 -1
- package/lib/LazyCheckout.d.ts +28 -0
- package/lib/LazyCheckout.d.ts.map +1 -0
- package/lib/LazyCheckout.js +40 -0
- package/lib/LazyCheckout.js.map +1 -0
- package/lib/LogViewer.d.ts +129 -85
- package/lib/LogViewer.d.ts.map +1 -1
- package/lib/LogViewer.js +103 -77
- package/lib/LogViewer.js.map +1 -1
- package/lib/MergeHealth.d.ts +221 -0
- package/lib/MergeHealth.d.ts.map +1 -0
- package/lib/MergeHealth.js +258 -0
- package/lib/MergeHealth.js.map +1 -0
- package/lib/NodeIdUtilities.d.ts +105 -0
- package/lib/NodeIdUtilities.d.ts.map +1 -0
- package/lib/NodeIdUtilities.js +53 -0
- package/lib/NodeIdUtilities.js.map +1 -0
- package/lib/PayloadUtilities.d.ts +42 -0
- package/lib/PayloadUtilities.d.ts.map +1 -0
- package/lib/PayloadUtilities.js +110 -0
- package/lib/PayloadUtilities.js.map +1 -0
- package/lib/ReconciliationPath.d.ts +18 -13
- package/lib/ReconciliationPath.d.ts.map +1 -1
- package/lib/ReconciliationPath.js.map +1 -1
- package/lib/RevisionValueCache.d.ts +11 -2
- package/lib/RevisionValueCache.d.ts.map +1 -1
- package/lib/RevisionValueCache.js +2 -3
- package/lib/RevisionValueCache.js.map +1 -1
- package/lib/RevisionView.d.ts +83 -0
- package/lib/RevisionView.d.ts.map +1 -0
- package/lib/RevisionView.js +175 -0
- package/lib/RevisionView.js.map +1 -0
- package/lib/SerializationUtilities.d.ts +36 -0
- package/lib/SerializationUtilities.d.ts.map +1 -0
- package/lib/SerializationUtilities.js +95 -0
- package/lib/SerializationUtilities.js.map +1 -0
- package/lib/SharedTree.d.ts +439 -0
- package/lib/SharedTree.d.ts.map +1 -0
- package/lib/SharedTree.js +1104 -0
- package/lib/SharedTree.js.map +1 -0
- package/lib/SharedTreeEncoder.d.ts +102 -0
- package/lib/SharedTreeEncoder.d.ts.map +1 -0
- package/lib/SharedTreeEncoder.js +308 -0
- package/lib/SharedTreeEncoder.js.map +1 -0
- package/lib/StringInterner.d.ts +46 -0
- package/lib/StringInterner.d.ts.map +1 -0
- package/lib/StringInterner.js +57 -0
- package/lib/StringInterner.js.map +1 -0
- package/lib/Summary.d.ts +40 -0
- package/lib/Summary.d.ts.map +1 -0
- package/lib/Summary.js +19 -0
- package/lib/Summary.js.map +1 -0
- package/lib/SummaryBackCompatibility.d.ts +22 -22
- package/lib/SummaryBackCompatibility.d.ts.map +1 -1
- package/lib/SummaryBackCompatibility.js +29 -32
- package/lib/SummaryBackCompatibility.js.map +1 -1
- package/lib/SummaryTestUtilities.d.ts +31 -0
- package/lib/SummaryTestUtilities.d.ts.map +1 -0
- package/lib/SummaryTestUtilities.js +32 -0
- package/lib/SummaryTestUtilities.js.map +1 -0
- package/lib/Transaction.d.ts +52 -0
- package/lib/Transaction.d.ts.map +1 -0
- package/lib/Transaction.js +68 -0
- package/lib/Transaction.js.map +1 -0
- package/lib/TransactionInternal.d.ts +540 -0
- package/lib/TransactionInternal.d.ts.map +1 -0
- package/lib/TransactionInternal.js +622 -0
- package/lib/TransactionInternal.js.map +1 -0
- package/lib/TreeCompressor.d.ts +36 -0
- package/lib/TreeCompressor.d.ts.map +1 -0
- package/lib/TreeCompressor.js +133 -0
- package/lib/TreeCompressor.js.map +1 -0
- package/lib/TreeNodeHandle.d.ts +12 -18
- package/lib/TreeNodeHandle.d.ts.map +1 -1
- package/lib/TreeNodeHandle.js +14 -24
- package/lib/TreeNodeHandle.js.map +1 -1
- package/lib/TreeView.d.ts +166 -0
- package/lib/TreeView.d.ts.map +1 -0
- package/lib/TreeView.js +214 -0
- package/lib/TreeView.js.map +1 -0
- package/lib/TreeViewUtilities.d.ts +21 -0
- package/lib/TreeViewUtilities.d.ts.map +1 -0
- package/lib/TreeViewUtilities.js +71 -0
- package/lib/TreeViewUtilities.js.map +1 -0
- package/lib/{default-edits/UndoRedoHandler.d.ts → UndoRedoHandler.d.ts} +2 -2
- package/lib/UndoRedoHandler.d.ts.map +1 -0
- package/lib/{default-edits/UndoRedoHandler.js → UndoRedoHandler.js} +3 -7
- package/lib/UndoRedoHandler.js.map +1 -0
- package/lib/id-compressor/AppendOnlySortedMap.d.ts +127 -0
- package/lib/id-compressor/AppendOnlySortedMap.d.ts.map +1 -0
- package/lib/id-compressor/AppendOnlySortedMap.js +278 -0
- package/lib/id-compressor/AppendOnlySortedMap.js.map +1 -0
- package/lib/id-compressor/IdCompressor.d.ts +389 -0
- package/lib/id-compressor/IdCompressor.d.ts.map +1 -0
- package/lib/id-compressor/IdCompressor.js +1343 -0
- package/lib/id-compressor/IdCompressor.js.map +1 -0
- package/lib/id-compressor/IdRange.d.ts +11 -0
- package/lib/id-compressor/IdRange.d.ts.map +1 -0
- package/lib/id-compressor/IdRange.js +25 -0
- package/lib/id-compressor/IdRange.js.map +1 -0
- package/lib/id-compressor/NumericUuid.d.ts +63 -0
- package/lib/id-compressor/NumericUuid.d.ts.map +1 -0
- package/lib/id-compressor/NumericUuid.js +365 -0
- package/lib/id-compressor/NumericUuid.js.map +1 -0
- package/lib/id-compressor/index.d.ts +12 -0
- package/lib/id-compressor/index.d.ts.map +1 -0
- package/lib/id-compressor/index.js +12 -0
- package/lib/id-compressor/index.js.map +1 -0
- package/lib/id-compressor/persisted-types/0.0.1.d.ts +156 -0
- package/lib/id-compressor/persisted-types/0.0.1.d.ts.map +1 -0
- package/lib/{test/Snapshot.tests.d.ts → id-compressor/persisted-types/0.0.1.js} +1 -1
- package/lib/id-compressor/persisted-types/0.0.1.js.map +1 -0
- package/lib/id-compressor/persisted-types/index.d.ts +6 -0
- package/lib/id-compressor/persisted-types/index.d.ts.map +1 -0
- package/lib/id-compressor/persisted-types/index.js +6 -0
- package/lib/id-compressor/persisted-types/index.js.map +1 -0
- package/lib/index.d.ts +29 -9
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +23 -6
- package/lib/index.js.map +1 -1
- package/lib/persisted-types/0.0.2.d.ts +385 -0
- package/lib/persisted-types/0.0.2.d.ts.map +1 -0
- package/lib/persisted-types/0.0.2.js +110 -0
- package/lib/persisted-types/0.0.2.js.map +1 -0
- package/lib/persisted-types/0.1.1.d.ts +314 -0
- package/lib/persisted-types/0.1.1.d.ts.map +1 -0
- package/lib/persisted-types/0.1.1.js +150 -0
- package/lib/persisted-types/0.1.1.js.map +1 -0
- package/lib/persisted-types/index.d.ts +7 -0
- package/lib/persisted-types/index.d.ts.map +1 -0
- package/lib/persisted-types/index.js +8 -0
- package/lib/persisted-types/index.js.map +1 -0
- package/lib/test/AppendOnlySortedMap.tests.d.ts +6 -0
- package/lib/test/AppendOnlySortedMap.tests.d.ts.map +1 -0
- package/lib/test/AppendOnlySortedMap.tests.js +169 -0
- package/lib/test/AppendOnlySortedMap.tests.js.map +1 -0
- package/lib/test/{SnapshotUtilities.tests.d.ts → ChangeCompression.tests.d.ts} +1 -1
- package/lib/test/ChangeCompression.tests.d.ts.map +1 -0
- package/lib/test/ChangeCompression.tests.js +145 -0
- package/lib/test/ChangeCompression.tests.js.map +1 -0
- package/lib/test/Checkout.tests.d.ts +2 -3
- package/lib/test/Checkout.tests.d.ts.map +1 -1
- package/lib/test/Checkout.tests.js +126 -69
- package/lib/test/Checkout.tests.js.map +1 -1
- package/lib/test/Common.tests.js +60 -2
- package/lib/test/Common.tests.js.map +1 -1
- package/lib/test/{BasicCheckout.tests.d.ts → EagerCheckout.tests.d.ts} +1 -1
- package/lib/test/EagerCheckout.tests.d.ts.map +1 -0
- package/lib/test/EagerCheckout.tests.js +20 -0
- package/lib/test/EagerCheckout.tests.js.map +1 -0
- package/lib/test/Edit.tests.js +22 -14
- package/lib/test/Edit.tests.js.map +1 -1
- package/lib/test/{Anchors.glassBox.tests.d.ts → EditLog.perf.tests.d.ts} +1 -1
- package/lib/test/EditLog.perf.tests.d.ts.map +1 -0
- package/lib/test/EditLog.perf.tests.js +30 -0
- package/lib/test/EditLog.perf.tests.js.map +1 -0
- package/lib/test/EditLog.tests.js +10 -6
- package/lib/test/EditLog.tests.js.map +1 -1
- package/lib/test/EditUtilities.tests.d.ts +6 -0
- package/lib/test/EditUtilities.tests.d.ts.map +1 -0
- package/lib/test/EditUtilities.tests.js +503 -0
- package/lib/test/EditUtilities.tests.js.map +1 -0
- package/lib/test/Forest.perf.tests.d.ts +6 -0
- package/lib/test/Forest.perf.tests.d.ts.map +1 -0
- package/lib/test/Forest.perf.tests.js +133 -0
- package/lib/test/Forest.perf.tests.js.map +1 -0
- package/lib/test/Forest.tests.js +54 -27
- package/lib/test/Forest.tests.js.map +1 -1
- package/lib/test/GenericTransaction.tests.js +12 -3
- package/lib/test/GenericTransaction.tests.js.map +1 -1
- package/lib/test/HistoryEditFactory.tests.d.ts +6 -0
- package/lib/test/HistoryEditFactory.tests.d.ts.map +1 -0
- package/lib/test/HistoryEditFactory.tests.js +90 -0
- package/lib/test/HistoryEditFactory.tests.js.map +1 -0
- package/lib/test/IdCompressor.perf.tests.d.ts +6 -0
- package/lib/test/IdCompressor.perf.tests.d.ts.map +1 -0
- package/lib/test/IdCompressor.perf.tests.js +304 -0
- package/lib/test/IdCompressor.perf.tests.js.map +1 -0
- package/lib/test/IdCompressor.tests.d.ts +6 -0
- package/lib/test/IdCompressor.tests.d.ts.map +1 -0
- package/lib/test/IdCompressor.tests.js +1075 -0
- package/lib/test/IdCompressor.tests.js.map +1 -0
- package/lib/test/IdConversion.tests.d.ts +6 -0
- package/lib/test/IdConversion.tests.d.ts.map +1 -0
- package/lib/test/IdConversion.tests.js +36 -0
- package/lib/test/IdConversion.tests.js.map +1 -0
- package/lib/test/LazyCheckout.tests.d.ts +6 -0
- package/lib/test/LazyCheckout.tests.d.ts.map +1 -0
- package/lib/test/LazyCheckout.tests.js +22 -0
- package/lib/test/LazyCheckout.tests.js.map +1 -0
- package/lib/test/LogViewer.tests.js +276 -191
- package/lib/test/LogViewer.tests.js.map +1 -1
- package/lib/test/{SharedTreeWithAnchors.tests.d.ts → MergeHealthTelemetryHeartbeat.tests.d.ts} +1 -1
- package/lib/test/MergeHealthTelemetryHeartbeat.tests.d.ts.map +1 -0
- package/lib/test/MergeHealthTelemetryHeartbeat.tests.js +342 -0
- package/lib/test/MergeHealthTelemetryHeartbeat.tests.js.map +1 -0
- package/lib/test/NumericUuid.perf.tests.d.ts +6 -0
- package/lib/test/NumericUuid.perf.tests.d.ts.map +1 -0
- package/lib/test/NumericUuid.perf.tests.js +68 -0
- package/lib/test/NumericUuid.perf.tests.js.map +1 -0
- package/lib/test/NumericUuid.tests.d.ts +6 -0
- package/lib/test/NumericUuid.tests.d.ts.map +1 -0
- package/lib/test/NumericUuid.tests.js +191 -0
- package/lib/test/NumericUuid.tests.js.map +1 -0
- package/lib/test/RevisionView.tests.d.ts +6 -0
- package/lib/test/RevisionView.tests.d.ts.map +1 -0
- package/lib/test/RevisionView.tests.js +133 -0
- package/lib/test/RevisionView.tests.js.map +1 -0
- package/lib/test/SharedTree.perf.tests.d.ts +6 -0
- package/lib/test/SharedTree.perf.tests.d.ts.map +1 -0
- package/lib/test/SharedTree.perf.tests.js +39 -0
- package/lib/test/SharedTree.perf.tests.js.map +1 -0
- package/lib/test/SharedTree.tests.js +15 -3
- package/lib/test/SharedTree.tests.js.map +1 -1
- package/lib/test/StringInterner.tests.d.ts +6 -0
- package/lib/test/StringInterner.tests.d.ts.map +1 -0
- package/lib/test/StringInterner.tests.js +71 -0
- package/lib/test/StringInterner.tests.js.map +1 -0
- package/lib/test/Summary.tests.d.ts +8 -0
- package/lib/test/Summary.tests.d.ts.map +1 -0
- package/lib/test/Summary.tests.js +407 -0
- package/lib/test/Summary.tests.js.map +1 -0
- package/lib/test/Transaction.tests.js +76 -330
- package/lib/test/Transaction.tests.js.map +1 -1
- package/lib/test/TransactionInternal.tests.d.ts +6 -0
- package/lib/test/TransactionInternal.tests.d.ts.map +1 -0
- package/lib/test/TransactionInternal.tests.js +568 -0
- package/lib/test/TransactionInternal.tests.js.map +1 -0
- package/lib/test/TreeCompression.tests.d.ts +6 -0
- package/lib/test/TreeCompression.tests.d.ts.map +1 -0
- package/lib/test/TreeCompression.tests.js +292 -0
- package/lib/test/TreeCompression.tests.js.map +1 -0
- package/lib/test/TreeView.tests.d.ts +6 -0
- package/lib/test/TreeView.tests.d.ts.map +1 -0
- package/lib/test/TreeView.tests.js +176 -0
- package/lib/test/TreeView.tests.js.map +1 -0
- package/lib/test/UndoRedoHandler.tests.js +2 -2
- package/lib/test/UndoRedoHandler.tests.js.map +1 -1
- package/lib/test/Virtualization.tests.js +146 -62
- package/lib/test/Virtualization.tests.js.map +1 -1
- package/lib/test/fuzz/Generators.d.ts +19 -0
- package/lib/test/fuzz/Generators.d.ts.map +1 -0
- package/lib/test/fuzz/Generators.js +420 -0
- package/lib/test/fuzz/Generators.js.map +1 -0
- package/lib/test/fuzz/SharedTreeFuzzTests.d.ts +20 -0
- package/lib/test/fuzz/SharedTreeFuzzTests.d.ts.map +1 -0
- package/lib/test/fuzz/SharedTreeFuzzTests.js +217 -0
- package/lib/test/fuzz/SharedTreeFuzzTests.js.map +1 -0
- package/lib/test/fuzz/Types.d.ts +133 -0
- package/lib/test/fuzz/Types.d.ts.map +1 -0
- package/lib/test/{GenericTransactionWithAnchors.tests.d.ts → fuzz/Types.js} +2 -2
- package/lib/test/fuzz/Types.js.map +1 -0
- package/lib/test/utilities/IdCompressorTestUtilities.d.ts +180 -0
- package/lib/test/utilities/IdCompressorTestUtilities.d.ts.map +1 -0
- package/lib/test/utilities/IdCompressorTestUtilities.js +528 -0
- package/lib/test/utilities/IdCompressorTestUtilities.js.map +1 -0
- package/lib/test/utilities/MockTransaction.d.ts +26 -7
- package/lib/test/utilities/MockTransaction.d.ts.map +1 -1
- package/lib/test/utilities/MockTransaction.js +40 -11
- package/lib/test/utilities/MockTransaction.js.map +1 -1
- package/lib/test/utilities/PendingLocalStateTests.d.ts +12 -0
- package/lib/test/utilities/PendingLocalStateTests.d.ts.map +1 -0
- package/lib/test/utilities/PendingLocalStateTests.js +105 -0
- package/lib/test/utilities/PendingLocalStateTests.js.map +1 -0
- package/lib/test/utilities/SharedTreeTests.d.ts +3 -4
- package/lib/test/utilities/SharedTreeTests.d.ts.map +1 -1
- package/lib/test/utilities/SharedTreeTests.js +696 -439
- package/lib/test/utilities/SharedTreeTests.js.map +1 -1
- package/lib/test/utilities/SharedTreeVersioningTests.d.ts +11 -0
- package/lib/test/utilities/SharedTreeVersioningTests.d.ts.map +1 -0
- package/lib/test/utilities/SharedTreeVersioningTests.js +370 -0
- package/lib/test/utilities/SharedTreeVersioningTests.js.map +1 -0
- package/lib/test/utilities/SummaryLoadPerfTests.d.ts +10 -0
- package/lib/test/utilities/SummaryLoadPerfTests.d.ts.map +1 -0
- package/lib/test/utilities/SummaryLoadPerfTests.js +102 -0
- package/lib/test/utilities/SummaryLoadPerfTests.js.map +1 -0
- package/lib/test/utilities/SummarySizeTests.d.ts +11 -0
- package/lib/test/utilities/SummarySizeTests.d.ts.map +1 -0
- package/lib/test/utilities/SummarySizeTests.js +158 -0
- package/lib/test/utilities/SummarySizeTests.js.map +1 -0
- package/lib/test/utilities/TestCommon.d.ts +9 -0
- package/lib/test/utilities/TestCommon.d.ts.map +1 -0
- package/lib/test/utilities/TestCommon.js +13 -0
- package/lib/test/utilities/TestCommon.js.map +1 -0
- package/lib/test/utilities/TestNode.d.ts +140 -0
- package/lib/test/utilities/TestNode.d.ts.map +1 -0
- package/lib/test/utilities/TestNode.js +292 -0
- package/lib/test/utilities/TestNode.js.map +1 -0
- package/lib/test/utilities/TestUtilities.d.ts +84 -70
- package/lib/test/utilities/TestUtilities.d.ts.map +1 -1
- package/lib/test/utilities/TestUtilities.js +218 -143
- package/lib/test/utilities/TestUtilities.js.map +1 -1
- package/lib/test/utilities/UndoRedoTests.d.ts +4 -5
- package/lib/test/utilities/UndoRedoTests.d.ts.map +1 -1
- package/lib/test/utilities/UndoRedoTests.js +138 -149
- package/lib/test/utilities/UndoRedoTests.js.map +1 -1
- package/package.json +22 -17
- package/src/ChangeCompression.ts +159 -0
- package/src/{default-edits/PersistedTypes.ts → ChangeTypes.ts} +62 -125
- package/src/Checkout.ts +82 -53
- package/src/Common.ts +317 -117
- package/src/EagerCheckout.ts +38 -0
- package/src/EditLog.ts +153 -100
- package/src/EditUtilities.ts +559 -0
- package/src/EventTypes.ts +74 -0
- package/src/Forest.ts +81 -73
- package/src/{default-edits/HistoryEditFactory.ts → HistoryEditFactory.ts} +103 -53
- package/src/IdConversion.ts +125 -0
- package/src/Identifiers.ts +101 -1
- package/src/InitialTree.ts +5 -4
- package/src/LazyCheckout.ts +51 -0
- package/src/LogViewer.ts +242 -166
- package/src/MergeHealth.ts +447 -0
- package/src/NodeIdUtilities.ts +156 -0
- package/src/PayloadUtilities.ts +124 -0
- package/src/ReconciliationPath.ts +18 -13
- package/src/RevisionValueCache.ts +14 -5
- package/src/RevisionView.ts +252 -0
- package/src/SerializationUtilities.ts +130 -0
- package/src/SharedTree.ts +1501 -0
- package/src/SharedTreeEncoder.ts +493 -0
- package/src/StringInterner.ts +72 -0
- package/src/Summary.ts +48 -0
- package/src/SummaryBackCompatibility.ts +47 -57
- package/src/SummaryTestUtilities.ts +54 -0
- package/src/Transaction.ts +89 -0
- package/src/TransactionInternal.ts +1087 -0
- package/src/TreeCompressor.ts +213 -0
- package/src/TreeNodeHandle.ts +19 -32
- package/src/TreeView.ts +322 -0
- package/src/TreeViewUtilities.ts +77 -0
- package/src/{default-edits/UndoRedoHandler.ts → UndoRedoHandler.ts} +8 -13
- package/src/id-compressor/AppendOnlySortedMap.ts +325 -0
- package/src/id-compressor/IdCompressor.md +3 -0
- package/src/id-compressor/IdCompressor.ts +1848 -0
- package/src/id-compressor/IdRange.ts +33 -0
- package/src/id-compressor/NumericUuid.ts +414 -0
- package/src/id-compressor/index.ts +13 -0
- package/src/id-compressor/persisted-types/0.0.1.ts +179 -0
- package/src/id-compressor/persisted-types/README.md +3 -0
- package/src/id-compressor/persisted-types/index.ts +6 -0
- package/src/index.ts +118 -59
- package/src/persisted-types/0.0.2.ts +442 -0
- package/src/persisted-types/0.1.1.ts +476 -0
- package/src/persisted-types/README.md +22 -0
- package/src/persisted-types/index.ts +9 -0
- package/.mocharc.js +0 -41
- package/api/tree.api.md +0 -729
- package/dist/BasicCheckout.d.ts +0 -23
- package/dist/BasicCheckout.d.ts.map +0 -1
- package/dist/BasicCheckout.js.map +0 -1
- package/dist/Snapshot.d.ts +0 -198
- package/dist/Snapshot.d.ts.map +0 -1
- package/dist/Snapshot.js +0 -267
- package/dist/Snapshot.js.map +0 -1
- package/dist/SnapshotUtilities.d.ts +0 -29
- package/dist/SnapshotUtilities.d.ts.map +0 -1
- package/dist/SnapshotUtilities.js +0 -73
- package/dist/SnapshotUtilities.js.map +0 -1
- package/dist/anchored-edits/AnchorResolution.d.ts +0 -144
- package/dist/anchored-edits/AnchorResolution.d.ts.map +0 -1
- package/dist/anchored-edits/AnchorResolution.js +0 -162
- package/dist/anchored-edits/AnchorResolution.js.map +0 -1
- package/dist/anchored-edits/Factory.d.ts +0 -56
- package/dist/anchored-edits/Factory.d.ts.map +0 -1
- package/dist/anchored-edits/Factory.js +0 -79
- package/dist/anchored-edits/Factory.js.map +0 -1
- package/dist/anchored-edits/PersistedTypes.d.ts +0 -245
- package/dist/anchored-edits/PersistedTypes.d.ts.map +0 -1
- package/dist/anchored-edits/PersistedTypes.js +0 -131
- package/dist/anchored-edits/PersistedTypes.js.map +0 -1
- package/dist/anchored-edits/SharedTreeWithAnchors.d.ts +0 -120
- package/dist/anchored-edits/SharedTreeWithAnchors.d.ts.map +0 -1
- package/dist/anchored-edits/SharedTreeWithAnchors.js +0 -115
- package/dist/anchored-edits/SharedTreeWithAnchors.js.map +0 -1
- package/dist/anchored-edits/TransactionWithAnchors.d.ts +0 -28
- package/dist/anchored-edits/TransactionWithAnchors.d.ts.map +0 -1
- package/dist/anchored-edits/TransactionWithAnchors.js +0 -36
- package/dist/anchored-edits/TransactionWithAnchors.js.map +0 -1
- package/dist/anchored-edits/index.d.ts +0 -10
- package/dist/anchored-edits/index.d.ts.map +0 -1
- package/dist/anchored-edits/index.js +0 -34
- package/dist/anchored-edits/index.js.map +0 -1
- package/dist/default-edits/EditUtilities.d.ts +0 -57
- package/dist/default-edits/EditUtilities.d.ts.map +0 -1
- package/dist/default-edits/EditUtilities.js +0 -192
- package/dist/default-edits/EditUtilities.js.map +0 -1
- package/dist/default-edits/Factory.d.ts +0 -56
- package/dist/default-edits/Factory.d.ts.map +0 -1
- package/dist/default-edits/Factory.js +0 -79
- package/dist/default-edits/Factory.js.map +0 -1
- package/dist/default-edits/HistoryEditFactory.d.ts +0 -19
- package/dist/default-edits/HistoryEditFactory.d.ts.map +0 -1
- package/dist/default-edits/HistoryEditFactory.js +0 -187
- package/dist/default-edits/HistoryEditFactory.js.map +0 -1
- package/dist/default-edits/PersistedTypes.d.ts.map +0 -1
- package/dist/default-edits/PersistedTypes.js.map +0 -1
- package/dist/default-edits/SharedTree.d.ts +0 -111
- package/dist/default-edits/SharedTree.d.ts.map +0 -1
- package/dist/default-edits/SharedTree.js +0 -124
- package/dist/default-edits/SharedTree.js.map +0 -1
- package/dist/default-edits/Summary.d.ts +0 -15
- package/dist/default-edits/Summary.d.ts.map +0 -1
- package/dist/default-edits/Summary.js +0 -35
- package/dist/default-edits/Summary.js.map +0 -1
- package/dist/default-edits/Transaction.d.ts +0 -41
- package/dist/default-edits/Transaction.d.ts.map +0 -1
- package/dist/default-edits/Transaction.js +0 -225
- package/dist/default-edits/Transaction.js.map +0 -1
- package/dist/default-edits/UndoRedoHandler.d.ts.map +0 -1
- package/dist/default-edits/UndoRedoHandler.js.map +0 -1
- package/dist/default-edits/index.d.ts +0 -13
- package/dist/default-edits/index.d.ts.map +0 -1
- package/dist/default-edits/index.js +0 -41
- package/dist/default-edits/index.js.map +0 -1
- package/dist/generic/GenericEditUtilities.d.ts +0 -26
- package/dist/generic/GenericEditUtilities.d.ts.map +0 -1
- package/dist/generic/GenericEditUtilities.js +0 -45
- package/dist/generic/GenericEditUtilities.js.map +0 -1
- package/dist/generic/GenericSharedTree.d.ts +0 -221
- package/dist/generic/GenericSharedTree.d.ts.map +0 -1
- package/dist/generic/GenericSharedTree.js +0 -447
- package/dist/generic/GenericSharedTree.js.map +0 -1
- package/dist/generic/GenericTransaction.d.ts +0 -87
- package/dist/generic/GenericTransaction.d.ts.map +0 -1
- package/dist/generic/GenericTransaction.js +0 -144
- package/dist/generic/GenericTransaction.js.map +0 -1
- package/dist/generic/PersistedTypes.d.ts +0 -194
- package/dist/generic/PersistedTypes.d.ts.map +0 -1
- package/dist/generic/PersistedTypes.js +0 -42
- package/dist/generic/PersistedTypes.js.map +0 -1
- package/dist/generic/Summary.d.ts +0 -63
- package/dist/generic/Summary.d.ts.map +0 -1
- package/dist/generic/Summary.js +0 -64
- package/dist/generic/Summary.js.map +0 -1
- package/dist/generic/index.d.ts +0 -10
- package/dist/generic/index.d.ts.map +0 -1
- package/dist/generic/index.js +0 -26
- package/dist/generic/index.js.map +0 -1
- package/docs/Future.md +0 -155
- package/lib/BasicCheckout.d.ts +0 -23
- package/lib/BasicCheckout.d.ts.map +0 -1
- package/lib/BasicCheckout.js.map +0 -1
- package/lib/Snapshot.d.ts +0 -198
- package/lib/Snapshot.d.ts.map +0 -1
- package/lib/Snapshot.js +0 -263
- package/lib/Snapshot.js.map +0 -1
- package/lib/SnapshotUtilities.d.ts +0 -29
- package/lib/SnapshotUtilities.d.ts.map +0 -1
- package/lib/SnapshotUtilities.js +0 -67
- package/lib/SnapshotUtilities.js.map +0 -1
- package/lib/anchored-edits/AnchorResolution.d.ts +0 -144
- package/lib/anchored-edits/AnchorResolution.d.ts.map +0 -1
- package/lib/anchored-edits/AnchorResolution.js +0 -152
- package/lib/anchored-edits/AnchorResolution.js.map +0 -1
- package/lib/anchored-edits/Factory.d.ts +0 -56
- package/lib/anchored-edits/Factory.d.ts.map +0 -1
- package/lib/anchored-edits/Factory.js +0 -74
- package/lib/anchored-edits/Factory.js.map +0 -1
- package/lib/anchored-edits/PersistedTypes.d.ts +0 -245
- package/lib/anchored-edits/PersistedTypes.d.ts.map +0 -1
- package/lib/anchored-edits/PersistedTypes.js +0 -128
- package/lib/anchored-edits/PersistedTypes.js.map +0 -1
- package/lib/anchored-edits/SharedTreeWithAnchors.d.ts +0 -120
- package/lib/anchored-edits/SharedTreeWithAnchors.d.ts.map +0 -1
- package/lib/anchored-edits/SharedTreeWithAnchors.js +0 -110
- package/lib/anchored-edits/SharedTreeWithAnchors.js.map +0 -1
- package/lib/anchored-edits/TransactionWithAnchors.d.ts +0 -28
- package/lib/anchored-edits/TransactionWithAnchors.d.ts.map +0 -1
- package/lib/anchored-edits/TransactionWithAnchors.js +0 -32
- package/lib/anchored-edits/TransactionWithAnchors.js.map +0 -1
- package/lib/anchored-edits/index.d.ts +0 -10
- package/lib/anchored-edits/index.d.ts.map +0 -1
- package/lib/anchored-edits/index.js +0 -11
- package/lib/anchored-edits/index.js.map +0 -1
- package/lib/default-edits/EditUtilities.d.ts +0 -57
- package/lib/default-edits/EditUtilities.d.ts.map +0 -1
- package/lib/default-edits/EditUtilities.js +0 -181
- package/lib/default-edits/EditUtilities.js.map +0 -1
- package/lib/default-edits/Factory.d.ts +0 -56
- package/lib/default-edits/Factory.d.ts.map +0 -1
- package/lib/default-edits/Factory.js +0 -74
- package/lib/default-edits/Factory.js.map +0 -1
- package/lib/default-edits/HistoryEditFactory.d.ts +0 -19
- package/lib/default-edits/HistoryEditFactory.d.ts.map +0 -1
- package/lib/default-edits/HistoryEditFactory.js.map +0 -1
- package/lib/default-edits/PersistedTypes.d.ts.map +0 -1
- package/lib/default-edits/PersistedTypes.js.map +0 -1
- package/lib/default-edits/SharedTree.d.ts +0 -111
- package/lib/default-edits/SharedTree.d.ts.map +0 -1
- package/lib/default-edits/SharedTree.js +0 -100
- package/lib/default-edits/SharedTree.js.map +0 -1
- package/lib/default-edits/Summary.d.ts +0 -15
- package/lib/default-edits/Summary.d.ts.map +0 -1
- package/lib/default-edits/Summary.js +0 -31
- package/lib/default-edits/Summary.js.map +0 -1
- package/lib/default-edits/Transaction.d.ts +0 -41
- package/lib/default-edits/Transaction.d.ts.map +0 -1
- package/lib/default-edits/Transaction.js +0 -221
- package/lib/default-edits/Transaction.js.map +0 -1
- package/lib/default-edits/UndoRedoHandler.d.ts.map +0 -1
- package/lib/default-edits/UndoRedoHandler.js.map +0 -1
- package/lib/default-edits/index.d.ts +0 -13
- package/lib/default-edits/index.d.ts.map +0 -1
- package/lib/default-edits/index.js +0 -14
- package/lib/default-edits/index.js.map +0 -1
- package/lib/generic/GenericEditUtilities.d.ts +0 -26
- package/lib/generic/GenericEditUtilities.d.ts.map +0 -1
- package/lib/generic/GenericEditUtilities.js +0 -38
- package/lib/generic/GenericEditUtilities.js.map +0 -1
- package/lib/generic/GenericSharedTree.d.ts +0 -221
- package/lib/generic/GenericSharedTree.d.ts.map +0 -1
- package/lib/generic/GenericSharedTree.js +0 -443
- package/lib/generic/GenericSharedTree.js.map +0 -1
- package/lib/generic/GenericTransaction.d.ts +0 -87
- package/lib/generic/GenericTransaction.d.ts.map +0 -1
- package/lib/generic/GenericTransaction.js +0 -140
- package/lib/generic/GenericTransaction.js.map +0 -1
- package/lib/generic/PersistedTypes.d.ts +0 -194
- package/lib/generic/PersistedTypes.d.ts.map +0 -1
- package/lib/generic/PersistedTypes.js +0 -39
- package/lib/generic/PersistedTypes.js.map +0 -1
- package/lib/generic/Summary.d.ts +0 -63
- package/lib/generic/Summary.d.ts.map +0 -1
- package/lib/generic/Summary.js +0 -58
- package/lib/generic/Summary.js.map +0 -1
- package/lib/generic/index.d.ts +0 -10
- package/lib/generic/index.d.ts.map +0 -1
- package/lib/generic/index.js +0 -11
- package/lib/generic/index.js.map +0 -1
- package/lib/test/Anchors.glassBox.tests.d.ts.map +0 -1
- package/lib/test/Anchors.glassBox.tests.js +0 -410
- package/lib/test/Anchors.glassBox.tests.js.map +0 -1
- package/lib/test/BasicCheckout.tests.d.ts.map +0 -1
- package/lib/test/BasicCheckout.tests.js +0 -8
- package/lib/test/BasicCheckout.tests.js.map +0 -1
- package/lib/test/GenericTransactionWithAnchors.tests.d.ts.map +0 -1
- package/lib/test/GenericTransactionWithAnchors.tests.js +0 -25
- package/lib/test/GenericTransactionWithAnchors.tests.js.map +0 -1
- package/lib/test/SharedTreeWithAnchors.tests.d.ts.map +0 -1
- package/lib/test/SharedTreeWithAnchors.tests.js +0 -420
- package/lib/test/SharedTreeWithAnchors.tests.js.map +0 -1
- package/lib/test/Snapshot.tests.d.ts.map +0 -1
- package/lib/test/Snapshot.tests.js +0 -96
- package/lib/test/Snapshot.tests.js.map +0 -1
- package/lib/test/SnapshotUtilities.tests.d.ts.map +0 -1
- package/lib/test/SnapshotUtilities.tests.js +0 -168
- package/lib/test/SnapshotUtilities.tests.js.map +0 -1
- package/lib/test/undoRedoStackManager.d.ts +0 -26
- package/lib/test/undoRedoStackManager.d.ts.map +0 -1
- package/lib/test/undoRedoStackManager.js +0 -176
- package/lib/test/undoRedoStackManager.js.map +0 -1
- package/lib/test/utilities/SummaryFormatCompatibilityTests.d.ts +0 -13
- package/lib/test/utilities/SummaryFormatCompatibilityTests.d.ts.map +0 -1
- package/lib/test/utilities/SummaryFormatCompatibilityTests.js +0 -154
- package/lib/test/utilities/SummaryFormatCompatibilityTests.js.map +0 -1
- package/src/BasicCheckout.ts +0 -34
- package/src/Snapshot.ts +0 -363
- package/src/SnapshotUtilities.ts +0 -88
- package/src/anchored-edits/AnchorResolution.ts +0 -442
- package/src/anchored-edits/Factory.ts +0 -94
- package/src/anchored-edits/PersistedTypes.ts +0 -310
- package/src/anchored-edits/SharedTreeWithAnchors.ts +0 -200
- package/src/anchored-edits/TransactionWithAnchors.ts +0 -39
- package/src/anchored-edits/index.ts +0 -21
- package/src/default-edits/EditUtilities.ts +0 -220
- package/src/default-edits/Factory.ts +0 -94
- package/src/default-edits/SharedTree.ts +0 -174
- package/src/default-edits/Summary.ts +0 -44
- package/src/default-edits/Transaction.ts +0 -262
- package/src/default-edits/index.ts +0 -29
- package/src/generic/GenericEditUtilities.ts +0 -46
- package/src/generic/GenericSharedTree.ts +0 -593
- package/src/generic/GenericTransaction.ts +0 -194
- package/src/generic/PersistedTypes.ts +0 -221
- package/src/generic/Summary.ts +0 -113
- package/src/generic/index.ts +0 -41
|
@@ -0,0 +1,622 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* Copyright (c) Microsoft Corporation and contributors. All rights reserved.
|
|
3
|
+
* Licensed under the MIT License.
|
|
4
|
+
*/
|
|
5
|
+
import { assert, copyPropertyIfDefined, fail, Result } from './Common';
|
|
6
|
+
import { isDetachedSequenceId } from './Identifiers';
|
|
7
|
+
import { rangeFromStableRange } from './TreeViewUtilities';
|
|
8
|
+
import { ChangeTypeInternal, ConstraintEffect, EditStatus, } from './persisted-types';
|
|
9
|
+
import { detachRange, insertIntoTrait, validateStablePlace, validateStableRange, PlaceValidationResult, RangeValidationResultKind, } from './EditUtilities';
|
|
10
|
+
/**
|
|
11
|
+
* A mutable transaction for applying sequences of changes to a TreeView.
|
|
12
|
+
* Allows viewing the intermediate states.
|
|
13
|
+
*
|
|
14
|
+
* Contains necessary state to apply changes within an edit to a TreeView.
|
|
15
|
+
*
|
|
16
|
+
* May have any number of changes applied to make up the edit.
|
|
17
|
+
* Use `close` to complete the transaction, returning the array of changes and an EditingResult showing the
|
|
18
|
+
* results of applying the changes as an Edit to the initial TreeView (passed to the constructor).
|
|
19
|
+
*
|
|
20
|
+
* No data outside the Transaction is modified by Transaction:
|
|
21
|
+
* the results from `close` must be used to actually submit an `Edit`.
|
|
22
|
+
*/
|
|
23
|
+
export class GenericTransaction {
|
|
24
|
+
/**
|
|
25
|
+
* Create and open an edit of the provided `TreeView`. After applying 0 or more changes, this editor should be closed via `close()`.
|
|
26
|
+
* @param view - the `TreeView` at which this edit begins. The first change will be applied against this view.
|
|
27
|
+
*/
|
|
28
|
+
constructor(view, policy) {
|
|
29
|
+
this.open = true;
|
|
30
|
+
this.before = view;
|
|
31
|
+
this.policy = policy;
|
|
32
|
+
this.state = {
|
|
33
|
+
view: view.openForTransaction(),
|
|
34
|
+
status: EditStatus.Applied,
|
|
35
|
+
changes: [],
|
|
36
|
+
steps: [],
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
/** Whether or not this transaction has been closed via `close()` */
|
|
40
|
+
get isOpen() {
|
|
41
|
+
return this.open;
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* The most up-to-date `TreeView` for this edit. This is the state of the tree after all changes applied so far.
|
|
45
|
+
*/
|
|
46
|
+
get view() {
|
|
47
|
+
return this.state.view;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* The status code of the most recent attempted change.
|
|
51
|
+
*/
|
|
52
|
+
get status() {
|
|
53
|
+
return this.state.status;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* The status code of the most recent attempted change.
|
|
57
|
+
*/
|
|
58
|
+
get changes() {
|
|
59
|
+
return this.state.changes;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* The status code of the most recent attempted change.
|
|
63
|
+
*/
|
|
64
|
+
get steps() {
|
|
65
|
+
return this.state.steps;
|
|
66
|
+
}
|
|
67
|
+
/** @returns the final `EditStatus` and `TreeView` after all changes are applied. */
|
|
68
|
+
close() {
|
|
69
|
+
assert(this.open, 'transaction has already been closed');
|
|
70
|
+
this.open = false;
|
|
71
|
+
if (this.state.status === EditStatus.Applied) {
|
|
72
|
+
const validation = this.policy.validateOnClose(this.state);
|
|
73
|
+
if (Result.isOk(validation)) {
|
|
74
|
+
if (validation.result !== this.view) {
|
|
75
|
+
this.state = Object.assign(Object.assign({}, this.state), { view: validation.result });
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
status: EditStatus.Applied,
|
|
79
|
+
steps: this.steps,
|
|
80
|
+
changes: this.changes,
|
|
81
|
+
before: this.before,
|
|
82
|
+
after: this.view.close(),
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
this.state = Object.assign(Object.assign({}, this.state), validation.error);
|
|
86
|
+
return Object.assign(Object.assign({}, validation.error), { steps: this.steps, changes: this.changes, before: this.before });
|
|
87
|
+
}
|
|
88
|
+
return {
|
|
89
|
+
status: this.state.status,
|
|
90
|
+
failure: this.state.failure,
|
|
91
|
+
steps: this.steps,
|
|
92
|
+
changes: this.changes,
|
|
93
|
+
before: this.before,
|
|
94
|
+
};
|
|
95
|
+
}
|
|
96
|
+
/**
|
|
97
|
+
* A helper to apply a sequence of changes. Changes will be applied one after the other. If a change fails to apply,
|
|
98
|
+
* the remaining changes in `changes` will be ignored.
|
|
99
|
+
* @param changes - the sequence of changes to apply.
|
|
100
|
+
* @param path - the reconciliation path for the first change.
|
|
101
|
+
* @returns this
|
|
102
|
+
*/
|
|
103
|
+
applyChanges(changes, path = []) {
|
|
104
|
+
const iter = changes[Symbol.iterator]();
|
|
105
|
+
const firsChangeInternal = iter.next().value;
|
|
106
|
+
let iterResult = iter.next();
|
|
107
|
+
if (iterResult.done === true) {
|
|
108
|
+
for (const change of changes) {
|
|
109
|
+
if (this.applyChange(change, path).status !== EditStatus.Applied) {
|
|
110
|
+
return this;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
return this;
|
|
114
|
+
}
|
|
115
|
+
if (this.applyChange(firsChangeInternal, path).status !== EditStatus.Applied) {
|
|
116
|
+
return this;
|
|
117
|
+
}
|
|
118
|
+
const ongoingEdit = {
|
|
119
|
+
0: this.steps[this.steps.length - 1],
|
|
120
|
+
before: this.view,
|
|
121
|
+
after: this.view,
|
|
122
|
+
length: 1,
|
|
123
|
+
};
|
|
124
|
+
/**
|
|
125
|
+
* We use a Proxy instead of `{ ...path, ...objectWithOngoingEdit }` to avoid eagerly demanding all parts of the path, which may
|
|
126
|
+
* require extensive computation.
|
|
127
|
+
*/
|
|
128
|
+
const pathWithOngoingEdit = new Proxy(path, {
|
|
129
|
+
get: (target, prop) => {
|
|
130
|
+
if (prop === 'length') {
|
|
131
|
+
return target.length + 1;
|
|
132
|
+
}
|
|
133
|
+
return prop === String(target.length) ? ongoingEdit : target[prop];
|
|
134
|
+
},
|
|
135
|
+
});
|
|
136
|
+
while (iterResult.done !== true) {
|
|
137
|
+
if (this.applyChange(iterResult.value, pathWithOngoingEdit).status !== EditStatus.Applied) {
|
|
138
|
+
return this;
|
|
139
|
+
}
|
|
140
|
+
ongoingEdit[ongoingEdit.length] = this.steps[this.steps.length - 1];
|
|
141
|
+
ongoingEdit.length += 1;
|
|
142
|
+
ongoingEdit.after = this.view;
|
|
143
|
+
iterResult = iter.next();
|
|
144
|
+
}
|
|
145
|
+
return this;
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* Attempt to apply the given change as part of this edit. This method should not be called if a previous change in this edit failed to
|
|
149
|
+
* apply.
|
|
150
|
+
* @param change - the change to apply
|
|
151
|
+
* @param path - the reconciliation path for the change.
|
|
152
|
+
* @returns this
|
|
153
|
+
*/
|
|
154
|
+
applyChange(change, path = []) {
|
|
155
|
+
assert(this.open, 'Editor must be open to apply changes.');
|
|
156
|
+
if (this.state.status !== EditStatus.Applied) {
|
|
157
|
+
fail('Cannot apply change to an edit unless all previous changes have applied');
|
|
158
|
+
}
|
|
159
|
+
const resolutionResult = this.policy.tryResolveChange(this.state, change, path);
|
|
160
|
+
if (Result.isError(resolutionResult)) {
|
|
161
|
+
this.state = Object.assign(Object.assign({}, this.state), resolutionResult.error);
|
|
162
|
+
return this;
|
|
163
|
+
}
|
|
164
|
+
const resolvedChange = resolutionResult.result;
|
|
165
|
+
const changeResult = this.policy.dispatchChange(this.state, resolvedChange);
|
|
166
|
+
if (Result.isOk(changeResult)) {
|
|
167
|
+
this.state = {
|
|
168
|
+
status: EditStatus.Applied,
|
|
169
|
+
view: changeResult.result,
|
|
170
|
+
changes: this.changes.concat(change),
|
|
171
|
+
steps: this.steps.concat({ resolvedChange, after: changeResult.result }),
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
else {
|
|
175
|
+
this.state = Object.assign(Object.assign({}, this.state), changeResult.error);
|
|
176
|
+
}
|
|
177
|
+
return this;
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* A mutable transaction for applying sequences of changes to a TreeView.
|
|
182
|
+
* Allows viewing the intermediate states.
|
|
183
|
+
*
|
|
184
|
+
* Contains necessary state to apply changes within an edit to a TreeView.
|
|
185
|
+
*
|
|
186
|
+
* May have any number of changes applied to make up the edit.
|
|
187
|
+
* Use `close` to complete the transaction, returning the array of changes and an EditingResult showing the
|
|
188
|
+
* results of applying the changes as an Edit to the initial TreeView (passed to the constructor).
|
|
189
|
+
*
|
|
190
|
+
* No data outside the Transaction is modified by Transaction:
|
|
191
|
+
* the results from `close` must be used to actually submit an `Edit`.
|
|
192
|
+
* @public
|
|
193
|
+
*/
|
|
194
|
+
export var TransactionInternal;
|
|
195
|
+
(function (TransactionInternal) {
|
|
196
|
+
/**
|
|
197
|
+
* Makes a new {@link GenericTransaction} that follows the {@link TransactionInternal.Policy} policy.
|
|
198
|
+
*/
|
|
199
|
+
function factory(view) {
|
|
200
|
+
return new GenericTransaction(view, new Policy());
|
|
201
|
+
}
|
|
202
|
+
TransactionInternal.factory = factory;
|
|
203
|
+
/**
|
|
204
|
+
* The policy followed by a {@link TransactionInternal}.
|
|
205
|
+
*/
|
|
206
|
+
class Policy {
|
|
207
|
+
constructor() {
|
|
208
|
+
/**
|
|
209
|
+
* Maps detached sequences of nodes to their NodeIds
|
|
210
|
+
*/
|
|
211
|
+
this.detached = new Map();
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Resolves change with Result.Ok
|
|
215
|
+
*
|
|
216
|
+
* @param state - Unused
|
|
217
|
+
* @param change - Change to resolve
|
|
218
|
+
* @returns Result.Ok which contains change
|
|
219
|
+
*/
|
|
220
|
+
tryResolveChange(state, change) {
|
|
221
|
+
return Result.ok(change);
|
|
222
|
+
}
|
|
223
|
+
/**
|
|
224
|
+
* Validates the transaction when it is closed
|
|
225
|
+
*
|
|
226
|
+
* @param state - Current state
|
|
227
|
+
* @returns a {@link ChangeResult} containing either the change result or a Failure
|
|
228
|
+
*/
|
|
229
|
+
validateOnClose(state) {
|
|
230
|
+
// Making the policy choice that storing a detached sequences in an edit but not using it is an error.
|
|
231
|
+
return this.detached.size !== 0
|
|
232
|
+
? Result.error({
|
|
233
|
+
status: EditStatus.Malformed,
|
|
234
|
+
failure: {
|
|
235
|
+
kind: FailureKind.UnusedDetachedSequence,
|
|
236
|
+
sequenceId: this.detached.keys().next().value,
|
|
237
|
+
},
|
|
238
|
+
})
|
|
239
|
+
: Result.ok(state.view);
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Applies a given change
|
|
243
|
+
*
|
|
244
|
+
* @param state - Current state
|
|
245
|
+
* @param change - Change to apply
|
|
246
|
+
* @returns a {@link ChangeResult} containing either the change result or a Failure
|
|
247
|
+
*/
|
|
248
|
+
dispatchChange(state, change) {
|
|
249
|
+
switch (change.type) {
|
|
250
|
+
case ChangeTypeInternal.Build:
|
|
251
|
+
return this.applyBuild(state, change);
|
|
252
|
+
case ChangeTypeInternal.Insert:
|
|
253
|
+
return this.applyInsert(state, change);
|
|
254
|
+
case ChangeTypeInternal.Detach:
|
|
255
|
+
return this.applyDetach(state, change);
|
|
256
|
+
case ChangeTypeInternal.Constraint:
|
|
257
|
+
return this.applyConstraint(state, change);
|
|
258
|
+
case ChangeTypeInternal.SetValue:
|
|
259
|
+
return this.applySetValue(state, change);
|
|
260
|
+
default:
|
|
261
|
+
return fail('Attempted to apply unsupported change');
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
applyBuild(state, change) {
|
|
265
|
+
if (this.detached.has(change.destination)) {
|
|
266
|
+
return Result.error({
|
|
267
|
+
status: EditStatus.Malformed,
|
|
268
|
+
failure: {
|
|
269
|
+
kind: FailureKind.DetachedSequenceIdAlreadyInUse,
|
|
270
|
+
change,
|
|
271
|
+
sequenceId: change.destination,
|
|
272
|
+
},
|
|
273
|
+
});
|
|
274
|
+
}
|
|
275
|
+
let idAlreadyPresent;
|
|
276
|
+
let duplicateIdInBuild;
|
|
277
|
+
let invalidId;
|
|
278
|
+
let detachedSequenceNotFound;
|
|
279
|
+
const map = new Map();
|
|
280
|
+
const newIds = this.createViewNodesForTree(change.source, (id, viewNode) => {
|
|
281
|
+
if (map.has(id)) {
|
|
282
|
+
duplicateIdInBuild = id;
|
|
283
|
+
return true;
|
|
284
|
+
}
|
|
285
|
+
if (state.view.hasNode(viewNode.identifier)) {
|
|
286
|
+
idAlreadyPresent = id;
|
|
287
|
+
return true;
|
|
288
|
+
}
|
|
289
|
+
map.set(id, viewNode);
|
|
290
|
+
return false;
|
|
291
|
+
}, (detachedId) => {
|
|
292
|
+
detachedSequenceNotFound = detachedId;
|
|
293
|
+
});
|
|
294
|
+
if (idAlreadyPresent !== undefined) {
|
|
295
|
+
return Result.error({
|
|
296
|
+
status: EditStatus.Invalid,
|
|
297
|
+
failure: { kind: FailureKind.IdAlreadyInUse, change, id: idAlreadyPresent },
|
|
298
|
+
});
|
|
299
|
+
}
|
|
300
|
+
if (duplicateIdInBuild !== undefined) {
|
|
301
|
+
return Result.error({
|
|
302
|
+
status: EditStatus.Malformed,
|
|
303
|
+
failure: { kind: FailureKind.DuplicateIdInBuild, change, id: duplicateIdInBuild },
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
if (invalidId !== undefined) {
|
|
307
|
+
return Result.error({
|
|
308
|
+
status: EditStatus.Invalid,
|
|
309
|
+
failure: { kind: FailureKind.UnknownId, change, id: invalidId },
|
|
310
|
+
});
|
|
311
|
+
}
|
|
312
|
+
if (detachedSequenceNotFound !== undefined) {
|
|
313
|
+
return Result.error({
|
|
314
|
+
status: EditStatus.Malformed,
|
|
315
|
+
failure: {
|
|
316
|
+
kind: FailureKind.DetachedSequenceNotFound,
|
|
317
|
+
change,
|
|
318
|
+
sequenceId: detachedSequenceNotFound,
|
|
319
|
+
},
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
const view = state.view.addNodes(map.values());
|
|
323
|
+
this.detached.set(change.destination, newIds !== null && newIds !== void 0 ? newIds : fail('Unhandled failure case in Transaction.createViewNodesForTree'));
|
|
324
|
+
return Result.ok(view);
|
|
325
|
+
}
|
|
326
|
+
applyInsert(state, change) {
|
|
327
|
+
const source = this.detached.get(change.source);
|
|
328
|
+
if (source === undefined) {
|
|
329
|
+
return Result.error({
|
|
330
|
+
status: EditStatus.Malformed,
|
|
331
|
+
failure: {
|
|
332
|
+
kind: FailureKind.DetachedSequenceNotFound,
|
|
333
|
+
change,
|
|
334
|
+
sequenceId: change.source,
|
|
335
|
+
},
|
|
336
|
+
});
|
|
337
|
+
}
|
|
338
|
+
const validatedDestination = validateStablePlace(state.view, change.destination);
|
|
339
|
+
if (validatedDestination.result !== PlaceValidationResult.Valid) {
|
|
340
|
+
return Result.error({
|
|
341
|
+
status: validatedDestination.result === PlaceValidationResult.Malformed
|
|
342
|
+
? EditStatus.Malformed
|
|
343
|
+
: EditStatus.Invalid,
|
|
344
|
+
failure: {
|
|
345
|
+
kind: FailureKind.BadPlace,
|
|
346
|
+
change,
|
|
347
|
+
place: change.destination,
|
|
348
|
+
placeFailure: validatedDestination.result,
|
|
349
|
+
},
|
|
350
|
+
});
|
|
351
|
+
}
|
|
352
|
+
this.detached.delete(change.source);
|
|
353
|
+
const view = insertIntoTrait(state.view, source, validatedDestination);
|
|
354
|
+
return Result.ok(view);
|
|
355
|
+
}
|
|
356
|
+
applyDetach(state, change) {
|
|
357
|
+
const validatedSource = validateStableRange(state.view, change.source);
|
|
358
|
+
if (validatedSource.result !== RangeValidationResultKind.Valid) {
|
|
359
|
+
return Result.error({
|
|
360
|
+
status: validatedSource.result === RangeValidationResultKind.PlacesInDifferentTraits ||
|
|
361
|
+
validatedSource.result === RangeValidationResultKind.Inverted ||
|
|
362
|
+
validatedSource.result.placeFailure !== PlaceValidationResult.Malformed
|
|
363
|
+
? EditStatus.Invalid
|
|
364
|
+
: EditStatus.Malformed,
|
|
365
|
+
failure: {
|
|
366
|
+
kind: FailureKind.BadRange,
|
|
367
|
+
change,
|
|
368
|
+
range: change.source,
|
|
369
|
+
rangeFailure: validatedSource.result,
|
|
370
|
+
},
|
|
371
|
+
});
|
|
372
|
+
}
|
|
373
|
+
const result = detachRange(state.view, validatedSource);
|
|
374
|
+
let modifiedView = result.view;
|
|
375
|
+
const { detached } = result;
|
|
376
|
+
// Store or dispose detached
|
|
377
|
+
if (change.destination !== undefined) {
|
|
378
|
+
if (this.detached.has(change.destination)) {
|
|
379
|
+
return Result.error({
|
|
380
|
+
status: EditStatus.Malformed,
|
|
381
|
+
failure: {
|
|
382
|
+
kind: FailureKind.DetachedSequenceIdAlreadyInUse,
|
|
383
|
+
change,
|
|
384
|
+
sequenceId: change.destination,
|
|
385
|
+
},
|
|
386
|
+
});
|
|
387
|
+
}
|
|
388
|
+
this.detached.set(change.destination, detached);
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
modifiedView = modifiedView.deleteNodes(detached);
|
|
392
|
+
}
|
|
393
|
+
return Result.ok(modifiedView);
|
|
394
|
+
}
|
|
395
|
+
applyConstraint(state, change) {
|
|
396
|
+
// TODO: Implement identityHash and contentHash
|
|
397
|
+
assert(change.identityHash === undefined, 'identityHash constraint is not implemented');
|
|
398
|
+
assert(change.contentHash === undefined, 'contentHash constraint is not implemented');
|
|
399
|
+
const validatedChange = validateStableRange(state.view, change.toConstrain);
|
|
400
|
+
if (validatedChange.result !== RangeValidationResultKind.Valid) {
|
|
401
|
+
return validatedChange.result !== RangeValidationResultKind.PlacesInDifferentTraits &&
|
|
402
|
+
validatedChange.result !== RangeValidationResultKind.Inverted &&
|
|
403
|
+
validatedChange.result.placeFailure !== PlaceValidationResult.Malformed
|
|
404
|
+
? change.effect === ConstraintEffect.ValidRetry
|
|
405
|
+
? Result.ok(state.view)
|
|
406
|
+
: Result.error({
|
|
407
|
+
status: EditStatus.Invalid,
|
|
408
|
+
failure: {
|
|
409
|
+
kind: FailureKind.ConstraintViolation,
|
|
410
|
+
constraint: change,
|
|
411
|
+
violation: {
|
|
412
|
+
kind: ConstraintViolationKind.BadRange,
|
|
413
|
+
rangeFailure: validatedChange.result,
|
|
414
|
+
},
|
|
415
|
+
},
|
|
416
|
+
})
|
|
417
|
+
: Result.error({
|
|
418
|
+
status: EditStatus.Malformed,
|
|
419
|
+
failure: {
|
|
420
|
+
kind: FailureKind.ConstraintViolation,
|
|
421
|
+
constraint: change,
|
|
422
|
+
violation: {
|
|
423
|
+
kind: ConstraintViolationKind.BadRange,
|
|
424
|
+
rangeFailure: validatedChange.result,
|
|
425
|
+
},
|
|
426
|
+
},
|
|
427
|
+
});
|
|
428
|
+
}
|
|
429
|
+
const { start, end } = rangeFromStableRange(state.view, validatedChange);
|
|
430
|
+
const startIndex = state.view.findIndexWithinTrait(start);
|
|
431
|
+
const endIndex = state.view.findIndexWithinTrait(end);
|
|
432
|
+
if (change.length !== undefined && change.length !== endIndex - startIndex) {
|
|
433
|
+
return Result.error({
|
|
434
|
+
status: EditStatus.Invalid,
|
|
435
|
+
failure: {
|
|
436
|
+
kind: FailureKind.ConstraintViolation,
|
|
437
|
+
constraint: change,
|
|
438
|
+
violation: {
|
|
439
|
+
kind: ConstraintViolationKind.BadLength,
|
|
440
|
+
actual: endIndex - startIndex,
|
|
441
|
+
},
|
|
442
|
+
},
|
|
443
|
+
});
|
|
444
|
+
}
|
|
445
|
+
if (change.parentNode !== undefined && change.parentNode !== end.trait.parent) {
|
|
446
|
+
return Result.error({
|
|
447
|
+
status: EditStatus.Invalid,
|
|
448
|
+
failure: {
|
|
449
|
+
kind: FailureKind.ConstraintViolation,
|
|
450
|
+
constraint: change,
|
|
451
|
+
violation: {
|
|
452
|
+
kind: ConstraintViolationKind.BadParent,
|
|
453
|
+
actual: change.parentNode,
|
|
454
|
+
},
|
|
455
|
+
},
|
|
456
|
+
});
|
|
457
|
+
}
|
|
458
|
+
if (change.label !== undefined && change.label !== end.trait.label) {
|
|
459
|
+
return Result.error({
|
|
460
|
+
status: EditStatus.Invalid,
|
|
461
|
+
failure: {
|
|
462
|
+
kind: FailureKind.ConstraintViolation,
|
|
463
|
+
constraint: change,
|
|
464
|
+
violation: {
|
|
465
|
+
kind: ConstraintViolationKind.BadLabel,
|
|
466
|
+
actual: end.trait.label,
|
|
467
|
+
},
|
|
468
|
+
},
|
|
469
|
+
});
|
|
470
|
+
}
|
|
471
|
+
return Result.ok(state.view);
|
|
472
|
+
}
|
|
473
|
+
applySetValue(state, change) {
|
|
474
|
+
if (!state.view.hasNode(change.nodeToModify)) {
|
|
475
|
+
return Result.error({
|
|
476
|
+
status: EditStatus.Invalid,
|
|
477
|
+
failure: { kind: FailureKind.UnknownId, change, id: change.nodeToModify },
|
|
478
|
+
});
|
|
479
|
+
}
|
|
480
|
+
const newView = state.view.setNodeValue(change.nodeToModify, change.payload);
|
|
481
|
+
return Result.ok(newView);
|
|
482
|
+
}
|
|
483
|
+
/**
|
|
484
|
+
* Generates tree view nodes from the supplied edit nodes.
|
|
485
|
+
* Invokes onCreateNode for each new node, and halts creation early if it returns true.
|
|
486
|
+
* Invokes onInvalidDetachedId and halts early for any invalid detached IDs referenced in the edit node sequence.
|
|
487
|
+
* @returns all the top-level node IDs in `sequence` (both from nodes and from detached sequences).
|
|
488
|
+
*/
|
|
489
|
+
createViewNodesForTree(sequence, onCreateNode, onInvalidDetachedId) {
|
|
490
|
+
const topLevelIds = [];
|
|
491
|
+
const unprocessed = [];
|
|
492
|
+
for (const buildNode of sequence) {
|
|
493
|
+
if (isDetachedSequenceId(buildNode)) {
|
|
494
|
+
const detachedIds = this.getDetachedNodeIds(buildNode, onInvalidDetachedId);
|
|
495
|
+
if (detachedIds === undefined) {
|
|
496
|
+
return undefined;
|
|
497
|
+
}
|
|
498
|
+
topLevelIds.push(...detachedIds);
|
|
499
|
+
}
|
|
500
|
+
else {
|
|
501
|
+
unprocessed.push(buildNode);
|
|
502
|
+
topLevelIds.push(buildNode.identifier);
|
|
503
|
+
}
|
|
504
|
+
}
|
|
505
|
+
while (unprocessed.length > 0) {
|
|
506
|
+
const node = unprocessed.pop();
|
|
507
|
+
assert(node !== undefined && !isDetachedSequenceId(node));
|
|
508
|
+
const traits = new Map();
|
|
509
|
+
// eslint-disable-next-line no-restricted-syntax
|
|
510
|
+
for (const key in node.traits) {
|
|
511
|
+
if (Object.prototype.hasOwnProperty.call(node.traits, key)) {
|
|
512
|
+
const children = node.traits[key];
|
|
513
|
+
if (children.length > 0) {
|
|
514
|
+
const childIds = [];
|
|
515
|
+
for (const child of children) {
|
|
516
|
+
if (isDetachedSequenceId(child)) {
|
|
517
|
+
const detachedIds = this.getDetachedNodeIds(child, onInvalidDetachedId);
|
|
518
|
+
if (detachedIds === undefined) {
|
|
519
|
+
return undefined;
|
|
520
|
+
}
|
|
521
|
+
childIds.push(...detachedIds);
|
|
522
|
+
}
|
|
523
|
+
else {
|
|
524
|
+
childIds.push(child.identifier);
|
|
525
|
+
unprocessed.push(child);
|
|
526
|
+
}
|
|
527
|
+
}
|
|
528
|
+
traits.set(key, childIds);
|
|
529
|
+
}
|
|
530
|
+
}
|
|
531
|
+
}
|
|
532
|
+
const newNode = {
|
|
533
|
+
identifier: node.identifier,
|
|
534
|
+
definition: node.definition,
|
|
535
|
+
traits,
|
|
536
|
+
};
|
|
537
|
+
copyPropertyIfDefined(node, newNode, 'payload');
|
|
538
|
+
if (onCreateNode(node.identifier, newNode)) {
|
|
539
|
+
return undefined;
|
|
540
|
+
}
|
|
541
|
+
}
|
|
542
|
+
return topLevelIds;
|
|
543
|
+
}
|
|
544
|
+
getDetachedNodeIds(detachedId, onInvalidDetachedId) {
|
|
545
|
+
// Retrieve the detached sequence from the void.
|
|
546
|
+
const detachedNodeIds = this.detached.get(detachedId);
|
|
547
|
+
if (detachedNodeIds === undefined) {
|
|
548
|
+
onInvalidDetachedId(detachedId);
|
|
549
|
+
return undefined;
|
|
550
|
+
}
|
|
551
|
+
// Since we have retrieved the sequence, remove it from the void to prevent a second tree from multi-parenting it later
|
|
552
|
+
this.detached.delete(detachedId);
|
|
553
|
+
return detachedNodeIds;
|
|
554
|
+
}
|
|
555
|
+
}
|
|
556
|
+
TransactionInternal.Policy = Policy;
|
|
557
|
+
/**
|
|
558
|
+
* The kinds of failures that a transaction might encounter.
|
|
559
|
+
*/
|
|
560
|
+
let FailureKind;
|
|
561
|
+
(function (FailureKind) {
|
|
562
|
+
/**
|
|
563
|
+
* Transaction has an unused DetachedSequenceId
|
|
564
|
+
*/
|
|
565
|
+
FailureKind["UnusedDetachedSequence"] = "UnusedDetachedSequence";
|
|
566
|
+
/**
|
|
567
|
+
* Transaction has a build operation using an already in use DetachedSequenceID.
|
|
568
|
+
*/
|
|
569
|
+
FailureKind["DetachedSequenceIdAlreadyInUse"] = "DetachedSequenceIdAlreadyInUse";
|
|
570
|
+
/**
|
|
571
|
+
* Transaction tries to operate on an unknown DetachedSequenceID
|
|
572
|
+
*/
|
|
573
|
+
FailureKind["DetachedSequenceNotFound"] = "DetachedSequenceNotFound";
|
|
574
|
+
/**
|
|
575
|
+
* Transaction has a build which uses a duplicated NodeId
|
|
576
|
+
*/
|
|
577
|
+
FailureKind["DuplicateIdInBuild"] = "DuplicateIdInBuild";
|
|
578
|
+
/**
|
|
579
|
+
* Transaction tries to build a node using an ID which is already used in the current state
|
|
580
|
+
*/
|
|
581
|
+
FailureKind["IdAlreadyInUse"] = "IdAlreadyInUse";
|
|
582
|
+
/**
|
|
583
|
+
* Transaction tries to set value of an unknown node
|
|
584
|
+
*/
|
|
585
|
+
FailureKind["UnknownId"] = "UnknownId";
|
|
586
|
+
/**
|
|
587
|
+
* Transaction tries to insert in an invalid Place
|
|
588
|
+
*/
|
|
589
|
+
FailureKind["BadPlace"] = "BadPlace";
|
|
590
|
+
/**
|
|
591
|
+
* Transaction tries to detach an invalid Range
|
|
592
|
+
*/
|
|
593
|
+
FailureKind["BadRange"] = "BadRange";
|
|
594
|
+
/**
|
|
595
|
+
* Transaction has an invalid constraint
|
|
596
|
+
*/
|
|
597
|
+
FailureKind["ConstraintViolation"] = "ConstraintViolation";
|
|
598
|
+
})(FailureKind = TransactionInternal.FailureKind || (TransactionInternal.FailureKind = {}));
|
|
599
|
+
/**
|
|
600
|
+
* Enum of possible kinds of constraint violations that can be encountered
|
|
601
|
+
*/
|
|
602
|
+
let ConstraintViolationKind;
|
|
603
|
+
(function (ConstraintViolationKind) {
|
|
604
|
+
/**
|
|
605
|
+
* The constraint failed because it applies to an invalid range
|
|
606
|
+
*/
|
|
607
|
+
ConstraintViolationKind["BadRange"] = "BadRange";
|
|
608
|
+
/**
|
|
609
|
+
* The constraint failed because the length prescribed by the constraint does not match the length of range being constrained
|
|
610
|
+
*/
|
|
611
|
+
ConstraintViolationKind["BadLength"] = "BadLength";
|
|
612
|
+
/**
|
|
613
|
+
* The constraint failed because the parent prescribed by the constraint does not match the actual parent of the range being constrained
|
|
614
|
+
*/
|
|
615
|
+
ConstraintViolationKind["BadParent"] = "BadParent";
|
|
616
|
+
/**
|
|
617
|
+
* The constraint failed because the trait label prescribed by the constraint does not match the actual trait label of the range being constrained
|
|
618
|
+
*/
|
|
619
|
+
ConstraintViolationKind["BadLabel"] = "BadLabel";
|
|
620
|
+
})(ConstraintViolationKind = TransactionInternal.ConstraintViolationKind || (TransactionInternal.ConstraintViolationKind = {}));
|
|
621
|
+
})(TransactionInternal || (TransactionInternal = {}));
|
|
622
|
+
//# sourceMappingURL=TransactionInternal.js.map
|