@fluidframework/tree 2.51.0-347100 → 2.52.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (609) hide show
  1. package/.eslintrc.cjs +3 -2
  2. package/.vscode/settings.json +0 -1
  3. package/CHANGELOG.md +92 -0
  4. package/api-report/tree.alpha.api.md +3 -2
  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 +14 -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 +2 -3
  98. package/dist/feature-libraries/index.d.ts.map +1 -1
  99. package/dist/feature-libraries/index.js +3 -11
  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 -19
  104. package/dist/feature-libraries/modular-schema/comparison.js.map +1 -1
  105. package/dist/feature-libraries/modular-schema/index.d.ts +0 -1
  106. package/dist/feature-libraries/modular-schema/index.d.ts.map +1 -1
  107. package/dist/feature-libraries/modular-schema/index.js +1 -8
  108. package/dist/feature-libraries/modular-schema/index.js.map +1 -1
  109. package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
  110. package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
  111. package/dist/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  112. package/dist/feature-libraries/object-forest/objectForest.js +2 -3
  113. package/dist/feature-libraries/object-forest/objectForest.js.map +1 -1
  114. package/dist/index.d.ts +1 -1
  115. package/dist/index.d.ts.map +1 -1
  116. package/dist/index.js +6 -2
  117. package/dist/index.js.map +1 -1
  118. package/dist/packageVersion.d.ts +1 -1
  119. package/dist/packageVersion.d.ts.map +1 -1
  120. package/dist/packageVersion.js +1 -1
  121. package/dist/packageVersion.js.map +1 -1
  122. package/dist/shared-tree/independentView.d.ts +8 -0
  123. package/dist/shared-tree/independentView.d.ts.map +1 -1
  124. package/dist/shared-tree/independentView.js +23 -11
  125. package/dist/shared-tree/independentView.js.map +1 -1
  126. package/dist/shared-tree/schematizeTree.d.ts +1 -1
  127. package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
  128. package/dist/shared-tree/schematizeTree.js +5 -4
  129. package/dist/shared-tree/schematizeTree.js.map +1 -1
  130. package/dist/shared-tree/schematizingTreeView.d.ts +0 -1
  131. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  132. package/dist/shared-tree/schematizingTreeView.js +7 -10
  133. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  134. package/dist/shared-tree/sharedTree.d.ts.map +1 -1
  135. package/dist/shared-tree/sharedTree.js +1 -29
  136. package/dist/shared-tree/sharedTree.js.map +1 -1
  137. package/dist/shared-tree/tree.js +1 -1
  138. package/dist/shared-tree/tree.js.map +1 -1
  139. package/dist/shared-tree/treeAlpha.d.ts +20 -6
  140. package/dist/shared-tree/treeAlpha.d.ts.map +1 -1
  141. package/dist/shared-tree/treeAlpha.js +9 -4
  142. package/dist/shared-tree/treeAlpha.js.map +1 -1
  143. package/dist/shared-tree/treeCheckout.d.ts +2 -1
  144. package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
  145. package/dist/shared-tree/treeCheckout.js +33 -1
  146. package/dist/shared-tree/treeCheckout.js.map +1 -1
  147. package/dist/shared-tree-core/branch.d.ts.map +1 -1
  148. package/dist/shared-tree-core/branch.js +1 -1
  149. package/dist/shared-tree-core/branch.js.map +1 -1
  150. package/dist/simple-tree/api/conciseTree.d.ts +2 -2
  151. package/dist/simple-tree/api/conciseTree.d.ts.map +1 -1
  152. package/dist/simple-tree/api/conciseTree.js +6 -6
  153. package/dist/simple-tree/api/conciseTree.js.map +1 -1
  154. package/dist/simple-tree/api/configuration.d.ts +8 -2
  155. package/dist/simple-tree/api/configuration.d.ts.map +1 -1
  156. package/dist/simple-tree/api/configuration.js.map +1 -1
  157. package/dist/simple-tree/api/create.d.ts +8 -7
  158. package/dist/simple-tree/api/create.d.ts.map +1 -1
  159. package/dist/simple-tree/api/create.js +35 -22
  160. package/dist/simple-tree/api/create.js.map +1 -1
  161. package/dist/simple-tree/api/customTree.d.ts +25 -4
  162. package/dist/simple-tree/api/customTree.d.ts.map +1 -1
  163. package/dist/simple-tree/api/customTree.js +42 -16
  164. package/dist/simple-tree/api/customTree.js.map +1 -1
  165. package/dist/simple-tree/api/discrepancies.d.ts +98 -0
  166. package/dist/simple-tree/api/discrepancies.d.ts.map +1 -0
  167. package/dist/simple-tree/api/discrepancies.js +255 -0
  168. package/dist/simple-tree/api/discrepancies.js.map +1 -0
  169. package/dist/simple-tree/api/schemaCompatibilityTester.d.ts +8 -21
  170. package/dist/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
  171. package/dist/simple-tree/api/schemaCompatibilityTester.js +19 -169
  172. package/dist/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
  173. package/dist/simple-tree/api/schemaCreationUtilities.d.ts.map +1 -1
  174. package/dist/simple-tree/api/schemaCreationUtilities.js +2 -2
  175. package/dist/simple-tree/api/schemaCreationUtilities.js.map +1 -1
  176. package/dist/simple-tree/api/schemaFactory.d.ts +7 -4
  177. package/dist/simple-tree/api/schemaFactory.d.ts.map +1 -1
  178. package/dist/simple-tree/api/schemaFactory.js.map +1 -1
  179. package/dist/simple-tree/api/storedSchema.d.ts.map +1 -1
  180. package/dist/simple-tree/api/storedSchema.js +5 -1
  181. package/dist/simple-tree/api/storedSchema.js.map +1 -1
  182. package/dist/simple-tree/api/treeBeta.d.ts +2 -2
  183. package/dist/simple-tree/api/treeBeta.d.ts.map +1 -1
  184. package/dist/simple-tree/api/treeBeta.js +10 -4
  185. package/dist/simple-tree/api/treeBeta.js.map +1 -1
  186. package/dist/simple-tree/api/verboseTree.d.ts +2 -2
  187. package/dist/simple-tree/api/verboseTree.d.ts.map +1 -1
  188. package/dist/simple-tree/api/verboseTree.js +15 -15
  189. package/dist/simple-tree/api/verboseTree.js.map +1 -1
  190. package/dist/simple-tree/core/allowedTypes.d.ts +20 -4
  191. package/dist/simple-tree/core/allowedTypes.d.ts.map +1 -1
  192. package/dist/simple-tree/core/allowedTypes.js +45 -13
  193. package/dist/simple-tree/core/allowedTypes.js.map +1 -1
  194. package/dist/simple-tree/core/context.d.ts +13 -2
  195. package/dist/simple-tree/core/context.d.ts.map +1 -1
  196. package/dist/simple-tree/core/context.js +22 -9
  197. package/dist/simple-tree/core/context.js.map +1 -1
  198. package/dist/simple-tree/core/index.d.ts +2 -2
  199. package/dist/simple-tree/core/index.d.ts.map +1 -1
  200. package/dist/simple-tree/core/index.js +3 -1
  201. package/dist/simple-tree/core/index.js.map +1 -1
  202. package/dist/simple-tree/core/treeNodeKernel.d.ts +1 -1
  203. package/dist/simple-tree/core/treeNodeKernel.js +1 -1
  204. package/dist/simple-tree/core/treeNodeKernel.js.map +1 -1
  205. package/dist/simple-tree/core/treeNodeValid.d.ts +1 -1
  206. package/dist/simple-tree/core/treeNodeValid.d.ts.map +1 -1
  207. package/dist/simple-tree/core/treeNodeValid.js +8 -1
  208. package/dist/simple-tree/core/treeNodeValid.js.map +1 -1
  209. package/dist/simple-tree/core/walkSchema.d.ts +3 -0
  210. package/dist/simple-tree/core/walkSchema.d.ts.map +1 -1
  211. package/dist/simple-tree/core/walkSchema.js +2 -0
  212. package/dist/simple-tree/core/walkSchema.js.map +1 -1
  213. package/dist/simple-tree/createContext.d.ts +2 -0
  214. package/dist/simple-tree/createContext.d.ts.map +1 -1
  215. package/dist/simple-tree/createContext.js +3 -1
  216. package/dist/simple-tree/createContext.js.map +1 -1
  217. package/dist/simple-tree/fieldSchema.d.ts +1 -0
  218. package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
  219. package/dist/simple-tree/fieldSchema.js +1 -0
  220. package/dist/simple-tree/fieldSchema.js.map +1 -1
  221. package/dist/simple-tree/index.d.ts +5 -4
  222. package/dist/simple-tree/index.d.ts.map +1 -1
  223. package/dist/simple-tree/index.js +8 -3
  224. package/dist/simple-tree/index.js.map +1 -1
  225. package/dist/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  226. package/dist/simple-tree/node-kinds/array/arrayNode.js +1 -1
  227. package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  228. package/dist/simple-tree/node-kinds/index.d.ts +1 -1
  229. package/dist/simple-tree/node-kinds/index.d.ts.map +1 -1
  230. package/dist/simple-tree/node-kinds/index.js +1 -2
  231. package/dist/simple-tree/node-kinds/index.js.map +1 -1
  232. package/dist/simple-tree/node-kinds/object/index.d.ts +1 -1
  233. package/dist/simple-tree/node-kinds/object/index.d.ts.map +1 -1
  234. package/dist/simple-tree/node-kinds/object/index.js +1 -2
  235. package/dist/simple-tree/node-kinds/object/index.js.map +1 -1
  236. package/dist/simple-tree/node-kinds/object/objectNode.d.ts +2 -7
  237. package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  238. package/dist/simple-tree/node-kinds/object/objectNode.js +4 -18
  239. package/dist/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  240. package/dist/simple-tree/prepareForInsertion.d.ts +5 -5
  241. package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
  242. package/dist/simple-tree/prepareForInsertion.js +9 -3
  243. package/dist/simple-tree/prepareForInsertion.js.map +1 -1
  244. package/dist/simple-tree/toStoredSchema.d.ts +3 -0
  245. package/dist/simple-tree/toStoredSchema.d.ts.map +1 -1
  246. package/dist/simple-tree/toStoredSchema.js +3 -0
  247. package/dist/simple-tree/toStoredSchema.js.map +1 -1
  248. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
  249. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  250. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  251. package/dist/simple-tree/walkFieldSchema.d.ts +1 -0
  252. package/dist/simple-tree/walkFieldSchema.d.ts.map +1 -1
  253. package/dist/simple-tree/walkFieldSchema.js +1 -0
  254. package/dist/simple-tree/walkFieldSchema.js.map +1 -1
  255. package/lib/codec/codec.d.ts +2 -1
  256. package/lib/codec/codec.d.ts.map +1 -1
  257. package/lib/codec/codec.js +4 -3
  258. package/lib/codec/codec.js.map +1 -1
  259. package/lib/core/index.d.ts +1 -1
  260. package/lib/core/index.d.ts.map +1 -1
  261. package/lib/core/index.js +1 -1
  262. package/lib/core/index.js.map +1 -1
  263. package/lib/core/rebase/index.d.ts +1 -1
  264. package/lib/core/rebase/index.d.ts.map +1 -1
  265. package/lib/core/rebase/index.js +1 -1
  266. package/lib/core/rebase/index.js.map +1 -1
  267. package/lib/core/rebase/types.d.ts +3 -1
  268. package/lib/core/rebase/types.d.ts.map +1 -1
  269. package/lib/core/rebase/types.js +1 -0
  270. package/lib/core/rebase/types.js.map +1 -1
  271. package/lib/core/schema-stored/schema.d.ts +1 -23
  272. package/lib/core/schema-stored/schema.d.ts.map +1 -1
  273. package/lib/core/schema-stored/schema.js +2 -2
  274. package/lib/core/schema-stored/schema.js.map +1 -1
  275. package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
  276. package/lib/core/tree/detachedFieldIndex.js +2 -3
  277. package/lib/core/tree/detachedFieldIndex.js.map +1 -1
  278. package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
  279. package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
  280. package/lib/core/tree/detachedFieldIndexCodecCommon.js +64 -0
  281. package/lib/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
  282. package/lib/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
  283. package/lib/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
  284. package/lib/core/tree/detachedFieldIndexCodecV1.js +51 -0
  285. package/lib/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
  286. package/lib/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
  287. package/lib/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
  288. package/lib/core/tree/detachedFieldIndexCodecV2.js +45 -0
  289. package/lib/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
  290. package/lib/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
  291. package/lib/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
  292. package/lib/core/tree/detachedFieldIndexCodecs.js +21 -0
  293. package/lib/core/tree/detachedFieldIndexCodecs.js.map +1 -0
  294. package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
  295. package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
  296. package/lib/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +13 -10
  297. package/lib/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
  298. package/lib/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
  299. package/lib/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
  300. package/lib/core/tree/detachedFieldIndexFormatV1.js +9 -0
  301. package/lib/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
  302. package/lib/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
  303. package/lib/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
  304. package/lib/core/tree/detachedFieldIndexFormatV2.js +11 -0
  305. package/lib/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
  306. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
  307. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  308. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js +19 -19
  309. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  310. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
  311. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  312. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
  313. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  314. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
  315. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  316. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js +70 -57
  317. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  318. package/lib/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
  319. package/lib/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
  320. package/lib/feature-libraries/chunked-forest/codec/format.js +17 -11
  321. package/lib/feature-libraries/chunked-forest/codec/format.js.map +1 -1
  322. package/{dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts → lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
  323. package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
  324. package/lib/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +21 -15
  325. package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
  326. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
  327. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  328. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +19 -19
  329. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  330. package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
  331. package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
  332. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
  333. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  334. package/lib/feature-libraries/default-schema/defaultFieldKinds.js +14 -2
  335. package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  336. package/lib/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
  337. package/lib/feature-libraries/default-schema/defaultSchema.js +0 -2
  338. package/lib/feature-libraries/default-schema/defaultSchema.js.map +1 -1
  339. package/lib/feature-libraries/default-schema/index.d.ts +1 -1
  340. package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
  341. package/lib/feature-libraries/default-schema/index.js +1 -1
  342. package/lib/feature-libraries/default-schema/index.js.map +1 -1
  343. package/lib/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
  344. package/lib/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  345. package/lib/feature-libraries/default-schema/schemaChecker.js +29 -24
  346. package/lib/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  347. package/lib/feature-libraries/index.d.ts +2 -3
  348. package/lib/feature-libraries/index.d.ts.map +1 -1
  349. package/lib/feature-libraries/index.js +2 -3
  350. package/lib/feature-libraries/index.js.map +1 -1
  351. package/lib/feature-libraries/modular-schema/comparison.d.ts +5 -6
  352. package/lib/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
  353. package/lib/feature-libraries/modular-schema/comparison.js +14 -17
  354. package/lib/feature-libraries/modular-schema/comparison.js.map +1 -1
  355. package/lib/feature-libraries/modular-schema/index.d.ts +0 -1
  356. package/lib/feature-libraries/modular-schema/index.d.ts.map +1 -1
  357. package/lib/feature-libraries/modular-schema/index.js +0 -1
  358. package/lib/feature-libraries/modular-schema/index.js.map +1 -1
  359. package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
  360. package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
  361. package/lib/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  362. package/lib/feature-libraries/object-forest/objectForest.js +3 -4
  363. package/lib/feature-libraries/object-forest/objectForest.js.map +1 -1
  364. package/lib/index.d.ts +1 -1
  365. package/lib/index.d.ts.map +1 -1
  366. package/lib/index.js +2 -2
  367. package/lib/index.js.map +1 -1
  368. package/lib/packageVersion.d.ts +1 -1
  369. package/lib/packageVersion.d.ts.map +1 -1
  370. package/lib/packageVersion.js +1 -1
  371. package/lib/packageVersion.js.map +1 -1
  372. package/lib/shared-tree/independentView.d.ts +8 -0
  373. package/lib/shared-tree/independentView.d.ts.map +1 -1
  374. package/lib/shared-tree/independentView.js +21 -10
  375. package/lib/shared-tree/independentView.js.map +1 -1
  376. package/lib/shared-tree/schematizeTree.d.ts +1 -1
  377. package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
  378. package/lib/shared-tree/schematizeTree.js +3 -2
  379. package/lib/shared-tree/schematizeTree.js.map +1 -1
  380. package/lib/shared-tree/schematizingTreeView.d.ts +0 -1
  381. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  382. package/lib/shared-tree/schematizingTreeView.js +8 -11
  383. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  384. package/lib/shared-tree/sharedTree.d.ts.map +1 -1
  385. package/lib/shared-tree/sharedTree.js +2 -30
  386. package/lib/shared-tree/sharedTree.js.map +1 -1
  387. package/lib/shared-tree/tree.js +1 -1
  388. package/lib/shared-tree/tree.js.map +1 -1
  389. package/lib/shared-tree/treeAlpha.d.ts +20 -6
  390. package/lib/shared-tree/treeAlpha.d.ts.map +1 -1
  391. package/lib/shared-tree/treeAlpha.js +10 -5
  392. package/lib/shared-tree/treeAlpha.js.map +1 -1
  393. package/lib/shared-tree/treeCheckout.d.ts +2 -1
  394. package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
  395. package/lib/shared-tree/treeCheckout.js +34 -2
  396. package/lib/shared-tree/treeCheckout.js.map +1 -1
  397. package/lib/shared-tree-core/branch.d.ts.map +1 -1
  398. package/lib/shared-tree-core/branch.js +1 -1
  399. package/lib/shared-tree-core/branch.js.map +1 -1
  400. package/lib/simple-tree/api/conciseTree.d.ts +2 -2
  401. package/lib/simple-tree/api/conciseTree.d.ts.map +1 -1
  402. package/lib/simple-tree/api/conciseTree.js +6 -6
  403. package/lib/simple-tree/api/conciseTree.js.map +1 -1
  404. package/lib/simple-tree/api/configuration.d.ts +8 -2
  405. package/lib/simple-tree/api/configuration.d.ts.map +1 -1
  406. package/lib/simple-tree/api/configuration.js.map +1 -1
  407. package/lib/simple-tree/api/create.d.ts +8 -7
  408. package/lib/simple-tree/api/create.d.ts.map +1 -1
  409. package/lib/simple-tree/api/create.js +38 -25
  410. package/lib/simple-tree/api/create.js.map +1 -1
  411. package/lib/simple-tree/api/customTree.d.ts +25 -4
  412. package/lib/simple-tree/api/customTree.d.ts.map +1 -1
  413. package/lib/simple-tree/api/customTree.js +43 -17
  414. package/lib/simple-tree/api/customTree.js.map +1 -1
  415. package/lib/simple-tree/api/discrepancies.d.ts +98 -0
  416. package/lib/simple-tree/api/discrepancies.d.ts.map +1 -0
  417. package/lib/simple-tree/api/discrepancies.js +250 -0
  418. package/lib/simple-tree/api/discrepancies.js.map +1 -0
  419. package/lib/simple-tree/api/schemaCompatibilityTester.d.ts +8 -21
  420. package/lib/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
  421. package/lib/simple-tree/api/schemaCompatibilityTester.js +19 -169
  422. package/lib/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
  423. package/lib/simple-tree/api/schemaCreationUtilities.d.ts.map +1 -1
  424. package/lib/simple-tree/api/schemaCreationUtilities.js +2 -2
  425. package/lib/simple-tree/api/schemaCreationUtilities.js.map +1 -1
  426. package/lib/simple-tree/api/schemaFactory.d.ts +7 -4
  427. package/lib/simple-tree/api/schemaFactory.d.ts.map +1 -1
  428. package/lib/simple-tree/api/schemaFactory.js.map +1 -1
  429. package/lib/simple-tree/api/storedSchema.d.ts.map +1 -1
  430. package/lib/simple-tree/api/storedSchema.js +6 -2
  431. package/lib/simple-tree/api/storedSchema.js.map +1 -1
  432. package/lib/simple-tree/api/treeBeta.d.ts +2 -2
  433. package/lib/simple-tree/api/treeBeta.d.ts.map +1 -1
  434. package/lib/simple-tree/api/treeBeta.js +8 -2
  435. package/lib/simple-tree/api/treeBeta.js.map +1 -1
  436. package/lib/simple-tree/api/verboseTree.d.ts +2 -2
  437. package/lib/simple-tree/api/verboseTree.d.ts.map +1 -1
  438. package/lib/simple-tree/api/verboseTree.js +9 -9
  439. package/lib/simple-tree/api/verboseTree.js.map +1 -1
  440. package/lib/simple-tree/core/allowedTypes.d.ts +20 -4
  441. package/lib/simple-tree/core/allowedTypes.d.ts.map +1 -1
  442. package/lib/simple-tree/core/allowedTypes.js +42 -12
  443. package/lib/simple-tree/core/allowedTypes.js.map +1 -1
  444. package/lib/simple-tree/core/context.d.ts +13 -2
  445. package/lib/simple-tree/core/context.d.ts.map +1 -1
  446. package/lib/simple-tree/core/context.js +22 -9
  447. package/lib/simple-tree/core/context.js.map +1 -1
  448. package/lib/simple-tree/core/index.d.ts +2 -2
  449. package/lib/simple-tree/core/index.d.ts.map +1 -1
  450. package/lib/simple-tree/core/index.js +2 -2
  451. package/lib/simple-tree/core/index.js.map +1 -1
  452. package/lib/simple-tree/core/treeNodeKernel.d.ts +1 -1
  453. package/lib/simple-tree/core/treeNodeKernel.js +1 -1
  454. package/lib/simple-tree/core/treeNodeKernel.js.map +1 -1
  455. package/lib/simple-tree/core/treeNodeValid.d.ts +1 -1
  456. package/lib/simple-tree/core/treeNodeValid.d.ts.map +1 -1
  457. package/lib/simple-tree/core/treeNodeValid.js +8 -1
  458. package/lib/simple-tree/core/treeNodeValid.js.map +1 -1
  459. package/lib/simple-tree/core/walkSchema.d.ts +3 -0
  460. package/lib/simple-tree/core/walkSchema.d.ts.map +1 -1
  461. package/lib/simple-tree/core/walkSchema.js +2 -0
  462. package/lib/simple-tree/core/walkSchema.js.map +1 -1
  463. package/lib/simple-tree/createContext.d.ts +2 -0
  464. package/lib/simple-tree/createContext.d.ts.map +1 -1
  465. package/lib/simple-tree/createContext.js +3 -1
  466. package/lib/simple-tree/createContext.js.map +1 -1
  467. package/lib/simple-tree/fieldSchema.d.ts +1 -0
  468. package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
  469. package/lib/simple-tree/fieldSchema.js +1 -0
  470. package/lib/simple-tree/fieldSchema.js.map +1 -1
  471. package/lib/simple-tree/index.d.ts +5 -4
  472. package/lib/simple-tree/index.d.ts.map +1 -1
  473. package/lib/simple-tree/index.js +5 -4
  474. package/lib/simple-tree/index.js.map +1 -1
  475. package/lib/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  476. package/lib/simple-tree/node-kinds/array/arrayNode.js +1 -1
  477. package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  478. package/lib/simple-tree/node-kinds/index.d.ts +1 -1
  479. package/lib/simple-tree/node-kinds/index.d.ts.map +1 -1
  480. package/lib/simple-tree/node-kinds/index.js +1 -1
  481. package/lib/simple-tree/node-kinds/index.js.map +1 -1
  482. package/lib/simple-tree/node-kinds/object/index.d.ts +1 -1
  483. package/lib/simple-tree/node-kinds/object/index.d.ts.map +1 -1
  484. package/lib/simple-tree/node-kinds/object/index.js +1 -1
  485. package/lib/simple-tree/node-kinds/object/index.js.map +1 -1
  486. package/lib/simple-tree/node-kinds/object/objectNode.d.ts +2 -7
  487. package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  488. package/lib/simple-tree/node-kinds/object/objectNode.js +3 -16
  489. package/lib/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  490. package/lib/simple-tree/prepareForInsertion.d.ts +5 -5
  491. package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
  492. package/lib/simple-tree/prepareForInsertion.js +11 -5
  493. package/lib/simple-tree/prepareForInsertion.js.map +1 -1
  494. package/lib/simple-tree/toStoredSchema.d.ts +3 -0
  495. package/lib/simple-tree/toStoredSchema.d.ts.map +1 -1
  496. package/lib/simple-tree/toStoredSchema.js +3 -0
  497. package/lib/simple-tree/toStoredSchema.js.map +1 -1
  498. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
  499. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  500. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +1 -1
  501. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  502. package/lib/simple-tree/walkFieldSchema.d.ts +1 -0
  503. package/lib/simple-tree/walkFieldSchema.d.ts.map +1 -1
  504. package/lib/simple-tree/walkFieldSchema.js +1 -0
  505. package/lib/simple-tree/walkFieldSchema.js.map +1 -1
  506. package/package.json +23 -23
  507. package/src/codec/codec.ts +4 -3
  508. package/src/core/index.ts +2 -0
  509. package/src/core/rebase/index.ts +2 -0
  510. package/src/core/rebase/types.ts +4 -0
  511. package/src/core/schema-stored/schema.ts +2 -26
  512. package/src/core/tree/detachedFieldIndex.ts +4 -6
  513. package/src/core/tree/detachedFieldIndexCodecCommon.ts +87 -0
  514. package/src/core/tree/{detachedFieldIndexCodec.ts → detachedFieldIndexCodecV1.ts} +22 -68
  515. package/src/core/tree/detachedFieldIndexCodecV2.ts +72 -0
  516. package/src/core/tree/detachedFieldIndexCodecs.ts +44 -0
  517. package/src/core/tree/{detachedFieldIndexFormat.ts → detachedFieldIndexFormatCommon.ts} +32 -23
  518. package/src/core/tree/detachedFieldIndexFormatV1.ts +15 -0
  519. package/src/core/tree/detachedFieldIndexFormatV2.ts +17 -0
  520. package/src/feature-libraries/chunked-forest/codec/README.md +1 -1
  521. package/src/feature-libraries/chunked-forest/codec/chunkDecoding.ts +25 -25
  522. package/src/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.ts +10 -6
  523. package/src/feature-libraries/chunked-forest/codec/compressedEncode.ts +96 -73
  524. package/src/feature-libraries/chunked-forest/codec/format.ts +20 -14
  525. package/src/feature-libraries/chunked-forest/codec/{nodeShape.ts → nodeEncoder.ts} +23 -17
  526. package/src/feature-libraries/chunked-forest/codec/schemaBasedEncode.ts +34 -34
  527. package/src/feature-libraries/chunked-forest/codec/uncompressedEncode.ts +5 -5
  528. package/src/feature-libraries/default-schema/defaultFieldKinds.ts +10 -0
  529. package/src/feature-libraries/default-schema/defaultSchema.ts +0 -2
  530. package/src/feature-libraries/default-schema/index.ts +1 -1
  531. package/src/feature-libraries/default-schema/schemaChecker.ts +47 -30
  532. package/src/feature-libraries/index.ts +1 -18
  533. package/src/feature-libraries/modular-schema/comparison.ts +14 -33
  534. package/src/feature-libraries/modular-schema/index.ts +0 -17
  535. package/src/feature-libraries/object-forest/objectForest.ts +10 -6
  536. package/src/index.ts +5 -0
  537. package/src/packageVersion.ts +1 -1
  538. package/src/shared-tree/independentView.ts +45 -19
  539. package/src/shared-tree/schematizeTree.ts +3 -3
  540. package/src/shared-tree/schematizingTreeView.ts +17 -17
  541. package/src/shared-tree/sharedTree.ts +2 -42
  542. package/src/shared-tree/tree.ts +1 -1
  543. package/src/shared-tree/treeAlpha.ts +30 -18
  544. package/src/shared-tree/treeCheckout.ts +55 -11
  545. package/src/shared-tree-core/branch.ts +1 -6
  546. package/src/simple-tree/api/conciseTree.ts +9 -7
  547. package/src/simple-tree/api/configuration.ts +8 -2
  548. package/src/simple-tree/api/create.ts +49 -36
  549. package/src/simple-tree/api/customTree.ts +59 -20
  550. package/src/simple-tree/api/discrepancies.ts +473 -0
  551. package/src/simple-tree/api/schemaCompatibilityTester.ts +28 -242
  552. package/src/simple-tree/api/schemaCreationUtilities.ts +5 -2
  553. package/src/simple-tree/api/schemaFactory.ts +7 -4
  554. package/src/simple-tree/api/storedSchema.ts +6 -10
  555. package/src/simple-tree/api/treeBeta.ts +17 -4
  556. package/src/simple-tree/api/verboseTree.ts +17 -8
  557. package/src/simple-tree/core/allowedTypes.ts +54 -21
  558. package/src/simple-tree/core/context.ts +24 -22
  559. package/src/simple-tree/core/index.ts +2 -1
  560. package/src/simple-tree/core/treeNodeKernel.ts +1 -1
  561. package/src/simple-tree/core/treeNodeValid.ts +9 -2
  562. package/src/simple-tree/core/walkSchema.ts +3 -0
  563. package/src/simple-tree/createContext.ts +6 -1
  564. package/src/simple-tree/fieldSchema.ts +1 -0
  565. package/src/simple-tree/index.ts +6 -3
  566. package/src/simple-tree/node-kinds/array/arrayNode.ts +32 -19
  567. package/src/simple-tree/node-kinds/index.ts +1 -1
  568. package/src/simple-tree/node-kinds/object/index.ts +1 -1
  569. package/src/simple-tree/node-kinds/object/objectNode.ts +9 -27
  570. package/src/simple-tree/prepareForInsertion.ts +17 -9
  571. package/src/simple-tree/toStoredSchema.ts +3 -0
  572. package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +6 -2
  573. package/src/simple-tree/walkFieldSchema.ts +1 -0
  574. package/dist/core/tree/detachedFieldIndexCodec.d.ts +0 -11
  575. package/dist/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
  576. package/dist/core/tree/detachedFieldIndexCodec.js +0 -100
  577. package/dist/core/tree/detachedFieldIndexCodec.js.map +0 -1
  578. package/dist/core/tree/detachedFieldIndexFormat.d.ts +0 -33
  579. package/dist/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
  580. package/dist/core/tree/detachedFieldIndexFormat.js.map +0 -1
  581. package/dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
  582. package/dist/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
  583. package/dist/feature-libraries/initializeForest.d.ts +0 -18
  584. package/dist/feature-libraries/initializeForest.d.ts.map +0 -1
  585. package/dist/feature-libraries/initializeForest.js +0 -35
  586. package/dist/feature-libraries/initializeForest.js.map +0 -1
  587. package/dist/feature-libraries/modular-schema/discrepancies.d.ts +0 -174
  588. package/dist/feature-libraries/modular-schema/discrepancies.d.ts.map +0 -1
  589. package/dist/feature-libraries/modular-schema/discrepancies.js +0 -361
  590. package/dist/feature-libraries/modular-schema/discrepancies.js.map +0 -1
  591. package/lib/core/tree/detachedFieldIndexCodec.d.ts +0 -11
  592. package/lib/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
  593. package/lib/core/tree/detachedFieldIndexCodec.js +0 -96
  594. package/lib/core/tree/detachedFieldIndexCodec.js.map +0 -1
  595. package/lib/core/tree/detachedFieldIndexFormat.d.ts +0 -33
  596. package/lib/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
  597. package/lib/core/tree/detachedFieldIndexFormat.js.map +0 -1
  598. package/lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
  599. package/lib/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
  600. package/lib/feature-libraries/initializeForest.d.ts +0 -18
  601. package/lib/feature-libraries/initializeForest.d.ts.map +0 -1
  602. package/lib/feature-libraries/initializeForest.js +0 -31
  603. package/lib/feature-libraries/initializeForest.js.map +0 -1
  604. package/lib/feature-libraries/modular-schema/discrepancies.d.ts +0 -174
  605. package/lib/feature-libraries/modular-schema/discrepancies.d.ts.map +0 -1
  606. package/lib/feature-libraries/modular-schema/discrepancies.js +0 -354
  607. package/lib/feature-libraries/modular-schema/discrepancies.js.map +0 -1
  608. package/src/feature-libraries/initializeForest.ts +0 -55
  609. package/src/feature-libraries/modular-schema/discrepancies.ts +0 -567
@@ -1,55 +0,0 @@
1
- /*!
2
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
- * Licensed under the MIT License.
4
- */
5
-
6
- import { assert } from "@fluidframework/core-utils/internal";
7
- import type { SessionSpaceCompressedId, IIdCompressor } from "@fluidframework/id-compressor";
8
-
9
- import {
10
- type DeltaRoot,
11
- type IEditableForest,
12
- type ITreeCursorSynchronous,
13
- type RevisionTagCodec,
14
- combineVisitors,
15
- deltaForRootInitialization,
16
- makeDetachedFieldIndex,
17
- visitDelta,
18
- } from "../core/index.js";
19
-
20
- /**
21
- * Initializes the given forest with the given content.
22
- * @remarks The forest must be empty when this function is called.
23
- * This does not perform an edit in the typical sense.
24
- * Instead, it creates a delta expressing a creation and insertion of the `content` under the {@link rootFieldKey}, and then applies the delta to the forest.
25
- * If `visitAnchors` is enabled, then the delta will also be applied to the forest's {@link AnchorSet} (in which case there must be no existing anchors when this function is called).
26
- *
27
- * @remarks
28
- * This does not perform an edit: it updates the forest content as if there was an edit that did that.
29
- */
30
- export function initializeForest(
31
- forest: IEditableForest,
32
- content: ITreeCursorSynchronous,
33
- revisionTagCodec: RevisionTagCodec,
34
- idCompressor: IIdCompressor,
35
- visitAnchors = false,
36
- ): void {
37
- assert(forest.isEmpty, 0x747 /* forest must be empty */);
38
- const delta: DeltaRoot = deltaForRootInitialization(forest.chunkField(content));
39
- let visitor = forest.acquireVisitor();
40
- if (visitAnchors) {
41
- assert(forest.anchors.isEmpty(), 0x9b7 /* anchor set must be empty */);
42
- const anchorVisitor = forest.anchors.acquireVisitor();
43
- visitor = combineVisitors([visitor, anchorVisitor]);
44
- }
45
-
46
- // any detached trees built here are immediately attached so the revision used here doesn't matter
47
- // we use a dummy revision to make correctness checks in the detached field index easier
48
- visitDelta(
49
- delta,
50
- visitor,
51
- makeDetachedFieldIndex("init", revisionTagCodec, idCompressor),
52
- 0 as SessionSpaceCompressedId,
53
- );
54
- visitor.free();
55
- }
@@ -1,567 +0,0 @@
1
- /*!
2
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
- * Licensed under the MIT License.
4
- */
5
-
6
- import { assert } from "@fluidframework/core-utils/internal";
7
-
8
- import {
9
- type FieldKey,
10
- type FieldKindIdentifier,
11
- LeafNodeStoredSchema,
12
- MapNodeStoredSchema,
13
- ObjectNodeStoredSchema,
14
- storedEmptyFieldSchema,
15
- type TreeFieldStoredSchema,
16
- type TreeNodeSchemaIdentifier,
17
- type TreeNodeStoredSchema,
18
- type TreeStoredSchema,
19
- type TreeTypeSet,
20
- type ValueSchema,
21
- } from "../../core/index.js";
22
- import { brand } from "../../util/index.js";
23
-
24
- // TODO:
25
- // The comparisons in this file seem redundant with those in comparison.ts.
26
- // Rather than both existing, one of which just returns boolean and the other which returns additional details, a simple comparison which returns everything needed should be used.
27
-
28
- /**
29
- * Discriminated union (keyed on `mismatch`) of discrepancies between a view and stored schema.
30
- * @remarks
31
- *
32
- * 1. FieldDiscrepancy
33
- *
34
- * `FieldDiscrepancy` represents the differences between two `TreeFieldStoredSchema` objects. It consists of
35
- * three types of incompatibilities:
36
- *
37
- * - FieldKindDiscrepancy: Indicates the differences in `FieldKindIdentifier` between two `TreeFieldStoredSchema`
38
- * objects (e.g., optional, required, sequence, etc.).
39
- * - AllowedTypesDiscrepancy: Indicates the differences in the allowed child types between the two schemas.
40
- * - ValueSchemaDiscrepancy: Specifically indicates the differences in the `ValueSchema` of two
41
- * `LeafNodeStoredSchema` objects.
42
- *
43
- * 2. NodeDiscrepancy
44
- *
45
- * `NodeDiscrepancy` represents the differences between two `TreeNodeStoredSchema` objects and includes:
46
- *
47
- * - NodeKindDiscrepancy: Indicates the differences in the types of `TreeNodeStoredSchema` (currently supports
48
- * `ObjectNodeStoredSchema`, `MapNodeStoredSchema`, and `LeafNodeStoredSchema`).
49
- * - NodeFieldsDiscrepancy: Indicates the `FieldDiscrepancy` of `TreeFieldStoredSchema` within two
50
- * `TreeNodeStoredSchema`. It includes an array of `FieldDiscrepancy` instances in the `differences` field.
51
- *
52
- * When comparing two nodes for compatibility, it only makes sense to compare their fields if the nodes are of
53
- * the same kind (map, object, leaf).
54
- *
55
- * 3. Discrepancy
56
- *
57
- * Discrepancy consists of both `NodeDiscrepancy` and `FieldDiscrepancy`, representing any kind of
58
- * schema differences. See {@link getAllowedContentDiscrepancies} for more details about how we process it
59
- * and the ordering.
60
- */
61
- export type Discrepancy = FieldDiscrepancy | NodeDiscrepancy;
62
-
63
- export type NodeDiscrepancy = NodeKindDiscrepancy | NodeFieldsDiscrepancy;
64
-
65
- /**
66
- * A discrepancy in the declaration of a field.
67
- */
68
- export type FieldDiscrepancy =
69
- | AllowedTypeDiscrepancy
70
- | FieldKindDiscrepancy
71
- | ValueSchemaDiscrepancy;
72
-
73
- /**
74
- * Information about where a field discrepancy is located within a collection of schema.
75
- */
76
- export interface FieldDiscrepancyLocation {
77
- /**
78
- * The {@link TreeNodeSchemaIdentifier} that contains the discrepancy.
79
- *
80
- * Undefined iff the discrepancy is part of the root field schema.
81
- */
82
- identifier: TreeNodeSchemaIdentifier | undefined;
83
- /**
84
- * The {@link FieldKey} for the field that contains the discrepancy.
85
- * Undefined when:
86
- * - the discrepancy is part of the root field schema
87
- * - the discrepancy is for 'all fields' of a map node
88
- */
89
- fieldKey: FieldKey | undefined;
90
- }
91
-
92
- /**
93
- * A discrepancy in the allowed types of a field.
94
- *
95
- * @remarks
96
- * This reports the symmetric difference of allowed types in view/stored to enable more efficient checks for compatibility
97
- */
98
- export interface AllowedTypeDiscrepancy extends FieldDiscrepancyLocation {
99
- mismatch: "allowedTypes";
100
- /**
101
- * List of allowed type identifiers in viewed schema which are not allowed in stored schema
102
- */
103
- view: TreeNodeSchemaIdentifier[];
104
- /**
105
- * List of allowed type identifiers in stored schema which are not allowed in view schema
106
- */
107
- stored: TreeNodeSchemaIdentifier[];
108
- }
109
-
110
- export interface FieldKindDiscrepancy extends FieldDiscrepancyLocation {
111
- mismatch: "fieldKind";
112
- view: FieldKindIdentifier;
113
- stored: FieldKindIdentifier;
114
- }
115
-
116
- export interface ValueSchemaDiscrepancy {
117
- identifier: TreeNodeSchemaIdentifier;
118
- mismatch: "valueSchema";
119
- view: ValueSchema | undefined;
120
- stored: ValueSchema | undefined;
121
- }
122
-
123
- export interface NodeKindDiscrepancy {
124
- identifier: TreeNodeSchemaIdentifier;
125
- mismatch: "nodeKind";
126
- view: SchemaFactoryNodeKind | undefined;
127
- stored: SchemaFactoryNodeKind | undefined;
128
- }
129
-
130
- export interface NodeFieldsDiscrepancy {
131
- identifier: TreeNodeSchemaIdentifier;
132
- mismatch: "fields";
133
- differences: FieldDiscrepancy[];
134
- }
135
-
136
- type SchemaFactoryNodeKind = "object" | "leaf" | "map";
137
-
138
- function getNodeSchemaType(nodeSchema: TreeNodeStoredSchema): SchemaFactoryNodeKind {
139
- if (nodeSchema instanceof ObjectNodeStoredSchema) {
140
- return "object";
141
- } else if (nodeSchema instanceof MapNodeStoredSchema) {
142
- return "map";
143
- } else if (nodeSchema instanceof LeafNodeStoredSchema) {
144
- return "leaf";
145
- }
146
- throwUnsupportedNodeType(nodeSchema.constructor.name);
147
- }
148
-
149
- /**
150
- * Finds and reports discrepancies between a view schema and a stored schema.
151
- *
152
- * See documentation on {@link Discrepancy} for details of possible discrepancies.
153
- * @remarks
154
- * This function does not attempt to distinguish between equivalent representations of a node/field involving extraneous never trees.
155
- * For example, a Forbidden field with allowed type set `[]` is equivalent to an optional field with allowed type set `[]`,
156
- * as well as an optional field with an allowed type set containing only unconstructable types.
157
- *
158
- * It is up to the caller to determine whether such discrepancies matter.
159
- */
160
- export function* getAllowedContentDiscrepancies(
161
- view: TreeStoredSchema,
162
- stored: TreeStoredSchema,
163
- ): Iterable<Discrepancy> {
164
- // check root schema discrepancies
165
- yield* getFieldDiscrepancies(
166
- view.rootFieldSchema,
167
- stored.rootFieldSchema,
168
- undefined,
169
- undefined,
170
- );
171
-
172
- for (const result of compareMaps(view.nodeSchema, stored.nodeSchema)) {
173
- switch (result.type) {
174
- case "aExtra": {
175
- const viewType = getNodeSchemaType(result.value);
176
- yield {
177
- identifier: result.key,
178
- mismatch: "nodeKind",
179
- view: viewType,
180
- stored: undefined,
181
- };
182
- break;
183
- }
184
- case "bExtra": {
185
- const storedType = getNodeSchemaType(result.value);
186
- yield {
187
- identifier: result.key,
188
- mismatch: "nodeKind",
189
- view: undefined,
190
- stored: storedType,
191
- };
192
- break;
193
- }
194
- case "both": {
195
- yield* getNodeDiscrepancies(result.key, result.valueA, result.valueB);
196
- break;
197
- }
198
- default:
199
- break;
200
- }
201
- }
202
- }
203
-
204
- function* getNodeDiscrepancies(
205
- identifier: TreeNodeSchemaIdentifier,
206
- view: TreeNodeStoredSchema,
207
- stored: TreeNodeStoredSchema,
208
- ): Iterable<Discrepancy> {
209
- const viewType = getNodeSchemaType(view);
210
- const storedType = getNodeSchemaType(stored);
211
- if (viewType !== storedType) {
212
- yield {
213
- identifier,
214
- mismatch: "nodeKind",
215
- view: viewType,
216
- stored: storedType,
217
- };
218
- return;
219
- }
220
-
221
- switch (viewType) {
222
- case "object": {
223
- const differences = Array.from(
224
- trackObjectNodeDiscrepancies(
225
- identifier,
226
- view as ObjectNodeStoredSchema,
227
- stored as ObjectNodeStoredSchema,
228
- ),
229
- );
230
- if (differences.length > 0) {
231
- yield {
232
- identifier,
233
- mismatch: "fields",
234
- differences,
235
- } satisfies NodeFieldsDiscrepancy;
236
- }
237
- break;
238
- }
239
- case "map":
240
- yield* getFieldDiscrepancies(
241
- (view as MapNodeStoredSchema).mapFields,
242
- (stored as MapNodeStoredSchema).mapFields,
243
- identifier,
244
- undefined,
245
- );
246
- break;
247
- case "leaf": {
248
- const viewValue = (view as LeafNodeStoredSchema).leafValue;
249
- const storedValue = (stored as LeafNodeStoredSchema).leafValue;
250
- if (viewValue !== storedValue) {
251
- yield {
252
- identifier,
253
- mismatch: "valueSchema",
254
- view: viewValue,
255
- stored: storedValue,
256
- };
257
- }
258
- break;
259
- }
260
- default:
261
- break;
262
- }
263
- }
264
-
265
- /**
266
- * The function to track the discrepancies between two field stored schemas.
267
- *
268
- * @param keyOrRoot - If the key is missing, it indicates that this is the root field schema.
269
- */
270
- function* getFieldDiscrepancies(
271
- view: TreeFieldStoredSchema,
272
- stored: TreeFieldStoredSchema,
273
- identifier: TreeNodeSchemaIdentifier | undefined,
274
- fieldKey: FieldKey | undefined,
275
- ): Iterable<FieldDiscrepancy> {
276
- // Only track the symmetric differences of two sets.
277
- const findSetDiscrepancies = (
278
- a: TreeTypeSet,
279
- b: TreeTypeSet,
280
- ): [TreeNodeSchemaIdentifier[], TreeNodeSchemaIdentifier[]] => {
281
- const aDiff = [...a].filter((value) => !b.has(value));
282
- const bDiff = [...b].filter((value) => !a.has(value));
283
- return [aDiff, bDiff];
284
- };
285
-
286
- const [viewExtra, storedExtra] = findSetDiscrepancies(view.types, stored.types);
287
- if (viewExtra.length > 0 || storedExtra.length > 0) {
288
- yield {
289
- identifier,
290
- fieldKey,
291
- mismatch: "allowedTypes",
292
- view: viewExtra,
293
- stored: storedExtra,
294
- } satisfies AllowedTypeDiscrepancy;
295
- }
296
-
297
- if (view.kind !== stored.kind) {
298
- yield {
299
- identifier,
300
- fieldKey,
301
- mismatch: "fieldKind",
302
- view: view.kind,
303
- stored: stored.kind,
304
- } satisfies FieldKindDiscrepancy;
305
- }
306
- }
307
-
308
- function* trackObjectNodeDiscrepancies(
309
- identifier: TreeNodeSchemaIdentifier,
310
- view: ObjectNodeStoredSchema,
311
- stored: ObjectNodeStoredSchema,
312
- ): Iterable<FieldDiscrepancy> {
313
- /**
314
- * Similar to the logic used for tracking discrepancies between two node schemas, we will identify
315
- * three types of differences:
316
- * 1. Fields that exist in the view schema but not in the stored schema.
317
- * 2. Fields that exist in both schemas but have different contents.
318
- * 3. Fields that exist in the stored schema but not in the view schema.
319
- *
320
- * First, the view schema is iterated to track the first two types of differences.
321
- * Then, the stored schema is iterated to find the third type.
322
- */
323
-
324
- for (const result of compareMaps(view.objectNodeFields, stored.objectNodeFields)) {
325
- const fieldKey = result.key;
326
- switch (result.type) {
327
- case "aExtra": {
328
- if (result.value.kind === storedEmptyFieldSchema.kind) {
329
- // In one of view/stored, this field is explicitly forbidden, but in the other it is implicitly forbidden
330
- // (by way of omission). We treat these identically anyway.
331
- break;
332
- }
333
- yield {
334
- identifier,
335
- fieldKey,
336
- mismatch: "fieldKind",
337
- view: result.value.kind,
338
- stored: storedEmptyFieldSchema.kind,
339
- } satisfies FieldKindDiscrepancy;
340
- break;
341
- }
342
- case "bExtra": {
343
- if (result.value.kind === storedEmptyFieldSchema.kind) {
344
- // In one of view/stored, this field is explicitly forbidden, but in the other it is implicitly forbidden
345
- // (by way of omission). We treat these identically anyway.
346
- break;
347
- }
348
- yield {
349
- identifier,
350
- fieldKey,
351
- mismatch: "fieldKind",
352
- view: storedEmptyFieldSchema.kind,
353
- stored: result.value.kind,
354
- } satisfies FieldKindDiscrepancy;
355
- break;
356
- }
357
- case "both": {
358
- yield* getFieldDiscrepancies(result.valueA, result.valueB, identifier, fieldKey);
359
- break;
360
- }
361
- default:
362
- break;
363
- }
364
- }
365
- }
366
-
367
- function* compareMaps<K, V1, V2>(
368
- a: ReadonlyMap<K, V1>,
369
- b: ReadonlyMap<K, V2>,
370
- ): Iterable<
371
- | { type: "aExtra"; key: K; value: V1 }
372
- | { type: "bExtra"; key: K; value: V2 }
373
- | { type: "both"; key: K; valueA: V1; valueB: V2 }
374
- > {
375
- for (const [key, valueA] of a) {
376
- const valueB = b.get(key);
377
- yield valueB === undefined
378
- ? { type: "aExtra", key, value: valueA }
379
- : { type: "both", key, valueA, valueB };
380
- }
381
- for (const [key, valueB] of b) {
382
- if (!a.has(key)) {
383
- yield { type: "bExtra", key, value: valueB };
384
- }
385
- }
386
- }
387
- /**
388
- * @remarks
389
- *
390
- * This function uses incompatibilities to determine if changes to a document schema are backward-compatible, i.e., it determines
391
- * whether the `view` schema allows a superset of the documents that the `stored` schema allows.
392
- * According to the policy of schema evolution, `isRepoSuperset` supports three types of changes:
393
- * 1. Adding an optional field to an object node.
394
- * 2. Expanding the set of allowed types for a field.
395
- * 3. Relaxing a field kind to a more general field kind.
396
- *
397
- * Notes: We expect isRepoSuperset to return consistent results with allowsRepoSuperset. However, currently there are some scenarios
398
- * where the inconsistency will occur:
399
- *
400
- * - Different Node Kinds: If a and b have different node kinds (e.g., a is an objectNodeSchema and b is a mapNodeSchema),
401
- * `isRepoSuperset` will determine that a can never be the superset of b. In contrast, `allowsRepoSuperset` will continue
402
- * validating internal fields.
403
- */
404
- export function isRepoSuperset(view: TreeStoredSchema, stored: TreeStoredSchema): boolean {
405
- const discrepancies = getAllowedContentDiscrepancies(view, stored);
406
-
407
- for (const discrepancy of discrepancies) {
408
- switch (discrepancy.mismatch) {
409
- case "nodeKind": {
410
- if (discrepancy.stored !== undefined) {
411
- // It's fine for the view schema to know of a node type that the stored schema doesn't know about.
412
- return false;
413
- }
414
- break;
415
- }
416
- case "valueSchema":
417
- case "allowedTypes":
418
- case "fieldKind": {
419
- if (!isFieldDiscrepancyCompatible(discrepancy)) {
420
- return false;
421
- }
422
- break;
423
- }
424
- case "fields": {
425
- if (
426
- discrepancy.differences.some(
427
- (difference) => !isFieldDiscrepancyCompatible(difference),
428
- )
429
- ) {
430
- return false;
431
- }
432
- break;
433
- }
434
- // No default
435
- }
436
- }
437
- return true;
438
- }
439
-
440
- function isFieldDiscrepancyCompatible(discrepancy: FieldDiscrepancy): boolean {
441
- switch (discrepancy.mismatch) {
442
- case "allowedTypes": {
443
- // Since we only track the symmetric difference between the allowed types in the view and
444
- // stored schemas, it's sufficient to check if any extra allowed types still exist in the
445
- // stored schema.
446
- return discrepancy.stored.length === 0;
447
- }
448
- case "fieldKind": {
449
- return posetLte(discrepancy.stored, discrepancy.view, fieldRealizer);
450
- }
451
- case "valueSchema": {
452
- return false;
453
- }
454
- // No default
455
- }
456
- return false;
457
- }
458
-
459
- /**
460
- * A linear extension of a partially-ordered set of `T`s. See:
461
- * https://en.wikipedia.org/wiki/Linear_extension
462
- *
463
- * The linear extension is represented as a lookup from each poset element to its index in the linear extension.
464
- */
465
- export type LinearExtension<T> = Map<T, number>;
466
-
467
- /**
468
- * A realizer for a partially-ordered set. See:
469
- * https://en.wikipedia.org/wiki/Order_dimension
470
- */
471
- export type Realizer<T> = LinearExtension<T>[];
472
-
473
- /**
474
- * @privateRemarks
475
- * TODO: Knowledge of specific field kinds is not appropriate for modular schema.
476
- * This bit of field comparison should be dependency injected by default-schema if this comparison logic remains in modular-schema
477
- * (this is analogous to what is done in comparison.ts).
478
- */
479
- const FieldKindIdentifiers = {
480
- forbidden: brand<FieldKindIdentifier>("Forbidden"),
481
- required: brand<FieldKindIdentifier>("Value"),
482
- identifier: brand<FieldKindIdentifier>("Identifier"),
483
- optional: brand<FieldKindIdentifier>("Optional"),
484
- sequence: brand<FieldKindIdentifier>("Sequence"),
485
- };
486
-
487
- /**
488
- * A realizer for the partial order of field kind relaxability.
489
- *
490
- * It seems extremely likely that this partial order will remain dimension 2 over time (i.e. the set of allowed relaxations can be visualized
491
- * with a [dominance drawing](https://en.wikipedia.org/wiki/Dominance_drawing)), so this strategy allows efficient comarison between field kinds
492
- * without excessive casework.
493
- *
494
- * Hasse diagram for the partial order is shown below (lower fields can be relaxed to higher fields):
495
- * ```
496
- * sequence
497
- * |
498
- * optional
499
- * | \
500
- * required forbidden
501
- * |
502
- * identifier
503
- * ```
504
- */
505
- export const fieldRealizer: Realizer<FieldKindIdentifier> = [
506
- [
507
- FieldKindIdentifiers.forbidden,
508
- FieldKindIdentifiers.identifier,
509
- FieldKindIdentifiers.required,
510
- FieldKindIdentifiers.optional,
511
- FieldKindIdentifiers.sequence,
512
- ],
513
- [
514
- FieldKindIdentifiers.identifier,
515
- FieldKindIdentifiers.required,
516
- FieldKindIdentifiers.forbidden,
517
- FieldKindIdentifiers.optional,
518
- FieldKindIdentifiers.sequence,
519
- ],
520
- ].map((extension) => new Map(extension.map((identifier, index) => [identifier, index])));
521
-
522
- export const PosetComparisonResult = {
523
- Less: "<",
524
- Greater: ">",
525
- Equal: "=",
526
- Incomparable: "||",
527
- } as const;
528
- type PosetComparisonResult =
529
- (typeof PosetComparisonResult)[keyof typeof PosetComparisonResult];
530
-
531
- export function comparePosetElements<T>(
532
- a: T,
533
- b: T,
534
- realizer: Realizer<T>,
535
- ): PosetComparisonResult {
536
- let hasLessThanResult = false;
537
- let hasGreaterThanResult = false;
538
- for (const extension of realizer) {
539
- const aIndex = extension.get(a);
540
- const bIndex = extension.get(b);
541
- assert(aIndex !== undefined && bIndex !== undefined, 0xa72 /* Invalid realizer */);
542
- if (aIndex < bIndex) {
543
- hasLessThanResult = true;
544
- } else if (aIndex > bIndex) {
545
- hasGreaterThanResult = true;
546
- }
547
- }
548
-
549
- return hasLessThanResult
550
- ? hasGreaterThanResult
551
- ? PosetComparisonResult.Incomparable
552
- : PosetComparisonResult.Less
553
- : hasGreaterThanResult
554
- ? PosetComparisonResult.Greater
555
- : PosetComparisonResult.Equal;
556
- }
557
-
558
- export function posetLte<T>(a: T, b: T, realizer: Realizer<T>): boolean {
559
- const comparison = comparePosetElements(a, b, realizer);
560
- return (
561
- comparison === PosetComparisonResult.Less || comparison === PosetComparisonResult.Equal
562
- );
563
- }
564
-
565
- function throwUnsupportedNodeType(type: string): never {
566
- throw new TypeError(`Unsupported node stored schema type: ${type}`);
567
- }