@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.
Files changed (730) hide show
  1. package/.vscode/settings.json +0 -1
  2. package/CHANGELOG.md +43 -0
  3. package/api-report/tree.alpha.api.md +40 -30
  4. package/dist/alpha.d.ts +2 -1
  5. package/dist/codec/codec.d.ts +2 -1
  6. package/dist/codec/codec.d.ts.map +1 -1
  7. package/dist/codec/codec.js +4 -3
  8. package/dist/codec/codec.js.map +1 -1
  9. package/dist/core/index.d.ts +1 -1
  10. package/dist/core/index.d.ts.map +1 -1
  11. package/dist/core/index.js +3 -2
  12. package/dist/core/index.js.map +1 -1
  13. package/dist/core/rebase/index.d.ts +1 -1
  14. package/dist/core/rebase/index.d.ts.map +1 -1
  15. package/dist/core/rebase/index.js +2 -1
  16. package/dist/core/rebase/index.js.map +1 -1
  17. package/dist/core/rebase/types.d.ts +3 -1
  18. package/dist/core/rebase/types.d.ts.map +1 -1
  19. package/dist/core/rebase/types.js +2 -1
  20. package/dist/core/rebase/types.js.map +1 -1
  21. package/dist/core/schema-stored/schema.d.ts +1 -23
  22. package/dist/core/schema-stored/schema.d.ts.map +1 -1
  23. package/dist/core/schema-stored/schema.js +2 -2
  24. package/dist/core/schema-stored/schema.js.map +1 -1
  25. package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
  26. package/dist/core/tree/detachedFieldIndex.js +2 -3
  27. package/dist/core/tree/detachedFieldIndex.js.map +1 -1
  28. package/dist/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
  29. package/dist/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
  30. package/dist/core/tree/detachedFieldIndexCodecCommon.js +68 -0
  31. package/dist/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
  32. package/dist/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
  33. package/dist/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
  34. package/dist/core/tree/detachedFieldIndexCodecV1.js +55 -0
  35. package/dist/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
  36. package/dist/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
  37. package/dist/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
  38. package/dist/core/tree/detachedFieldIndexCodecV2.js +49 -0
  39. package/dist/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
  40. package/dist/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
  41. package/dist/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
  42. package/dist/core/tree/detachedFieldIndexCodecs.js +26 -0
  43. package/dist/core/tree/detachedFieldIndexCodecs.js.map +1 -0
  44. package/dist/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
  45. package/dist/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
  46. package/dist/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +18 -13
  47. package/dist/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
  48. package/dist/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
  49. package/dist/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
  50. package/dist/core/tree/detachedFieldIndexFormatV1.js +12 -0
  51. package/dist/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
  52. package/dist/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
  53. package/dist/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
  54. package/dist/core/tree/detachedFieldIndexFormatV2.js +14 -0
  55. package/dist/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
  56. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
  57. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  58. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js +21 -21
  59. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  60. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
  61. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  62. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
  63. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  64. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
  65. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  66. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js +74 -61
  67. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  68. package/dist/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
  69. package/dist/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
  70. package/dist/feature-libraries/chunked-forest/codec/format.js +18 -12
  71. package/dist/feature-libraries/chunked-forest/codec/format.js.map +1 -1
  72. package/{lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts → dist/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
  73. package/dist/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
  74. package/dist/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +23 -17
  75. package/dist/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
  76. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
  77. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  78. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +22 -22
  79. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  80. package/dist/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
  81. package/dist/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
  82. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
  83. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  84. package/dist/feature-libraries/default-schema/defaultFieldKinds.js +15 -2
  85. package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  86. package/dist/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
  87. package/dist/feature-libraries/default-schema/defaultSchema.js +0 -2
  88. package/dist/feature-libraries/default-schema/defaultSchema.js.map +1 -1
  89. package/dist/feature-libraries/default-schema/index.d.ts +1 -1
  90. package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
  91. package/dist/feature-libraries/default-schema/index.js +2 -2
  92. package/dist/feature-libraries/default-schema/index.js.map +1 -1
  93. package/dist/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
  94. package/dist/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  95. package/dist/feature-libraries/default-schema/schemaChecker.js +31 -26
  96. package/dist/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  97. package/dist/feature-libraries/index.d.ts +1 -2
  98. package/dist/feature-libraries/index.d.ts.map +1 -1
  99. package/dist/feature-libraries/index.js +2 -4
  100. package/dist/feature-libraries/index.js.map +1 -1
  101. package/dist/feature-libraries/modular-schema/comparison.d.ts +5 -6
  102. package/dist/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
  103. package/dist/feature-libraries/modular-schema/comparison.js +15 -16
  104. package/dist/feature-libraries/modular-schema/comparison.js.map +1 -1
  105. package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts +7 -0
  106. package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
  107. package/dist/feature-libraries/modular-schema/fieldChangeHandler.js +1 -0
  108. package/dist/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
  109. package/dist/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
  110. package/dist/feature-libraries/modular-schema/genericFieldKind.js +1 -0
  111. package/dist/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
  112. package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts +9 -1
  113. package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
  114. package/dist/feature-libraries/modular-schema/modularChangeFamily.js +49 -20
  115. package/dist/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
  116. package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
  117. package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
  118. package/dist/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  119. package/dist/feature-libraries/object-forest/objectForest.js +2 -3
  120. package/dist/feature-libraries/object-forest/objectForest.js.map +1 -1
  121. package/dist/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
  122. package/dist/feature-libraries/optional-field/optionalField.js +3 -0
  123. package/dist/feature-libraries/optional-field/optionalField.js.map +1 -1
  124. package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts +1 -0
  125. package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts.map +1 -1
  126. package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js +4 -0
  127. package/dist/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js.map +1 -1
  128. package/dist/index.d.ts +1 -1
  129. package/dist/index.d.ts.map +1 -1
  130. package/dist/index.js +6 -2
  131. package/dist/index.js.map +1 -1
  132. package/dist/jsonDomainSchema.d.ts +5 -3
  133. package/dist/jsonDomainSchema.d.ts.map +1 -1
  134. package/dist/jsonDomainSchema.js.map +1 -1
  135. package/dist/packageVersion.d.ts +1 -1
  136. package/dist/packageVersion.d.ts.map +1 -1
  137. package/dist/packageVersion.js +1 -1
  138. package/dist/packageVersion.js.map +1 -1
  139. package/dist/shared-tree/independentView.d.ts +8 -0
  140. package/dist/shared-tree/independentView.d.ts.map +1 -1
  141. package/dist/shared-tree/independentView.js +23 -11
  142. package/dist/shared-tree/independentView.js.map +1 -1
  143. package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
  144. package/dist/shared-tree/schematizeTree.js +1 -1
  145. package/dist/shared-tree/schematizeTree.js.map +1 -1
  146. package/dist/shared-tree/schematizingTreeView.d.ts +0 -1
  147. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  148. package/dist/shared-tree/schematizingTreeView.js +9 -12
  149. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  150. package/dist/shared-tree/sharedTree.d.ts.map +1 -1
  151. package/dist/shared-tree/sharedTree.js +1 -29
  152. package/dist/shared-tree/sharedTree.js.map +1 -1
  153. package/dist/shared-tree/treeAlpha.d.ts +20 -6
  154. package/dist/shared-tree/treeAlpha.d.ts.map +1 -1
  155. package/dist/shared-tree/treeAlpha.js +18 -7
  156. package/dist/shared-tree/treeAlpha.js.map +1 -1
  157. package/dist/shared-tree/treeCheckout.d.ts +2 -1
  158. package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
  159. package/dist/shared-tree/treeCheckout.js +32 -0
  160. package/dist/shared-tree/treeCheckout.js.map +1 -1
  161. package/dist/shared-tree-core/branch.d.ts.map +1 -1
  162. package/dist/shared-tree-core/branch.js +1 -1
  163. package/dist/shared-tree-core/branch.js.map +1 -1
  164. package/dist/simple-tree/api/conciseTree.d.ts +2 -2
  165. package/dist/simple-tree/api/conciseTree.d.ts.map +1 -1
  166. package/dist/simple-tree/api/conciseTree.js +6 -6
  167. package/dist/simple-tree/api/conciseTree.js.map +1 -1
  168. package/dist/simple-tree/api/configuration.d.ts +11 -2
  169. package/dist/simple-tree/api/configuration.d.ts.map +1 -1
  170. package/dist/simple-tree/api/configuration.js +5 -1
  171. package/dist/simple-tree/api/configuration.js.map +1 -1
  172. package/dist/simple-tree/api/create.d.ts +8 -7
  173. package/dist/simple-tree/api/create.d.ts.map +1 -1
  174. package/dist/simple-tree/api/create.js +33 -23
  175. package/dist/simple-tree/api/create.js.map +1 -1
  176. package/dist/simple-tree/api/customTree.d.ts +25 -4
  177. package/dist/simple-tree/api/customTree.d.ts.map +1 -1
  178. package/dist/simple-tree/api/customTree.js +42 -16
  179. package/dist/simple-tree/api/customTree.js.map +1 -1
  180. package/dist/simple-tree/api/discrepancies.d.ts +94 -0
  181. package/dist/simple-tree/api/discrepancies.d.ts.map +1 -0
  182. package/dist/simple-tree/api/discrepancies.js +256 -0
  183. package/dist/simple-tree/api/discrepancies.js.map +1 -0
  184. package/dist/simple-tree/api/index.d.ts +3 -2
  185. package/dist/simple-tree/api/index.d.ts.map +1 -1
  186. package/dist/simple-tree/api/index.js +3 -2
  187. package/dist/simple-tree/api/index.js.map +1 -1
  188. package/dist/simple-tree/api/schemaCompatibilityTester.d.ts +9 -7
  189. package/dist/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
  190. package/dist/simple-tree/api/schemaCompatibilityTester.js +17 -117
  191. package/dist/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
  192. package/dist/simple-tree/api/schemaFactory.d.ts +16 -159
  193. package/dist/simple-tree/api/schemaFactory.d.ts.map +1 -1
  194. package/dist/simple-tree/api/schemaFactory.js +4 -47
  195. package/dist/simple-tree/api/schemaFactory.js.map +1 -1
  196. package/dist/simple-tree/api/schemaFactoryAlpha.d.ts +157 -16
  197. package/dist/simple-tree/api/schemaFactoryAlpha.d.ts.map +1 -1
  198. package/dist/simple-tree/api/schemaFactoryAlpha.js +33 -11
  199. package/dist/simple-tree/api/schemaFactoryAlpha.js.map +1 -1
  200. package/dist/simple-tree/api/schemaFactoryRecursive.d.ts +1 -3
  201. package/dist/simple-tree/api/schemaFactoryRecursive.d.ts.map +1 -1
  202. package/dist/simple-tree/api/schemaFactoryRecursive.js +1 -7
  203. package/dist/simple-tree/api/schemaFactoryRecursive.js.map +1 -1
  204. package/dist/simple-tree/api/schemaStatics.d.ts +158 -0
  205. package/dist/simple-tree/api/schemaStatics.d.ts.map +1 -0
  206. package/dist/simple-tree/api/schemaStatics.js +59 -0
  207. package/dist/simple-tree/api/schemaStatics.js.map +1 -0
  208. package/dist/simple-tree/api/storedSchema.d.ts +5 -3
  209. package/dist/simple-tree/api/storedSchema.d.ts.map +1 -1
  210. package/dist/simple-tree/api/storedSchema.js +9 -3
  211. package/dist/simple-tree/api/storedSchema.js.map +1 -1
  212. package/dist/simple-tree/api/treeBeta.d.ts +2 -2
  213. package/dist/simple-tree/api/treeBeta.d.ts.map +1 -1
  214. package/dist/simple-tree/api/treeBeta.js +16 -4
  215. package/dist/simple-tree/api/treeBeta.js.map +1 -1
  216. package/dist/simple-tree/api/verboseTree.d.ts +2 -2
  217. package/dist/simple-tree/api/verboseTree.d.ts.map +1 -1
  218. package/dist/simple-tree/api/verboseTree.js +15 -15
  219. package/dist/simple-tree/api/verboseTree.js.map +1 -1
  220. package/dist/simple-tree/core/allowedTypes.d.ts +43 -11
  221. package/dist/simple-tree/core/allowedTypes.d.ts.map +1 -1
  222. package/dist/simple-tree/core/allowedTypes.js +51 -11
  223. package/dist/simple-tree/core/allowedTypes.js.map +1 -1
  224. package/dist/simple-tree/core/context.d.ts +13 -2
  225. package/dist/simple-tree/core/context.d.ts.map +1 -1
  226. package/dist/simple-tree/core/context.js +22 -9
  227. package/dist/simple-tree/core/context.js.map +1 -1
  228. package/dist/simple-tree/core/index.d.ts +6 -4
  229. package/dist/simple-tree/core/index.d.ts.map +1 -1
  230. package/dist/simple-tree/core/index.js +8 -1
  231. package/dist/simple-tree/core/index.js.map +1 -1
  232. package/dist/simple-tree/core/simpleNodeSchemaBase.d.ts +25 -0
  233. package/dist/simple-tree/core/simpleNodeSchemaBase.d.ts.map +1 -0
  234. package/dist/simple-tree/core/simpleNodeSchemaBase.js +7 -0
  235. package/dist/simple-tree/core/simpleNodeSchemaBase.js.map +1 -0
  236. package/dist/simple-tree/core/toStored.d.ts +32 -0
  237. package/dist/simple-tree/core/toStored.d.ts.map +1 -0
  238. package/dist/simple-tree/core/toStored.js +37 -0
  239. package/dist/simple-tree/core/toStored.js.map +1 -0
  240. package/dist/simple-tree/core/treeNodeKernel.d.ts +1 -1
  241. package/dist/simple-tree/core/treeNodeKernel.js +1 -1
  242. package/dist/simple-tree/core/treeNodeKernel.js.map +1 -1
  243. package/dist/simple-tree/core/treeNodeSchema.d.ts +7 -2
  244. package/dist/simple-tree/core/treeNodeSchema.d.ts.map +1 -1
  245. package/dist/simple-tree/core/treeNodeSchema.js.map +1 -1
  246. package/dist/simple-tree/core/treeNodeValid.d.ts +7 -2
  247. package/dist/simple-tree/core/treeNodeValid.d.ts.map +1 -1
  248. package/dist/simple-tree/core/treeNodeValid.js +19 -4
  249. package/dist/simple-tree/core/treeNodeValid.js.map +1 -1
  250. package/dist/simple-tree/core/walkSchema.d.ts +22 -5
  251. package/dist/simple-tree/core/walkSchema.d.ts.map +1 -1
  252. package/dist/simple-tree/core/walkSchema.js +6 -2
  253. package/dist/simple-tree/core/walkSchema.js.map +1 -1
  254. package/dist/simple-tree/createContext.d.ts +2 -0
  255. package/dist/simple-tree/createContext.d.ts.map +1 -1
  256. package/dist/simple-tree/createContext.js +4 -2
  257. package/dist/simple-tree/createContext.js.map +1 -1
  258. package/dist/simple-tree/fieldSchema.d.ts +1 -0
  259. package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
  260. package/dist/simple-tree/fieldSchema.js +2 -1
  261. package/dist/simple-tree/fieldSchema.js.map +1 -1
  262. package/dist/simple-tree/index.d.ts +7 -7
  263. package/dist/simple-tree/index.d.ts.map +1 -1
  264. package/dist/simple-tree/index.js +13 -8
  265. package/dist/simple-tree/index.js.map +1 -1
  266. package/dist/simple-tree/leafNodeSchema.d.ts.map +1 -1
  267. package/dist/simple-tree/leafNodeSchema.js +1 -0
  268. package/dist/simple-tree/leafNodeSchema.js.map +1 -1
  269. package/dist/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  270. package/dist/simple-tree/node-kinds/array/arrayNode.js +18 -4
  271. package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  272. package/dist/simple-tree/node-kinds/index.d.ts +1 -1
  273. package/dist/simple-tree/node-kinds/index.d.ts.map +1 -1
  274. package/dist/simple-tree/node-kinds/index.js +1 -2
  275. package/dist/simple-tree/node-kinds/index.js.map +1 -1
  276. package/dist/simple-tree/node-kinds/map/mapNode.d.ts.map +1 -1
  277. package/dist/simple-tree/node-kinds/map/mapNode.js +9 -2
  278. package/dist/simple-tree/node-kinds/map/mapNode.js.map +1 -1
  279. package/dist/simple-tree/node-kinds/object/index.d.ts +1 -1
  280. package/dist/simple-tree/node-kinds/object/index.d.ts.map +1 -1
  281. package/dist/simple-tree/node-kinds/object/index.js +1 -2
  282. package/dist/simple-tree/node-kinds/object/index.js.map +1 -1
  283. package/dist/simple-tree/node-kinds/object/objectNode.d.ts +3 -8
  284. package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  285. package/dist/simple-tree/node-kinds/object/objectNode.js +41 -44
  286. package/dist/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  287. package/dist/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
  288. package/dist/simple-tree/node-kinds/record/recordNode.js +9 -2
  289. package/dist/simple-tree/node-kinds/record/recordNode.js.map +1 -1
  290. package/dist/simple-tree/prepareForInsertion.d.ts +6 -6
  291. package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
  292. package/dist/simple-tree/prepareForInsertion.js +19 -13
  293. package/dist/simple-tree/prepareForInsertion.js.map +1 -1
  294. package/dist/simple-tree/simpleSchema.d.ts +6 -21
  295. package/dist/simple-tree/simpleSchema.d.ts.map +1 -1
  296. package/dist/simple-tree/simpleSchema.js.map +1 -1
  297. package/dist/simple-tree/toStoredSchema.d.ts +38 -11
  298. package/dist/simple-tree/toStoredSchema.d.ts.map +1 -1
  299. package/dist/simple-tree/toStoredSchema.js +71 -33
  300. package/dist/simple-tree/toStoredSchema.js.map +1 -1
  301. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
  302. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  303. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  304. package/dist/simple-tree/walkFieldSchema.d.ts +1 -0
  305. package/dist/simple-tree/walkFieldSchema.d.ts.map +1 -1
  306. package/dist/simple-tree/walkFieldSchema.js +1 -0
  307. package/dist/simple-tree/walkFieldSchema.js.map +1 -1
  308. package/lib/alpha.d.ts +2 -1
  309. package/lib/codec/codec.d.ts +2 -1
  310. package/lib/codec/codec.d.ts.map +1 -1
  311. package/lib/codec/codec.js +4 -3
  312. package/lib/codec/codec.js.map +1 -1
  313. package/lib/core/index.d.ts +1 -1
  314. package/lib/core/index.d.ts.map +1 -1
  315. package/lib/core/index.js +1 -1
  316. package/lib/core/index.js.map +1 -1
  317. package/lib/core/rebase/index.d.ts +1 -1
  318. package/lib/core/rebase/index.d.ts.map +1 -1
  319. package/lib/core/rebase/index.js +1 -1
  320. package/lib/core/rebase/index.js.map +1 -1
  321. package/lib/core/rebase/types.d.ts +3 -1
  322. package/lib/core/rebase/types.d.ts.map +1 -1
  323. package/lib/core/rebase/types.js +1 -0
  324. package/lib/core/rebase/types.js.map +1 -1
  325. package/lib/core/schema-stored/schema.d.ts +1 -23
  326. package/lib/core/schema-stored/schema.d.ts.map +1 -1
  327. package/lib/core/schema-stored/schema.js +2 -2
  328. package/lib/core/schema-stored/schema.js.map +1 -1
  329. package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
  330. package/lib/core/tree/detachedFieldIndex.js +2 -3
  331. package/lib/core/tree/detachedFieldIndex.js.map +1 -1
  332. package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
  333. package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
  334. package/lib/core/tree/detachedFieldIndexCodecCommon.js +64 -0
  335. package/lib/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
  336. package/lib/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
  337. package/lib/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
  338. package/lib/core/tree/detachedFieldIndexCodecV1.js +51 -0
  339. package/lib/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
  340. package/lib/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
  341. package/lib/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
  342. package/lib/core/tree/detachedFieldIndexCodecV2.js +45 -0
  343. package/lib/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
  344. package/lib/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
  345. package/lib/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
  346. package/lib/core/tree/detachedFieldIndexCodecs.js +21 -0
  347. package/lib/core/tree/detachedFieldIndexCodecs.js.map +1 -0
  348. package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
  349. package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
  350. package/lib/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +13 -10
  351. package/lib/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
  352. package/lib/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
  353. package/lib/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
  354. package/lib/core/tree/detachedFieldIndexFormatV1.js +9 -0
  355. package/lib/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
  356. package/lib/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
  357. package/lib/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
  358. package/lib/core/tree/detachedFieldIndexFormatV2.js +11 -0
  359. package/lib/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
  360. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
  361. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  362. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js +19 -19
  363. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  364. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
  365. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  366. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
  367. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  368. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
  369. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  370. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js +70 -57
  371. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  372. package/lib/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
  373. package/lib/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
  374. package/lib/feature-libraries/chunked-forest/codec/format.js +17 -11
  375. package/lib/feature-libraries/chunked-forest/codec/format.js.map +1 -1
  376. package/{dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts → lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
  377. package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
  378. package/lib/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +21 -15
  379. package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
  380. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
  381. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  382. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +19 -19
  383. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  384. package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
  385. package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
  386. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
  387. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  388. package/lib/feature-libraries/default-schema/defaultFieldKinds.js +15 -2
  389. package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  390. package/lib/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
  391. package/lib/feature-libraries/default-schema/defaultSchema.js +0 -2
  392. package/lib/feature-libraries/default-schema/defaultSchema.js.map +1 -1
  393. package/lib/feature-libraries/default-schema/index.d.ts +1 -1
  394. package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
  395. package/lib/feature-libraries/default-schema/index.js +1 -1
  396. package/lib/feature-libraries/default-schema/index.js.map +1 -1
  397. package/lib/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
  398. package/lib/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  399. package/lib/feature-libraries/default-schema/schemaChecker.js +29 -24
  400. package/lib/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  401. package/lib/feature-libraries/index.d.ts +1 -2
  402. package/lib/feature-libraries/index.d.ts.map +1 -1
  403. package/lib/feature-libraries/index.js +1 -2
  404. package/lib/feature-libraries/index.js.map +1 -1
  405. package/lib/feature-libraries/modular-schema/comparison.d.ts +5 -6
  406. package/lib/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
  407. package/lib/feature-libraries/modular-schema/comparison.js +14 -14
  408. package/lib/feature-libraries/modular-schema/comparison.js.map +1 -1
  409. package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts +7 -0
  410. package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
  411. package/lib/feature-libraries/modular-schema/fieldChangeHandler.js +1 -0
  412. package/lib/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
  413. package/lib/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
  414. package/lib/feature-libraries/modular-schema/genericFieldKind.js +1 -0
  415. package/lib/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
  416. package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts +9 -1
  417. package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
  418. package/lib/feature-libraries/modular-schema/modularChangeFamily.js +50 -21
  419. package/lib/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
  420. package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
  421. package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
  422. package/lib/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  423. package/lib/feature-libraries/object-forest/objectForest.js +3 -4
  424. package/lib/feature-libraries/object-forest/objectForest.js.map +1 -1
  425. package/lib/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
  426. package/lib/feature-libraries/optional-field/optionalField.js +3 -0
  427. package/lib/feature-libraries/optional-field/optionalField.js.map +1 -1
  428. package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts +1 -0
  429. package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.d.ts.map +1 -1
  430. package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js +4 -0
  431. package/lib/feature-libraries/sequence-field/sequenceFieldChangeRebaser.js.map +1 -1
  432. package/lib/index.d.ts +1 -1
  433. package/lib/index.d.ts.map +1 -1
  434. package/lib/index.js +2 -2
  435. package/lib/index.js.map +1 -1
  436. package/lib/jsonDomainSchema.d.ts +5 -3
  437. package/lib/jsonDomainSchema.d.ts.map +1 -1
  438. package/lib/jsonDomainSchema.js.map +1 -1
  439. package/lib/packageVersion.d.ts +1 -1
  440. package/lib/packageVersion.d.ts.map +1 -1
  441. package/lib/packageVersion.js +1 -1
  442. package/lib/packageVersion.js.map +1 -1
  443. package/lib/shared-tree/independentView.d.ts +8 -0
  444. package/lib/shared-tree/independentView.d.ts.map +1 -1
  445. package/lib/shared-tree/independentView.js +21 -10
  446. package/lib/shared-tree/independentView.js.map +1 -1
  447. package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
  448. package/lib/shared-tree/schematizeTree.js +2 -2
  449. package/lib/shared-tree/schematizeTree.js.map +1 -1
  450. package/lib/shared-tree/schematizingTreeView.d.ts +0 -1
  451. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  452. package/lib/shared-tree/schematizingTreeView.js +10 -13
  453. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  454. package/lib/shared-tree/sharedTree.d.ts.map +1 -1
  455. package/lib/shared-tree/sharedTree.js +2 -30
  456. package/lib/shared-tree/sharedTree.js.map +1 -1
  457. package/lib/shared-tree/treeAlpha.d.ts +20 -6
  458. package/lib/shared-tree/treeAlpha.d.ts.map +1 -1
  459. package/lib/shared-tree/treeAlpha.js +19 -8
  460. package/lib/shared-tree/treeAlpha.js.map +1 -1
  461. package/lib/shared-tree/treeCheckout.d.ts +2 -1
  462. package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
  463. package/lib/shared-tree/treeCheckout.js +33 -1
  464. package/lib/shared-tree/treeCheckout.js.map +1 -1
  465. package/lib/shared-tree-core/branch.d.ts.map +1 -1
  466. package/lib/shared-tree-core/branch.js +1 -1
  467. package/lib/shared-tree-core/branch.js.map +1 -1
  468. package/lib/simple-tree/api/conciseTree.d.ts +2 -2
  469. package/lib/simple-tree/api/conciseTree.d.ts.map +1 -1
  470. package/lib/simple-tree/api/conciseTree.js +6 -6
  471. package/lib/simple-tree/api/conciseTree.js.map +1 -1
  472. package/lib/simple-tree/api/configuration.d.ts +11 -2
  473. package/lib/simple-tree/api/configuration.d.ts.map +1 -1
  474. package/lib/simple-tree/api/configuration.js +6 -2
  475. package/lib/simple-tree/api/configuration.js.map +1 -1
  476. package/lib/simple-tree/api/create.d.ts +8 -7
  477. package/lib/simple-tree/api/create.d.ts.map +1 -1
  478. package/lib/simple-tree/api/create.js +35 -25
  479. package/lib/simple-tree/api/create.js.map +1 -1
  480. package/lib/simple-tree/api/customTree.d.ts +25 -4
  481. package/lib/simple-tree/api/customTree.d.ts.map +1 -1
  482. package/lib/simple-tree/api/customTree.js +43 -17
  483. package/lib/simple-tree/api/customTree.js.map +1 -1
  484. package/lib/simple-tree/api/discrepancies.d.ts +94 -0
  485. package/lib/simple-tree/api/discrepancies.d.ts.map +1 -0
  486. package/lib/simple-tree/api/discrepancies.js +251 -0
  487. package/lib/simple-tree/api/discrepancies.js.map +1 -0
  488. package/lib/simple-tree/api/index.d.ts +3 -2
  489. package/lib/simple-tree/api/index.d.ts.map +1 -1
  490. package/lib/simple-tree/api/index.js +2 -1
  491. package/lib/simple-tree/api/index.js.map +1 -1
  492. package/lib/simple-tree/api/schemaCompatibilityTester.d.ts +9 -7
  493. package/lib/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
  494. package/lib/simple-tree/api/schemaCompatibilityTester.js +19 -119
  495. package/lib/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
  496. package/lib/simple-tree/api/schemaFactory.d.ts +16 -159
  497. package/lib/simple-tree/api/schemaFactory.d.ts.map +1 -1
  498. package/lib/simple-tree/api/schemaFactory.js +2 -45
  499. package/lib/simple-tree/api/schemaFactory.js.map +1 -1
  500. package/lib/simple-tree/api/schemaFactoryAlpha.d.ts +157 -16
  501. package/lib/simple-tree/api/schemaFactoryAlpha.d.ts.map +1 -1
  502. package/lib/simple-tree/api/schemaFactoryAlpha.js +23 -1
  503. package/lib/simple-tree/api/schemaFactoryAlpha.js.map +1 -1
  504. package/lib/simple-tree/api/schemaFactoryRecursive.d.ts +1 -3
  505. package/lib/simple-tree/api/schemaFactoryRecursive.d.ts.map +1 -1
  506. package/lib/simple-tree/api/schemaFactoryRecursive.js +0 -5
  507. package/lib/simple-tree/api/schemaFactoryRecursive.js.map +1 -1
  508. package/lib/simple-tree/api/schemaStatics.d.ts +158 -0
  509. package/lib/simple-tree/api/schemaStatics.d.ts.map +1 -0
  510. package/lib/simple-tree/api/schemaStatics.js +56 -0
  511. package/lib/simple-tree/api/schemaStatics.js.map +1 -0
  512. package/lib/simple-tree/api/storedSchema.d.ts +5 -3
  513. package/lib/simple-tree/api/storedSchema.d.ts.map +1 -1
  514. package/lib/simple-tree/api/storedSchema.js +12 -6
  515. package/lib/simple-tree/api/storedSchema.js.map +1 -1
  516. package/lib/simple-tree/api/treeBeta.d.ts +2 -2
  517. package/lib/simple-tree/api/treeBeta.d.ts.map +1 -1
  518. package/lib/simple-tree/api/treeBeta.js +14 -2
  519. package/lib/simple-tree/api/treeBeta.js.map +1 -1
  520. package/lib/simple-tree/api/verboseTree.d.ts +2 -2
  521. package/lib/simple-tree/api/verboseTree.d.ts.map +1 -1
  522. package/lib/simple-tree/api/verboseTree.js +9 -9
  523. package/lib/simple-tree/api/verboseTree.js.map +1 -1
  524. package/lib/simple-tree/core/allowedTypes.d.ts +43 -11
  525. package/lib/simple-tree/core/allowedTypes.d.ts.map +1 -1
  526. package/lib/simple-tree/core/allowedTypes.js +52 -11
  527. package/lib/simple-tree/core/allowedTypes.js.map +1 -1
  528. package/lib/simple-tree/core/context.d.ts +13 -2
  529. package/lib/simple-tree/core/context.d.ts.map +1 -1
  530. package/lib/simple-tree/core/context.js +22 -9
  531. package/lib/simple-tree/core/context.js.map +1 -1
  532. package/lib/simple-tree/core/index.d.ts +6 -4
  533. package/lib/simple-tree/core/index.d.ts.map +1 -1
  534. package/lib/simple-tree/core/index.js +4 -3
  535. package/lib/simple-tree/core/index.js.map +1 -1
  536. package/lib/simple-tree/core/simpleNodeSchemaBase.d.ts +25 -0
  537. package/lib/simple-tree/core/simpleNodeSchemaBase.d.ts.map +1 -0
  538. package/lib/simple-tree/core/simpleNodeSchemaBase.js +6 -0
  539. package/lib/simple-tree/core/simpleNodeSchemaBase.js.map +1 -0
  540. package/lib/simple-tree/core/toStored.d.ts +32 -0
  541. package/lib/simple-tree/core/toStored.d.ts.map +1 -0
  542. package/lib/simple-tree/core/toStored.js +32 -0
  543. package/lib/simple-tree/core/toStored.js.map +1 -0
  544. package/lib/simple-tree/core/treeNodeKernel.d.ts +1 -1
  545. package/lib/simple-tree/core/treeNodeKernel.js +1 -1
  546. package/lib/simple-tree/core/treeNodeKernel.js.map +1 -1
  547. package/lib/simple-tree/core/treeNodeSchema.d.ts +7 -2
  548. package/lib/simple-tree/core/treeNodeSchema.d.ts.map +1 -1
  549. package/lib/simple-tree/core/treeNodeSchema.js.map +1 -1
  550. package/lib/simple-tree/core/treeNodeValid.d.ts +7 -2
  551. package/lib/simple-tree/core/treeNodeValid.d.ts.map +1 -1
  552. package/lib/simple-tree/core/treeNodeValid.js +17 -3
  553. package/lib/simple-tree/core/treeNodeValid.js.map +1 -1
  554. package/lib/simple-tree/core/walkSchema.d.ts +22 -5
  555. package/lib/simple-tree/core/walkSchema.d.ts.map +1 -1
  556. package/lib/simple-tree/core/walkSchema.js +6 -2
  557. package/lib/simple-tree/core/walkSchema.js.map +1 -1
  558. package/lib/simple-tree/createContext.d.ts +2 -0
  559. package/lib/simple-tree/createContext.d.ts.map +1 -1
  560. package/lib/simple-tree/createContext.js +5 -3
  561. package/lib/simple-tree/createContext.js.map +1 -1
  562. package/lib/simple-tree/fieldSchema.d.ts +1 -0
  563. package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
  564. package/lib/simple-tree/fieldSchema.js +2 -1
  565. package/lib/simple-tree/fieldSchema.js.map +1 -1
  566. package/lib/simple-tree/index.d.ts +7 -7
  567. package/lib/simple-tree/index.d.ts.map +1 -1
  568. package/lib/simple-tree/index.js +5 -5
  569. package/lib/simple-tree/index.js.map +1 -1
  570. package/lib/simple-tree/leafNodeSchema.d.ts.map +1 -1
  571. package/lib/simple-tree/leafNodeSchema.js +2 -1
  572. package/lib/simple-tree/leafNodeSchema.js.map +1 -1
  573. package/lib/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  574. package/lib/simple-tree/node-kinds/array/arrayNode.js +21 -7
  575. package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  576. package/lib/simple-tree/node-kinds/index.d.ts +1 -1
  577. package/lib/simple-tree/node-kinds/index.d.ts.map +1 -1
  578. package/lib/simple-tree/node-kinds/index.js +1 -1
  579. package/lib/simple-tree/node-kinds/index.js.map +1 -1
  580. package/lib/simple-tree/node-kinds/map/mapNode.d.ts.map +1 -1
  581. package/lib/simple-tree/node-kinds/map/mapNode.js +12 -5
  582. package/lib/simple-tree/node-kinds/map/mapNode.js.map +1 -1
  583. package/lib/simple-tree/node-kinds/object/index.d.ts +1 -1
  584. package/lib/simple-tree/node-kinds/object/index.d.ts.map +1 -1
  585. package/lib/simple-tree/node-kinds/object/index.js +1 -1
  586. package/lib/simple-tree/node-kinds/object/index.js.map +1 -1
  587. package/lib/simple-tree/node-kinds/object/objectNode.d.ts +3 -8
  588. package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  589. package/lib/simple-tree/node-kinds/object/objectNode.js +19 -21
  590. package/lib/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  591. package/lib/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
  592. package/lib/simple-tree/node-kinds/record/recordNode.js +12 -5
  593. package/lib/simple-tree/node-kinds/record/recordNode.js.map +1 -1
  594. package/lib/simple-tree/prepareForInsertion.d.ts +6 -6
  595. package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
  596. package/lib/simple-tree/prepareForInsertion.js +21 -15
  597. package/lib/simple-tree/prepareForInsertion.js.map +1 -1
  598. package/lib/simple-tree/simpleSchema.d.ts +6 -21
  599. package/lib/simple-tree/simpleSchema.d.ts.map +1 -1
  600. package/lib/simple-tree/simpleSchema.js.map +1 -1
  601. package/lib/simple-tree/toStoredSchema.d.ts +38 -11
  602. package/lib/simple-tree/toStoredSchema.d.ts.map +1 -1
  603. package/lib/simple-tree/toStoredSchema.js +70 -34
  604. package/lib/simple-tree/toStoredSchema.js.map +1 -1
  605. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
  606. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  607. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +1 -1
  608. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  609. package/lib/simple-tree/walkFieldSchema.d.ts +1 -0
  610. package/lib/simple-tree/walkFieldSchema.d.ts.map +1 -1
  611. package/lib/simple-tree/walkFieldSchema.js +1 -0
  612. package/lib/simple-tree/walkFieldSchema.js.map +1 -1
  613. package/package.json +23 -23
  614. package/src/codec/codec.ts +4 -3
  615. package/src/core/index.ts +2 -0
  616. package/src/core/rebase/index.ts +2 -0
  617. package/src/core/rebase/types.ts +4 -0
  618. package/src/core/schema-stored/schema.ts +2 -26
  619. package/src/core/tree/detachedFieldIndex.ts +4 -6
  620. package/src/core/tree/detachedFieldIndexCodecCommon.ts +87 -0
  621. package/src/core/tree/{detachedFieldIndexCodec.ts → detachedFieldIndexCodecV1.ts} +22 -68
  622. package/src/core/tree/detachedFieldIndexCodecV2.ts +72 -0
  623. package/src/core/tree/detachedFieldIndexCodecs.ts +44 -0
  624. package/src/core/tree/{detachedFieldIndexFormat.ts → detachedFieldIndexFormatCommon.ts} +32 -23
  625. package/src/core/tree/detachedFieldIndexFormatV1.ts +15 -0
  626. package/src/core/tree/detachedFieldIndexFormatV2.ts +17 -0
  627. package/src/feature-libraries/chunked-forest/codec/README.md +1 -1
  628. package/src/feature-libraries/chunked-forest/codec/chunkDecoding.ts +25 -25
  629. package/src/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.ts +10 -6
  630. package/src/feature-libraries/chunked-forest/codec/compressedEncode.ts +96 -73
  631. package/src/feature-libraries/chunked-forest/codec/format.ts +20 -14
  632. package/src/feature-libraries/chunked-forest/codec/{nodeShape.ts → nodeEncoder.ts} +23 -17
  633. package/src/feature-libraries/chunked-forest/codec/schemaBasedEncode.ts +34 -34
  634. package/src/feature-libraries/chunked-forest/codec/uncompressedEncode.ts +5 -5
  635. package/src/feature-libraries/default-schema/defaultFieldKinds.ts +11 -0
  636. package/src/feature-libraries/default-schema/defaultSchema.ts +0 -2
  637. package/src/feature-libraries/default-schema/index.ts +1 -1
  638. package/src/feature-libraries/default-schema/schemaChecker.ts +47 -30
  639. package/src/feature-libraries/index.ts +1 -3
  640. package/src/feature-libraries/modular-schema/comparison.ts +14 -29
  641. package/src/feature-libraries/modular-schema/fieldChangeHandler.ts +9 -0
  642. package/src/feature-libraries/modular-schema/genericFieldKind.ts +1 -0
  643. package/src/feature-libraries/modular-schema/modularChangeFamily.ts +61 -19
  644. package/src/feature-libraries/object-forest/objectForest.ts +10 -6
  645. package/src/feature-libraries/optional-field/optionalField.ts +4 -0
  646. package/src/feature-libraries/sequence-field/sequenceFieldChangeRebaser.ts +4 -0
  647. package/src/index.ts +7 -1
  648. package/src/jsonDomainSchema.ts +4 -0
  649. package/src/packageVersion.ts +1 -1
  650. package/src/shared-tree/independentView.ts +45 -19
  651. package/src/shared-tree/schematizeTree.ts +2 -2
  652. package/src/shared-tree/schematizingTreeView.ts +24 -15
  653. package/src/shared-tree/sharedTree.ts +2 -42
  654. package/src/shared-tree/treeAlpha.ts +48 -22
  655. package/src/shared-tree/treeCheckout.ts +54 -10
  656. package/src/shared-tree-core/branch.ts +1 -6
  657. package/src/simple-tree/api/conciseTree.ts +9 -7
  658. package/src/simple-tree/api/configuration.ts +18 -4
  659. package/src/simple-tree/api/create.ts +44 -36
  660. package/src/simple-tree/api/customTree.ts +59 -20
  661. package/src/simple-tree/api/discrepancies.ts +474 -0
  662. package/src/simple-tree/api/index.ts +2 -3
  663. package/src/simple-tree/api/schemaCompatibilityTester.ts +23 -151
  664. package/src/simple-tree/api/schemaFactory.ts +13 -254
  665. package/src/simple-tree/api/schemaFactoryAlpha.ts +174 -1
  666. package/src/simple-tree/api/schemaFactoryRecursive.ts +1 -25
  667. package/src/simple-tree/api/schemaStatics.ts +291 -0
  668. package/src/simple-tree/api/storedSchema.ts +18 -14
  669. package/src/simple-tree/api/treeBeta.ts +24 -4
  670. package/src/simple-tree/api/verboseTree.ts +17 -8
  671. package/src/simple-tree/core/allowedTypes.ts +87 -34
  672. package/src/simple-tree/core/context.ts +24 -22
  673. package/src/simple-tree/core/index.ts +11 -2
  674. package/src/simple-tree/core/simpleNodeSchemaBase.ts +30 -0
  675. package/src/simple-tree/core/toStored.ts +58 -0
  676. package/src/simple-tree/core/treeNodeKernel.ts +1 -1
  677. package/src/simple-tree/core/treeNodeSchema.ts +8 -2
  678. package/src/simple-tree/core/treeNodeValid.ts +23 -4
  679. package/src/simple-tree/core/walkSchema.ts +26 -6
  680. package/src/simple-tree/createContext.ts +11 -3
  681. package/src/simple-tree/fieldSchema.ts +3 -1
  682. package/src/simple-tree/index.ts +19 -13
  683. package/src/simple-tree/leafNodeSchema.ts +2 -1
  684. package/src/simple-tree/node-kinds/array/arrayNode.ts +64 -23
  685. package/src/simple-tree/node-kinds/index.ts +0 -1
  686. package/src/simple-tree/node-kinds/map/mapNode.ts +23 -2
  687. package/src/simple-tree/node-kinds/object/index.ts +0 -1
  688. package/src/simple-tree/node-kinds/object/objectNode.ts +42 -30
  689. package/src/simple-tree/node-kinds/record/recordNode.ts +20 -2
  690. package/src/simple-tree/prepareForInsertion.ts +28 -15
  691. package/src/simple-tree/simpleSchema.ts +6 -26
  692. package/src/simple-tree/toStoredSchema.ts +110 -44
  693. package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +6 -2
  694. package/src/simple-tree/walkFieldSchema.ts +1 -0
  695. package/dist/core/tree/detachedFieldIndexCodec.d.ts +0 -11
  696. package/dist/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
  697. package/dist/core/tree/detachedFieldIndexCodec.js +0 -100
  698. package/dist/core/tree/detachedFieldIndexCodec.js.map +0 -1
  699. package/dist/core/tree/detachedFieldIndexFormat.d.ts +0 -33
  700. package/dist/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
  701. package/dist/core/tree/detachedFieldIndexFormat.js.map +0 -1
  702. package/dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
  703. package/dist/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
  704. package/dist/feature-libraries/initializeForest.d.ts +0 -18
  705. package/dist/feature-libraries/initializeForest.d.ts.map +0 -1
  706. package/dist/feature-libraries/initializeForest.js +0 -35
  707. package/dist/feature-libraries/initializeForest.js.map +0 -1
  708. package/dist/simple-tree/discrepancies.d.ts +0 -167
  709. package/dist/simple-tree/discrepancies.d.ts.map +0 -1
  710. package/dist/simple-tree/discrepancies.js +0 -382
  711. package/dist/simple-tree/discrepancies.js.map +0 -1
  712. package/lib/core/tree/detachedFieldIndexCodec.d.ts +0 -11
  713. package/lib/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
  714. package/lib/core/tree/detachedFieldIndexCodec.js +0 -96
  715. package/lib/core/tree/detachedFieldIndexCodec.js.map +0 -1
  716. package/lib/core/tree/detachedFieldIndexFormat.d.ts +0 -33
  717. package/lib/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
  718. package/lib/core/tree/detachedFieldIndexFormat.js.map +0 -1
  719. package/lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
  720. package/lib/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
  721. package/lib/feature-libraries/initializeForest.d.ts +0 -18
  722. package/lib/feature-libraries/initializeForest.d.ts.map +0 -1
  723. package/lib/feature-libraries/initializeForest.js +0 -31
  724. package/lib/feature-libraries/initializeForest.js.map +0 -1
  725. package/lib/simple-tree/discrepancies.d.ts +0 -167
  726. package/lib/simple-tree/discrepancies.d.ts.map +0 -1
  727. package/lib/simple-tree/discrepancies.js +0 -376
  728. package/lib/simple-tree/discrepancies.js.map +0 -1
  729. package/src/feature-libraries/initializeForest.ts +0 -55
  730. 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 EncodedNestedArray,
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 `cache`.
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
- cache: EncoderCache,
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, cache, buffer);
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
- cache: EncoderCache,
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
- cache: EncoderCache,
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
- cache: EncoderCache,
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
- shapes: EncoderCache,
135
+ context: EncoderContext,
136
136
  outputBuffer: BufferFormat,
137
137
  ): void {
138
- forEachNode(cursor, () => encoder.encodeNode(cursor, shapes, outputBuffer));
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
- shapes: EncoderCache,
151
+ context: EncoderContext,
152
152
  outputBuffer: BufferFormat,
153
153
  ): void {
154
- encoder.encodeNode(cursor, shapes, outputBuffer);
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
- cache: EncoderCache,
185
+ context: EncoderContext,
186
186
  outputBuffer: BufferFormat,
187
- shape: FieldEncoder,
187
+ encoder: FieldEncoder,
188
188
  ): void {
189
- outputBuffer.push(shape.shape);
190
- shape.encodeField(cursor, cache, outputBuffer);
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
- cache: EncoderCache,
195
+ context: EncoderContext,
196
196
  outputBuffer: BufferFormat,
197
- shape: NodeEncoder,
197
+ encoder: NodeEncoder,
198
198
  ): void {
199
- outputBuffer.push(shape.shape);
200
- shape.encodeNode(cursor, cache, outputBuffer);
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
- cache: EncoderCache,
205
+ context: EncoderContext,
206
206
  outputBuffer: BufferFormat,
207
- shape: NodesEncoder,
207
+ encoder: NodesEncoder,
208
208
  ): void {
209
- outputBuffer.push(shape.shape);
210
- shape.encodeNodes(cursor, cache, outputBuffer);
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
- cache: EncoderCache,
220
+ context: EncoderContext,
221
221
  outputBuffer: BufferFormat,
222
222
  ): void {
223
223
  // TODO: Fast path uniform chunk content.
224
- const shape = cache.shapeFromTree(cursor.type);
225
- AnyShape.encodeNode(cursor, cache, outputBuffer, shape);
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
- cache: EncoderCache,
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 = InlineArrayShape.empty;
244
- AnyShape.encodeField(cursor, cache, outputBuffer, shape);
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, cache, outputBuffer);
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 = cache.nestedArray(anyNodeEncoder);
255
- AnyShape.encodeField(cursor, cache, outputBuffer, shape);
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 EncodedInlineArray}.
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 InlineArrayShape
268
+ export class InlineArrayEncoder
266
269
  extends ShapeGeneric<EncodedChunkShape>
267
270
  implements NodesEncoder, FieldEncoder
268
271
  {
269
- public static readonly empty: InlineArrayShape = new InlineArrayShape(0, {
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 InlineArrayShape.empty;
275
+ return InlineArrayEncoder.empty;
273
276
  },
274
277
  encodeNodes(
275
278
  cursor: ITreeCursorSynchronous,
276
- shapes: EncoderCache,
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
- shapes: EncoderCache,
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, shapes, outputBuffer);
304
+ this.inner.encodeNodes(cursor, context, outputBuffer);
302
305
  }
303
306
  }
304
307
 
305
308
  public encodeField(
306
309
  cursor: ITreeCursorSynchronous,
307
- shapes: EncoderCache,
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, shapes, outputBuffer);
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 EncodedNestedArray} shape.
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 NestedArrayShape extends ShapeGeneric<EncodedChunkShape> implements FieldEncoder {
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
- cache: EncoderCache,
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, cache, buffer);
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: EncodedNestedArray =
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
- export class EncoderCache implements TreeShaper, FieldShaper {
440
- private readonly shapesFromSchema: Map<TreeNodeSchemaIdentifier, NodeEncoder> = new Map();
441
- private readonly nestedArrays: Map<NodeEncoder, NestedArrayShape> = new Map();
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 treeEncoder: TreeShapePolicy,
444
- private readonly fieldEncoder: FieldShapePolicy,
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 shapeFromTree(schemaName: TreeNodeSchemaIdentifier): NodeEncoder {
450
- return getOrCreate(this.shapesFromSchema, schemaName, () =>
451
- this.treeEncoder(this, schemaName),
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 nestedArray(inner: NodeEncoder): NestedArrayShape {
456
- return getOrCreate(this.nestedArrays, inner, () => new NestedArrayShape(inner));
472
+ public fieldEncoderFromSchema(fieldSchema: TreeFieldStoredSchema): FieldEncoder {
473
+ return new LazyFieldEncoder(this, fieldSchema, this.fieldEncoderFromPolicy);
457
474
  }
458
475
 
459
- public shapeFromField(field: TreeFieldStoredSchema): FieldEncoder {
460
- return new LazyFieldEncoder(this, field, this.fieldEncoder);
476
+ public nestedArrayEncoder(inner: NodeEncoder): NestedArrayEncoder {
477
+ return getOrCreate(this.nestedArrayEncoders, inner, () => new NestedArrayEncoder(inner));
461
478
  }
462
479
  }
463
480
 
464
- export interface TreeShaper {
465
- shapeFromTree(schemaName: TreeNodeSchemaIdentifier): NodeEncoder;
481
+ export interface NodeEncodeBuilder {
482
+ nodeEncoderFromSchema(schemaName: TreeNodeSchemaIdentifier): NodeEncoder;
466
483
  }
467
484
 
468
- export interface FieldShaper {
469
- shapeFromField(field: TreeFieldStoredSchema): FieldEncoder;
485
+ export interface FieldEncodeBuilder {
486
+ fieldEncoderFromSchema(schema: TreeFieldStoredSchema): FieldEncoder;
470
487
  }
471
488
 
472
- export type FieldShapePolicy = (
473
- treeShaper: TreeShaper,
474
- field: TreeFieldStoredSchema,
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
- export type TreeShapePolicy = (
478
- fieldShaper: FieldShaper,
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 cache: TreeShaper,
487
- public readonly field: TreeFieldStoredSchema,
488
- private readonly fieldEncoder: FieldShapePolicy,
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
- cache: EncoderCache,
515
+ context: EncoderContext,
493
516
  outputBuffer: BufferFormat,
494
517
  ): void {
495
- this.encoder.encodeField(cursor, cache, outputBuffer);
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.fieldEncoder(this.cache, this.field);
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 EncodedNestedArray = ShapeIndex;
27
+ export const EncodedNestedArrayShape = ShapeIndex;
28
28
 
29
29
  /**
30
30
  * Inline array.
31
31
  */
32
- export const EncodedInlineArray = Type.Object(
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 EncodedTreeShape} for usage.
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 EncodedTreeShape = Type.Object(
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 chunk shapes.
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 EncodedNestedArray} union member.
173
+ * {@link EncodedNestedArrayShape} union member.
168
174
  */
169
- a: Type.Optional(EncodedNestedArray),
175
+ a: Type.Optional(EncodedNestedArrayShape),
170
176
  /**
171
- * {@link EncodedInlineArray} union member.
177
+ * {@link EncodedInlineArrayShape} union member.
172
178
  */
173
- b: Type.Optional(EncodedInlineArray),
179
+ b: Type.Optional(EncodedInlineArrayShape),
174
180
  /**
175
- * {@link EncodedTreeShape} union member.
181
+ * {@link EncodedNodeShape} union member.
176
182
  */
177
- c: Type.Optional(EncodedTreeShape),
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 EncodedNestedArray = Static<typeof EncodedNestedArray>;
189
- export type EncodedInlineArray = Static<typeof EncodedInlineArray>;
190
- export type EncodedTreeShape = Static<typeof EncodedTreeShape>;
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 EncoderCache,
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
- export class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {
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 NodeShape.specializedFieldEncoders}.
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 NodeShape.specializedFieldEncoders} is often more efficient:
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 NodeShape.otherFieldsEncoder}.
48
- * If {@link NodeShape.otherFieldsEncoder} is undefined, then this must handle all non-empty fields.
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 NodeShape.specializedFieldEncoders}. These fields must
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, cache: EncoderCache): Value {
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 = cache.idCompressor.tryRecompress(cursor.value);
71
+ const sessionSpaceCompressedId = context.idCompressor.tryRecompress(cursor.value);
66
72
  if (sessionSpaceCompressedId !== undefined) {
67
- return cache.idCompressor.normalizeToOpSpace(sessionSpaceCompressedId);
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
- cache: EncoderCache,
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, cache), this.value, outputBuffer);
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, cache, outputBuffer);
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, cache, otherFieldsBuffer);
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(): NodeShape {
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
- shape: FieldEncoder | undefined,
184
+ encoder: FieldEncoder | undefined,
179
185
  shapes: DeduplicationTable<Shape<EncodedChunkShape>>,
180
186
  ): number | undefined {
181
- return shape === undefined ? undefined : dedupShape(shape.shape, shapes);
187
+ return encoder === undefined ? undefined : dedupShape(encoder.shape, shapes);
182
188
  }
183
189
 
184
190
  function dedupShape(