@fluidframework/tree 2.82.0 → 2.90.0-378676
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/CHANGELOG.md +43 -0
- package/README.md +33 -5
- package/api-report/tree.alpha.api.md +26 -21
- package/api-report/tree.beta.api.md +14 -2
- package/api-report/tree.legacy.beta.api.md +14 -2
- package/api-report/tree.legacy.public.api.md +1 -1
- package/api-report/tree.public.api.md +1 -1
- package/dist/alpha.d.ts +3 -3
- package/dist/beta.d.ts +1 -0
- package/dist/codec/codec.d.ts +3 -39
- package/dist/codec/codec.d.ts.map +1 -1
- package/dist/codec/codec.js +5 -50
- package/dist/codec/codec.js.map +1 -1
- package/dist/codec/index.d.ts +1 -1
- package/dist/codec/index.d.ts.map +1 -1
- package/dist/codec/index.js +1 -2
- package/dist/codec/index.js.map +1 -1
- package/dist/codec/versioned/codec.d.ts +20 -7
- package/dist/codec/versioned/codec.d.ts.map +1 -1
- package/dist/codec/versioned/codec.js +56 -30
- package/dist/codec/versioned/codec.js.map +1 -1
- package/dist/core/change-family/changeFamily.d.ts +4 -1
- package/dist/core/change-family/changeFamily.d.ts.map +1 -1
- package/dist/core/change-family/changeFamily.js.map +1 -1
- package/dist/core/change-family/index.d.ts +1 -1
- package/dist/core/change-family/index.d.ts.map +1 -1
- package/dist/core/change-family/index.js.map +1 -1
- package/dist/core/index.d.ts +3 -3
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +6 -4
- package/dist/core/index.js.map +1 -1
- package/dist/core/rebase/changeRebaser.d.ts +6 -1
- package/dist/core/rebase/changeRebaser.d.ts.map +1 -1
- package/dist/core/rebase/changeRebaser.js.map +1 -1
- package/dist/core/rebase/index.d.ts +1 -1
- package/dist/core/rebase/index.d.ts.map +1 -1
- package/dist/core/rebase/index.js +2 -1
- package/dist/core/rebase/index.js.map +1 -1
- package/dist/core/rebase/types.d.ts +1 -0
- package/dist/core/rebase/types.d.ts.map +1 -1
- package/dist/core/rebase/types.js +5 -1
- package/dist/core/rebase/types.js.map +1 -1
- package/dist/core/rebase/utils.d.ts.map +1 -1
- package/dist/core/rebase/utils.js +25 -7
- package/dist/core/rebase/utils.js.map +1 -1
- package/dist/core/tree/delta.d.ts +5 -0
- package/dist/core/tree/delta.d.ts.map +1 -1
- package/dist/core/tree/delta.js.map +1 -1
- package/dist/core/tree/detachedFieldIndex.d.ts +13 -1
- package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
- package/dist/core/tree/detachedFieldIndex.js +14 -1
- package/dist/core/tree/detachedFieldIndex.js.map +1 -1
- package/dist/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -1
- package/dist/core/tree/detachedFieldIndexCodecs.js +6 -4
- package/dist/core/tree/detachedFieldIndexCodecs.js.map +1 -1
- package/dist/core/tree/detachedFieldIndexTypes.d.ts +4 -0
- package/dist/core/tree/detachedFieldIndexTypes.d.ts.map +1 -1
- package/dist/core/tree/detachedFieldIndexTypes.js.map +1 -1
- package/dist/core/tree/index.d.ts +2 -2
- package/dist/core/tree/index.d.ts.map +1 -1
- package/dist/core/tree/index.js +4 -3
- package/dist/core/tree/index.js.map +1 -1
- package/dist/core/tree/pathTree.d.ts +11 -3
- package/dist/core/tree/pathTree.d.ts.map +1 -1
- package/dist/core/tree/pathTree.js +14 -2
- package/dist/core/tree/pathTree.js.map +1 -1
- package/dist/core/tree/visitDelta.d.ts.map +1 -1
- package/dist/core/tree/visitDelta.js +17 -13
- package/dist/core/tree/visitDelta.js.map +1 -1
- package/dist/extensibleUnionNode.d.ts +97 -0
- package/dist/extensibleUnionNode.d.ts.map +1 -0
- package/dist/{extensibleSchemaUnion.js → extensibleUnionNode.js} +28 -18
- package/dist/extensibleUnionNode.js.map +1 -0
- package/dist/feature-libraries/changeAtomIdBTree.d.ts +3 -2
- package/dist/feature-libraries/changeAtomIdBTree.d.ts.map +1 -1
- package/dist/feature-libraries/changeAtomIdBTree.js +15 -2
- package/dist/feature-libraries/changeAtomIdBTree.js.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/codecs.d.ts +1 -1
- package/dist/feature-libraries/chunked-forest/codec/codecs.d.ts.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/codecs.js +4 -4
- package/dist/feature-libraries/chunked-forest/codec/codecs.js.map +1 -1
- package/dist/feature-libraries/default-schema/defaultEditBuilder.d.ts +92 -44
- package/dist/feature-libraries/default-schema/defaultEditBuilder.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/defaultEditBuilder.js +220 -70
- package/dist/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
- package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/defaultFieldKinds.js +12 -2
- package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
- package/dist/feature-libraries/default-schema/index.d.ts +2 -1
- package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/index.js +4 -2
- package/dist/feature-libraries/default-schema/index.js.map +1 -1
- package/dist/feature-libraries/default-schema/locationBasedEditBuilder.d.ts +40 -0
- package/dist/feature-libraries/default-schema/locationBasedEditBuilder.d.ts.map +1 -0
- package/dist/feature-libraries/default-schema/locationBasedEditBuilder.js +153 -0
- package/dist/feature-libraries/default-schema/locationBasedEditBuilder.js.map +1 -0
- package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts +7 -6
- package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/mappedEditBuilder.js +15 -0
- package/dist/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
- package/dist/feature-libraries/deltaUtils.d.ts +1 -0
- package/dist/feature-libraries/deltaUtils.d.ts.map +1 -1
- package/dist/feature-libraries/deltaUtils.js +6 -1
- package/dist/feature-libraries/deltaUtils.js.map +1 -1
- package/dist/feature-libraries/flex-tree/context.d.ts +9 -0
- package/dist/feature-libraries/flex-tree/context.d.ts.map +1 -1
- package/dist/feature-libraries/flex-tree/context.js +6 -0
- package/dist/feature-libraries/flex-tree/context.js.map +1 -1
- package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts +6 -6
- package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
- package/dist/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
- package/dist/feature-libraries/flex-tree/lazyField.d.ts +8 -7
- package/dist/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
- package/dist/feature-libraries/flex-tree/lazyField.js +39 -8
- package/dist/feature-libraries/flex-tree/lazyField.js.map +1 -1
- package/dist/feature-libraries/forest-summary/codec.d.ts.map +1 -1
- package/dist/feature-libraries/forest-summary/codec.js +7 -1
- package/dist/feature-libraries/forest-summary/codec.js.map +1 -1
- package/dist/feature-libraries/forest-summary/formatCommon.d.ts +3 -3
- package/dist/feature-libraries/forest-summary/formatCommon.d.ts.map +1 -1
- package/dist/feature-libraries/forest-summary/formatCommon.js.map +1 -1
- package/dist/feature-libraries/forest-summary/formatV1.d.ts +2 -3
- package/dist/feature-libraries/forest-summary/formatV1.d.ts.map +1 -1
- package/dist/feature-libraries/forest-summary/formatV1.js +1 -2
- package/dist/feature-libraries/forest-summary/formatV1.js.map +1 -1
- package/dist/feature-libraries/forest-summary/formatV2.d.ts +2 -3
- package/dist/feature-libraries/forest-summary/formatV2.d.ts.map +1 -1
- package/dist/feature-libraries/forest-summary/formatV2.js +1 -2
- package/dist/feature-libraries/forest-summary/formatV2.js.map +1 -1
- package/dist/feature-libraries/index.d.ts +3 -3
- package/dist/feature-libraries/index.d.ts.map +1 -1
- package/dist/feature-libraries/index.js +8 -4
- package/dist/feature-libraries/index.js.map +1 -1
- package/dist/feature-libraries/mitigatedChangeFamily.d.ts.map +1 -1
- package/dist/feature-libraries/mitigatedChangeFamily.js +2 -2
- package/dist/feature-libraries/mitigatedChangeFamily.js.map +1 -1
- package/dist/feature-libraries/modular-schema/crossFieldQueries.d.ts +100 -24
- package/dist/feature-libraries/modular-schema/crossFieldQueries.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/crossFieldQueries.js +8 -12
- package/dist/feature-libraries/modular-schema/crossFieldQueries.js.map +1 -1
- package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts +85 -51
- package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
- package/dist/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/genericFieldKind.js +4 -9
- package/dist/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
- package/dist/feature-libraries/modular-schema/index.d.ts +3 -3
- package/dist/feature-libraries/modular-schema/index.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/index.js +2 -3
- package/dist/feature-libraries/modular-schema/index.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecV1.d.ts +20 -24
- package/dist/feature-libraries/modular-schema/modularChangeCodecV1.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecV1.js +277 -159
- package/dist/feature-libraries/modular-schema/modularChangeCodecV1.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecV2.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecV2.js +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecV2.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecV3.d.ts +15 -0
- package/dist/feature-libraries/modular-schema/modularChangeCodecV3.d.ts.map +1 -0
- package/dist/feature-libraries/modular-schema/modularChangeCodecV3.js +296 -0
- package/dist/feature-libraries/modular-schema/modularChangeCodecV3.js.map +1 -0
- package/dist/feature-libraries/modular-schema/modularChangeCodecs.d.ts +1 -0
- package/dist/feature-libraries/modular-schema/modularChangeCodecs.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeCodecs.js +8 -0
- package/dist/feature-libraries/modular-schema/modularChangeCodecs.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts +56 -22
- package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFamily.js +1390 -462
- package/dist/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFormatV1.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFormatV1.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFormatV2.d.ts +1 -2
- package/dist/feature-libraries/modular-schema/modularChangeFormatV2.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFormatV2.js +3 -3
- package/dist/feature-libraries/modular-schema/modularChangeFormatV2.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFormatV3.d.ts +74 -0
- package/dist/feature-libraries/modular-schema/modularChangeFormatV3.d.ts.map +1 -0
- package/dist/feature-libraries/modular-schema/modularChangeFormatV3.js +35 -0
- package/dist/feature-libraries/modular-schema/modularChangeFormatV3.js.map +1 -0
- package/dist/feature-libraries/modular-schema/modularChangeTypes.d.ts +49 -10
- package/dist/feature-libraries/modular-schema/modularChangeTypes.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeTypes.js +3 -3
- package/dist/feature-libraries/modular-schema/modularChangeTypes.js.map +1 -1
- package/dist/feature-libraries/optional-field/optionalField.d.ts +13 -32
- package/dist/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
- package/dist/feature-libraries/optional-field/optionalField.js +257 -446
- package/dist/feature-libraries/optional-field/optionalField.js.map +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts +23 -0
- package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts.map +1 -0
- package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.js +31 -0
- package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.js.map +1 -0
- package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts +31 -31
- package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts.map +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.js.map +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldCodecV2.d.ts +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldCodecV2.d.ts.map +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldCodecV2.js +57 -28
- package/dist/feature-libraries/optional-field/optionalFieldCodecV2.js.map +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldCodecV3.d.ts +12 -0
- package/dist/feature-libraries/optional-field/optionalFieldCodecV3.d.ts.map +1 -0
- package/dist/feature-libraries/optional-field/optionalFieldCodecV3.js +57 -0
- package/dist/feature-libraries/optional-field/optionalFieldCodecV3.js.map +1 -0
- package/dist/feature-libraries/optional-field/optionalFieldCodecs.d.ts.map +1 -1
- package/dist/feature-libraries/optional-field/optionalFieldCodecs.js +5 -1
- package/dist/feature-libraries/optional-field/optionalFieldCodecs.js.map +1 -1
- package/dist/feature-libraries/optional-field/requiredField.d.ts +3 -2
- package/dist/feature-libraries/optional-field/requiredField.d.ts.map +1 -1
- package/dist/feature-libraries/optional-field/requiredField.js +6 -1
- package/dist/feature-libraries/optional-field/requiredField.js.map +1 -1
- package/dist/feature-libraries/schema-index/codec.d.ts.map +1 -1
- package/dist/feature-libraries/schema-index/codec.js +6 -4
- package/dist/feature-libraries/schema-index/codec.js.map +1 -1
- package/dist/feature-libraries/sequence-field/compose.d.ts +6 -7
- package/dist/feature-libraries/sequence-field/compose.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/compose.js +81 -259
- package/dist/feature-libraries/sequence-field/compose.js.map +1 -1
- package/dist/feature-libraries/sequence-field/helperTypes.d.ts +14 -10
- package/dist/feature-libraries/sequence-field/helperTypes.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/helperTypes.js.map +1 -1
- package/dist/feature-libraries/sequence-field/invert.d.ts +3 -3
- package/dist/feature-libraries/sequence-field/invert.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/invert.js +65 -167
- package/dist/feature-libraries/sequence-field/invert.js.map +1 -1
- package/dist/feature-libraries/sequence-field/markQueue.d.ts +2 -2
- package/dist/feature-libraries/sequence-field/markQueue.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/markQueue.js.map +1 -1
- package/dist/feature-libraries/sequence-field/moveEffectTable.d.ts +4 -56
- package/dist/feature-libraries/sequence-field/moveEffectTable.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/moveEffectTable.js +7 -90
- package/dist/feature-libraries/sequence-field/moveEffectTable.js.map +1 -1
- package/dist/feature-libraries/sequence-field/rebase.d.ts +3 -3
- package/dist/feature-libraries/sequence-field/rebase.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/rebase.js +109 -116
- package/dist/feature-libraries/sequence-field/rebase.js.map +1 -1
- package/dist/feature-libraries/sequence-field/replaceRevisions.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/replaceRevisions.js +19 -32
- package/dist/feature-libraries/sequence-field/replaceRevisions.js.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.js +1 -2
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.js.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts +22 -4
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.js +388 -187
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.js.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.js +20 -62
- package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.js.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldEditor.d.ts +2 -2
- package/dist/feature-libraries/sequence-field/sequenceFieldEditor.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldEditor.js +13 -13
- package/dist/feature-libraries/sequence-field/sequenceFieldEditor.js.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts +3 -2
- package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.js +16 -111
- package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.js.map +1 -1
- package/dist/feature-libraries/sequence-field/types.d.ts +37 -74
- package/dist/feature-libraries/sequence-field/types.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/types.js.map +1 -1
- package/dist/feature-libraries/sequence-field/utils.d.ts +20 -25
- package/dist/feature-libraries/sequence-field/utils.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/utils.js +159 -320
- package/dist/feature-libraries/sequence-field/utils.js.map +1 -1
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/dist/legacy.d.ts +1 -0
- package/dist/packageVersion.d.ts +1 -1
- package/dist/packageVersion.d.ts.map +1 -1
- package/dist/packageVersion.js +1 -1
- package/dist/packageVersion.js.map +1 -1
- package/dist/shared-tree/independentView.d.ts.map +1 -1
- package/dist/shared-tree/independentView.js +1 -1
- package/dist/shared-tree/independentView.js.map +1 -1
- package/dist/shared-tree/index.d.ts +1 -1
- package/dist/shared-tree/index.d.ts.map +1 -1
- package/dist/shared-tree/index.js.map +1 -1
- package/dist/shared-tree/schematizeTree.d.ts +4 -4
- package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
- package/dist/shared-tree/schematizeTree.js +2 -1
- package/dist/shared-tree/schematizeTree.js.map +1 -1
- package/dist/shared-tree/schematizingTreeView.d.ts +1 -5
- package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
- package/dist/shared-tree/schematizingTreeView.js +21 -35
- package/dist/shared-tree/schematizingTreeView.js.map +1 -1
- package/dist/shared-tree/sharedTree.d.ts +9 -3
- package/dist/shared-tree/sharedTree.d.ts.map +1 -1
- package/dist/shared-tree/sharedTree.js +4 -1
- package/dist/shared-tree/sharedTree.js.map +1 -1
- package/dist/shared-tree/sharedTreeChangeCodecs.d.ts +1 -0
- package/dist/shared-tree/sharedTreeChangeCodecs.d.ts.map +1 -1
- package/dist/shared-tree/sharedTreeChangeCodecs.js +9 -1
- package/dist/shared-tree/sharedTreeChangeCodecs.js.map +1 -1
- package/dist/shared-tree/sharedTreeChangeFamily.d.ts +4 -4
- package/dist/shared-tree/sharedTreeChangeFamily.d.ts.map +1 -1
- package/dist/shared-tree/sharedTreeChangeFamily.js +2 -2
- package/dist/shared-tree/sharedTreeChangeFamily.js.map +1 -1
- package/dist/shared-tree/sharedTreeEditBuilder.d.ts +16 -6
- package/dist/shared-tree/sharedTreeEditBuilder.d.ts.map +1 -1
- package/dist/shared-tree/sharedTreeEditBuilder.js +14 -7
- package/dist/shared-tree/sharedTreeEditBuilder.js.map +1 -1
- package/dist/shared-tree/tree.d.ts +1 -1
- package/dist/shared-tree/tree.js.map +1 -1
- package/dist/shared-tree/treeAlpha.d.ts +1 -1
- package/dist/shared-tree/treeAlpha.js.map +1 -1
- package/dist/shared-tree/treeCheckout.d.ts +13 -11
- package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
- package/dist/shared-tree/treeCheckout.js +58 -10
- package/dist/shared-tree/treeCheckout.js.map +1 -1
- package/dist/shared-tree-core/branch.d.ts +3 -2
- package/dist/shared-tree-core/branch.d.ts.map +1 -1
- package/dist/shared-tree-core/branch.js +4 -3
- package/dist/shared-tree-core/branch.js.map +1 -1
- package/dist/shared-tree-core/editManager.d.ts +2 -2
- package/dist/shared-tree-core/editManager.d.ts.map +1 -1
- package/dist/shared-tree-core/editManager.js +9 -9
- package/dist/shared-tree-core/editManager.js.map +1 -1
- package/dist/shared-tree-core/editManagerCodecs.d.ts +4 -0
- package/dist/shared-tree-core/editManagerCodecs.d.ts.map +1 -1
- package/dist/shared-tree-core/editManagerCodecs.js +10 -2
- package/dist/shared-tree-core/editManagerCodecs.js.map +1 -1
- package/dist/shared-tree-core/editManagerCodecsCommons.d.ts +3 -3
- package/dist/shared-tree-core/editManagerCodecsCommons.d.ts.map +1 -1
- package/dist/shared-tree-core/editManagerCodecsCommons.js +2 -2
- package/dist/shared-tree-core/editManagerCodecsCommons.js.map +1 -1
- package/dist/shared-tree-core/editManagerCodecsV1toV4.d.ts +2 -2
- package/dist/shared-tree-core/editManagerCodecsV1toV4.d.ts.map +1 -1
- package/dist/shared-tree-core/editManagerCodecsV1toV4.js +1 -1
- package/dist/shared-tree-core/editManagerCodecsV1toV4.js.map +1 -1
- package/dist/shared-tree-core/editManagerCodecsVSharedBranches.d.ts +2 -2
- package/dist/shared-tree-core/editManagerCodecsVSharedBranches.d.ts.map +1 -1
- package/dist/shared-tree-core/editManagerCodecsVSharedBranches.js +1 -1
- package/dist/shared-tree-core/editManagerCodecsVSharedBranches.js.map +1 -1
- package/dist/shared-tree-core/editManagerFormatCommons.d.ts +1 -0
- package/dist/shared-tree-core/editManagerFormatCommons.d.ts.map +1 -1
- package/dist/shared-tree-core/editManagerFormatCommons.js +6 -0
- package/dist/shared-tree-core/editManagerFormatCommons.js.map +1 -1
- package/dist/shared-tree-core/editManagerFormatV1toV4.d.ts +2 -2
- package/dist/shared-tree-core/editManagerFormatV1toV4.d.ts.map +1 -1
- package/dist/shared-tree-core/editManagerFormatV1toV4.js +1 -0
- package/dist/shared-tree-core/editManagerFormatV1toV4.js.map +1 -1
- package/dist/shared-tree-core/index.d.ts +2 -2
- package/dist/shared-tree-core/index.d.ts.map +1 -1
- package/dist/shared-tree-core/index.js +3 -1
- package/dist/shared-tree-core/index.js.map +1 -1
- package/dist/shared-tree-core/messageCodecV1ToV4.d.ts +1 -1
- package/dist/shared-tree-core/messageCodecV1ToV4.d.ts.map +1 -1
- package/dist/shared-tree-core/messageCodecV1ToV4.js.map +1 -1
- package/dist/shared-tree-core/messageCodecs.d.ts +4 -0
- package/dist/shared-tree-core/messageCodecs.d.ts.map +1 -1
- package/dist/shared-tree-core/messageCodecs.js +12 -4
- package/dist/shared-tree-core/messageCodecs.js.map +1 -1
- package/dist/shared-tree-core/messageFormat.d.ts +1 -0
- package/dist/shared-tree-core/messageFormat.d.ts.map +1 -1
- package/dist/shared-tree-core/messageFormat.js +6 -0
- package/dist/shared-tree-core/messageFormat.js.map +1 -1
- package/dist/shared-tree-core/messageFormatV1ToV4.d.ts +2 -2
- package/dist/shared-tree-core/messageFormatV1ToV4.d.ts.map +1 -1
- package/dist/shared-tree-core/messageFormatV1ToV4.js +1 -0
- package/dist/shared-tree-core/messageFormatV1ToV4.js.map +1 -1
- package/dist/shared-tree-core/sharedTreeCore.d.ts +1 -0
- package/dist/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
- package/dist/shared-tree-core/sharedTreeCore.js +1 -1
- package/dist/shared-tree-core/sharedTreeCore.js.map +1 -1
- package/dist/simple-tree/api/index.d.ts +1 -1
- package/dist/simple-tree/api/index.d.ts.map +1 -1
- package/dist/simple-tree/api/index.js +2 -2
- package/dist/simple-tree/api/index.js.map +1 -1
- package/dist/simple-tree/api/snapshotCompatibilityChecker.d.ts +148 -29
- package/dist/simple-tree/api/snapshotCompatibilityChecker.d.ts.map +1 -1
- package/dist/simple-tree/api/snapshotCompatibilityChecker.js +180 -99
- package/dist/simple-tree/api/snapshotCompatibilityChecker.js.map +1 -1
- package/dist/simple-tree/api/tree.d.ts +1 -1
- package/dist/simple-tree/api/tree.js.map +1 -1
- package/dist/simple-tree/api/treeBeta.d.ts +1 -1
- package/dist/simple-tree/api/treeBeta.js.map +1 -1
- package/dist/simple-tree/core/allowedTypes.d.ts +1 -1
- package/dist/simple-tree/core/allowedTypes.js.map +1 -1
- package/dist/simple-tree/core/unhydratedFlexTree.d.ts +17 -12
- package/dist/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
- package/dist/simple-tree/core/unhydratedFlexTree.js +88 -8
- package/dist/simple-tree/core/unhydratedFlexTree.js.map +1 -1
- package/dist/simple-tree/fieldSchema.d.ts +4 -4
- package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
- package/dist/simple-tree/fieldSchema.js.map +1 -1
- package/dist/simple-tree/index.d.ts +3 -3
- package/dist/simple-tree/index.d.ts.map +1 -1
- package/dist/simple-tree/index.js +3 -3
- package/dist/simple-tree/index.js.map +1 -1
- package/dist/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/array/arrayNode.js +9 -16
- package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
- package/dist/simple-tree/node-kinds/common.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/common.js +1 -1
- package/dist/simple-tree/node-kinds/common.js.map +1 -1
- package/dist/simple-tree/node-kinds/map/mapNode.js +2 -2
- package/dist/simple-tree/node-kinds/map/mapNode.js.map +1 -1
- package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/object/objectNode.js +19 -19
- package/dist/simple-tree/node-kinds/object/objectNode.js.map +1 -1
- package/dist/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/record/recordNode.js +4 -2
- package/dist/simple-tree/node-kinds/record/recordNode.js.map +1 -1
- package/dist/simple-tree/prepareForInsertion.d.ts +54 -47
- package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
- package/dist/simple-tree/prepareForInsertion.js +183 -125
- package/dist/simple-tree/prepareForInsertion.js.map +1 -1
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +8 -3
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js +59 -19
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
- package/dist/text/textDomainFormatted.d.ts +3 -3
- package/dist/text/textDomainFormatted.d.ts.map +1 -1
- package/dist/text/textDomainFormatted.js +48 -32
- package/dist/text/textDomainFormatted.js.map +1 -1
- package/dist/treeFactory.d.ts.map +1 -1
- package/dist/treeFactory.js +12 -2
- package/dist/treeFactory.js.map +1 -1
- package/dist/util/bTreeUtils.d.ts.map +1 -1
- package/dist/util/bTreeUtils.js +6 -6
- package/dist/util/bTreeUtils.js.map +1 -1
- package/dist/util/index.d.ts +1 -1
- package/dist/util/index.d.ts.map +1 -1
- package/dist/util/index.js +2 -1
- package/dist/util/index.js.map +1 -1
- package/dist/util/rangeMap.d.ts +23 -11
- package/dist/util/rangeMap.d.ts.map +1 -1
- package/dist/util/rangeMap.js +42 -10
- package/dist/util/rangeMap.js.map +1 -1
- package/lib/alpha.d.ts +3 -3
- package/lib/beta.d.ts +1 -0
- package/lib/codec/codec.d.ts +3 -39
- package/lib/codec/codec.d.ts.map +1 -1
- package/lib/codec/codec.js +4 -47
- package/lib/codec/codec.js.map +1 -1
- package/lib/codec/index.d.ts +1 -1
- package/lib/codec/index.d.ts.map +1 -1
- package/lib/codec/index.js +1 -1
- package/lib/codec/index.js.map +1 -1
- package/lib/codec/versioned/codec.d.ts +20 -7
- package/lib/codec/versioned/codec.d.ts.map +1 -1
- package/lib/codec/versioned/codec.js +59 -33
- package/lib/codec/versioned/codec.js.map +1 -1
- package/lib/core/change-family/changeFamily.d.ts +4 -1
- package/lib/core/change-family/changeFamily.d.ts.map +1 -1
- package/lib/core/change-family/changeFamily.js.map +1 -1
- package/lib/core/change-family/index.d.ts +1 -1
- package/lib/core/change-family/index.d.ts.map +1 -1
- package/lib/core/change-family/index.js.map +1 -1
- package/lib/core/index.d.ts +3 -3
- package/lib/core/index.d.ts.map +1 -1
- package/lib/core/index.js +2 -2
- package/lib/core/index.js.map +1 -1
- package/lib/core/rebase/changeRebaser.d.ts +6 -1
- package/lib/core/rebase/changeRebaser.d.ts.map +1 -1
- package/lib/core/rebase/changeRebaser.js.map +1 -1
- package/lib/core/rebase/index.d.ts +1 -1
- package/lib/core/rebase/index.d.ts.map +1 -1
- package/lib/core/rebase/index.js +1 -1
- package/lib/core/rebase/index.js.map +1 -1
- package/lib/core/rebase/types.d.ts +1 -0
- package/lib/core/rebase/types.d.ts.map +1 -1
- package/lib/core/rebase/types.js +3 -0
- package/lib/core/rebase/types.js.map +1 -1
- package/lib/core/rebase/utils.d.ts.map +1 -1
- package/lib/core/rebase/utils.js +25 -7
- package/lib/core/rebase/utils.js.map +1 -1
- package/lib/core/tree/delta.d.ts +5 -0
- package/lib/core/tree/delta.d.ts.map +1 -1
- package/lib/core/tree/delta.js.map +1 -1
- package/lib/core/tree/detachedFieldIndex.d.ts +13 -1
- package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
- package/lib/core/tree/detachedFieldIndex.js +15 -2
- package/lib/core/tree/detachedFieldIndex.js.map +1 -1
- package/lib/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -1
- package/lib/core/tree/detachedFieldIndexCodecs.js +6 -4
- package/lib/core/tree/detachedFieldIndexCodecs.js.map +1 -1
- package/lib/core/tree/detachedFieldIndexTypes.d.ts +4 -0
- package/lib/core/tree/detachedFieldIndexTypes.d.ts.map +1 -1
- package/lib/core/tree/detachedFieldIndexTypes.js.map +1 -1
- package/lib/core/tree/index.d.ts +2 -2
- package/lib/core/tree/index.d.ts.map +1 -1
- package/lib/core/tree/index.js +1 -1
- package/lib/core/tree/index.js.map +1 -1
- package/lib/core/tree/pathTree.d.ts +11 -3
- package/lib/core/tree/pathTree.d.ts.map +1 -1
- package/lib/core/tree/pathTree.js +12 -1
- package/lib/core/tree/pathTree.js.map +1 -1
- package/lib/core/tree/visitDelta.d.ts.map +1 -1
- package/lib/core/tree/visitDelta.js +17 -13
- package/lib/core/tree/visitDelta.js.map +1 -1
- package/lib/extensibleUnionNode.d.ts +97 -0
- package/lib/extensibleUnionNode.d.ts.map +1 -0
- package/lib/{extensibleSchemaUnion.js → extensibleUnionNode.js} +28 -18
- package/lib/extensibleUnionNode.js.map +1 -0
- package/lib/feature-libraries/changeAtomIdBTree.d.ts +3 -2
- package/lib/feature-libraries/changeAtomIdBTree.d.ts.map +1 -1
- package/lib/feature-libraries/changeAtomIdBTree.js +15 -3
- package/lib/feature-libraries/changeAtomIdBTree.js.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/codecs.d.ts +1 -1
- package/lib/feature-libraries/chunked-forest/codec/codecs.d.ts.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/codecs.js +5 -5
- package/lib/feature-libraries/chunked-forest/codec/codecs.js.map +1 -1
- package/lib/feature-libraries/default-schema/defaultEditBuilder.d.ts +92 -44
- package/lib/feature-libraries/default-schema/defaultEditBuilder.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/defaultEditBuilder.js +217 -69
- package/lib/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
- package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/defaultFieldKinds.js +12 -2
- package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
- package/lib/feature-libraries/default-schema/index.d.ts +2 -1
- package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/index.js +2 -1
- package/lib/feature-libraries/default-schema/index.js.map +1 -1
- package/lib/feature-libraries/default-schema/locationBasedEditBuilder.d.ts +40 -0
- package/lib/feature-libraries/default-schema/locationBasedEditBuilder.d.ts.map +1 -0
- package/lib/feature-libraries/default-schema/locationBasedEditBuilder.js +149 -0
- package/lib/feature-libraries/default-schema/locationBasedEditBuilder.js.map +1 -0
- package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts +7 -6
- package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/mappedEditBuilder.js +15 -0
- package/lib/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
- package/lib/feature-libraries/deltaUtils.d.ts +1 -0
- package/lib/feature-libraries/deltaUtils.d.ts.map +1 -1
- package/lib/feature-libraries/deltaUtils.js +5 -1
- package/lib/feature-libraries/deltaUtils.js.map +1 -1
- package/lib/feature-libraries/flex-tree/context.d.ts +9 -0
- package/lib/feature-libraries/flex-tree/context.d.ts.map +1 -1
- package/lib/feature-libraries/flex-tree/context.js +6 -0
- package/lib/feature-libraries/flex-tree/context.js.map +1 -1
- package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts +6 -6
- package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
- package/lib/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
- package/lib/feature-libraries/flex-tree/lazyField.d.ts +8 -7
- package/lib/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
- package/lib/feature-libraries/flex-tree/lazyField.js +40 -9
- package/lib/feature-libraries/flex-tree/lazyField.js.map +1 -1
- package/lib/feature-libraries/forest-summary/codec.d.ts.map +1 -1
- package/lib/feature-libraries/forest-summary/codec.js +8 -2
- package/lib/feature-libraries/forest-summary/codec.js.map +1 -1
- package/lib/feature-libraries/forest-summary/formatCommon.d.ts +3 -3
- package/lib/feature-libraries/forest-summary/formatCommon.d.ts.map +1 -1
- package/lib/feature-libraries/forest-summary/formatCommon.js.map +1 -1
- package/lib/feature-libraries/forest-summary/formatV1.d.ts +2 -3
- package/lib/feature-libraries/forest-summary/formatV1.d.ts.map +1 -1
- package/lib/feature-libraries/forest-summary/formatV1.js +1 -2
- package/lib/feature-libraries/forest-summary/formatV1.js.map +1 -1
- package/lib/feature-libraries/forest-summary/formatV2.d.ts +2 -3
- package/lib/feature-libraries/forest-summary/formatV2.d.ts.map +1 -1
- package/lib/feature-libraries/forest-summary/formatV2.js +1 -2
- package/lib/feature-libraries/forest-summary/formatV2.js.map +1 -1
- package/lib/feature-libraries/index.d.ts +3 -3
- package/lib/feature-libraries/index.d.ts.map +1 -1
- package/lib/feature-libraries/index.js +3 -3
- package/lib/feature-libraries/index.js.map +1 -1
- package/lib/feature-libraries/mitigatedChangeFamily.d.ts.map +1 -1
- package/lib/feature-libraries/mitigatedChangeFamily.js +2 -2
- package/lib/feature-libraries/mitigatedChangeFamily.js.map +1 -1
- package/lib/feature-libraries/modular-schema/crossFieldQueries.d.ts +100 -24
- package/lib/feature-libraries/modular-schema/crossFieldQueries.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/crossFieldQueries.js +7 -10
- package/lib/feature-libraries/modular-schema/crossFieldQueries.js.map +1 -1
- package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts +85 -51
- package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
- package/lib/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/genericFieldKind.js +4 -9
- package/lib/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
- package/lib/feature-libraries/modular-schema/index.d.ts +3 -3
- package/lib/feature-libraries/modular-schema/index.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/index.js +1 -1
- package/lib/feature-libraries/modular-schema/index.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecV1.d.ts +20 -24
- package/lib/feature-libraries/modular-schema/modularChangeCodecV1.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecV1.js +268 -145
- package/lib/feature-libraries/modular-schema/modularChangeCodecV1.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecV2.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecV2.js +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecV2.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecV3.d.ts +15 -0
- package/lib/feature-libraries/modular-schema/modularChangeCodecV3.d.ts.map +1 -0
- package/lib/feature-libraries/modular-schema/modularChangeCodecV3.js +292 -0
- package/lib/feature-libraries/modular-schema/modularChangeCodecV3.js.map +1 -0
- package/lib/feature-libraries/modular-schema/modularChangeCodecs.d.ts +1 -0
- package/lib/feature-libraries/modular-schema/modularChangeCodecs.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeCodecs.js +8 -0
- package/lib/feature-libraries/modular-schema/modularChangeCodecs.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts +56 -22
- package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFamily.js +1387 -468
- package/lib/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormatV1.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormatV1.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormatV2.d.ts +1 -2
- package/lib/feature-libraries/modular-schema/modularChangeFormatV2.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormatV2.js +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormatV2.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormatV3.d.ts +74 -0
- package/lib/feature-libraries/modular-schema/modularChangeFormatV3.d.ts.map +1 -0
- package/lib/feature-libraries/modular-schema/modularChangeFormatV3.js +32 -0
- package/lib/feature-libraries/modular-schema/modularChangeFormatV3.js.map +1 -0
- package/lib/feature-libraries/modular-schema/modularChangeTypes.d.ts +49 -10
- package/lib/feature-libraries/modular-schema/modularChangeTypes.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeTypes.js +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeTypes.js.map +1 -1
- package/lib/feature-libraries/optional-field/optionalField.d.ts +13 -32
- package/lib/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
- package/lib/feature-libraries/optional-field/optionalField.js +254 -442
- package/lib/feature-libraries/optional-field/optionalField.js.map +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts +23 -0
- package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts.map +1 -0
- package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.js +27 -0
- package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.js.map +1 -0
- package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts +31 -31
- package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts.map +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.js.map +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldCodecV2.d.ts +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldCodecV2.d.ts.map +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldCodecV2.js +55 -26
- package/lib/feature-libraries/optional-field/optionalFieldCodecV2.js.map +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldCodecV3.d.ts +12 -0
- package/lib/feature-libraries/optional-field/optionalFieldCodecV3.d.ts.map +1 -0
- package/lib/feature-libraries/optional-field/optionalFieldCodecV3.js +53 -0
- package/lib/feature-libraries/optional-field/optionalFieldCodecV3.js.map +1 -0
- package/lib/feature-libraries/optional-field/optionalFieldCodecs.d.ts.map +1 -1
- package/lib/feature-libraries/optional-field/optionalFieldCodecs.js +5 -1
- package/lib/feature-libraries/optional-field/optionalFieldCodecs.js.map +1 -1
- package/lib/feature-libraries/optional-field/requiredField.d.ts +3 -2
- package/lib/feature-libraries/optional-field/requiredField.d.ts.map +1 -1
- package/lib/feature-libraries/optional-field/requiredField.js +5 -1
- package/lib/feature-libraries/optional-field/requiredField.js.map +1 -1
- package/lib/feature-libraries/schema-index/codec.d.ts.map +1 -1
- package/lib/feature-libraries/schema-index/codec.js +6 -4
- package/lib/feature-libraries/schema-index/codec.js.map +1 -1
- package/lib/feature-libraries/sequence-field/compose.d.ts +6 -7
- package/lib/feature-libraries/sequence-field/compose.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/compose.js +83 -261
- package/lib/feature-libraries/sequence-field/compose.js.map +1 -1
- package/lib/feature-libraries/sequence-field/helperTypes.d.ts +14 -10
- package/lib/feature-libraries/sequence-field/helperTypes.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/helperTypes.js.map +1 -1
- package/lib/feature-libraries/sequence-field/invert.d.ts +3 -3
- package/lib/feature-libraries/sequence-field/invert.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/invert.js +67 -169
- package/lib/feature-libraries/sequence-field/invert.js.map +1 -1
- package/lib/feature-libraries/sequence-field/markQueue.d.ts +2 -2
- package/lib/feature-libraries/sequence-field/markQueue.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/markQueue.js.map +1 -1
- package/lib/feature-libraries/sequence-field/moveEffectTable.d.ts +4 -56
- package/lib/feature-libraries/sequence-field/moveEffectTable.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/moveEffectTable.js +6 -84
- package/lib/feature-libraries/sequence-field/moveEffectTable.js.map +1 -1
- package/lib/feature-libraries/sequence-field/rebase.d.ts +3 -3
- package/lib/feature-libraries/sequence-field/rebase.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/rebase.js +111 -118
- package/lib/feature-libraries/sequence-field/rebase.js.map +1 -1
- package/lib/feature-libraries/sequence-field/replaceRevisions.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/replaceRevisions.js +19 -32
- package/lib/feature-libraries/sequence-field/replaceRevisions.js.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.js +2 -3
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.js.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts +22 -4
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.js +379 -182
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.js.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.js +21 -63
- package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.js.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldEditor.d.ts +2 -2
- package/lib/feature-libraries/sequence-field/sequenceFieldEditor.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldEditor.js +13 -13
- package/lib/feature-libraries/sequence-field/sequenceFieldEditor.js.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts +3 -2
- package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.js +16 -111
- package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.js.map +1 -1
- package/lib/feature-libraries/sequence-field/types.d.ts +37 -74
- package/lib/feature-libraries/sequence-field/types.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/types.js.map +1 -1
- package/lib/feature-libraries/sequence-field/utils.d.ts +20 -25
- package/lib/feature-libraries/sequence-field/utils.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/utils.js +155 -313
- package/lib/feature-libraries/sequence-field/utils.js.map +1 -1
- package/lib/index.d.ts +2 -2
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/legacy.d.ts +1 -0
- package/lib/packageVersion.d.ts +1 -1
- package/lib/packageVersion.d.ts.map +1 -1
- package/lib/packageVersion.js +1 -1
- package/lib/packageVersion.js.map +1 -1
- package/lib/shared-tree/independentView.d.ts.map +1 -1
- package/lib/shared-tree/independentView.js +1 -1
- package/lib/shared-tree/independentView.js.map +1 -1
- package/lib/shared-tree/index.d.ts +1 -1
- package/lib/shared-tree/index.d.ts.map +1 -1
- package/lib/shared-tree/index.js.map +1 -1
- package/lib/shared-tree/schematizeTree.d.ts +4 -4
- package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
- package/lib/shared-tree/schematizeTree.js +3 -2
- package/lib/shared-tree/schematizeTree.js.map +1 -1
- package/lib/shared-tree/schematizingTreeView.d.ts +1 -5
- package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
- package/lib/shared-tree/schematizingTreeView.js +24 -38
- package/lib/shared-tree/schematizingTreeView.js.map +1 -1
- package/lib/shared-tree/sharedTree.d.ts +9 -3
- package/lib/shared-tree/sharedTree.d.ts.map +1 -1
- package/lib/shared-tree/sharedTree.js +4 -1
- package/lib/shared-tree/sharedTree.js.map +1 -1
- package/lib/shared-tree/sharedTreeChangeCodecs.d.ts +1 -0
- package/lib/shared-tree/sharedTreeChangeCodecs.d.ts.map +1 -1
- package/lib/shared-tree/sharedTreeChangeCodecs.js +9 -1
- package/lib/shared-tree/sharedTreeChangeCodecs.js.map +1 -1
- package/lib/shared-tree/sharedTreeChangeFamily.d.ts +4 -4
- package/lib/shared-tree/sharedTreeChangeFamily.d.ts.map +1 -1
- package/lib/shared-tree/sharedTreeChangeFamily.js +3 -3
- package/lib/shared-tree/sharedTreeChangeFamily.js.map +1 -1
- package/lib/shared-tree/sharedTreeEditBuilder.d.ts +16 -6
- package/lib/shared-tree/sharedTreeEditBuilder.d.ts.map +1 -1
- package/lib/shared-tree/sharedTreeEditBuilder.js +12 -6
- package/lib/shared-tree/sharedTreeEditBuilder.js.map +1 -1
- package/lib/shared-tree/tree.d.ts +1 -1
- package/lib/shared-tree/tree.js.map +1 -1
- package/lib/shared-tree/treeAlpha.d.ts +1 -1
- package/lib/shared-tree/treeAlpha.js.map +1 -1
- package/lib/shared-tree/treeCheckout.d.ts +13 -11
- package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
- package/lib/shared-tree/treeCheckout.js +61 -13
- package/lib/shared-tree/treeCheckout.js.map +1 -1
- package/lib/shared-tree-core/branch.d.ts +3 -2
- package/lib/shared-tree-core/branch.d.ts.map +1 -1
- package/lib/shared-tree-core/branch.js +4 -3
- package/lib/shared-tree-core/branch.js.map +1 -1
- package/lib/shared-tree-core/editManager.d.ts +2 -2
- package/lib/shared-tree-core/editManager.d.ts.map +1 -1
- package/lib/shared-tree-core/editManager.js +9 -9
- package/lib/shared-tree-core/editManager.js.map +1 -1
- package/lib/shared-tree-core/editManagerCodecs.d.ts +4 -0
- package/lib/shared-tree-core/editManagerCodecs.d.ts.map +1 -1
- package/lib/shared-tree-core/editManagerCodecs.js +8 -1
- package/lib/shared-tree-core/editManagerCodecs.js.map +1 -1
- package/lib/shared-tree-core/editManagerCodecsCommons.d.ts +3 -3
- package/lib/shared-tree-core/editManagerCodecsCommons.d.ts.map +1 -1
- package/lib/shared-tree-core/editManagerCodecsCommons.js +2 -2
- package/lib/shared-tree-core/editManagerCodecsCommons.js.map +1 -1
- package/lib/shared-tree-core/editManagerCodecsV1toV4.d.ts +2 -2
- package/lib/shared-tree-core/editManagerCodecsV1toV4.d.ts.map +1 -1
- package/lib/shared-tree-core/editManagerCodecsV1toV4.js +2 -2
- package/lib/shared-tree-core/editManagerCodecsV1toV4.js.map +1 -1
- package/lib/shared-tree-core/editManagerCodecsVSharedBranches.d.ts +2 -2
- package/lib/shared-tree-core/editManagerCodecsVSharedBranches.d.ts.map +1 -1
- package/lib/shared-tree-core/editManagerCodecsVSharedBranches.js +2 -2
- package/lib/shared-tree-core/editManagerCodecsVSharedBranches.js.map +1 -1
- package/lib/shared-tree-core/editManagerFormatCommons.d.ts +1 -0
- package/lib/shared-tree-core/editManagerFormatCommons.d.ts.map +1 -1
- package/lib/shared-tree-core/editManagerFormatCommons.js +6 -0
- package/lib/shared-tree-core/editManagerFormatCommons.js.map +1 -1
- package/lib/shared-tree-core/editManagerFormatV1toV4.d.ts +2 -2
- package/lib/shared-tree-core/editManagerFormatV1toV4.d.ts.map +1 -1
- package/lib/shared-tree-core/editManagerFormatV1toV4.js +1 -0
- package/lib/shared-tree-core/editManagerFormatV1toV4.js.map +1 -1
- package/lib/shared-tree-core/index.d.ts +2 -2
- package/lib/shared-tree-core/index.d.ts.map +1 -1
- package/lib/shared-tree-core/index.js +2 -2
- package/lib/shared-tree-core/index.js.map +1 -1
- package/lib/shared-tree-core/messageCodecV1ToV4.d.ts +1 -1
- package/lib/shared-tree-core/messageCodecV1ToV4.d.ts.map +1 -1
- package/lib/shared-tree-core/messageCodecV1ToV4.js.map +1 -1
- package/lib/shared-tree-core/messageCodecs.d.ts +4 -0
- package/lib/shared-tree-core/messageCodecs.d.ts.map +1 -1
- package/lib/shared-tree-core/messageCodecs.js +10 -3
- package/lib/shared-tree-core/messageCodecs.js.map +1 -1
- package/lib/shared-tree-core/messageFormat.d.ts +1 -0
- package/lib/shared-tree-core/messageFormat.d.ts.map +1 -1
- package/lib/shared-tree-core/messageFormat.js +6 -0
- package/lib/shared-tree-core/messageFormat.js.map +1 -1
- package/lib/shared-tree-core/messageFormatV1ToV4.d.ts +2 -2
- package/lib/shared-tree-core/messageFormatV1ToV4.d.ts.map +1 -1
- package/lib/shared-tree-core/messageFormatV1ToV4.js +1 -0
- package/lib/shared-tree-core/messageFormatV1ToV4.js.map +1 -1
- package/lib/shared-tree-core/sharedTreeCore.d.ts +1 -0
- package/lib/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
- package/lib/shared-tree-core/sharedTreeCore.js +1 -1
- package/lib/shared-tree-core/sharedTreeCore.js.map +1 -1
- package/lib/simple-tree/api/index.d.ts +1 -1
- package/lib/simple-tree/api/index.d.ts.map +1 -1
- package/lib/simple-tree/api/index.js +1 -1
- package/lib/simple-tree/api/index.js.map +1 -1
- package/lib/simple-tree/api/snapshotCompatibilityChecker.d.ts +148 -29
- package/lib/simple-tree/api/snapshotCompatibilityChecker.d.ts.map +1 -1
- package/lib/simple-tree/api/snapshotCompatibilityChecker.js +179 -98
- package/lib/simple-tree/api/snapshotCompatibilityChecker.js.map +1 -1
- package/lib/simple-tree/api/tree.d.ts +1 -1
- package/lib/simple-tree/api/tree.js.map +1 -1
- package/lib/simple-tree/api/treeBeta.d.ts +1 -1
- package/lib/simple-tree/api/treeBeta.js.map +1 -1
- package/lib/simple-tree/core/allowedTypes.d.ts +1 -1
- package/lib/simple-tree/core/allowedTypes.js.map +1 -1
- package/lib/simple-tree/core/unhydratedFlexTree.d.ts +17 -12
- package/lib/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
- package/lib/simple-tree/core/unhydratedFlexTree.js +87 -8
- package/lib/simple-tree/core/unhydratedFlexTree.js.map +1 -1
- package/lib/simple-tree/fieldSchema.d.ts +4 -4
- package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
- package/lib/simple-tree/fieldSchema.js.map +1 -1
- package/lib/simple-tree/index.d.ts +3 -3
- package/lib/simple-tree/index.d.ts.map +1 -1
- package/lib/simple-tree/index.js +2 -2
- package/lib/simple-tree/index.js.map +1 -1
- package/lib/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/array/arrayNode.js +11 -18
- package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
- package/lib/simple-tree/node-kinds/common.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/common.js +2 -2
- package/lib/simple-tree/node-kinds/common.js.map +1 -1
- package/lib/simple-tree/node-kinds/map/mapNode.js +2 -2
- package/lib/simple-tree/node-kinds/map/mapNode.js.map +1 -1
- package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/object/objectNode.js +20 -20
- package/lib/simple-tree/node-kinds/object/objectNode.js.map +1 -1
- package/lib/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/record/recordNode.js +4 -2
- package/lib/simple-tree/node-kinds/record/recordNode.js.map +1 -1
- package/lib/simple-tree/prepareForInsertion.d.ts +54 -47
- package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
- package/lib/simple-tree/prepareForInsertion.js +184 -125
- package/lib/simple-tree/prepareForInsertion.js.map +1 -1
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +8 -3
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +56 -17
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
- package/lib/text/textDomainFormatted.d.ts +3 -3
- package/lib/text/textDomainFormatted.d.ts.map +1 -1
- package/lib/text/textDomainFormatted.js +30 -14
- package/lib/text/textDomainFormatted.js.map +1 -1
- package/lib/treeFactory.d.ts.map +1 -1
- package/lib/treeFactory.js +13 -3
- package/lib/treeFactory.js.map +1 -1
- package/lib/util/bTreeUtils.d.ts.map +1 -1
- package/lib/util/bTreeUtils.js +6 -6
- package/lib/util/bTreeUtils.js.map +1 -1
- package/lib/util/index.d.ts +1 -1
- package/lib/util/index.d.ts.map +1 -1
- package/lib/util/index.js +1 -1
- package/lib/util/index.js.map +1 -1
- package/lib/util/rangeMap.d.ts +23 -11
- package/lib/util/rangeMap.d.ts.map +1 -1
- package/lib/util/rangeMap.js +40 -9
- package/lib/util/rangeMap.js.map +1 -1
- package/package.json +23 -23
- package/src/codec/codec.ts +10 -112
- package/src/codec/index.ts +0 -3
- package/src/codec/versioned/codec.ts +119 -83
- package/src/core/change-family/changeFamily.ts +5 -0
- package/src/core/change-family/index.ts +1 -0
- package/src/core/index.ts +4 -1
- package/src/core/rebase/changeRebaser.ts +6 -1
- package/src/core/rebase/index.ts +1 -0
- package/src/core/rebase/types.ts +4 -0
- package/src/core/rebase/utils.ts +31 -7
- package/src/core/tree/delta.ts +6 -0
- package/src/core/tree/detachedFieldIndex.ts +29 -1
- package/src/core/tree/detachedFieldIndexCodecs.ts +6 -4
- package/src/core/tree/detachedFieldIndexTypes.ts +5 -0
- package/src/core/tree/index.ts +13 -12
- package/src/core/tree/pathTree.ts +16 -4
- package/src/core/tree/visitDelta.ts +31 -11
- package/src/{extensibleSchemaUnion.ts → extensibleUnionNode.ts} +61 -19
- package/src/feature-libraries/changeAtomIdBTree.ts +28 -3
- package/src/feature-libraries/chunked-forest/codec/codecs.ts +5 -11
- package/src/feature-libraries/default-schema/defaultEditBuilder.ts +369 -127
- package/src/feature-libraries/default-schema/defaultFieldKinds.ts +13 -4
- package/src/feature-libraries/default-schema/index.ts +16 -5
- package/src/feature-libraries/default-schema/locationBasedEditBuilder.ts +231 -0
- package/src/feature-libraries/default-schema/mappedEditBuilder.ts +35 -9
- package/src/feature-libraries/deltaUtils.ts +6 -1
- package/src/feature-libraries/flex-tree/context.ts +17 -0
- package/src/feature-libraries/flex-tree/flexTreeTypes.ts +7 -8
- package/src/feature-libraries/flex-tree/lazyField.ts +65 -24
- package/src/feature-libraries/forest-summary/codec.ts +8 -7
- package/src/feature-libraries/forest-summary/formatCommon.ts +5 -3
- package/src/feature-libraries/forest-summary/formatV1.ts +1 -3
- package/src/feature-libraries/forest-summary/formatV2.ts +1 -3
- package/src/feature-libraries/index.ts +22 -9
- package/src/feature-libraries/mitigatedChangeFamily.ts +3 -1
- package/src/feature-libraries/modular-schema/crossFieldQueries.ts +144 -47
- package/src/feature-libraries/modular-schema/fieldChangeHandler.ts +113 -58
- package/src/feature-libraries/modular-schema/genericFieldKind.ts +7 -18
- package/src/feature-libraries/modular-schema/index.ts +16 -16
- package/src/feature-libraries/modular-schema/modularChangeCodecV1.ts +626 -352
- package/src/feature-libraries/modular-schema/modularChangeCodecV2.ts +1 -0
- package/src/feature-libraries/modular-schema/modularChangeCodecV3.ts +649 -0
- package/src/feature-libraries/modular-schema/modularChangeCodecs.ts +14 -0
- package/src/feature-libraries/modular-schema/modularChangeFamily.ts +2694 -748
- package/src/feature-libraries/modular-schema/modularChangeFormatV1.ts +1 -0
- package/src/feature-libraries/modular-schema/modularChangeFormatV2.ts +1 -1
- package/src/feature-libraries/modular-schema/modularChangeFormatV3.ts +67 -0
- package/src/feature-libraries/modular-schema/modularChangeTypes.ts +62 -10
- package/src/feature-libraries/optional-field/optionalField.ts +359 -568
- package/src/feature-libraries/optional-field/optionalFieldChangeFormatV3.ts +45 -0
- package/src/feature-libraries/optional-field/optionalFieldChangeTypes.ts +31 -35
- package/src/feature-libraries/optional-field/optionalFieldCodecV2.ts +89 -35
- package/src/feature-libraries/optional-field/optionalFieldCodecV3.ts +94 -0
- package/src/feature-libraries/optional-field/optionalFieldCodecs.ts +5 -1
- package/src/feature-libraries/optional-field/requiredField.ts +15 -2
- package/src/feature-libraries/schema-index/codec.ts +6 -4
- package/src/feature-libraries/sequence-field/compose.ts +137 -522
- package/src/feature-libraries/sequence-field/helperTypes.ts +34 -19
- package/src/feature-libraries/sequence-field/invert.ts +102 -228
- package/src/feature-libraries/sequence-field/markQueue.ts +2 -2
- package/src/feature-libraries/sequence-field/moveEffectTable.ts +8 -195
- package/src/feature-libraries/sequence-field/rebase.ts +171 -207
- package/src/feature-libraries/sequence-field/replaceRevisions.ts +26 -52
- package/src/feature-libraries/sequence-field/sequenceFieldChangeHandler.ts +8 -3
- package/src/feature-libraries/sequence-field/sequenceFieldCodecV2.ts +677 -229
- package/src/feature-libraries/sequence-field/sequenceFieldCodecV3.ts +56 -70
- package/src/feature-libraries/sequence-field/sequenceFieldEditor.ts +28 -30
- package/src/feature-libraries/sequence-field/sequenceFieldToDelta.ts +21 -131
- package/src/feature-libraries/sequence-field/types.ts +40 -79
- package/src/feature-libraries/sequence-field/utils.ts +211 -370
- package/src/index.ts +3 -3
- package/src/packageVersion.ts +1 -1
- package/src/shared-tree/independentView.ts +12 -6
- package/src/shared-tree/index.ts +3 -2
- package/src/shared-tree/schematizeTree.ts +21 -8
- package/src/shared-tree/schematizingTreeView.ts +38 -68
- package/src/shared-tree/sharedTree.ts +30 -15
- package/src/shared-tree/sharedTreeChangeCodecs.ts +10 -2
- package/src/shared-tree/sharedTreeChangeFamily.ts +7 -4
- package/src/shared-tree/sharedTreeEditBuilder.ts +43 -8
- package/src/shared-tree/tree.ts +1 -1
- package/src/shared-tree/treeAlpha.ts +1 -1
- package/src/shared-tree/treeCheckout.ts +95 -21
- package/src/shared-tree-core/branch.ts +8 -2
- package/src/shared-tree-core/editManager.ts +16 -2
- package/src/shared-tree-core/editManagerCodecs.ts +11 -1
- package/src/shared-tree-core/editManagerCodecsCommons.ts +7 -7
- package/src/shared-tree-core/editManagerCodecsV1toV4.ts +3 -10
- package/src/shared-tree-core/editManagerCodecsVSharedBranches.ts +3 -10
- package/src/shared-tree-core/editManagerFormatCommons.ts +6 -0
- package/src/shared-tree-core/editManagerFormatV1toV4.ts +3 -1
- package/src/shared-tree-core/index.ts +2 -0
- package/src/shared-tree-core/messageCodecV1ToV4.ts +2 -1
- package/src/shared-tree-core/messageCodecs.ts +13 -7
- package/src/shared-tree-core/messageFormat.ts +6 -0
- package/src/shared-tree-core/messageFormatV1ToV4.ts +3 -1
- package/src/shared-tree-core/sharedTreeCore.ts +4 -1
- package/src/simple-tree/api/index.ts +2 -2
- package/src/simple-tree/api/snapshotCompatibilityChecker.ts +344 -142
- package/src/simple-tree/api/tree.ts +1 -1
- package/src/simple-tree/api/treeBeta.ts +1 -1
- package/src/simple-tree/core/allowedTypes.ts +1 -1
- package/src/simple-tree/core/unhydratedFlexTree.ts +124 -35
- package/src/simple-tree/fieldSchema.ts +6 -4
- package/src/simple-tree/index.ts +4 -3
- package/src/simple-tree/node-kinds/array/arrayNode.ts +20 -24
- package/src/simple-tree/node-kinds/common.ts +2 -5
- package/src/simple-tree/node-kinds/map/mapNode.ts +4 -4
- package/src/simple-tree/node-kinds/object/objectNode.ts +26 -26
- package/src/simple-tree/node-kinds/record/recordNode.ts +10 -9
- package/src/simple-tree/prepareForInsertion.ts +342 -200
- package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +83 -22
- package/src/text/textDomainFormatted.ts +37 -17
- package/src/treeFactory.ts +16 -4
- package/src/util/bTreeUtils.ts +10 -6
- package/src/util/index.ts +3 -0
- package/src/util/rangeMap.ts +67 -22
- package/api-extractor-lint.json +0 -4
- package/dist/extensibleSchemaUnion.d.ts +0 -72
- package/dist/extensibleSchemaUnion.d.ts.map +0 -1
- package/dist/extensibleSchemaUnion.js.map +0 -1
- package/dist/feature-libraries/sequence-field/relevantRemovedRoots.d.ts +0 -9
- package/dist/feature-libraries/sequence-field/relevantRemovedRoots.d.ts.map +0 -1
- package/dist/feature-libraries/sequence-field/relevantRemovedRoots.js +0 -50
- package/dist/feature-libraries/sequence-field/relevantRemovedRoots.js.map +0 -1
- package/docs/main/sequence-field/move-composition.md +0 -46
- package/lib/extensibleSchemaUnion.d.ts +0 -72
- package/lib/extensibleSchemaUnion.d.ts.map +0 -1
- package/lib/extensibleSchemaUnion.js.map +0 -1
- package/lib/feature-libraries/sequence-field/relevantRemovedRoots.d.ts +0 -9
- package/lib/feature-libraries/sequence-field/relevantRemovedRoots.d.ts.map +0 -1
- package/lib/feature-libraries/sequence-field/relevantRemovedRoots.js +0 -46
- package/lib/feature-libraries/sequence-field/relevantRemovedRoots.js.map +0 -1
- package/src/feature-libraries/sequence-field/relevantRemovedRoots.ts +0 -57
|
@@ -9,6 +9,7 @@ import {
|
|
|
9
9
|
getConfigForMinVersionForCollab,
|
|
10
10
|
lowestMinVersionForCollab,
|
|
11
11
|
} from "@fluidframework/runtime-utils/internal";
|
|
12
|
+
import { Type } from "@sinclair/typebox";
|
|
12
13
|
|
|
13
14
|
import {
|
|
14
15
|
type CodecTree,
|
|
@@ -21,12 +22,9 @@ import type { FieldKey, ITreeCursorSynchronous } from "../../core/index.js";
|
|
|
21
22
|
import { brand, type JsonCompatibleReadOnly } from "../../util/index.js";
|
|
22
23
|
import type { FieldBatchCodec, FieldBatchEncodingContext } from "../chunked-forest/index.js";
|
|
23
24
|
|
|
24
|
-
import {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
type Format,
|
|
28
|
-
FormatCommon,
|
|
29
|
-
} from "./formatCommon.js";
|
|
25
|
+
import { ForestFormatVersion, validVersions, type Format } from "./formatCommon.js";
|
|
26
|
+
import { FormatV1 } from "./formatV1.js";
|
|
27
|
+
import { FormatV2 } from "./formatV2.js";
|
|
30
28
|
|
|
31
29
|
/**
|
|
32
30
|
* Uses field cursors
|
|
@@ -61,7 +59,10 @@ export function makeForestSummarizerCodec(
|
|
|
61
59
|
): ForestCodec {
|
|
62
60
|
const inner = fieldBatchCodec;
|
|
63
61
|
const writeVersion = clientVersionToForestFormatVersion(options.minVersionForCollab);
|
|
64
|
-
const formatSchema =
|
|
62
|
+
const formatSchema = Type.Union([FormatV1, FormatV2]);
|
|
63
|
+
// Both the encode and decode logic here support both v1 and v2, as does `validVersions` and `formatSchema`.
|
|
64
|
+
// This makes this use of makeVersionedValidatedCodec atypical as it is a single call being used to make a codec that supports all versions,
|
|
65
|
+
// instead of one call per version, then using another utility to select between them based on version.
|
|
65
66
|
return makeVersionedValidatedCodec(options, validVersions, formatSchema, {
|
|
66
67
|
encode: (data: FieldSet, context: FieldBatchEncodingContext): Format => {
|
|
67
68
|
const keys: FieldKey[] = [];
|
|
@@ -20,8 +20,8 @@ export type ForestFormatVersion = Values<typeof ForestFormatVersion>;
|
|
|
20
20
|
|
|
21
21
|
export const validVersions = new Set([...Object.values(ForestFormatVersion)]);
|
|
22
22
|
|
|
23
|
-
export const FormatCommon = (
|
|
24
|
-
version:
|
|
23
|
+
export const FormatCommon = <const TVersion extends ForestFormatVersion>(
|
|
24
|
+
version: TVersion,
|
|
25
25
|
// Return type is intentionally derived.
|
|
26
26
|
// eslint-disable-next-line @typescript-eslint/explicit-function-return-type
|
|
27
27
|
) =>
|
|
@@ -33,4 +33,6 @@ export const FormatCommon = (
|
|
|
33
33
|
},
|
|
34
34
|
{ additionalProperties: false },
|
|
35
35
|
);
|
|
36
|
-
export type Format = Static<
|
|
36
|
+
export type Format<TVersion extends ForestFormatVersion = ForestFormatVersion> = Static<
|
|
37
|
+
ReturnType<typeof FormatCommon<TVersion>>
|
|
38
|
+
>;
|
|
@@ -5,9 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
import type { Static } from "@sinclair/typebox";
|
|
7
7
|
|
|
8
|
-
import { brand } from "../../util/index.js";
|
|
9
|
-
|
|
10
8
|
import { FormatCommon, ForestFormatVersion } from "./formatCommon.js";
|
|
11
9
|
|
|
12
|
-
export const FormatV1 = FormatCommon(
|
|
10
|
+
export const FormatV1 = FormatCommon(ForestFormatVersion.v1);
|
|
13
11
|
export type FormatV1 = Static<typeof FormatV1>;
|
|
@@ -5,9 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
import type { Static } from "@sinclair/typebox";
|
|
7
7
|
|
|
8
|
-
import { brand } from "../../util/index.js";
|
|
9
|
-
|
|
10
8
|
import { FormatCommon, ForestFormatVersion } from "./formatCommon.js";
|
|
11
9
|
|
|
12
|
-
export const FormatV2 = FormatCommon(
|
|
10
|
+
export const FormatV2 = FormatCommon(ForestFormatVersion.v2);
|
|
13
11
|
export type FormatV2 = Static<typeof FormatV2>;
|
|
@@ -69,8 +69,10 @@ export {
|
|
|
69
69
|
type NodeChangeInverter,
|
|
70
70
|
type NodeChangeRebaser,
|
|
71
71
|
type NodeChangePruner,
|
|
72
|
-
type
|
|
73
|
-
|
|
72
|
+
type ComposeNodeManager,
|
|
73
|
+
type InvertNodeManager,
|
|
74
|
+
type RebaseNodeManager,
|
|
75
|
+
NodeMoveType,
|
|
74
76
|
FlexFieldKind,
|
|
75
77
|
type FullSchemaPolicy,
|
|
76
78
|
allowsRepoSuperset,
|
|
@@ -79,7 +81,6 @@ export {
|
|
|
79
81
|
type HasFieldChanges,
|
|
80
82
|
type NodeExistsConstraint,
|
|
81
83
|
ModularChangeFamily,
|
|
82
|
-
type RelevantRemovedRootsFromChild,
|
|
83
84
|
EncodedModularChangesetV1,
|
|
84
85
|
EncodedModularChangesetV2,
|
|
85
86
|
updateRefreshers,
|
|
@@ -92,7 +93,11 @@ export {
|
|
|
92
93
|
ModularChangeFormatVersion,
|
|
93
94
|
} from "./modular-schema/index.js";
|
|
94
95
|
|
|
95
|
-
export {
|
|
96
|
+
export {
|
|
97
|
+
mapRootChanges,
|
|
98
|
+
nodeIdFromChangeAtom,
|
|
99
|
+
changeAtomFromDetachedNodeId,
|
|
100
|
+
} from "./deltaUtils.js";
|
|
96
101
|
|
|
97
102
|
export {
|
|
98
103
|
type TreeChunk,
|
|
@@ -128,17 +133,25 @@ export {
|
|
|
128
133
|
export {
|
|
129
134
|
FieldKinds,
|
|
130
135
|
type DefaultChangeset,
|
|
136
|
+
type DetachedRootIds,
|
|
131
137
|
DefaultChangeFamily,
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
type
|
|
135
|
-
type
|
|
136
|
-
type
|
|
138
|
+
type IdBasedChangeFamilyDataEditor,
|
|
139
|
+
DefaultIdBasedDataEditor,
|
|
140
|
+
type DataEditor,
|
|
141
|
+
type RequiredFieldEditor,
|
|
142
|
+
type OptionalFieldEditor,
|
|
143
|
+
type SequenceFieldEditor,
|
|
137
144
|
defaultSchemaPolicy,
|
|
138
145
|
fieldKinds,
|
|
139
146
|
fieldKindConfigurations,
|
|
140
147
|
intoDelta,
|
|
141
148
|
relevantRemovedRoots,
|
|
149
|
+
type DetachedRootLocation,
|
|
150
|
+
type DetachedRootsLocation,
|
|
151
|
+
type DetachedRootIdRange,
|
|
152
|
+
type Locator,
|
|
153
|
+
LocationBasedDataEditor,
|
|
154
|
+
type ILocationBasedDataEditor,
|
|
142
155
|
getCodecTreeForModularChangeFormat,
|
|
143
156
|
} from "./default-schema/index.js";
|
|
144
157
|
|
|
@@ -7,6 +7,7 @@ import type {
|
|
|
7
7
|
ChangeFamily,
|
|
8
8
|
ChangeFamilyEditor,
|
|
9
9
|
ChangeRebaser,
|
|
10
|
+
EditorOptions,
|
|
10
11
|
RevisionMetadataSource,
|
|
11
12
|
RevisionReplacer,
|
|
12
13
|
RevisionTag,
|
|
@@ -36,8 +37,9 @@ export function makeMitigatedChangeFamily<TEditor extends ChangeFamilyEditor, TC
|
|
|
36
37
|
buildEditor: (
|
|
37
38
|
mintRevisionTag: () => RevisionTag,
|
|
38
39
|
changeReceiver: (change: TaggedChange<TChange>) => void,
|
|
40
|
+
options?: EditorOptions,
|
|
39
41
|
): TEditor => {
|
|
40
|
-
return unmitigatedChangeFamily.buildEditor(mintRevisionTag, changeReceiver);
|
|
42
|
+
return unmitigatedChangeFamily.buildEditor(mintRevisionTag, changeReceiver, options);
|
|
41
43
|
},
|
|
42
44
|
rebaser: makeMitigatedRebaser(unmitigatedChangeFamily.rebaser, fallbackChange, onError),
|
|
43
45
|
codecs: unmitigatedChangeFamily.codecs,
|
|
@@ -16,23 +16,13 @@ import type { NodeId } from "./modularChangeTypes.js";
|
|
|
16
16
|
export type CrossFieldMap<T> = ChangeAtomIdRangeMap<T>;
|
|
17
17
|
export type CrossFieldQuerySet = CrossFieldMap<boolean>;
|
|
18
18
|
|
|
19
|
-
export function addCrossFieldQuery(
|
|
20
|
-
set: CrossFieldQuerySet,
|
|
21
|
-
revision: RevisionTag | undefined,
|
|
22
|
-
id: ChangesetLocalId,
|
|
23
|
-
count: number,
|
|
24
|
-
): void {
|
|
25
|
-
setInCrossFieldMap(set, revision, id, count, true);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
19
|
export function setInCrossFieldMap<T>(
|
|
29
20
|
map: CrossFieldMap<T>,
|
|
30
|
-
|
|
31
|
-
id: ChangesetLocalId,
|
|
21
|
+
id: ChangeAtomId,
|
|
32
22
|
count: number,
|
|
33
23
|
value: T,
|
|
34
24
|
): void {
|
|
35
|
-
map.set(
|
|
25
|
+
map.set(id, count, value);
|
|
36
26
|
}
|
|
37
27
|
|
|
38
28
|
export function getFirstFromCrossFieldMap<T>(
|
|
@@ -40,60 +30,167 @@ export function getFirstFromCrossFieldMap<T>(
|
|
|
40
30
|
revision: RevisionTag | undefined,
|
|
41
31
|
id: ChangesetLocalId,
|
|
42
32
|
count: number,
|
|
43
|
-
): RangeQueryResult<
|
|
33
|
+
): RangeQueryResult<T | undefined> {
|
|
44
34
|
return map.getFirst({ revision, localId: id }, count);
|
|
45
35
|
}
|
|
46
36
|
|
|
47
|
-
export enum
|
|
48
|
-
|
|
49
|
-
|
|
37
|
+
export enum NodeMoveType {
|
|
38
|
+
Detach,
|
|
39
|
+
Attach,
|
|
50
40
|
}
|
|
51
41
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
42
|
+
export interface InvertNodeManager {
|
|
43
|
+
/**
|
|
44
|
+
* Transfers the given node changes from the input context of the field changeset being inverted to the input context of the detached space (from which it may be further moved).
|
|
45
|
+
*
|
|
46
|
+
* This must be called for each detach in the field kind when rolling-back or reverting a detach.
|
|
47
|
+
* This implies that all detaches in the field must be inverted.
|
|
48
|
+
* @param detachId - The ID of the detach to invert.
|
|
49
|
+
* @param count - The number of nodes being detached.
|
|
50
|
+
* @param nodeChanges - The node changes to transfer.
|
|
51
|
+
* @param newAttachId - The ID that the nodes will be attached with in the inverted changeset of this field.
|
|
52
|
+
*/
|
|
53
|
+
invertDetach(
|
|
54
|
+
detachId: ChangeAtomId,
|
|
55
|
+
count: number,
|
|
56
|
+
nodeChanges: NodeId | undefined,
|
|
57
|
+
newAttachId: ChangeAtomId,
|
|
58
|
+
): void;
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Gets the node changes associated with the node being attached in input changeset.
|
|
62
|
+
*
|
|
63
|
+
* This must be called for each attach in the field kind when rolling-back or reverting a attach.
|
|
64
|
+
* This implies that all attaches in the field must be inverted.
|
|
65
|
+
* @param attachId - The ID of the attach to invert.
|
|
66
|
+
* @param count - The number of nodes being attached.
|
|
67
|
+
*/
|
|
68
|
+
invertAttach(
|
|
69
|
+
attachId: ChangeAtomId,
|
|
70
|
+
count: number,
|
|
71
|
+
): RangeQueryResult<DetachedNodeEntry | undefined>;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
export interface ComposeNodeManager {
|
|
75
|
+
/**
|
|
76
|
+
* Allows a field kind to query nested changes associated with a node in the input context of the new changeset.
|
|
77
|
+
* This should be called for every detach in the base changeset.
|
|
78
|
+
* @param baseDetachId - The ID of the detach in the base changeset.
|
|
79
|
+
* @param count - The number of nodes being detached.
|
|
80
|
+
*/
|
|
81
|
+
getNewChangesForBaseDetach(
|
|
82
|
+
baseDetachId: ChangeAtomId,
|
|
83
|
+
count: number,
|
|
84
|
+
): RangeQueryResult<DetachedNodeEntry | undefined>;
|
|
85
|
+
|
|
57
86
|
/**
|
|
58
|
-
*
|
|
59
|
-
*
|
|
87
|
+
* Must be called by a field kind when composing an attach in the base changeset with a detach in the new changeset.
|
|
88
|
+
* This allows Modular Change Family to keep track of how a given node is being renamed.
|
|
89
|
+
* @param baseAttachId - The ID of the attach in the base changeset.
|
|
90
|
+
* @param newDetachId - The ID of the detach in the new changeset.
|
|
91
|
+
* @param count - The number of nodes being attached then detached.
|
|
60
92
|
*/
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
id: ChangesetLocalId,
|
|
93
|
+
composeAttachDetach(
|
|
94
|
+
baseAttachId: ChangeAtomId,
|
|
95
|
+
newDetachId: ChangeAtomId,
|
|
65
96
|
count: number,
|
|
66
|
-
|
|
67
|
-
|
|
97
|
+
): void;
|
|
98
|
+
|
|
99
|
+
/**
|
|
100
|
+
* Must be called by a field kind when composing an attach in the base changeset with nested changes the new changeset.
|
|
101
|
+
*
|
|
102
|
+
* This is needed because child changes are represented at the location of the node they impact in the input context of a changeset.
|
|
103
|
+
* So if the later of the two changes being composed carries nested changes for a node,
|
|
104
|
+
* then in the composed changeset, these nested changes need to be represented at the location of that node in the input context of the composed changeset.
|
|
105
|
+
*
|
|
106
|
+
* @param baseAttachId - The ID of the attach in the base changeset.
|
|
107
|
+
* @param newChanges - The ID of the nested changes associated with this node in the new changeset.
|
|
108
|
+
*/
|
|
109
|
+
sendNewChangesToBaseSourceLocation(baseAttachId: ChangeAtomId, newChanges: NodeId): void;
|
|
68
110
|
|
|
111
|
+
// XXX: It doesn't seem like it should be mandatory to call this if you don't want the rename to be removed (e.g., optional field pin).
|
|
69
112
|
/**
|
|
70
|
-
*
|
|
71
|
-
*
|
|
72
|
-
*
|
|
113
|
+
* Must be called by a field kind when composing a detach in the base changeset with an attach of the same nodes in the new changeset.
|
|
114
|
+
* @param baseDetachId - The ID of the detach in the base changeset.
|
|
115
|
+
* @param newAttachId - The ID of the attach in the new changeset.
|
|
116
|
+
* @param count - The number of nodes being detached then attached.
|
|
117
|
+
* @param convertToPin - Should be set to true if the composed change will include a detach and attach with `newAttachId`.
|
|
118
|
+
* Otherwise the composed change should not include either `baseDetachId` or `newAttachId`.
|
|
73
119
|
*/
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
id: ChangesetLocalId,
|
|
120
|
+
composeDetachAttach(
|
|
121
|
+
baseDetachId: ChangeAtomId,
|
|
122
|
+
newAttachId: ChangeAtomId,
|
|
78
123
|
count: number,
|
|
79
|
-
|
|
80
|
-
invalidateDependents: boolean,
|
|
124
|
+
convertToPin: boolean,
|
|
81
125
|
): void;
|
|
126
|
+
}
|
|
82
127
|
|
|
128
|
+
export interface RebaseNodeManager {
|
|
129
|
+
// XXX: It's not clear whether the returned changes are already rebased or not.
|
|
83
130
|
/**
|
|
84
|
-
*
|
|
85
|
-
*
|
|
131
|
+
* Must be called by a field kind when rebasing over an attach.
|
|
132
|
+
* The returned child changes and detach intentions must be represented in the output changeset.
|
|
133
|
+
* @param baseAttachId - The ID of the attach that is being rebased over.
|
|
134
|
+
* @param count - The number of nodes attached by the base attach.
|
|
135
|
+
* @returns The new nested changes and detach intentions associated with the node in the changeset being rebased.
|
|
86
136
|
*/
|
|
87
|
-
|
|
137
|
+
getNewChangesForBaseAttach(
|
|
138
|
+
baseAttachId: ChangeAtomId,
|
|
139
|
+
count: number,
|
|
140
|
+
): RangeQueryResult<RebaseDetachedNodeEntry | undefined>;
|
|
88
141
|
|
|
142
|
+
// XXX: It's not clear if this must be called even when newDetachId and nodeChange are undefined.
|
|
143
|
+
// XXX: It's not clear if it's okay to call this once with a newDetachId then once with a nodeChange.
|
|
144
|
+
// XXX: It's not clear if nodeChange should be rebased already, or should not be rebased, or if it doesn't matter.
|
|
89
145
|
/**
|
|
90
|
-
*
|
|
91
|
-
*
|
|
146
|
+
* Must be called by a field kind when rebasing over a detach.
|
|
147
|
+
* The field kind must provide the nested changes and detach intentions associated with the node in the changeset being rebased.
|
|
148
|
+
* @param baseDetachId - The ID of the detach that is being rebased over.
|
|
149
|
+
* @param count - The number of nodes detached by the base detach.
|
|
150
|
+
* @param newDetachId - The ID associated the detach intention (if any) for these nodes in the rebased changeset.
|
|
151
|
+
* @param nodeChange - The nested changes (if any) associated with this node in the rebased changeset.
|
|
152
|
+
* @param newDetachCellId - An additional ID to associate with this node.
|
|
153
|
+
* This ID will be included in the result of {@link getNewChangesForBaseAttach}.
|
|
154
|
+
* This is only used by sequence field for compatibility with earlier client versions.
|
|
92
155
|
*/
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
revision: RevisionTag | undefined,
|
|
96
|
-
id: ChangesetLocalId,
|
|
156
|
+
rebaseOverDetach(
|
|
157
|
+
baseDetachId: ChangeAtomId,
|
|
97
158
|
count: number,
|
|
159
|
+
newDetachId: ChangeAtomId | undefined,
|
|
160
|
+
nodeChange: NodeId | undefined,
|
|
161
|
+
newDetachCellId?: ChangeAtomId,
|
|
98
162
|
): void;
|
|
163
|
+
|
|
164
|
+
addDetach(id: ChangeAtomId, count: number): void;
|
|
165
|
+
removeDetach(id: ChangeAtomId, count: number): void;
|
|
166
|
+
|
|
167
|
+
/**
|
|
168
|
+
* Returns whether nodes which were either previously detached by `id` or the base changeset is now detaching with `id`
|
|
169
|
+
* are also reattached by the base changeset.
|
|
170
|
+
*/
|
|
171
|
+
doesBaseAttachNodes(id: ChangeAtomId, count: number): RangeQueryResult<boolean>;
|
|
172
|
+
|
|
173
|
+
/**
|
|
174
|
+
* Returns the root ID the base change renames `id` to, if any.
|
|
175
|
+
*/
|
|
176
|
+
getBaseRename(id: ChangeAtomId, count: number): RangeQueryResult<ChangeAtomId | undefined>;
|
|
177
|
+
|
|
178
|
+
/**
|
|
179
|
+
* Given a detached node ID in the base changeset's output context,
|
|
180
|
+
* returns the ID the rebased changeset renames that ID to, if any.
|
|
181
|
+
*/
|
|
182
|
+
getNewRenameForBaseRename(
|
|
183
|
+
baseRenameTo: ChangeAtomId,
|
|
184
|
+
count: number,
|
|
185
|
+
): RangeQueryResult<ChangeAtomId | undefined>;
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
export interface DetachedNodeEntry {
|
|
189
|
+
nodeChange?: NodeId;
|
|
190
|
+
detachId?: ChangeAtomId;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
export interface RebaseDetachedNodeEntry extends DetachedNodeEntry {
|
|
194
|
+
// This is only needed for sequence field to implement detach cell IDs.
|
|
195
|
+
cellRename?: ChangeAtomId;
|
|
99
196
|
}
|
|
@@ -5,10 +5,9 @@
|
|
|
5
5
|
|
|
6
6
|
import type { ICodecFamily, IJsonCodec } from "../../codec/index.js";
|
|
7
7
|
import type {
|
|
8
|
+
ChangeAtomId,
|
|
9
|
+
ChangeAtomIdRangeMap,
|
|
8
10
|
ChangeEncodingContext,
|
|
9
|
-
DeltaDetachedNodeChanges,
|
|
10
|
-
DeltaDetachedNodeId,
|
|
11
|
-
DeltaDetachedNodeRename,
|
|
12
11
|
DeltaFieldChanges,
|
|
13
12
|
DeltaFieldMap,
|
|
14
13
|
EncodedRevisionTag,
|
|
@@ -16,35 +15,18 @@ import type {
|
|
|
16
15
|
RevisionReplacer,
|
|
17
16
|
RevisionTag,
|
|
18
17
|
} from "../../core/index.js";
|
|
19
|
-
import type { IdAllocator, Invariant } from "../../util/index.js";
|
|
18
|
+
import type { IdAllocator, Invariant, RangeQueryResult } from "../../util/index.js";
|
|
19
|
+
import type { ChangeAtomIdBTree } from "../changeAtomIdBTree.js";
|
|
20
20
|
|
|
21
|
-
import type {
|
|
21
|
+
import type {
|
|
22
|
+
ComposeNodeManager,
|
|
23
|
+
InvertNodeManager,
|
|
24
|
+
RebaseNodeManager,
|
|
25
|
+
} from "./crossFieldQueries.js";
|
|
22
26
|
import type { EncodedNodeChangeset } from "./modularChangeFormatV1.js";
|
|
23
|
-
import type { CrossFieldKeyRange, NodeId } from "./modularChangeTypes.js";
|
|
24
|
-
|
|
25
|
-
export type NestedChangesIndices = [
|
|
26
|
-
NodeId,
|
|
27
|
-
number | undefined /* inputIndex */,
|
|
28
|
-
number | undefined /* outputIndex */,
|
|
29
|
-
][];
|
|
27
|
+
import type { CrossFieldKeyRange, NodeId, RebaseVersion } from "./modularChangeTypes.js";
|
|
30
28
|
|
|
31
|
-
|
|
32
|
-
* The return value of calling {@link FieldChangeHandler.intoDelta}.
|
|
33
|
-
*/
|
|
34
|
-
export interface FieldChangeDelta {
|
|
35
|
-
/**
|
|
36
|
-
* {@inheritdoc DeltaFieldChanges}
|
|
37
|
-
*/
|
|
38
|
-
readonly local?: DeltaFieldChanges;
|
|
39
|
-
/**
|
|
40
|
-
* {@inheritdoc DeltaRoot.global}
|
|
41
|
-
*/
|
|
42
|
-
readonly global?: readonly DeltaDetachedNodeChanges[];
|
|
43
|
-
/**
|
|
44
|
-
* {@inheritdoc DeltaRoot.rename}
|
|
45
|
-
*/
|
|
46
|
-
readonly rename?: readonly DeltaDetachedNodeRename[];
|
|
47
|
-
}
|
|
29
|
+
export type NestedChangesIndices = readonly (readonly [NodeId, inputIndex: number])[];
|
|
48
30
|
|
|
49
31
|
/**
|
|
50
32
|
* Functionality provided by a field kind which will be composed with other `FieldChangeHandler`s to
|
|
@@ -65,27 +47,7 @@ export interface FieldChangeHandler<
|
|
|
65
47
|
>,
|
|
66
48
|
) => ICodecFamily<TChangeset, FieldChangeEncodingContext>;
|
|
67
49
|
readonly editor: TEditor;
|
|
68
|
-
intoDelta(change: TChangeset, deltaFromChild: ToDelta):
|
|
69
|
-
/**
|
|
70
|
-
* Returns the set of removed roots that should be in memory for the given change to be applied.
|
|
71
|
-
* A removed root is relevant if any of the following is true:
|
|
72
|
-
* - It is being inserted
|
|
73
|
-
* - It is being restored
|
|
74
|
-
* - It is being edited
|
|
75
|
-
* - The ID it is associated with is being changed
|
|
76
|
-
*
|
|
77
|
-
* Implementations are allowed to be conservative by returning more removed roots than strictly necessary
|
|
78
|
-
* (though they should, for the sake of performance, try to avoid doing so).
|
|
79
|
-
*
|
|
80
|
-
* Implementations are not allowed to return IDs for non-root trees, even if they are removed.
|
|
81
|
-
*
|
|
82
|
-
* @param change - The change to be applied.
|
|
83
|
-
* @param relevantRemovedRootsFromChild - Delegate for collecting relevant removed roots from child changes.
|
|
84
|
-
*/
|
|
85
|
-
readonly relevantRemovedRoots: (
|
|
86
|
-
change: TChangeset,
|
|
87
|
-
relevantRemovedRootsFromChild: RelevantRemovedRootsFromChild,
|
|
88
|
-
) => Iterable<DeltaDetachedNodeId>;
|
|
50
|
+
intoDelta(change: TChangeset, deltaFromChild: ToDelta): DeltaFieldChanges;
|
|
89
51
|
|
|
90
52
|
/**
|
|
91
53
|
* Returns whether this change is empty, meaning that it represents no modifications to the field
|
|
@@ -114,6 +76,12 @@ export interface FieldChangeHandler<
|
|
|
114
76
|
*/
|
|
115
77
|
getCrossFieldKeys(change: TChangeset): CrossFieldKeyRange[];
|
|
116
78
|
|
|
79
|
+
// XXX: Document
|
|
80
|
+
getDetachCellIds(
|
|
81
|
+
change: TChangeset,
|
|
82
|
+
rootRenames: ChangeAtomIdRangeMap<ChangeAtomId>,
|
|
83
|
+
): { detachId: ChangeAtomId; cellId: ChangeAtomId; count: number }[];
|
|
84
|
+
|
|
117
85
|
createEmpty(): TChangeset;
|
|
118
86
|
}
|
|
119
87
|
|
|
@@ -130,7 +98,7 @@ export interface FieldChangeRebaser<TChangeset> {
|
|
|
130
98
|
change2: TChangeset,
|
|
131
99
|
composeChild: NodeChangeComposer,
|
|
132
100
|
genId: IdAllocator,
|
|
133
|
-
|
|
101
|
+
nodeManager: ComposeNodeManager,
|
|
134
102
|
revisionMetadata: RevisionMetadataSource,
|
|
135
103
|
): TChangeset;
|
|
136
104
|
|
|
@@ -143,10 +111,11 @@ export interface FieldChangeRebaser<TChangeset> {
|
|
|
143
111
|
isRollback: boolean,
|
|
144
112
|
genId: IdAllocator,
|
|
145
113
|
revision: RevisionTag | undefined,
|
|
146
|
-
|
|
114
|
+
nodeManager: InvertNodeManager,
|
|
147
115
|
revisionMetadata: RevisionMetadataSource,
|
|
148
116
|
): TChangeset;
|
|
149
117
|
|
|
118
|
+
// XXX: It's not clear whether `rebaseChild` must be called in all cases.
|
|
150
119
|
/**
|
|
151
120
|
* Rebase `change` over `over`.
|
|
152
121
|
* See `ChangeRebaser` for details.
|
|
@@ -156,8 +125,9 @@ export interface FieldChangeRebaser<TChangeset> {
|
|
|
156
125
|
over: TChangeset,
|
|
157
126
|
rebaseChild: NodeChangeRebaser,
|
|
158
127
|
genId: IdAllocator,
|
|
159
|
-
|
|
128
|
+
nodeManager: RebaseNodeManager,
|
|
160
129
|
revisionMetadata: RebaseRevisionMetadata,
|
|
130
|
+
rebaseVersion: RebaseVersion,
|
|
161
131
|
): TChangeset;
|
|
162
132
|
|
|
163
133
|
/**
|
|
@@ -246,11 +216,6 @@ export type NodeChangeComposer = (
|
|
|
246
216
|
|
|
247
217
|
export type NodeChangePruner = (change: NodeId) => NodeId | undefined;
|
|
248
218
|
|
|
249
|
-
/**
|
|
250
|
-
* A function that returns the set of removed roots that should be in memory for a given node changeset to be applied.
|
|
251
|
-
*/
|
|
252
|
-
export type RelevantRemovedRootsFromChild = (child: NodeId) => Iterable<DeltaDetachedNodeId>;
|
|
253
|
-
|
|
254
219
|
export interface RebaseRevisionMetadata extends RevisionMetadataSource {
|
|
255
220
|
readonly getRevisionToRebase: () => RevisionTag | undefined;
|
|
256
221
|
readonly getBaseRevisions: () => RevisionTag[];
|
|
@@ -258,6 +223,96 @@ export interface RebaseRevisionMetadata extends RevisionMetadataSource {
|
|
|
258
223
|
|
|
259
224
|
export interface FieldChangeEncodingContext {
|
|
260
225
|
readonly baseContext: ChangeEncodingContext;
|
|
226
|
+
|
|
227
|
+
/**
|
|
228
|
+
* A map from root ID to node ID, containing all roots which were last detached from this field.
|
|
229
|
+
* The field must encode these root node changes.
|
|
230
|
+
* This is only needed when encoding to a ModularChangeFormat older than v3,
|
|
231
|
+
* as in those versions, changes to root nodes were represented in the field they were last detached from.
|
|
232
|
+
* This should only be used during encoding.
|
|
233
|
+
*/
|
|
234
|
+
readonly rootNodeChanges: ChangeAtomIdBTree<NodeId>;
|
|
235
|
+
|
|
236
|
+
/**
|
|
237
|
+
* A map from input context root ID to output context root ID, containing all roots which were last detached from this field.
|
|
238
|
+
* The field must encode these renames.
|
|
239
|
+
* This is only needed when encoding to a ModularChangeFormat older than v3,
|
|
240
|
+
* as in those versions, root node renames were represented in the field they were last detached from.
|
|
241
|
+
* This should only be used during encoding.
|
|
242
|
+
*/
|
|
243
|
+
readonly rootRenames: ChangeAtomIdRangeMap<ChangeAtomId>;
|
|
244
|
+
|
|
245
|
+
// This should only be called during encoding.
|
|
261
246
|
encodeNode(nodeId: NodeId): EncodedNodeChangeset;
|
|
247
|
+
|
|
248
|
+
/**
|
|
249
|
+
* Returns the input context root ID from an output context root ID.
|
|
250
|
+
* This is only needed for encoding to sequence field format v3 and older.
|
|
251
|
+
* This should only be called during encoding.
|
|
252
|
+
*/
|
|
253
|
+
getInputRootId(
|
|
254
|
+
outputRootId: ChangeAtomId,
|
|
255
|
+
count: number,
|
|
256
|
+
): RangeQueryResult<ChangeAtomId | undefined>;
|
|
257
|
+
|
|
258
|
+
/**
|
|
259
|
+
* Returns the input context root ID from an output context root ID.
|
|
260
|
+
* This is only needed for encoding to sequence field format v3 and older.
|
|
261
|
+
* This should only be called during encoding.
|
|
262
|
+
*/
|
|
263
|
+
isAttachId(id: ChangeAtomId, count: number): RangeQueryResult<boolean>;
|
|
264
|
+
|
|
265
|
+
/**
|
|
266
|
+
* Returns whether `id` is used as a detach ID in this changeset.
|
|
267
|
+
* This is only needed for encoding to sequence field format v3 and older.
|
|
268
|
+
* This should only be called during encoding.
|
|
269
|
+
*/
|
|
270
|
+
isDetachId(id: ChangeAtomId, count: number): RangeQueryResult<boolean>;
|
|
271
|
+
|
|
272
|
+
/**
|
|
273
|
+
* Returns the detach cell ID for the attach associated with `moveId`.
|
|
274
|
+
* If there is no associated detach cell ID, or the ID is the same as `moveId`,
|
|
275
|
+
* this will return undefined.
|
|
276
|
+
* This is only needed for encoding to sequence field format v3 and older.
|
|
277
|
+
* This should only be called during encoding.
|
|
278
|
+
*/
|
|
279
|
+
getCellIdForMove(
|
|
280
|
+
moveId: ChangeAtomId,
|
|
281
|
+
count: number,
|
|
282
|
+
): RangeQueryResult<ChangeAtomId | undefined>;
|
|
283
|
+
|
|
284
|
+
// This should only be called during decoding.
|
|
262
285
|
decodeNode(encodedNode: EncodedNodeChangeset): NodeId;
|
|
286
|
+
|
|
287
|
+
/**
|
|
288
|
+
* Must be called for each root node changeset encoded in this field.
|
|
289
|
+
* This is only needed when encoding to a ModularChangeFormat older than v3,
|
|
290
|
+
* as in those versions, changes to root node were represented in the field they were last detached from.
|
|
291
|
+
* This should only be called during decoding.
|
|
292
|
+
*/
|
|
293
|
+
decodeRootNodeChange(detachId: ChangeAtomId, encodedNode: EncodedNodeChangeset): void;
|
|
294
|
+
|
|
295
|
+
/**
|
|
296
|
+
* Must be called for each root node rename encoded in this field.
|
|
297
|
+
* This is only needed when encoding to a ModularChangeFormat older than v3,
|
|
298
|
+
* as in those versions, root node renames were represented in the field they were last detached from.
|
|
299
|
+
* This should only be called during decoding.
|
|
300
|
+
*/
|
|
301
|
+
decodeRootRename(oldId: ChangeAtomId, newId: ChangeAtomId, count: number): void;
|
|
302
|
+
|
|
303
|
+
/**
|
|
304
|
+
* Must be called for each node which has its detach location changed to this field.
|
|
305
|
+
* The node may be either detached by this change, or already detached in this change's input context.
|
|
306
|
+
* This is only needed when encoding to a ModularChangeFormat older than v3,
|
|
307
|
+
* as in those versions, root node locations were represented in the field they were last detached from.
|
|
308
|
+
* This should only be called during decoding.
|
|
309
|
+
*/
|
|
310
|
+
decodeMoveAndDetach(detachId: ChangeAtomId, count: number): void;
|
|
311
|
+
|
|
312
|
+
/**
|
|
313
|
+
* Generates a new ChangeAtomId which has not been used in this changeset.
|
|
314
|
+
* This is only needed for decoding optional field format v2 and older.
|
|
315
|
+
* This should only be called during decoding.
|
|
316
|
+
*/
|
|
317
|
+
generateId(): ChangeAtomId;
|
|
263
318
|
}
|