@fluidframework/tree 2.51.0 → 2.53.0-350190
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/.vscode/settings.json +0 -1
- package/CHANGELOG.md +43 -0
- package/api-report/tree.alpha.api.md +40 -30
- package/dist/alpha.d.ts +2 -1
- package/dist/codec/codec.d.ts +2 -1
- package/dist/codec/codec.d.ts.map +1 -1
- package/dist/codec/codec.js +4 -3
- package/dist/codec/codec.js.map +1 -1
- package/dist/core/index.d.ts +1 -1
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +3 -2
- package/dist/core/index.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 +3 -1
- package/dist/core/rebase/types.d.ts.map +1 -1
- package/dist/core/rebase/types.js +2 -1
- package/dist/core/rebase/types.js.map +1 -1
- package/dist/core/schema-stored/schema.d.ts +1 -23
- package/dist/core/schema-stored/schema.d.ts.map +1 -1
- package/dist/core/schema-stored/schema.js +2 -2
- package/dist/core/schema-stored/schema.js.map +1 -1
- package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
- package/dist/core/tree/detachedFieldIndex.js +2 -3
- package/dist/core/tree/detachedFieldIndex.js.map +1 -1
- package/dist/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
- package/dist/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecCommon.js +68 -0
- package/dist/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
- package/dist/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecV1.js +55 -0
- package/dist/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
- package/dist/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecV2.js +49 -0
- package/dist/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
- package/dist/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
- package/dist/core/tree/detachedFieldIndexCodecs.js +26 -0
- package/dist/core/tree/detachedFieldIndexCodecs.js.map +1 -0
- package/dist/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
- package/dist/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
- package/dist/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +18 -13
- package/dist/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
- package/dist/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
- package/dist/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
- package/dist/core/tree/detachedFieldIndexFormatV1.js +12 -0
- package/dist/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
- package/dist/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
- package/dist/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
- package/dist/core/tree/detachedFieldIndexFormatV2.js +14 -0
- package/dist/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
- package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
- package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js +21 -21
- package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
- package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
- package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
- package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js +74 -61
- package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
- package/dist/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/format.js +18 -12
- package/dist/feature-libraries/chunked-forest/codec/format.js.map +1 -1
- package/{lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts → dist/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
- package/dist/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
- package/dist/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +23 -17
- package/dist/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
- package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
- package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +22 -22
- package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
- package/dist/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
- package/dist/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
- package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
- package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/defaultFieldKinds.js +15 -2
- package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
- package/dist/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/defaultSchema.js +0 -2
- package/dist/feature-libraries/default-schema/defaultSchema.js.map +1 -1
- package/dist/feature-libraries/default-schema/index.d.ts +1 -1
- package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/index.js +2 -2
- package/dist/feature-libraries/default-schema/index.js.map +1 -1
- package/dist/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
- package/dist/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
- package/dist/feature-libraries/default-schema/schemaChecker.js +31 -26
- package/dist/feature-libraries/default-schema/schemaChecker.js.map +1 -1
- package/dist/feature-libraries/index.d.ts +1 -2
- package/dist/feature-libraries/index.d.ts.map +1 -1
- package/dist/feature-libraries/index.js +2 -4
- package/dist/feature-libraries/index.js.map +1 -1
- package/dist/feature-libraries/modular-schema/comparison.d.ts +5 -6
- package/dist/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/comparison.js +15 -16
- package/dist/feature-libraries/modular-schema/comparison.js.map +1 -1
- package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts +7 -0
- package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/fieldChangeHandler.js +1 -0
- 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 +1 -0
- package/dist/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts +9 -1
- package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFamily.js +49 -20
- package/dist/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
- package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
- package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
- package/dist/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
- package/dist/feature-libraries/object-forest/objectForest.js +2 -3
- package/dist/feature-libraries/object-forest/objectForest.js.map +1 -1
- package/dist/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
- package/dist/feature-libraries/optional-field/optionalField.js +3 -0
- package/dist/feature-libraries/optional-field/optionalField.js.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts +1 -0
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts.map +1 -1
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js +4 -0
- package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js.map +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -2
- package/dist/index.js.map +1 -1
- package/dist/jsonDomainSchema.d.ts +5 -3
- package/dist/jsonDomainSchema.d.ts.map +1 -1
- package/dist/jsonDomainSchema.js.map +1 -1
- 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 +8 -0
- package/dist/shared-tree/independentView.d.ts.map +1 -1
- package/dist/shared-tree/independentView.js +23 -11
- package/dist/shared-tree/independentView.js.map +1 -1
- package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
- package/dist/shared-tree/schematizeTree.js +1 -1
- package/dist/shared-tree/schematizeTree.js.map +1 -1
- package/dist/shared-tree/schematizingTreeView.d.ts +0 -1
- package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
- package/dist/shared-tree/schematizingTreeView.js +9 -12
- package/dist/shared-tree/schematizingTreeView.js.map +1 -1
- package/dist/shared-tree/sharedTree.d.ts.map +1 -1
- package/dist/shared-tree/sharedTree.js +1 -29
- package/dist/shared-tree/sharedTree.js.map +1 -1
- package/dist/shared-tree/treeAlpha.d.ts +20 -6
- package/dist/shared-tree/treeAlpha.d.ts.map +1 -1
- package/dist/shared-tree/treeAlpha.js +18 -7
- package/dist/shared-tree/treeAlpha.js.map +1 -1
- package/dist/shared-tree/treeCheckout.d.ts +2 -1
- package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
- package/dist/shared-tree/treeCheckout.js +32 -0
- package/dist/shared-tree/treeCheckout.js.map +1 -1
- package/dist/shared-tree-core/branch.d.ts.map +1 -1
- package/dist/shared-tree-core/branch.js +1 -1
- package/dist/shared-tree-core/branch.js.map +1 -1
- package/dist/simple-tree/api/conciseTree.d.ts +2 -2
- package/dist/simple-tree/api/conciseTree.d.ts.map +1 -1
- package/dist/simple-tree/api/conciseTree.js +6 -6
- package/dist/simple-tree/api/conciseTree.js.map +1 -1
- package/dist/simple-tree/api/configuration.d.ts +11 -2
- package/dist/simple-tree/api/configuration.d.ts.map +1 -1
- package/dist/simple-tree/api/configuration.js +5 -1
- package/dist/simple-tree/api/configuration.js.map +1 -1
- package/dist/simple-tree/api/create.d.ts +8 -7
- package/dist/simple-tree/api/create.d.ts.map +1 -1
- package/dist/simple-tree/api/create.js +33 -23
- package/dist/simple-tree/api/create.js.map +1 -1
- package/dist/simple-tree/api/customTree.d.ts +25 -4
- package/dist/simple-tree/api/customTree.d.ts.map +1 -1
- package/dist/simple-tree/api/customTree.js +42 -16
- package/dist/simple-tree/api/customTree.js.map +1 -1
- package/dist/simple-tree/api/discrepancies.d.ts +94 -0
- package/dist/simple-tree/api/discrepancies.d.ts.map +1 -0
- package/dist/simple-tree/api/discrepancies.js +256 -0
- package/dist/simple-tree/api/discrepancies.js.map +1 -0
- package/dist/simple-tree/api/index.d.ts +3 -2
- package/dist/simple-tree/api/index.d.ts.map +1 -1
- package/dist/simple-tree/api/index.js +3 -2
- package/dist/simple-tree/api/index.js.map +1 -1
- package/dist/simple-tree/api/schemaCompatibilityTester.d.ts +9 -7
- package/dist/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
- package/dist/simple-tree/api/schemaCompatibilityTester.js +17 -117
- package/dist/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
- package/dist/simple-tree/api/schemaFactory.d.ts +16 -159
- package/dist/simple-tree/api/schemaFactory.d.ts.map +1 -1
- package/dist/simple-tree/api/schemaFactory.js +4 -47
- package/dist/simple-tree/api/schemaFactory.js.map +1 -1
- package/dist/simple-tree/api/schemaFactoryAlpha.d.ts +157 -16
- package/dist/simple-tree/api/schemaFactoryAlpha.d.ts.map +1 -1
- package/dist/simple-tree/api/schemaFactoryAlpha.js +33 -11
- package/dist/simple-tree/api/schemaFactoryAlpha.js.map +1 -1
- package/dist/simple-tree/api/schemaFactoryRecursive.d.ts +1 -3
- package/dist/simple-tree/api/schemaFactoryRecursive.d.ts.map +1 -1
- package/dist/simple-tree/api/schemaFactoryRecursive.js +1 -7
- package/dist/simple-tree/api/schemaFactoryRecursive.js.map +1 -1
- package/dist/simple-tree/api/schemaStatics.d.ts +158 -0
- package/dist/simple-tree/api/schemaStatics.d.ts.map +1 -0
- package/dist/simple-tree/api/schemaStatics.js +59 -0
- package/dist/simple-tree/api/schemaStatics.js.map +1 -0
- package/dist/simple-tree/api/storedSchema.d.ts +5 -3
- package/dist/simple-tree/api/storedSchema.d.ts.map +1 -1
- package/dist/simple-tree/api/storedSchema.js +9 -3
- package/dist/simple-tree/api/storedSchema.js.map +1 -1
- package/dist/simple-tree/api/treeBeta.d.ts +2 -2
- package/dist/simple-tree/api/treeBeta.d.ts.map +1 -1
- package/dist/simple-tree/api/treeBeta.js +16 -4
- package/dist/simple-tree/api/treeBeta.js.map +1 -1
- package/dist/simple-tree/api/verboseTree.d.ts +2 -2
- package/dist/simple-tree/api/verboseTree.d.ts.map +1 -1
- package/dist/simple-tree/api/verboseTree.js +15 -15
- package/dist/simple-tree/api/verboseTree.js.map +1 -1
- package/dist/simple-tree/core/allowedTypes.d.ts +43 -11
- package/dist/simple-tree/core/allowedTypes.d.ts.map +1 -1
- package/dist/simple-tree/core/allowedTypes.js +51 -11
- package/dist/simple-tree/core/allowedTypes.js.map +1 -1
- package/dist/simple-tree/core/context.d.ts +13 -2
- package/dist/simple-tree/core/context.d.ts.map +1 -1
- package/dist/simple-tree/core/context.js +22 -9
- package/dist/simple-tree/core/context.js.map +1 -1
- package/dist/simple-tree/core/index.d.ts +6 -4
- package/dist/simple-tree/core/index.d.ts.map +1 -1
- package/dist/simple-tree/core/index.js +8 -1
- package/dist/simple-tree/core/index.js.map +1 -1
- package/dist/simple-tree/core/simpleNodeSchemaBase.d.ts +25 -0
- package/dist/simple-tree/core/simpleNodeSchemaBase.d.ts.map +1 -0
- package/dist/simple-tree/core/simpleNodeSchemaBase.js +7 -0
- package/dist/simple-tree/core/simpleNodeSchemaBase.js.map +1 -0
- package/dist/simple-tree/core/toStored.d.ts +32 -0
- package/dist/simple-tree/core/toStored.d.ts.map +1 -0
- package/dist/simple-tree/core/toStored.js +37 -0
- package/dist/simple-tree/core/toStored.js.map +1 -0
- package/dist/simple-tree/core/treeNodeKernel.d.ts +1 -1
- package/dist/simple-tree/core/treeNodeKernel.js +1 -1
- package/dist/simple-tree/core/treeNodeKernel.js.map +1 -1
- package/dist/simple-tree/core/treeNodeSchema.d.ts +7 -2
- package/dist/simple-tree/core/treeNodeSchema.d.ts.map +1 -1
- package/dist/simple-tree/core/treeNodeSchema.js.map +1 -1
- package/dist/simple-tree/core/treeNodeValid.d.ts +7 -2
- package/dist/simple-tree/core/treeNodeValid.d.ts.map +1 -1
- package/dist/simple-tree/core/treeNodeValid.js +19 -4
- package/dist/simple-tree/core/treeNodeValid.js.map +1 -1
- package/dist/simple-tree/core/walkSchema.d.ts +22 -5
- package/dist/simple-tree/core/walkSchema.d.ts.map +1 -1
- package/dist/simple-tree/core/walkSchema.js +6 -2
- package/dist/simple-tree/core/walkSchema.js.map +1 -1
- package/dist/simple-tree/createContext.d.ts +2 -0
- package/dist/simple-tree/createContext.d.ts.map +1 -1
- package/dist/simple-tree/createContext.js +4 -2
- package/dist/simple-tree/createContext.js.map +1 -1
- package/dist/simple-tree/fieldSchema.d.ts +1 -0
- package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
- package/dist/simple-tree/fieldSchema.js +2 -1
- package/dist/simple-tree/fieldSchema.js.map +1 -1
- package/dist/simple-tree/index.d.ts +7 -7
- package/dist/simple-tree/index.d.ts.map +1 -1
- package/dist/simple-tree/index.js +13 -8
- package/dist/simple-tree/index.js.map +1 -1
- package/dist/simple-tree/leafNodeSchema.d.ts.map +1 -1
- package/dist/simple-tree/leafNodeSchema.js +1 -0
- package/dist/simple-tree/leafNodeSchema.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 +18 -4
- package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
- package/dist/simple-tree/node-kinds/index.d.ts +1 -1
- package/dist/simple-tree/node-kinds/index.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/index.js +1 -2
- package/dist/simple-tree/node-kinds/index.js.map +1 -1
- package/dist/simple-tree/node-kinds/map/mapNode.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/map/mapNode.js +9 -2
- package/dist/simple-tree/node-kinds/map/mapNode.js.map +1 -1
- package/dist/simple-tree/node-kinds/object/index.d.ts +1 -1
- package/dist/simple-tree/node-kinds/object/index.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/object/index.js +1 -2
- package/dist/simple-tree/node-kinds/object/index.js.map +1 -1
- package/dist/simple-tree/node-kinds/object/objectNode.d.ts +3 -8
- package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
- package/dist/simple-tree/node-kinds/object/objectNode.js +41 -44
- 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 +9 -2
- package/dist/simple-tree/node-kinds/record/recordNode.js.map +1 -1
- package/dist/simple-tree/prepareForInsertion.d.ts +6 -6
- package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
- package/dist/simple-tree/prepareForInsertion.js +19 -13
- package/dist/simple-tree/prepareForInsertion.js.map +1 -1
- package/dist/simple-tree/simpleSchema.d.ts +6 -21
- package/dist/simple-tree/simpleSchema.d.ts.map +1 -1
- package/dist/simple-tree/simpleSchema.js.map +1 -1
- package/dist/simple-tree/toStoredSchema.d.ts +38 -11
- package/dist/simple-tree/toStoredSchema.d.ts.map +1 -1
- package/dist/simple-tree/toStoredSchema.js +71 -33
- package/dist/simple-tree/toStoredSchema.js.map +1 -1
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
- package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
- package/dist/simple-tree/walkFieldSchema.d.ts +1 -0
- package/dist/simple-tree/walkFieldSchema.d.ts.map +1 -1
- package/dist/simple-tree/walkFieldSchema.js +1 -0
- package/dist/simple-tree/walkFieldSchema.js.map +1 -1
- package/lib/alpha.d.ts +2 -1
- package/lib/codec/codec.d.ts +2 -1
- package/lib/codec/codec.d.ts.map +1 -1
- package/lib/codec/codec.js +4 -3
- package/lib/codec/codec.js.map +1 -1
- package/lib/core/index.d.ts +1 -1
- package/lib/core/index.d.ts.map +1 -1
- package/lib/core/index.js +1 -1
- package/lib/core/index.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 +3 -1
- package/lib/core/rebase/types.d.ts.map +1 -1
- package/lib/core/rebase/types.js +1 -0
- package/lib/core/rebase/types.js.map +1 -1
- package/lib/core/schema-stored/schema.d.ts +1 -23
- package/lib/core/schema-stored/schema.d.ts.map +1 -1
- package/lib/core/schema-stored/schema.js +2 -2
- package/lib/core/schema-stored/schema.js.map +1 -1
- package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
- package/lib/core/tree/detachedFieldIndex.js +2 -3
- package/lib/core/tree/detachedFieldIndex.js.map +1 -1
- package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
- package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecCommon.js +64 -0
- package/lib/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
- package/lib/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecV1.js +51 -0
- package/lib/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
- package/lib/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecV2.js +45 -0
- package/lib/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
- package/lib/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
- package/lib/core/tree/detachedFieldIndexCodecs.js +21 -0
- package/lib/core/tree/detachedFieldIndexCodecs.js.map +1 -0
- package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
- package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
- package/lib/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +13 -10
- package/lib/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
- package/lib/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
- package/lib/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
- package/lib/core/tree/detachedFieldIndexFormatV1.js +9 -0
- package/lib/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
- package/lib/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
- package/lib/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
- package/lib/core/tree/detachedFieldIndexFormatV2.js +11 -0
- package/lib/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
- package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
- package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js +19 -19
- package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
- package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
- package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
- package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js +70 -57
- package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
- package/lib/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/format.js +17 -11
- package/lib/feature-libraries/chunked-forest/codec/format.js.map +1 -1
- package/{dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts → lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
- package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
- package/lib/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +21 -15
- package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
- package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
- package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +19 -19
- package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
- package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
- package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
- package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
- package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/defaultFieldKinds.js +15 -2
- package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
- package/lib/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/defaultSchema.js +0 -2
- package/lib/feature-libraries/default-schema/defaultSchema.js.map +1 -1
- package/lib/feature-libraries/default-schema/index.d.ts +1 -1
- package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/index.js +1 -1
- package/lib/feature-libraries/default-schema/index.js.map +1 -1
- package/lib/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
- package/lib/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
- package/lib/feature-libraries/default-schema/schemaChecker.js +29 -24
- package/lib/feature-libraries/default-schema/schemaChecker.js.map +1 -1
- package/lib/feature-libraries/index.d.ts +1 -2
- package/lib/feature-libraries/index.d.ts.map +1 -1
- package/lib/feature-libraries/index.js +1 -2
- package/lib/feature-libraries/index.js.map +1 -1
- package/lib/feature-libraries/modular-schema/comparison.d.ts +5 -6
- package/lib/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/comparison.js +14 -14
- package/lib/feature-libraries/modular-schema/comparison.js.map +1 -1
- package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts +7 -0
- package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/fieldChangeHandler.js +1 -0
- 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 +1 -0
- package/lib/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts +9 -1
- package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFamily.js +50 -21
- package/lib/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
- package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
- package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
- package/lib/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
- package/lib/feature-libraries/object-forest/objectForest.js +3 -4
- package/lib/feature-libraries/object-forest/objectForest.js.map +1 -1
- package/lib/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
- package/lib/feature-libraries/optional-field/optionalField.js +3 -0
- package/lib/feature-libraries/optional-field/optionalField.js.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts +1 -0
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts.map +1 -1
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js +4 -0
- package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js.map +1 -1
- package/lib/index.d.ts +1 -1
- package/lib/index.d.ts.map +1 -1
- package/lib/index.js +2 -2
- package/lib/index.js.map +1 -1
- package/lib/jsonDomainSchema.d.ts +5 -3
- package/lib/jsonDomainSchema.d.ts.map +1 -1
- package/lib/jsonDomainSchema.js.map +1 -1
- 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 +8 -0
- package/lib/shared-tree/independentView.d.ts.map +1 -1
- package/lib/shared-tree/independentView.js +21 -10
- package/lib/shared-tree/independentView.js.map +1 -1
- package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
- package/lib/shared-tree/schematizeTree.js +2 -2
- package/lib/shared-tree/schematizeTree.js.map +1 -1
- package/lib/shared-tree/schematizingTreeView.d.ts +0 -1
- package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
- package/lib/shared-tree/schematizingTreeView.js +10 -13
- package/lib/shared-tree/schematizingTreeView.js.map +1 -1
- package/lib/shared-tree/sharedTree.d.ts.map +1 -1
- package/lib/shared-tree/sharedTree.js +2 -30
- package/lib/shared-tree/sharedTree.js.map +1 -1
- package/lib/shared-tree/treeAlpha.d.ts +20 -6
- package/lib/shared-tree/treeAlpha.d.ts.map +1 -1
- package/lib/shared-tree/treeAlpha.js +19 -8
- package/lib/shared-tree/treeAlpha.js.map +1 -1
- package/lib/shared-tree/treeCheckout.d.ts +2 -1
- package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
- package/lib/shared-tree/treeCheckout.js +33 -1
- package/lib/shared-tree/treeCheckout.js.map +1 -1
- package/lib/shared-tree-core/branch.d.ts.map +1 -1
- package/lib/shared-tree-core/branch.js +1 -1
- package/lib/shared-tree-core/branch.js.map +1 -1
- package/lib/simple-tree/api/conciseTree.d.ts +2 -2
- package/lib/simple-tree/api/conciseTree.d.ts.map +1 -1
- package/lib/simple-tree/api/conciseTree.js +6 -6
- package/lib/simple-tree/api/conciseTree.js.map +1 -1
- package/lib/simple-tree/api/configuration.d.ts +11 -2
- package/lib/simple-tree/api/configuration.d.ts.map +1 -1
- package/lib/simple-tree/api/configuration.js +6 -2
- package/lib/simple-tree/api/configuration.js.map +1 -1
- package/lib/simple-tree/api/create.d.ts +8 -7
- package/lib/simple-tree/api/create.d.ts.map +1 -1
- package/lib/simple-tree/api/create.js +35 -25
- package/lib/simple-tree/api/create.js.map +1 -1
- package/lib/simple-tree/api/customTree.d.ts +25 -4
- package/lib/simple-tree/api/customTree.d.ts.map +1 -1
- package/lib/simple-tree/api/customTree.js +43 -17
- package/lib/simple-tree/api/customTree.js.map +1 -1
- package/lib/simple-tree/api/discrepancies.d.ts +94 -0
- package/lib/simple-tree/api/discrepancies.d.ts.map +1 -0
- package/lib/simple-tree/api/discrepancies.js +251 -0
- package/lib/simple-tree/api/discrepancies.js.map +1 -0
- package/lib/simple-tree/api/index.d.ts +3 -2
- package/lib/simple-tree/api/index.d.ts.map +1 -1
- package/lib/simple-tree/api/index.js +2 -1
- package/lib/simple-tree/api/index.js.map +1 -1
- package/lib/simple-tree/api/schemaCompatibilityTester.d.ts +9 -7
- package/lib/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
- package/lib/simple-tree/api/schemaCompatibilityTester.js +19 -119
- package/lib/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
- package/lib/simple-tree/api/schemaFactory.d.ts +16 -159
- package/lib/simple-tree/api/schemaFactory.d.ts.map +1 -1
- package/lib/simple-tree/api/schemaFactory.js +2 -45
- package/lib/simple-tree/api/schemaFactory.js.map +1 -1
- package/lib/simple-tree/api/schemaFactoryAlpha.d.ts +157 -16
- package/lib/simple-tree/api/schemaFactoryAlpha.d.ts.map +1 -1
- package/lib/simple-tree/api/schemaFactoryAlpha.js +23 -1
- package/lib/simple-tree/api/schemaFactoryAlpha.js.map +1 -1
- package/lib/simple-tree/api/schemaFactoryRecursive.d.ts +1 -3
- package/lib/simple-tree/api/schemaFactoryRecursive.d.ts.map +1 -1
- package/lib/simple-tree/api/schemaFactoryRecursive.js +0 -5
- package/lib/simple-tree/api/schemaFactoryRecursive.js.map +1 -1
- package/lib/simple-tree/api/schemaStatics.d.ts +158 -0
- package/lib/simple-tree/api/schemaStatics.d.ts.map +1 -0
- package/lib/simple-tree/api/schemaStatics.js +56 -0
- package/lib/simple-tree/api/schemaStatics.js.map +1 -0
- package/lib/simple-tree/api/storedSchema.d.ts +5 -3
- package/lib/simple-tree/api/storedSchema.d.ts.map +1 -1
- package/lib/simple-tree/api/storedSchema.js +12 -6
- package/lib/simple-tree/api/storedSchema.js.map +1 -1
- package/lib/simple-tree/api/treeBeta.d.ts +2 -2
- package/lib/simple-tree/api/treeBeta.d.ts.map +1 -1
- package/lib/simple-tree/api/treeBeta.js +14 -2
- package/lib/simple-tree/api/treeBeta.js.map +1 -1
- package/lib/simple-tree/api/verboseTree.d.ts +2 -2
- package/lib/simple-tree/api/verboseTree.d.ts.map +1 -1
- package/lib/simple-tree/api/verboseTree.js +9 -9
- package/lib/simple-tree/api/verboseTree.js.map +1 -1
- package/lib/simple-tree/core/allowedTypes.d.ts +43 -11
- package/lib/simple-tree/core/allowedTypes.d.ts.map +1 -1
- package/lib/simple-tree/core/allowedTypes.js +52 -11
- package/lib/simple-tree/core/allowedTypes.js.map +1 -1
- package/lib/simple-tree/core/context.d.ts +13 -2
- package/lib/simple-tree/core/context.d.ts.map +1 -1
- package/lib/simple-tree/core/context.js +22 -9
- package/lib/simple-tree/core/context.js.map +1 -1
- package/lib/simple-tree/core/index.d.ts +6 -4
- package/lib/simple-tree/core/index.d.ts.map +1 -1
- package/lib/simple-tree/core/index.js +4 -3
- package/lib/simple-tree/core/index.js.map +1 -1
- package/lib/simple-tree/core/simpleNodeSchemaBase.d.ts +25 -0
- package/lib/simple-tree/core/simpleNodeSchemaBase.d.ts.map +1 -0
- package/lib/simple-tree/core/simpleNodeSchemaBase.js +6 -0
- package/lib/simple-tree/core/simpleNodeSchemaBase.js.map +1 -0
- package/lib/simple-tree/core/toStored.d.ts +32 -0
- package/lib/simple-tree/core/toStored.d.ts.map +1 -0
- package/lib/simple-tree/core/toStored.js +32 -0
- package/lib/simple-tree/core/toStored.js.map +1 -0
- package/lib/simple-tree/core/treeNodeKernel.d.ts +1 -1
- package/lib/simple-tree/core/treeNodeKernel.js +1 -1
- package/lib/simple-tree/core/treeNodeKernel.js.map +1 -1
- package/lib/simple-tree/core/treeNodeSchema.d.ts +7 -2
- package/lib/simple-tree/core/treeNodeSchema.d.ts.map +1 -1
- package/lib/simple-tree/core/treeNodeSchema.js.map +1 -1
- package/lib/simple-tree/core/treeNodeValid.d.ts +7 -2
- package/lib/simple-tree/core/treeNodeValid.d.ts.map +1 -1
- package/lib/simple-tree/core/treeNodeValid.js +17 -3
- package/lib/simple-tree/core/treeNodeValid.js.map +1 -1
- package/lib/simple-tree/core/walkSchema.d.ts +22 -5
- package/lib/simple-tree/core/walkSchema.d.ts.map +1 -1
- package/lib/simple-tree/core/walkSchema.js +6 -2
- package/lib/simple-tree/core/walkSchema.js.map +1 -1
- package/lib/simple-tree/createContext.d.ts +2 -0
- package/lib/simple-tree/createContext.d.ts.map +1 -1
- package/lib/simple-tree/createContext.js +5 -3
- package/lib/simple-tree/createContext.js.map +1 -1
- package/lib/simple-tree/fieldSchema.d.ts +1 -0
- package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
- package/lib/simple-tree/fieldSchema.js +2 -1
- package/lib/simple-tree/fieldSchema.js.map +1 -1
- package/lib/simple-tree/index.d.ts +7 -7
- package/lib/simple-tree/index.d.ts.map +1 -1
- package/lib/simple-tree/index.js +5 -5
- package/lib/simple-tree/index.js.map +1 -1
- package/lib/simple-tree/leafNodeSchema.d.ts.map +1 -1
- package/lib/simple-tree/leafNodeSchema.js +2 -1
- package/lib/simple-tree/leafNodeSchema.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 +21 -7
- package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
- package/lib/simple-tree/node-kinds/index.d.ts +1 -1
- package/lib/simple-tree/node-kinds/index.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/index.js +1 -1
- package/lib/simple-tree/node-kinds/index.js.map +1 -1
- package/lib/simple-tree/node-kinds/map/mapNode.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/map/mapNode.js +12 -5
- package/lib/simple-tree/node-kinds/map/mapNode.js.map +1 -1
- package/lib/simple-tree/node-kinds/object/index.d.ts +1 -1
- package/lib/simple-tree/node-kinds/object/index.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/object/index.js +1 -1
- package/lib/simple-tree/node-kinds/object/index.js.map +1 -1
- package/lib/simple-tree/node-kinds/object/objectNode.d.ts +3 -8
- package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
- package/lib/simple-tree/node-kinds/object/objectNode.js +19 -21
- 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 +12 -5
- package/lib/simple-tree/node-kinds/record/recordNode.js.map +1 -1
- package/lib/simple-tree/prepareForInsertion.d.ts +6 -6
- package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
- package/lib/simple-tree/prepareForInsertion.js +21 -15
- package/lib/simple-tree/prepareForInsertion.js.map +1 -1
- package/lib/simple-tree/simpleSchema.d.ts +6 -21
- package/lib/simple-tree/simpleSchema.d.ts.map +1 -1
- package/lib/simple-tree/simpleSchema.js.map +1 -1
- package/lib/simple-tree/toStoredSchema.d.ts +38 -11
- package/lib/simple-tree/toStoredSchema.d.ts.map +1 -1
- package/lib/simple-tree/toStoredSchema.js +70 -34
- package/lib/simple-tree/toStoredSchema.js.map +1 -1
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +1 -1
- package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
- package/lib/simple-tree/walkFieldSchema.d.ts +1 -0
- package/lib/simple-tree/walkFieldSchema.d.ts.map +1 -1
- package/lib/simple-tree/walkFieldSchema.js +1 -0
- package/lib/simple-tree/walkFieldSchema.js.map +1 -1
- package/package.json +23 -23
- package/src/codec/codec.ts +4 -3
- package/src/core/index.ts +2 -0
- package/src/core/rebase/index.ts +2 -0
- package/src/core/rebase/types.ts +4 -0
- package/src/core/schema-stored/schema.ts +2 -26
- package/src/core/tree/detachedFieldIndex.ts +4 -6
- package/src/core/tree/detachedFieldIndexCodecCommon.ts +87 -0
- package/src/core/tree/{detachedFieldIndexCodec.ts → detachedFieldIndexCodecV1.ts} +22 -68
- package/src/core/tree/detachedFieldIndexCodecV2.ts +72 -0
- package/src/core/tree/detachedFieldIndexCodecs.ts +44 -0
- package/src/core/tree/{detachedFieldIndexFormat.ts → detachedFieldIndexFormatCommon.ts} +32 -23
- package/src/core/tree/detachedFieldIndexFormatV1.ts +15 -0
- package/src/core/tree/detachedFieldIndexFormatV2.ts +17 -0
- package/src/feature-libraries/chunked-forest/codec/README.md +1 -1
- package/src/feature-libraries/chunked-forest/codec/chunkDecoding.ts +25 -25
- package/src/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.ts +10 -6
- package/src/feature-libraries/chunked-forest/codec/compressedEncode.ts +96 -73
- package/src/feature-libraries/chunked-forest/codec/format.ts +20 -14
- package/src/feature-libraries/chunked-forest/codec/{nodeShape.ts → nodeEncoder.ts} +23 -17
- package/src/feature-libraries/chunked-forest/codec/schemaBasedEncode.ts +34 -34
- package/src/feature-libraries/chunked-forest/codec/uncompressedEncode.ts +5 -5
- package/src/feature-libraries/default-schema/defaultFieldKinds.ts +11 -0
- package/src/feature-libraries/default-schema/defaultSchema.ts +0 -2
- package/src/feature-libraries/default-schema/index.ts +1 -1
- package/src/feature-libraries/default-schema/schemaChecker.ts +47 -30
- package/src/feature-libraries/index.ts +1 -3
- package/src/feature-libraries/modular-schema/comparison.ts +14 -29
- package/src/feature-libraries/modular-schema/fieldChangeHandler.ts +9 -0
- package/src/feature-libraries/modular-schema/genericFieldKind.ts +1 -0
- package/src/feature-libraries/modular-schema/modularChangeFamily.ts +61 -19
- package/src/feature-libraries/object-forest/objectForest.ts +10 -6
- package/src/feature-libraries/optional-field/optionalField.ts +4 -0
- package/src/feature-libraries/sequence-field/sequenceFieldChangeRebaser.ts +4 -0
- package/src/index.ts +7 -1
- package/src/jsonDomainSchema.ts +4 -0
- package/src/packageVersion.ts +1 -1
- package/src/shared-tree/independentView.ts +45 -19
- package/src/shared-tree/schematizeTree.ts +2 -2
- package/src/shared-tree/schematizingTreeView.ts +24 -15
- package/src/shared-tree/sharedTree.ts +2 -42
- package/src/shared-tree/treeAlpha.ts +48 -22
- package/src/shared-tree/treeCheckout.ts +54 -10
- package/src/shared-tree-core/branch.ts +1 -6
- package/src/simple-tree/api/conciseTree.ts +9 -7
- package/src/simple-tree/api/configuration.ts +18 -4
- package/src/simple-tree/api/create.ts +44 -36
- package/src/simple-tree/api/customTree.ts +59 -20
- package/src/simple-tree/api/discrepancies.ts +474 -0
- package/src/simple-tree/api/index.ts +2 -3
- package/src/simple-tree/api/schemaCompatibilityTester.ts +23 -151
- package/src/simple-tree/api/schemaFactory.ts +13 -254
- package/src/simple-tree/api/schemaFactoryAlpha.ts +174 -1
- package/src/simple-tree/api/schemaFactoryRecursive.ts +1 -25
- package/src/simple-tree/api/schemaStatics.ts +291 -0
- package/src/simple-tree/api/storedSchema.ts +18 -14
- package/src/simple-tree/api/treeBeta.ts +24 -4
- package/src/simple-tree/api/verboseTree.ts +17 -8
- package/src/simple-tree/core/allowedTypes.ts +87 -34
- package/src/simple-tree/core/context.ts +24 -22
- package/src/simple-tree/core/index.ts +11 -2
- package/src/simple-tree/core/simpleNodeSchemaBase.ts +30 -0
- package/src/simple-tree/core/toStored.ts +58 -0
- package/src/simple-tree/core/treeNodeKernel.ts +1 -1
- package/src/simple-tree/core/treeNodeSchema.ts +8 -2
- package/src/simple-tree/core/treeNodeValid.ts +23 -4
- package/src/simple-tree/core/walkSchema.ts +26 -6
- package/src/simple-tree/createContext.ts +11 -3
- package/src/simple-tree/fieldSchema.ts +3 -1
- package/src/simple-tree/index.ts +19 -13
- package/src/simple-tree/leafNodeSchema.ts +2 -1
- package/src/simple-tree/node-kinds/array/arrayNode.ts +64 -23
- package/src/simple-tree/node-kinds/index.ts +0 -1
- package/src/simple-tree/node-kinds/map/mapNode.ts +23 -2
- package/src/simple-tree/node-kinds/object/index.ts +0 -1
- package/src/simple-tree/node-kinds/object/objectNode.ts +42 -30
- package/src/simple-tree/node-kinds/record/recordNode.ts +20 -2
- package/src/simple-tree/prepareForInsertion.ts +28 -15
- package/src/simple-tree/simpleSchema.ts +6 -26
- package/src/simple-tree/toStoredSchema.ts +110 -44
- package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +6 -2
- package/src/simple-tree/walkFieldSchema.ts +1 -0
- package/dist/core/tree/detachedFieldIndexCodec.d.ts +0 -11
- package/dist/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
- package/dist/core/tree/detachedFieldIndexCodec.js +0 -100
- package/dist/core/tree/detachedFieldIndexCodec.js.map +0 -1
- package/dist/core/tree/detachedFieldIndexFormat.d.ts +0 -33
- package/dist/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
- package/dist/core/tree/detachedFieldIndexFormat.js.map +0 -1
- package/dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
- package/dist/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
- package/dist/feature-libraries/initializeForest.d.ts +0 -18
- package/dist/feature-libraries/initializeForest.d.ts.map +0 -1
- package/dist/feature-libraries/initializeForest.js +0 -35
- package/dist/feature-libraries/initializeForest.js.map +0 -1
- package/dist/simple-tree/discrepancies.d.ts +0 -167
- package/dist/simple-tree/discrepancies.d.ts.map +0 -1
- package/dist/simple-tree/discrepancies.js +0 -382
- package/dist/simple-tree/discrepancies.js.map +0 -1
- package/lib/core/tree/detachedFieldIndexCodec.d.ts +0 -11
- package/lib/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
- package/lib/core/tree/detachedFieldIndexCodec.js +0 -96
- package/lib/core/tree/detachedFieldIndexCodec.js.map +0 -1
- package/lib/core/tree/detachedFieldIndexFormat.d.ts +0 -33
- package/lib/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
- package/lib/core/tree/detachedFieldIndexFormat.js.map +0 -1
- package/lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
- package/lib/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
- package/lib/feature-libraries/initializeForest.d.ts +0 -18
- package/lib/feature-libraries/initializeForest.d.ts.map +0 -1
- package/lib/feature-libraries/initializeForest.js +0 -31
- package/lib/feature-libraries/initializeForest.js.map +0 -1
- package/lib/simple-tree/discrepancies.d.ts +0 -167
- package/lib/simple-tree/discrepancies.d.ts.map +0 -1
- package/lib/simple-tree/discrepancies.js +0 -376
- package/lib/simple-tree/discrepancies.js.map +0 -1
- package/src/feature-libraries/initializeForest.ts +0 -55
- package/src/simple-tree/discrepancies.ts +0 -648
|
@@ -30,7 +30,7 @@ import {
|
|
|
30
30
|
type EncodedAnyShape,
|
|
31
31
|
type EncodedChunkShape,
|
|
32
32
|
type EncodedFieldBatch,
|
|
33
|
-
type
|
|
33
|
+
type EncodedNestedArrayShape,
|
|
34
34
|
type EncodedValueShape,
|
|
35
35
|
SpecialField,
|
|
36
36
|
version,
|
|
@@ -41,18 +41,18 @@ import {
|
|
|
41
41
|
*
|
|
42
42
|
* Optimized for encoded size and encoding performance.
|
|
43
43
|
*
|
|
44
|
-
* Most of the compression strategy comes from the policy provided via `
|
|
44
|
+
* Most of the compression strategy comes from the policy provided via `context`.
|
|
45
45
|
*/
|
|
46
46
|
export function compressedEncode(
|
|
47
47
|
fieldBatch: FieldBatch,
|
|
48
|
-
|
|
48
|
+
context: EncoderContext,
|
|
49
49
|
): EncodedFieldBatch {
|
|
50
50
|
const batchBuffer: BufferFormat[] = [];
|
|
51
51
|
|
|
52
52
|
// Populate buffer, including shape and identifier references
|
|
53
53
|
for (const cursor of fieldBatch) {
|
|
54
54
|
const buffer: BufferFormat = [];
|
|
55
|
-
anyFieldEncoder.encodeField(cursor,
|
|
55
|
+
anyFieldEncoder.encodeField(cursor, context, buffer);
|
|
56
56
|
batchBuffer.push(buffer);
|
|
57
57
|
}
|
|
58
58
|
return updateShapesAndIdentifiersEncoding(version, batchBuffer);
|
|
@@ -91,7 +91,7 @@ export interface NodeEncoder extends Encoder {
|
|
|
91
91
|
*/
|
|
92
92
|
encodeNode(
|
|
93
93
|
cursor: ITreeCursorSynchronous,
|
|
94
|
-
|
|
94
|
+
context: EncoderContext,
|
|
95
95
|
outputBuffer: BufferFormat,
|
|
96
96
|
): void;
|
|
97
97
|
}
|
|
@@ -105,7 +105,7 @@ export interface NodesEncoder extends Encoder {
|
|
|
105
105
|
*/
|
|
106
106
|
encodeNodes(
|
|
107
107
|
cursor: ITreeCursorSynchronous,
|
|
108
|
-
|
|
108
|
+
context: EncoderContext,
|
|
109
109
|
outputBuffer: BufferFormat,
|
|
110
110
|
): void;
|
|
111
111
|
}
|
|
@@ -119,7 +119,7 @@ export interface FieldEncoder extends Encoder {
|
|
|
119
119
|
*/
|
|
120
120
|
encodeField(
|
|
121
121
|
cursor: ITreeCursorSynchronous,
|
|
122
|
-
|
|
122
|
+
context: EncoderContext,
|
|
123
123
|
outputBuffer: BufferFormat,
|
|
124
124
|
): void;
|
|
125
125
|
}
|
|
@@ -132,10 +132,10 @@ export function asFieldEncoder(encoder: NodeEncoder): FieldEncoder {
|
|
|
132
132
|
return {
|
|
133
133
|
encodeField(
|
|
134
134
|
cursor: ITreeCursorSynchronous,
|
|
135
|
-
|
|
135
|
+
context: EncoderContext,
|
|
136
136
|
outputBuffer: BufferFormat,
|
|
137
137
|
): void {
|
|
138
|
-
forEachNode(cursor, () => encoder.encodeNode(cursor,
|
|
138
|
+
forEachNode(cursor, () => encoder.encodeNode(cursor, context, outputBuffer));
|
|
139
139
|
},
|
|
140
140
|
shape: encoder.shape,
|
|
141
141
|
};
|
|
@@ -148,10 +148,10 @@ export function asNodesEncoder(encoder: NodeEncoder): NodesEncoder {
|
|
|
148
148
|
return {
|
|
149
149
|
encodeNodes(
|
|
150
150
|
cursor: ITreeCursorSynchronous,
|
|
151
|
-
|
|
151
|
+
context: EncoderContext,
|
|
152
152
|
outputBuffer: BufferFormat,
|
|
153
153
|
): void {
|
|
154
|
-
encoder.encodeNode(cursor,
|
|
154
|
+
encoder.encodeNode(cursor, context, outputBuffer);
|
|
155
155
|
cursor.nextNode();
|
|
156
156
|
},
|
|
157
157
|
shape: encoder.shape,
|
|
@@ -182,32 +182,32 @@ export class AnyShape extends ShapeGeneric<EncodedChunkShape> {
|
|
|
182
182
|
|
|
183
183
|
public static encodeField(
|
|
184
184
|
cursor: ITreeCursorSynchronous,
|
|
185
|
-
|
|
185
|
+
context: EncoderContext,
|
|
186
186
|
outputBuffer: BufferFormat,
|
|
187
|
-
|
|
187
|
+
encoder: FieldEncoder,
|
|
188
188
|
): void {
|
|
189
|
-
outputBuffer.push(
|
|
190
|
-
|
|
189
|
+
outputBuffer.push(encoder.shape);
|
|
190
|
+
encoder.encodeField(cursor, context, outputBuffer);
|
|
191
191
|
}
|
|
192
192
|
|
|
193
193
|
public static encodeNode(
|
|
194
194
|
cursor: ITreeCursorSynchronous,
|
|
195
|
-
|
|
195
|
+
context: EncoderContext,
|
|
196
196
|
outputBuffer: BufferFormat,
|
|
197
|
-
|
|
197
|
+
encoder: NodeEncoder,
|
|
198
198
|
): void {
|
|
199
|
-
outputBuffer.push(
|
|
200
|
-
|
|
199
|
+
outputBuffer.push(encoder.shape);
|
|
200
|
+
encoder.encodeNode(cursor, context, outputBuffer);
|
|
201
201
|
}
|
|
202
202
|
|
|
203
203
|
public static encodeNodes(
|
|
204
204
|
cursor: ITreeCursorSynchronous,
|
|
205
|
-
|
|
205
|
+
context: EncoderContext,
|
|
206
206
|
outputBuffer: BufferFormat,
|
|
207
|
-
|
|
207
|
+
encoder: NodesEncoder,
|
|
208
208
|
): void {
|
|
209
|
-
outputBuffer.push(
|
|
210
|
-
|
|
209
|
+
outputBuffer.push(encoder.shape);
|
|
210
|
+
encoder.encodeNodes(cursor, context, outputBuffer);
|
|
211
211
|
}
|
|
212
212
|
}
|
|
213
213
|
|
|
@@ -217,12 +217,12 @@ export class AnyShape extends ShapeGeneric<EncodedChunkShape> {
|
|
|
217
217
|
export const anyNodeEncoder: NodeEncoder = {
|
|
218
218
|
encodeNode(
|
|
219
219
|
cursor: ITreeCursorSynchronous,
|
|
220
|
-
|
|
220
|
+
context: EncoderContext,
|
|
221
221
|
outputBuffer: BufferFormat,
|
|
222
222
|
): void {
|
|
223
223
|
// TODO: Fast path uniform chunk content.
|
|
224
|
-
const shape =
|
|
225
|
-
AnyShape.encodeNode(cursor,
|
|
224
|
+
const shape = context.nodeEncoderFromSchema(cursor.type);
|
|
225
|
+
AnyShape.encodeNode(cursor, context, outputBuffer, shape);
|
|
226
226
|
},
|
|
227
227
|
|
|
228
228
|
shape: AnyShape.instance,
|
|
@@ -234,25 +234,25 @@ export const anyNodeEncoder: NodeEncoder = {
|
|
|
234
234
|
export const anyFieldEncoder: FieldEncoder = {
|
|
235
235
|
encodeField(
|
|
236
236
|
cursor: ITreeCursorSynchronous,
|
|
237
|
-
|
|
237
|
+
context: EncoderContext,
|
|
238
238
|
outputBuffer: BufferFormat,
|
|
239
239
|
): void {
|
|
240
240
|
// TODO: Fast path uniform chunks.
|
|
241
241
|
|
|
242
242
|
if (cursor.getFieldLength() === 0) {
|
|
243
|
-
const shape =
|
|
244
|
-
AnyShape.encodeField(cursor,
|
|
243
|
+
const shape = InlineArrayEncoder.empty;
|
|
244
|
+
AnyShape.encodeField(cursor, context, outputBuffer, shape);
|
|
245
245
|
} else if (cursor.getFieldLength() === 1) {
|
|
246
246
|
// Fast path chunk of size one size one at least: skip nested array.
|
|
247
247
|
cursor.enterNode(0);
|
|
248
|
-
anyNodeEncoder.encodeNode(cursor,
|
|
248
|
+
anyNodeEncoder.encodeNode(cursor, context, outputBuffer);
|
|
249
249
|
cursor.exitNode();
|
|
250
250
|
} else {
|
|
251
251
|
// TODO: more efficient encoding for common cases.
|
|
252
252
|
// Could try to find more specific shape compatible with all children than `anyNodeEncoder`.
|
|
253
253
|
|
|
254
|
-
const shape =
|
|
255
|
-
AnyShape.encodeField(cursor,
|
|
254
|
+
const shape = context.nestedArrayEncoder(anyNodeEncoder);
|
|
255
|
+
AnyShape.encodeField(cursor, context, outputBuffer, shape);
|
|
256
256
|
}
|
|
257
257
|
},
|
|
258
258
|
|
|
@@ -260,20 +260,23 @@ export const anyFieldEncoder: FieldEncoder = {
|
|
|
260
260
|
};
|
|
261
261
|
|
|
262
262
|
/**
|
|
263
|
-
* Encodes a chunk using {@link
|
|
263
|
+
* Encodes a chunk using {@link EncodedInlineArrayShape}.
|
|
264
|
+
* @remarks
|
|
265
|
+
* The fact this is also a Shape is an implementation detail of the encoder: that allows the shape it uses to be itself,
|
|
266
|
+
* which is an easy way to keep all the related code together without extra objects.
|
|
264
267
|
*/
|
|
265
|
-
export class
|
|
268
|
+
export class InlineArrayEncoder
|
|
266
269
|
extends ShapeGeneric<EncodedChunkShape>
|
|
267
270
|
implements NodesEncoder, FieldEncoder
|
|
268
271
|
{
|
|
269
|
-
public static readonly empty:
|
|
272
|
+
public static readonly empty: InlineArrayEncoder = new InlineArrayEncoder(0, {
|
|
270
273
|
get shape() {
|
|
271
274
|
// Not actually used, makes count work without adding an additional shape.
|
|
272
|
-
return
|
|
275
|
+
return InlineArrayEncoder.empty;
|
|
273
276
|
},
|
|
274
277
|
encodeNodes(
|
|
275
278
|
cursor: ITreeCursorSynchronous,
|
|
276
|
-
|
|
279
|
+
context: EncoderContext,
|
|
277
280
|
outputBuffer: BufferFormat,
|
|
278
281
|
): void {
|
|
279
282
|
fail(0xb4d /* Empty array should not encode any nodes */);
|
|
@@ -292,19 +295,19 @@ export class InlineArrayShape
|
|
|
292
295
|
|
|
293
296
|
public encodeNodes(
|
|
294
297
|
cursor: ITreeCursorSynchronous,
|
|
295
|
-
|
|
298
|
+
context: EncoderContext,
|
|
296
299
|
outputBuffer: BufferFormat,
|
|
297
300
|
): void {
|
|
298
301
|
// Linter is wrong about this loop being for-of compatible.
|
|
299
302
|
// eslint-disable-next-line @typescript-eslint/prefer-for-of
|
|
300
303
|
for (let index = 0; index < this.length; index++) {
|
|
301
|
-
this.inner.encodeNodes(cursor,
|
|
304
|
+
this.inner.encodeNodes(cursor, context, outputBuffer);
|
|
302
305
|
}
|
|
303
306
|
}
|
|
304
307
|
|
|
305
308
|
public encodeField(
|
|
306
309
|
cursor: ITreeCursorSynchronous,
|
|
307
|
-
|
|
310
|
+
context: EncoderContext,
|
|
308
311
|
outputBuffer: BufferFormat,
|
|
309
312
|
): void {
|
|
310
313
|
// Its possible individual items from this array encode multiple nodes, so don't assume === here.
|
|
@@ -313,7 +316,7 @@ export class InlineArrayShape
|
|
|
313
316
|
0x73c /* unexpected length for fixed length array */,
|
|
314
317
|
);
|
|
315
318
|
cursor.firstNode();
|
|
316
|
-
this.encodeNodes(cursor,
|
|
319
|
+
this.encodeNodes(cursor, context, outputBuffer);
|
|
317
320
|
assert(
|
|
318
321
|
cursor.mode === CursorLocationType.Fields,
|
|
319
322
|
0x73d /* should return to fields mode when finished encoding */,
|
|
@@ -345,9 +348,15 @@ export class InlineArrayShape
|
|
|
345
348
|
}
|
|
346
349
|
|
|
347
350
|
/**
|
|
348
|
-
* Encodes a field as a nested array with the {@link
|
|
351
|
+
* Encodes a field as a nested array with the {@link EncodedNestedArrayShape} shape.
|
|
352
|
+
* @remarks
|
|
353
|
+
* The fact this is also a Shape is an implementation detail of the encoder: that allows the shape it uses to be itself,
|
|
354
|
+
* which is an easy way to keep all the related code together without extra objects.
|
|
349
355
|
*/
|
|
350
|
-
export class
|
|
356
|
+
export class NestedArrayEncoder
|
|
357
|
+
extends ShapeGeneric<EncodedChunkShape>
|
|
358
|
+
implements FieldEncoder
|
|
359
|
+
{
|
|
351
360
|
public readonly shape: Shape;
|
|
352
361
|
|
|
353
362
|
public constructor(public readonly inner: NodeEncoder) {
|
|
@@ -357,7 +366,7 @@ export class NestedArrayShape extends ShapeGeneric<EncodedChunkShape> implements
|
|
|
357
366
|
|
|
358
367
|
public encodeField(
|
|
359
368
|
cursor: ITreeCursorSynchronous,
|
|
360
|
-
|
|
369
|
+
context: EncoderContext,
|
|
361
370
|
outputBuffer: BufferFormat,
|
|
362
371
|
): void {
|
|
363
372
|
const buffer: BufferFormat = [];
|
|
@@ -365,7 +374,7 @@ export class NestedArrayShape extends ShapeGeneric<EncodedChunkShape> implements
|
|
|
365
374
|
const length = cursor.getFieldLength();
|
|
366
375
|
forEachNode(cursor, () => {
|
|
367
376
|
const before = buffer.length;
|
|
368
|
-
this.inner.encodeNode(cursor,
|
|
377
|
+
this.inner.encodeNode(cursor, context, buffer);
|
|
369
378
|
allNonZeroSize &&= buffer.length - before !== 0;
|
|
370
379
|
});
|
|
371
380
|
if (buffer.length === 0) {
|
|
@@ -385,7 +394,7 @@ export class NestedArrayShape extends ShapeGeneric<EncodedChunkShape> implements
|
|
|
385
394
|
identifiers: DeduplicationTable<string>,
|
|
386
395
|
shapes: DeduplicationTable<Shape>,
|
|
387
396
|
): EncodedChunkShape {
|
|
388
|
-
const shape:
|
|
397
|
+
const shape: EncodedNestedArrayShape =
|
|
389
398
|
shapes.valueToIndex.get(this.inner.shape) ??
|
|
390
399
|
fail(0xb4f /* index for shape not found in table */);
|
|
391
400
|
return {
|
|
@@ -436,46 +445,60 @@ export function encodeValue(
|
|
|
436
445
|
}
|
|
437
446
|
}
|
|
438
447
|
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
448
|
+
/**
|
|
449
|
+
* Provides common contextual information during encoding, like schema and policy settings.
|
|
450
|
+
* Also, provides a cache to avoid duplicating equivalent shapes during a batch of encode operations.
|
|
451
|
+
* To avoid Shape duplication, any Shapes used in the encoding should either be:
|
|
452
|
+
* - Singletons defined in a static scope.
|
|
453
|
+
* - Cached in this object for future reuse such that all equivalent Shapes are deduplicated.
|
|
454
|
+
*/
|
|
455
|
+
export class EncoderContext implements NodeEncodeBuilder, FieldEncodeBuilder {
|
|
456
|
+
private readonly nodeEncodersFromSchema: Map<TreeNodeSchemaIdentifier, NodeEncoder> =
|
|
457
|
+
new Map();
|
|
458
|
+
private readonly nestedArrayEncoders: Map<NodeEncoder, NestedArrayEncoder> = new Map();
|
|
442
459
|
public constructor(
|
|
443
|
-
private readonly
|
|
444
|
-
private readonly
|
|
460
|
+
private readonly nodeEncoderFromPolicy: NodeEncoderPolicy,
|
|
461
|
+
private readonly fieldEncoderFromPolicy: FieldEncoderPolicy,
|
|
445
462
|
public readonly fieldShapes: ReadonlyMap<FieldKindIdentifier, FlexFieldKind>,
|
|
446
463
|
public readonly idCompressor: IIdCompressor,
|
|
447
464
|
) {}
|
|
448
465
|
|
|
449
|
-
public
|
|
450
|
-
return getOrCreate(this.
|
|
451
|
-
this.
|
|
466
|
+
public nodeEncoderFromSchema(schemaName: TreeNodeSchemaIdentifier): NodeEncoder {
|
|
467
|
+
return getOrCreate(this.nodeEncodersFromSchema, schemaName, () =>
|
|
468
|
+
this.nodeEncoderFromPolicy(this, schemaName),
|
|
452
469
|
);
|
|
453
470
|
}
|
|
454
471
|
|
|
455
|
-
public
|
|
456
|
-
return
|
|
472
|
+
public fieldEncoderFromSchema(fieldSchema: TreeFieldStoredSchema): FieldEncoder {
|
|
473
|
+
return new LazyFieldEncoder(this, fieldSchema, this.fieldEncoderFromPolicy);
|
|
457
474
|
}
|
|
458
475
|
|
|
459
|
-
public
|
|
460
|
-
return
|
|
476
|
+
public nestedArrayEncoder(inner: NodeEncoder): NestedArrayEncoder {
|
|
477
|
+
return getOrCreate(this.nestedArrayEncoders, inner, () => new NestedArrayEncoder(inner));
|
|
461
478
|
}
|
|
462
479
|
}
|
|
463
480
|
|
|
464
|
-
export interface
|
|
465
|
-
|
|
481
|
+
export interface NodeEncodeBuilder {
|
|
482
|
+
nodeEncoderFromSchema(schemaName: TreeNodeSchemaIdentifier): NodeEncoder;
|
|
466
483
|
}
|
|
467
484
|
|
|
468
|
-
export interface
|
|
469
|
-
|
|
485
|
+
export interface FieldEncodeBuilder {
|
|
486
|
+
fieldEncoderFromSchema(schema: TreeFieldStoredSchema): FieldEncoder;
|
|
470
487
|
}
|
|
471
488
|
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
489
|
+
/**
|
|
490
|
+
* The policy for building a {@link FieldEncoder} for a field.
|
|
491
|
+
*/
|
|
492
|
+
export type FieldEncoderPolicy = (
|
|
493
|
+
nodeBuilder: NodeEncodeBuilder,
|
|
494
|
+
schema: TreeFieldStoredSchema,
|
|
475
495
|
) => FieldEncoder;
|
|
476
496
|
|
|
477
|
-
|
|
478
|
-
|
|
497
|
+
/**
|
|
498
|
+
* The policy for building a {@link NodeEncoder} for a node.
|
|
499
|
+
*/
|
|
500
|
+
export type NodeEncoderPolicy = (
|
|
501
|
+
fieldBuilder: FieldEncodeBuilder,
|
|
479
502
|
schemaName: TreeNodeSchemaIdentifier,
|
|
480
503
|
) => NodeEncoder;
|
|
481
504
|
|
|
@@ -483,21 +506,21 @@ class LazyFieldEncoder implements FieldEncoder {
|
|
|
483
506
|
private encoderLazy: FieldEncoder | undefined;
|
|
484
507
|
|
|
485
508
|
public constructor(
|
|
486
|
-
public readonly
|
|
487
|
-
public readonly
|
|
488
|
-
private readonly
|
|
509
|
+
public readonly nodeBuilder: NodeEncodeBuilder,
|
|
510
|
+
public readonly fieldSchema: TreeFieldStoredSchema,
|
|
511
|
+
private readonly fieldEncoderFromPolicy: FieldEncoderPolicy,
|
|
489
512
|
) {}
|
|
490
513
|
public encodeField(
|
|
491
514
|
cursor: ITreeCursorSynchronous,
|
|
492
|
-
|
|
515
|
+
context: EncoderContext,
|
|
493
516
|
outputBuffer: BufferFormat,
|
|
494
517
|
): void {
|
|
495
|
-
this.encoder.encodeField(cursor,
|
|
518
|
+
this.encoder.encodeField(cursor, context, outputBuffer);
|
|
496
519
|
}
|
|
497
520
|
|
|
498
521
|
private get encoder(): FieldEncoder {
|
|
499
522
|
if (this.encoderLazy === undefined) {
|
|
500
|
-
this.encoderLazy = this.
|
|
523
|
+
this.encoderLazy = this.fieldEncoderFromPolicy(this.nodeBuilder, this.fieldSchema);
|
|
501
524
|
}
|
|
502
525
|
return this.encoderLazy;
|
|
503
526
|
}
|
|
@@ -24,12 +24,12 @@ export const validVersions = new Set([version]);
|
|
|
24
24
|
* Top level length is implied from length of data array.
|
|
25
25
|
* All content are of this shape.
|
|
26
26
|
*/
|
|
27
|
-
export const
|
|
27
|
+
export const EncodedNestedArrayShape = ShapeIndex;
|
|
28
28
|
|
|
29
29
|
/**
|
|
30
30
|
* Inline array.
|
|
31
31
|
*/
|
|
32
|
-
export const
|
|
32
|
+
export const EncodedInlineArrayShape = Type.Object(
|
|
33
33
|
{
|
|
34
34
|
length: Count,
|
|
35
35
|
/**
|
|
@@ -123,7 +123,7 @@ export enum SpecialField {
|
|
|
123
123
|
* In the future other value shape formats may be added, likely as objects.
|
|
124
124
|
*
|
|
125
125
|
* @remarks
|
|
126
|
-
* See {@link
|
|
126
|
+
* See {@link EncodedNodeShape} for usage.
|
|
127
127
|
*/
|
|
128
128
|
export const EncodedValueShape = Type.Union([
|
|
129
129
|
Type.Boolean(),
|
|
@@ -134,7 +134,7 @@ export const EncodedValueShape = Type.Union([
|
|
|
134
134
|
]);
|
|
135
135
|
export type EncodedValueShape = undefined | Static<typeof EncodedValueShape>;
|
|
136
136
|
|
|
137
|
-
export const
|
|
137
|
+
export const EncodedNodeShape = Type.Object(
|
|
138
138
|
{
|
|
139
139
|
/**
|
|
140
140
|
* If not provided, inlined in data.
|
|
@@ -157,24 +157,30 @@ export const EncodedTreeShape = Type.Object(
|
|
|
157
157
|
);
|
|
158
158
|
|
|
159
159
|
/**
|
|
160
|
-
* Discriminated union of
|
|
160
|
+
* Discriminated union that represents the shapes of chunks in the encoded data.
|
|
161
|
+
* "Chunk" here refers to a chunk of tree data, rooted at a range of nodes, that is encoded as a
|
|
162
|
+
* single unit in a specific format represented by one of the shapes in this union.
|
|
163
|
+
*
|
|
164
|
+
* The concept of "chunk" is same for the tree data in memory and in the encoded wire format.
|
|
165
|
+
* The physical representation of the chunk may differ, but the logical structure remains the same.
|
|
166
|
+
* This is similar to other such concepts in the system.
|
|
161
167
|
*
|
|
162
168
|
* See {@link DiscriminatedUnionDispatcher} for more information on this pattern.
|
|
163
169
|
*/
|
|
164
170
|
export const EncodedChunkShape = Type.Object(
|
|
165
171
|
{
|
|
166
172
|
/**
|
|
167
|
-
* {@link
|
|
173
|
+
* {@link EncodedNestedArrayShape} union member.
|
|
168
174
|
*/
|
|
169
|
-
a: Type.Optional(
|
|
175
|
+
a: Type.Optional(EncodedNestedArrayShape),
|
|
170
176
|
/**
|
|
171
|
-
* {@link
|
|
177
|
+
* {@link EncodedInlineArrayShape} union member.
|
|
172
178
|
*/
|
|
173
|
-
b: Type.Optional(
|
|
179
|
+
b: Type.Optional(EncodedInlineArrayShape),
|
|
174
180
|
/**
|
|
175
|
-
* {@link
|
|
181
|
+
* {@link EncodedNodeShape} union member.
|
|
176
182
|
*/
|
|
177
|
-
c: Type.Optional(
|
|
183
|
+
c: Type.Optional(EncodedNodeShape),
|
|
178
184
|
/**
|
|
179
185
|
* {@link EncodedAnyShape} union member.
|
|
180
186
|
*/
|
|
@@ -185,9 +191,9 @@ export const EncodedChunkShape = Type.Object(
|
|
|
185
191
|
|
|
186
192
|
export type EncodedChunkShape = Static<typeof EncodedChunkShape>;
|
|
187
193
|
|
|
188
|
-
export type
|
|
189
|
-
export type
|
|
190
|
-
export type
|
|
194
|
+
export type EncodedNestedArrayShape = Static<typeof EncodedNestedArrayShape>;
|
|
195
|
+
export type EncodedInlineArrayShape = Static<typeof EncodedInlineArrayShape>;
|
|
196
|
+
export type EncodedNodeShape = Static<typeof EncodedNodeShape>;
|
|
191
197
|
export type EncodedAnyShape = Static<typeof EncodedAnyShape>;
|
|
192
198
|
|
|
193
199
|
export const EncodedFieldBatch = EncodedFieldBatchGeneric(version, EncodedChunkShape);
|
|
@@ -18,7 +18,7 @@ import { brand } from "../../../util/index.js";
|
|
|
18
18
|
import type { Counter, DeduplicationTable } from "./chunkCodecUtilities.js";
|
|
19
19
|
import { type BufferFormat, IdentifierToken, Shape } from "./chunkEncodingGeneric.js";
|
|
20
20
|
import {
|
|
21
|
-
type
|
|
21
|
+
type EncoderContext,
|
|
22
22
|
type FieldEncoder,
|
|
23
23
|
type KeyedFieldEncoder,
|
|
24
24
|
type NodeEncoder,
|
|
@@ -26,9 +26,15 @@ import {
|
|
|
26
26
|
} from "./compressedEncode.js";
|
|
27
27
|
import type { EncodedChunkShape, EncodedFieldShape, EncodedValueShape } from "./format.js";
|
|
28
28
|
|
|
29
|
-
|
|
29
|
+
/**
|
|
30
|
+
* Encodes a node with the {@link EncodedNodeShape} shape.
|
|
31
|
+
* @remarks
|
|
32
|
+
* The fact this is also a Shape is an implementation detail of the encoder: that allows the shape it uses to be itself,
|
|
33
|
+
* which is an easy way to keep all the related code together without extra objects.
|
|
34
|
+
*/
|
|
35
|
+
export class NodeShapeBasedEncoder extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
30
36
|
/**
|
|
31
|
-
* Set of keys for fields that are encoded using {@link
|
|
37
|
+
* Set of keys for fields that are encoded using {@link NodeShapeBasedEncoder.specializedFieldEncoders}.
|
|
32
38
|
* TODO: Ensure uniform chunks, encoding and identifier generation sort fields the same.
|
|
33
39
|
*/
|
|
34
40
|
private readonly specializedFieldKeys: Set<FieldKey>;
|
|
@@ -39,17 +45,17 @@ export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
|
39
45
|
/**
|
|
40
46
|
* Encoders for a specific set of fields, by key, in the order they will be encoded.
|
|
41
47
|
* These are fields for which specialized encoding is provided as an optimization.
|
|
42
|
-
* Using these for a given field instead of falling back to {@link
|
|
48
|
+
* Using these for a given field instead of falling back to {@link NodeShapeBasedEncoder.specializedFieldEncoders} is often more efficient:
|
|
43
49
|
* this avoids the need to explicitly include the key and shape in the encoded data for each node instance.
|
|
44
50
|
* Instead, this information is here, and thus is encoded only once as part of the node shape.
|
|
45
51
|
* These encoders will be used, even if the field they apply to is empty (which can add overhead for fields which are usually empty).
|
|
46
52
|
*
|
|
47
|
-
* Any fields not included here will be encoded using {@link
|
|
48
|
-
* If {@link
|
|
53
|
+
* Any fields not included here will be encoded using {@link NodeShapeBasedEncoder.otherFieldsEncoder}.
|
|
54
|
+
* If {@link NodeShapeBasedEncoder.otherFieldsEncoder} is undefined, then this must handle all non-empty fields.
|
|
49
55
|
*/
|
|
50
56
|
public readonly specializedFieldEncoders: readonly KeyedFieldEncoder[],
|
|
51
57
|
/**
|
|
52
|
-
* Encoder for all other fields that are not in {@link
|
|
58
|
+
* Encoder for all other fields that are not in {@link NodeShapeBasedEncoder.specializedFieldEncoders}. These fields must
|
|
53
59
|
* be encoded after the specialized fields.
|
|
54
60
|
*/
|
|
55
61
|
public readonly otherFieldsEncoder: undefined | FieldEncoder,
|
|
@@ -58,13 +64,13 @@ export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
|
58
64
|
this.specializedFieldKeys = new Set(this.specializedFieldEncoders.map((f) => f.key));
|
|
59
65
|
}
|
|
60
66
|
|
|
61
|
-
private getValueToEncode(cursor: ITreeCursorSynchronous,
|
|
67
|
+
private getValueToEncode(cursor: ITreeCursorSynchronous, context: EncoderContext): Value {
|
|
62
68
|
if (this.value === 0) {
|
|
63
69
|
assert(typeof cursor.value === "string", 0x9aa /* identifier must be type string */);
|
|
64
70
|
if (isStableId(cursor.value)) {
|
|
65
|
-
const sessionSpaceCompressedId =
|
|
71
|
+
const sessionSpaceCompressedId = context.idCompressor.tryRecompress(cursor.value);
|
|
66
72
|
if (sessionSpaceCompressedId !== undefined) {
|
|
67
|
-
return
|
|
73
|
+
return context.idCompressor.normalizeToOpSpace(sessionSpaceCompressedId);
|
|
68
74
|
}
|
|
69
75
|
}
|
|
70
76
|
}
|
|
@@ -73,7 +79,7 @@ export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
|
73
79
|
|
|
74
80
|
public encodeNode(
|
|
75
81
|
cursor: ITreeCursorSynchronous,
|
|
76
|
-
|
|
82
|
+
context: EncoderContext,
|
|
77
83
|
outputBuffer: BufferFormat<EncodedChunkShape>,
|
|
78
84
|
): void {
|
|
79
85
|
if (this.type === undefined) {
|
|
@@ -81,10 +87,10 @@ export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
|
81
87
|
} else {
|
|
82
88
|
assert(cursor.type === this.type, 0x741 /* type must match shape */);
|
|
83
89
|
}
|
|
84
|
-
encodeValue(this.getValueToEncode(cursor,
|
|
90
|
+
encodeValue(this.getValueToEncode(cursor, context), this.value, outputBuffer);
|
|
85
91
|
for (const fieldEncoder of this.specializedFieldEncoders) {
|
|
86
92
|
cursor.enterField(brand(fieldEncoder.key));
|
|
87
|
-
fieldEncoder.encoder.encodeField(cursor,
|
|
93
|
+
fieldEncoder.encoder.encodeField(cursor, context, outputBuffer);
|
|
88
94
|
cursor.exitField();
|
|
89
95
|
}
|
|
90
96
|
|
|
@@ -98,7 +104,7 @@ export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
|
98
104
|
0x742 /* had extra local fields when shape does not support them */,
|
|
99
105
|
);
|
|
100
106
|
otherFieldsBuffer.push(new IdentifierToken(key));
|
|
101
|
-
this.otherFieldsEncoder.encodeField(cursor,
|
|
107
|
+
this.otherFieldsEncoder.encodeField(cursor, context, otherFieldsBuffer);
|
|
102
108
|
}
|
|
103
109
|
});
|
|
104
110
|
|
|
@@ -139,7 +145,7 @@ export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
|
|
|
139
145
|
}
|
|
140
146
|
}
|
|
141
147
|
|
|
142
|
-
public get shape():
|
|
148
|
+
public get shape(): Shape<EncodedChunkShape> {
|
|
143
149
|
return this;
|
|
144
150
|
}
|
|
145
151
|
}
|
|
@@ -175,10 +181,10 @@ function encodeOptionalIdentifier(
|
|
|
175
181
|
}
|
|
176
182
|
|
|
177
183
|
function encodeOptionalFieldShape(
|
|
178
|
-
|
|
184
|
+
encoder: FieldEncoder | undefined,
|
|
179
185
|
shapes: DeduplicationTable<Shape<EncodedChunkShape>>,
|
|
180
186
|
): number | undefined {
|
|
181
|
-
return
|
|
187
|
+
return encoder === undefined ? undefined : dedupShape(encoder.shape, shapes);
|
|
182
188
|
}
|
|
183
189
|
|
|
184
190
|
function dedupShape(
|