@fluidframework/tree 2.83.0 → 2.90.0-378676

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (781) hide show
  1. package/api-report/tree.alpha.api.md +1 -0
  2. package/dist/core/change-family/changeFamily.d.ts +4 -1
  3. package/dist/core/change-family/changeFamily.d.ts.map +1 -1
  4. package/dist/core/change-family/changeFamily.js.map +1 -1
  5. package/dist/core/change-family/index.d.ts +1 -1
  6. package/dist/core/change-family/index.d.ts.map +1 -1
  7. package/dist/core/change-family/index.js.map +1 -1
  8. package/dist/core/index.d.ts +3 -3
  9. package/dist/core/index.d.ts.map +1 -1
  10. package/dist/core/index.js +6 -4
  11. package/dist/core/index.js.map +1 -1
  12. package/dist/core/rebase/changeRebaser.d.ts +6 -1
  13. package/dist/core/rebase/changeRebaser.d.ts.map +1 -1
  14. package/dist/core/rebase/changeRebaser.js.map +1 -1
  15. package/dist/core/rebase/index.d.ts +1 -1
  16. package/dist/core/rebase/index.d.ts.map +1 -1
  17. package/dist/core/rebase/index.js +2 -1
  18. package/dist/core/rebase/index.js.map +1 -1
  19. package/dist/core/rebase/types.d.ts +1 -0
  20. package/dist/core/rebase/types.d.ts.map +1 -1
  21. package/dist/core/rebase/types.js +5 -1
  22. package/dist/core/rebase/types.js.map +1 -1
  23. package/dist/core/rebase/utils.d.ts.map +1 -1
  24. package/dist/core/rebase/utils.js +25 -7
  25. package/dist/core/rebase/utils.js.map +1 -1
  26. package/dist/core/tree/delta.d.ts +5 -0
  27. package/dist/core/tree/delta.d.ts.map +1 -1
  28. package/dist/core/tree/delta.js.map +1 -1
  29. package/dist/core/tree/detachedFieldIndex.d.ts +13 -1
  30. package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
  31. package/dist/core/tree/detachedFieldIndex.js +14 -1
  32. package/dist/core/tree/detachedFieldIndex.js.map +1 -1
  33. package/dist/core/tree/detachedFieldIndexTypes.d.ts +4 -0
  34. package/dist/core/tree/detachedFieldIndexTypes.d.ts.map +1 -1
  35. package/dist/core/tree/detachedFieldIndexTypes.js.map +1 -1
  36. package/dist/core/tree/index.d.ts +2 -2
  37. package/dist/core/tree/index.d.ts.map +1 -1
  38. package/dist/core/tree/index.js +4 -3
  39. package/dist/core/tree/index.js.map +1 -1
  40. package/dist/core/tree/pathTree.d.ts +11 -3
  41. package/dist/core/tree/pathTree.d.ts.map +1 -1
  42. package/dist/core/tree/pathTree.js +14 -2
  43. package/dist/core/tree/pathTree.js.map +1 -1
  44. package/dist/core/tree/visitDelta.d.ts.map +1 -1
  45. package/dist/core/tree/visitDelta.js +17 -13
  46. package/dist/core/tree/visitDelta.js.map +1 -1
  47. package/dist/feature-libraries/changeAtomIdBTree.d.ts +3 -2
  48. package/dist/feature-libraries/changeAtomIdBTree.d.ts.map +1 -1
  49. package/dist/feature-libraries/changeAtomIdBTree.js +15 -2
  50. package/dist/feature-libraries/changeAtomIdBTree.js.map +1 -1
  51. package/dist/feature-libraries/default-schema/defaultEditBuilder.d.ts +92 -44
  52. package/dist/feature-libraries/default-schema/defaultEditBuilder.d.ts.map +1 -1
  53. package/dist/feature-libraries/default-schema/defaultEditBuilder.js +220 -70
  54. package/dist/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
  55. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  56. package/dist/feature-libraries/default-schema/defaultFieldKinds.js +12 -2
  57. package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  58. package/dist/feature-libraries/default-schema/index.d.ts +2 -1
  59. package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
  60. package/dist/feature-libraries/default-schema/index.js +4 -2
  61. package/dist/feature-libraries/default-schema/index.js.map +1 -1
  62. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.d.ts +40 -0
  63. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.d.ts.map +1 -0
  64. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.js +153 -0
  65. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.js.map +1 -0
  66. package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts +7 -6
  67. package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
  68. package/dist/feature-libraries/default-schema/mappedEditBuilder.js +15 -0
  69. package/dist/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
  70. package/dist/feature-libraries/deltaUtils.d.ts +1 -0
  71. package/dist/feature-libraries/deltaUtils.d.ts.map +1 -1
  72. package/dist/feature-libraries/deltaUtils.js +6 -1
  73. package/dist/feature-libraries/deltaUtils.js.map +1 -1
  74. package/dist/feature-libraries/flex-tree/context.d.ts +9 -0
  75. package/dist/feature-libraries/flex-tree/context.d.ts.map +1 -1
  76. package/dist/feature-libraries/flex-tree/context.js +6 -0
  77. package/dist/feature-libraries/flex-tree/context.js.map +1 -1
  78. package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts +6 -6
  79. package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
  80. package/dist/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
  81. package/dist/feature-libraries/flex-tree/lazyField.d.ts +8 -7
  82. package/dist/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
  83. package/dist/feature-libraries/flex-tree/lazyField.js +39 -8
  84. package/dist/feature-libraries/flex-tree/lazyField.js.map +1 -1
  85. package/dist/feature-libraries/index.d.ts +3 -3
  86. package/dist/feature-libraries/index.d.ts.map +1 -1
  87. package/dist/feature-libraries/index.js +8 -4
  88. package/dist/feature-libraries/index.js.map +1 -1
  89. package/dist/feature-libraries/mitigatedChangeFamily.d.ts.map +1 -1
  90. package/dist/feature-libraries/mitigatedChangeFamily.js +2 -2
  91. package/dist/feature-libraries/mitigatedChangeFamily.js.map +1 -1
  92. package/dist/feature-libraries/modular-schema/crossFieldQueries.d.ts +100 -24
  93. package/dist/feature-libraries/modular-schema/crossFieldQueries.d.ts.map +1 -1
  94. package/dist/feature-libraries/modular-schema/crossFieldQueries.js +8 -12
  95. package/dist/feature-libraries/modular-schema/crossFieldQueries.js.map +1 -1
  96. package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts +85 -51
  97. package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
  98. package/dist/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
  99. package/dist/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
  100. package/dist/feature-libraries/modular-schema/genericFieldKind.js +4 -9
  101. package/dist/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
  102. package/dist/feature-libraries/modular-schema/index.d.ts +3 -3
  103. package/dist/feature-libraries/modular-schema/index.d.ts.map +1 -1
  104. package/dist/feature-libraries/modular-schema/index.js +2 -3
  105. package/dist/feature-libraries/modular-schema/index.js.map +1 -1
  106. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.d.ts +18 -22
  107. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.d.ts.map +1 -1
  108. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.js +276 -158
  109. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.js.map +1 -1
  110. package/dist/feature-libraries/modular-schema/modularChangeCodecV2.d.ts.map +1 -1
  111. package/dist/feature-libraries/modular-schema/modularChangeCodecV2.js +1 -1
  112. package/dist/feature-libraries/modular-schema/modularChangeCodecV2.js.map +1 -1
  113. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.d.ts +15 -0
  114. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.d.ts.map +1 -0
  115. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.js +296 -0
  116. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.js.map +1 -0
  117. package/dist/feature-libraries/modular-schema/modularChangeCodecs.d.ts +1 -0
  118. package/dist/feature-libraries/modular-schema/modularChangeCodecs.d.ts.map +1 -1
  119. package/dist/feature-libraries/modular-schema/modularChangeCodecs.js +8 -0
  120. package/dist/feature-libraries/modular-schema/modularChangeCodecs.js.map +1 -1
  121. package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts +56 -22
  122. package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
  123. package/dist/feature-libraries/modular-schema/modularChangeFamily.js +1390 -462
  124. package/dist/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
  125. package/dist/feature-libraries/modular-schema/modularChangeFormatV1.d.ts.map +1 -1
  126. package/dist/feature-libraries/modular-schema/modularChangeFormatV1.js.map +1 -1
  127. package/dist/feature-libraries/modular-schema/modularChangeFormatV2.d.ts +1 -2
  128. package/dist/feature-libraries/modular-schema/modularChangeFormatV2.d.ts.map +1 -1
  129. package/dist/feature-libraries/modular-schema/modularChangeFormatV2.js +3 -3
  130. package/dist/feature-libraries/modular-schema/modularChangeFormatV2.js.map +1 -1
  131. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.d.ts +74 -0
  132. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.d.ts.map +1 -0
  133. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.js +35 -0
  134. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.js.map +1 -0
  135. package/dist/feature-libraries/modular-schema/modularChangeTypes.d.ts +49 -10
  136. package/dist/feature-libraries/modular-schema/modularChangeTypes.d.ts.map +1 -1
  137. package/dist/feature-libraries/modular-schema/modularChangeTypes.js +3 -3
  138. package/dist/feature-libraries/modular-schema/modularChangeTypes.js.map +1 -1
  139. package/dist/feature-libraries/optional-field/optionalField.d.ts +13 -32
  140. package/dist/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
  141. package/dist/feature-libraries/optional-field/optionalField.js +257 -446
  142. package/dist/feature-libraries/optional-field/optionalField.js.map +1 -1
  143. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts +23 -0
  144. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts.map +1 -0
  145. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.js +31 -0
  146. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.js.map +1 -0
  147. package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts +31 -31
  148. package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts.map +1 -1
  149. package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.js.map +1 -1
  150. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.d.ts +1 -1
  151. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.d.ts.map +1 -1
  152. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.js +57 -28
  153. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.js.map +1 -1
  154. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.d.ts +12 -0
  155. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.d.ts.map +1 -0
  156. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.js +57 -0
  157. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.js.map +1 -0
  158. package/dist/feature-libraries/optional-field/optionalFieldCodecs.d.ts.map +1 -1
  159. package/dist/feature-libraries/optional-field/optionalFieldCodecs.js +5 -1
  160. package/dist/feature-libraries/optional-field/optionalFieldCodecs.js.map +1 -1
  161. package/dist/feature-libraries/optional-field/requiredField.d.ts +3 -2
  162. package/dist/feature-libraries/optional-field/requiredField.d.ts.map +1 -1
  163. package/dist/feature-libraries/optional-field/requiredField.js +6 -1
  164. package/dist/feature-libraries/optional-field/requiredField.js.map +1 -1
  165. package/dist/feature-libraries/sequence-field/compose.d.ts +6 -7
  166. package/dist/feature-libraries/sequence-field/compose.d.ts.map +1 -1
  167. package/dist/feature-libraries/sequence-field/compose.js +81 -259
  168. package/dist/feature-libraries/sequence-field/compose.js.map +1 -1
  169. package/dist/feature-libraries/sequence-field/helperTypes.d.ts +14 -10
  170. package/dist/feature-libraries/sequence-field/helperTypes.d.ts.map +1 -1
  171. package/dist/feature-libraries/sequence-field/helperTypes.js.map +1 -1
  172. package/dist/feature-libraries/sequence-field/invert.d.ts +3 -3
  173. package/dist/feature-libraries/sequence-field/invert.d.ts.map +1 -1
  174. package/dist/feature-libraries/sequence-field/invert.js +65 -167
  175. package/dist/feature-libraries/sequence-field/invert.js.map +1 -1
  176. package/dist/feature-libraries/sequence-field/markQueue.d.ts +2 -2
  177. package/dist/feature-libraries/sequence-field/markQueue.d.ts.map +1 -1
  178. package/dist/feature-libraries/sequence-field/markQueue.js.map +1 -1
  179. package/dist/feature-libraries/sequence-field/moveEffectTable.d.ts +4 -56
  180. package/dist/feature-libraries/sequence-field/moveEffectTable.d.ts.map +1 -1
  181. package/dist/feature-libraries/sequence-field/moveEffectTable.js +7 -90
  182. package/dist/feature-libraries/sequence-field/moveEffectTable.js.map +1 -1
  183. package/dist/feature-libraries/sequence-field/rebase.d.ts +3 -3
  184. package/dist/feature-libraries/sequence-field/rebase.d.ts.map +1 -1
  185. package/dist/feature-libraries/sequence-field/rebase.js +109 -116
  186. package/dist/feature-libraries/sequence-field/rebase.js.map +1 -1
  187. package/dist/feature-libraries/sequence-field/replaceRevisions.d.ts.map +1 -1
  188. package/dist/feature-libraries/sequence-field/replaceRevisions.js +19 -32
  189. package/dist/feature-libraries/sequence-field/replaceRevisions.js.map +1 -1
  190. package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.d.ts.map +1 -1
  191. package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.js +1 -2
  192. package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.js.map +1 -1
  193. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts +22 -4
  194. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts.map +1 -1
  195. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.js +388 -187
  196. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.js.map +1 -1
  197. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.d.ts.map +1 -1
  198. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.js +20 -62
  199. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.js.map +1 -1
  200. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.d.ts +2 -2
  201. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.d.ts.map +1 -1
  202. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.js +13 -13
  203. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.js.map +1 -1
  204. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts +3 -2
  205. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts.map +1 -1
  206. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.js +16 -111
  207. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.js.map +1 -1
  208. package/dist/feature-libraries/sequence-field/types.d.ts +37 -74
  209. package/dist/feature-libraries/sequence-field/types.d.ts.map +1 -1
  210. package/dist/feature-libraries/sequence-field/types.js.map +1 -1
  211. package/dist/feature-libraries/sequence-field/utils.d.ts +20 -25
  212. package/dist/feature-libraries/sequence-field/utils.d.ts.map +1 -1
  213. package/dist/feature-libraries/sequence-field/utils.js +159 -320
  214. package/dist/feature-libraries/sequence-field/utils.js.map +1 -1
  215. package/dist/packageVersion.d.ts +1 -1
  216. package/dist/packageVersion.d.ts.map +1 -1
  217. package/dist/packageVersion.js +1 -1
  218. package/dist/packageVersion.js.map +1 -1
  219. package/dist/shared-tree/independentView.d.ts.map +1 -1
  220. package/dist/shared-tree/independentView.js +1 -1
  221. package/dist/shared-tree/independentView.js.map +1 -1
  222. package/dist/shared-tree/index.d.ts +1 -1
  223. package/dist/shared-tree/index.d.ts.map +1 -1
  224. package/dist/shared-tree/index.js.map +1 -1
  225. package/dist/shared-tree/schematizeTree.d.ts +4 -4
  226. package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
  227. package/dist/shared-tree/schematizeTree.js +2 -1
  228. package/dist/shared-tree/schematizeTree.js.map +1 -1
  229. package/dist/shared-tree/schematizingTreeView.d.ts +1 -5
  230. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  231. package/dist/shared-tree/schematizingTreeView.js +21 -35
  232. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  233. package/dist/shared-tree/sharedTree.d.ts +9 -3
  234. package/dist/shared-tree/sharedTree.d.ts.map +1 -1
  235. package/dist/shared-tree/sharedTree.js +4 -1
  236. package/dist/shared-tree/sharedTree.js.map +1 -1
  237. package/dist/shared-tree/sharedTreeChangeCodecs.d.ts +1 -0
  238. package/dist/shared-tree/sharedTreeChangeCodecs.d.ts.map +1 -1
  239. package/dist/shared-tree/sharedTreeChangeCodecs.js +8 -0
  240. package/dist/shared-tree/sharedTreeChangeCodecs.js.map +1 -1
  241. package/dist/shared-tree/sharedTreeChangeFamily.d.ts +4 -4
  242. package/dist/shared-tree/sharedTreeChangeFamily.d.ts.map +1 -1
  243. package/dist/shared-tree/sharedTreeChangeFamily.js +2 -2
  244. package/dist/shared-tree/sharedTreeChangeFamily.js.map +1 -1
  245. package/dist/shared-tree/sharedTreeEditBuilder.d.ts +16 -6
  246. package/dist/shared-tree/sharedTreeEditBuilder.d.ts.map +1 -1
  247. package/dist/shared-tree/sharedTreeEditBuilder.js +14 -7
  248. package/dist/shared-tree/sharedTreeEditBuilder.js.map +1 -1
  249. package/dist/shared-tree/treeCheckout.d.ts +13 -11
  250. package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
  251. package/dist/shared-tree/treeCheckout.js +56 -6
  252. package/dist/shared-tree/treeCheckout.js.map +1 -1
  253. package/dist/shared-tree-core/branch.d.ts +3 -2
  254. package/dist/shared-tree-core/branch.d.ts.map +1 -1
  255. package/dist/shared-tree-core/branch.js +4 -3
  256. package/dist/shared-tree-core/branch.js.map +1 -1
  257. package/dist/shared-tree-core/editManager.d.ts +2 -2
  258. package/dist/shared-tree-core/editManager.d.ts.map +1 -1
  259. package/dist/shared-tree-core/editManager.js +9 -9
  260. package/dist/shared-tree-core/editManager.js.map +1 -1
  261. package/dist/shared-tree-core/editManagerCodecs.d.ts +4 -0
  262. package/dist/shared-tree-core/editManagerCodecs.d.ts.map +1 -1
  263. package/dist/shared-tree-core/editManagerCodecs.js +10 -2
  264. package/dist/shared-tree-core/editManagerCodecs.js.map +1 -1
  265. package/dist/shared-tree-core/editManagerFormatCommons.d.ts +1 -0
  266. package/dist/shared-tree-core/editManagerFormatCommons.d.ts.map +1 -1
  267. package/dist/shared-tree-core/editManagerFormatCommons.js +6 -0
  268. package/dist/shared-tree-core/editManagerFormatCommons.js.map +1 -1
  269. package/dist/shared-tree-core/editManagerFormatV1toV4.d.ts +2 -2
  270. package/dist/shared-tree-core/editManagerFormatV1toV4.d.ts.map +1 -1
  271. package/dist/shared-tree-core/editManagerFormatV1toV4.js +1 -0
  272. package/dist/shared-tree-core/editManagerFormatV1toV4.js.map +1 -1
  273. package/dist/shared-tree-core/index.d.ts +2 -2
  274. package/dist/shared-tree-core/index.d.ts.map +1 -1
  275. package/dist/shared-tree-core/index.js +3 -1
  276. package/dist/shared-tree-core/index.js.map +1 -1
  277. package/dist/shared-tree-core/messageCodecV1ToV4.d.ts +1 -1
  278. package/dist/shared-tree-core/messageCodecV1ToV4.d.ts.map +1 -1
  279. package/dist/shared-tree-core/messageCodecV1ToV4.js.map +1 -1
  280. package/dist/shared-tree-core/messageCodecs.d.ts +4 -0
  281. package/dist/shared-tree-core/messageCodecs.d.ts.map +1 -1
  282. package/dist/shared-tree-core/messageCodecs.js +10 -2
  283. package/dist/shared-tree-core/messageCodecs.js.map +1 -1
  284. package/dist/shared-tree-core/messageFormat.d.ts +1 -0
  285. package/dist/shared-tree-core/messageFormat.d.ts.map +1 -1
  286. package/dist/shared-tree-core/messageFormat.js +6 -0
  287. package/dist/shared-tree-core/messageFormat.js.map +1 -1
  288. package/dist/shared-tree-core/messageFormatV1ToV4.d.ts +2 -2
  289. package/dist/shared-tree-core/messageFormatV1ToV4.d.ts.map +1 -1
  290. package/dist/shared-tree-core/messageFormatV1ToV4.js +1 -0
  291. package/dist/shared-tree-core/messageFormatV1ToV4.js.map +1 -1
  292. package/dist/shared-tree-core/sharedTreeCore.d.ts +1 -0
  293. package/dist/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
  294. package/dist/shared-tree-core/sharedTreeCore.js +1 -1
  295. package/dist/shared-tree-core/sharedTreeCore.js.map +1 -1
  296. package/dist/simple-tree/core/unhydratedFlexTree.d.ts +16 -12
  297. package/dist/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
  298. package/dist/simple-tree/core/unhydratedFlexTree.js +59 -8
  299. package/dist/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  300. package/dist/simple-tree/fieldSchema.d.ts +4 -4
  301. package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
  302. package/dist/simple-tree/fieldSchema.js.map +1 -1
  303. package/dist/simple-tree/index.d.ts +2 -2
  304. package/dist/simple-tree/index.d.ts.map +1 -1
  305. package/dist/simple-tree/index.js +1 -1
  306. package/dist/simple-tree/index.js.map +1 -1
  307. package/dist/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  308. package/dist/simple-tree/node-kinds/array/arrayNode.js +5 -3
  309. package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  310. package/dist/simple-tree/node-kinds/common.d.ts.map +1 -1
  311. package/dist/simple-tree/node-kinds/common.js +1 -1
  312. package/dist/simple-tree/node-kinds/common.js.map +1 -1
  313. package/dist/simple-tree/node-kinds/map/mapNode.js +2 -2
  314. package/dist/simple-tree/node-kinds/map/mapNode.js.map +1 -1
  315. package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  316. package/dist/simple-tree/node-kinds/object/objectNode.js +19 -19
  317. package/dist/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  318. package/dist/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
  319. package/dist/simple-tree/node-kinds/record/recordNode.js +4 -2
  320. package/dist/simple-tree/node-kinds/record/recordNode.js.map +1 -1
  321. package/dist/simple-tree/prepareForInsertion.d.ts +54 -47
  322. package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
  323. package/dist/simple-tree/prepareForInsertion.js +183 -125
  324. package/dist/simple-tree/prepareForInsertion.js.map +1 -1
  325. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +8 -3
  326. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  327. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js +27 -13
  328. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  329. package/dist/treeFactory.d.ts.map +1 -1
  330. package/dist/treeFactory.js +12 -2
  331. package/dist/treeFactory.js.map +1 -1
  332. package/dist/util/index.d.ts +1 -1
  333. package/dist/util/index.d.ts.map +1 -1
  334. package/dist/util/index.js +2 -1
  335. package/dist/util/index.js.map +1 -1
  336. package/dist/util/rangeMap.d.ts +23 -11
  337. package/dist/util/rangeMap.d.ts.map +1 -1
  338. package/dist/util/rangeMap.js +43 -10
  339. package/dist/util/rangeMap.js.map +1 -1
  340. package/lib/core/change-family/changeFamily.d.ts +4 -1
  341. package/lib/core/change-family/changeFamily.d.ts.map +1 -1
  342. package/lib/core/change-family/changeFamily.js.map +1 -1
  343. package/lib/core/change-family/index.d.ts +1 -1
  344. package/lib/core/change-family/index.d.ts.map +1 -1
  345. package/lib/core/change-family/index.js.map +1 -1
  346. package/lib/core/index.d.ts +3 -3
  347. package/lib/core/index.d.ts.map +1 -1
  348. package/lib/core/index.js +2 -2
  349. package/lib/core/index.js.map +1 -1
  350. package/lib/core/rebase/changeRebaser.d.ts +6 -1
  351. package/lib/core/rebase/changeRebaser.d.ts.map +1 -1
  352. package/lib/core/rebase/changeRebaser.js.map +1 -1
  353. package/lib/core/rebase/index.d.ts +1 -1
  354. package/lib/core/rebase/index.d.ts.map +1 -1
  355. package/lib/core/rebase/index.js +1 -1
  356. package/lib/core/rebase/index.js.map +1 -1
  357. package/lib/core/rebase/types.d.ts +1 -0
  358. package/lib/core/rebase/types.d.ts.map +1 -1
  359. package/lib/core/rebase/types.js +3 -0
  360. package/lib/core/rebase/types.js.map +1 -1
  361. package/lib/core/rebase/utils.d.ts.map +1 -1
  362. package/lib/core/rebase/utils.js +25 -7
  363. package/lib/core/rebase/utils.js.map +1 -1
  364. package/lib/core/tree/delta.d.ts +5 -0
  365. package/lib/core/tree/delta.d.ts.map +1 -1
  366. package/lib/core/tree/delta.js.map +1 -1
  367. package/lib/core/tree/detachedFieldIndex.d.ts +13 -1
  368. package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
  369. package/lib/core/tree/detachedFieldIndex.js +15 -2
  370. package/lib/core/tree/detachedFieldIndex.js.map +1 -1
  371. package/lib/core/tree/detachedFieldIndexTypes.d.ts +4 -0
  372. package/lib/core/tree/detachedFieldIndexTypes.d.ts.map +1 -1
  373. package/lib/core/tree/detachedFieldIndexTypes.js.map +1 -1
  374. package/lib/core/tree/index.d.ts +2 -2
  375. package/lib/core/tree/index.d.ts.map +1 -1
  376. package/lib/core/tree/index.js +1 -1
  377. package/lib/core/tree/index.js.map +1 -1
  378. package/lib/core/tree/pathTree.d.ts +11 -3
  379. package/lib/core/tree/pathTree.d.ts.map +1 -1
  380. package/lib/core/tree/pathTree.js +12 -1
  381. package/lib/core/tree/pathTree.js.map +1 -1
  382. package/lib/core/tree/visitDelta.d.ts.map +1 -1
  383. package/lib/core/tree/visitDelta.js +17 -13
  384. package/lib/core/tree/visitDelta.js.map +1 -1
  385. package/lib/feature-libraries/changeAtomIdBTree.d.ts +3 -2
  386. package/lib/feature-libraries/changeAtomIdBTree.d.ts.map +1 -1
  387. package/lib/feature-libraries/changeAtomIdBTree.js +15 -3
  388. package/lib/feature-libraries/changeAtomIdBTree.js.map +1 -1
  389. package/lib/feature-libraries/default-schema/defaultEditBuilder.d.ts +92 -44
  390. package/lib/feature-libraries/default-schema/defaultEditBuilder.d.ts.map +1 -1
  391. package/lib/feature-libraries/default-schema/defaultEditBuilder.js +217 -69
  392. package/lib/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
  393. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  394. package/lib/feature-libraries/default-schema/defaultFieldKinds.js +12 -2
  395. package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  396. package/lib/feature-libraries/default-schema/index.d.ts +2 -1
  397. package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
  398. package/lib/feature-libraries/default-schema/index.js +2 -1
  399. package/lib/feature-libraries/default-schema/index.js.map +1 -1
  400. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.d.ts +40 -0
  401. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.d.ts.map +1 -0
  402. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.js +149 -0
  403. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.js.map +1 -0
  404. package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts +7 -6
  405. package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
  406. package/lib/feature-libraries/default-schema/mappedEditBuilder.js +15 -0
  407. package/lib/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
  408. package/lib/feature-libraries/deltaUtils.d.ts +1 -0
  409. package/lib/feature-libraries/deltaUtils.d.ts.map +1 -1
  410. package/lib/feature-libraries/deltaUtils.js +5 -1
  411. package/lib/feature-libraries/deltaUtils.js.map +1 -1
  412. package/lib/feature-libraries/flex-tree/context.d.ts +9 -0
  413. package/lib/feature-libraries/flex-tree/context.d.ts.map +1 -1
  414. package/lib/feature-libraries/flex-tree/context.js +6 -0
  415. package/lib/feature-libraries/flex-tree/context.js.map +1 -1
  416. package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts +6 -6
  417. package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
  418. package/lib/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
  419. package/lib/feature-libraries/flex-tree/lazyField.d.ts +8 -7
  420. package/lib/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
  421. package/lib/feature-libraries/flex-tree/lazyField.js +40 -9
  422. package/lib/feature-libraries/flex-tree/lazyField.js.map +1 -1
  423. package/lib/feature-libraries/index.d.ts +3 -3
  424. package/lib/feature-libraries/index.d.ts.map +1 -1
  425. package/lib/feature-libraries/index.js +3 -3
  426. package/lib/feature-libraries/index.js.map +1 -1
  427. package/lib/feature-libraries/mitigatedChangeFamily.d.ts.map +1 -1
  428. package/lib/feature-libraries/mitigatedChangeFamily.js +2 -2
  429. package/lib/feature-libraries/mitigatedChangeFamily.js.map +1 -1
  430. package/lib/feature-libraries/modular-schema/crossFieldQueries.d.ts +100 -24
  431. package/lib/feature-libraries/modular-schema/crossFieldQueries.d.ts.map +1 -1
  432. package/lib/feature-libraries/modular-schema/crossFieldQueries.js +7 -10
  433. package/lib/feature-libraries/modular-schema/crossFieldQueries.js.map +1 -1
  434. package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts +85 -51
  435. package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
  436. package/lib/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
  437. package/lib/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
  438. package/lib/feature-libraries/modular-schema/genericFieldKind.js +4 -9
  439. package/lib/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
  440. package/lib/feature-libraries/modular-schema/index.d.ts +3 -3
  441. package/lib/feature-libraries/modular-schema/index.d.ts.map +1 -1
  442. package/lib/feature-libraries/modular-schema/index.js +1 -1
  443. package/lib/feature-libraries/modular-schema/index.js.map +1 -1
  444. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.d.ts +18 -22
  445. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.d.ts.map +1 -1
  446. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.js +267 -144
  447. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.js.map +1 -1
  448. package/lib/feature-libraries/modular-schema/modularChangeCodecV2.d.ts.map +1 -1
  449. package/lib/feature-libraries/modular-schema/modularChangeCodecV2.js +1 -1
  450. package/lib/feature-libraries/modular-schema/modularChangeCodecV2.js.map +1 -1
  451. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.d.ts +15 -0
  452. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.d.ts.map +1 -0
  453. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.js +292 -0
  454. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.js.map +1 -0
  455. package/lib/feature-libraries/modular-schema/modularChangeCodecs.d.ts +1 -0
  456. package/lib/feature-libraries/modular-schema/modularChangeCodecs.d.ts.map +1 -1
  457. package/lib/feature-libraries/modular-schema/modularChangeCodecs.js +8 -0
  458. package/lib/feature-libraries/modular-schema/modularChangeCodecs.js.map +1 -1
  459. package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts +56 -22
  460. package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
  461. package/lib/feature-libraries/modular-schema/modularChangeFamily.js +1387 -468
  462. package/lib/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
  463. package/lib/feature-libraries/modular-schema/modularChangeFormatV1.d.ts.map +1 -1
  464. package/lib/feature-libraries/modular-schema/modularChangeFormatV1.js.map +1 -1
  465. package/lib/feature-libraries/modular-schema/modularChangeFormatV2.d.ts +1 -2
  466. package/lib/feature-libraries/modular-schema/modularChangeFormatV2.d.ts.map +1 -1
  467. package/lib/feature-libraries/modular-schema/modularChangeFormatV2.js +1 -1
  468. package/lib/feature-libraries/modular-schema/modularChangeFormatV2.js.map +1 -1
  469. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.d.ts +74 -0
  470. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.d.ts.map +1 -0
  471. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.js +32 -0
  472. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.js.map +1 -0
  473. package/lib/feature-libraries/modular-schema/modularChangeTypes.d.ts +49 -10
  474. package/lib/feature-libraries/modular-schema/modularChangeTypes.d.ts.map +1 -1
  475. package/lib/feature-libraries/modular-schema/modularChangeTypes.js +1 -1
  476. package/lib/feature-libraries/modular-schema/modularChangeTypes.js.map +1 -1
  477. package/lib/feature-libraries/optional-field/optionalField.d.ts +13 -32
  478. package/lib/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
  479. package/lib/feature-libraries/optional-field/optionalField.js +254 -442
  480. package/lib/feature-libraries/optional-field/optionalField.js.map +1 -1
  481. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts +23 -0
  482. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts.map +1 -0
  483. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.js +27 -0
  484. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.js.map +1 -0
  485. package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts +31 -31
  486. package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts.map +1 -1
  487. package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.js.map +1 -1
  488. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.d.ts +1 -1
  489. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.d.ts.map +1 -1
  490. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.js +55 -26
  491. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.js.map +1 -1
  492. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.d.ts +12 -0
  493. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.d.ts.map +1 -0
  494. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.js +53 -0
  495. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.js.map +1 -0
  496. package/lib/feature-libraries/optional-field/optionalFieldCodecs.d.ts.map +1 -1
  497. package/lib/feature-libraries/optional-field/optionalFieldCodecs.js +5 -1
  498. package/lib/feature-libraries/optional-field/optionalFieldCodecs.js.map +1 -1
  499. package/lib/feature-libraries/optional-field/requiredField.d.ts +3 -2
  500. package/lib/feature-libraries/optional-field/requiredField.d.ts.map +1 -1
  501. package/lib/feature-libraries/optional-field/requiredField.js +5 -1
  502. package/lib/feature-libraries/optional-field/requiredField.js.map +1 -1
  503. package/lib/feature-libraries/sequence-field/compose.d.ts +6 -7
  504. package/lib/feature-libraries/sequence-field/compose.d.ts.map +1 -1
  505. package/lib/feature-libraries/sequence-field/compose.js +83 -261
  506. package/lib/feature-libraries/sequence-field/compose.js.map +1 -1
  507. package/lib/feature-libraries/sequence-field/helperTypes.d.ts +14 -10
  508. package/lib/feature-libraries/sequence-field/helperTypes.d.ts.map +1 -1
  509. package/lib/feature-libraries/sequence-field/helperTypes.js.map +1 -1
  510. package/lib/feature-libraries/sequence-field/invert.d.ts +3 -3
  511. package/lib/feature-libraries/sequence-field/invert.d.ts.map +1 -1
  512. package/lib/feature-libraries/sequence-field/invert.js +67 -169
  513. package/lib/feature-libraries/sequence-field/invert.js.map +1 -1
  514. package/lib/feature-libraries/sequence-field/markQueue.d.ts +2 -2
  515. package/lib/feature-libraries/sequence-field/markQueue.d.ts.map +1 -1
  516. package/lib/feature-libraries/sequence-field/markQueue.js.map +1 -1
  517. package/lib/feature-libraries/sequence-field/moveEffectTable.d.ts +4 -56
  518. package/lib/feature-libraries/sequence-field/moveEffectTable.d.ts.map +1 -1
  519. package/lib/feature-libraries/sequence-field/moveEffectTable.js +6 -84
  520. package/lib/feature-libraries/sequence-field/moveEffectTable.js.map +1 -1
  521. package/lib/feature-libraries/sequence-field/rebase.d.ts +3 -3
  522. package/lib/feature-libraries/sequence-field/rebase.d.ts.map +1 -1
  523. package/lib/feature-libraries/sequence-field/rebase.js +111 -118
  524. package/lib/feature-libraries/sequence-field/rebase.js.map +1 -1
  525. package/lib/feature-libraries/sequence-field/replaceRevisions.d.ts.map +1 -1
  526. package/lib/feature-libraries/sequence-field/replaceRevisions.js +19 -32
  527. package/lib/feature-libraries/sequence-field/replaceRevisions.js.map +1 -1
  528. package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.d.ts.map +1 -1
  529. package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.js +2 -3
  530. package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.js.map +1 -1
  531. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts +22 -4
  532. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts.map +1 -1
  533. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.js +379 -182
  534. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.js.map +1 -1
  535. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.d.ts.map +1 -1
  536. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.js +21 -63
  537. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.js.map +1 -1
  538. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.d.ts +2 -2
  539. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.d.ts.map +1 -1
  540. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.js +13 -13
  541. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.js.map +1 -1
  542. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts +3 -2
  543. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts.map +1 -1
  544. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.js +16 -111
  545. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.js.map +1 -1
  546. package/lib/feature-libraries/sequence-field/types.d.ts +37 -74
  547. package/lib/feature-libraries/sequence-field/types.d.ts.map +1 -1
  548. package/lib/feature-libraries/sequence-field/types.js.map +1 -1
  549. package/lib/feature-libraries/sequence-field/utils.d.ts +20 -25
  550. package/lib/feature-libraries/sequence-field/utils.d.ts.map +1 -1
  551. package/lib/feature-libraries/sequence-field/utils.js +155 -313
  552. package/lib/feature-libraries/sequence-field/utils.js.map +1 -1
  553. package/lib/packageVersion.d.ts +1 -1
  554. package/lib/packageVersion.d.ts.map +1 -1
  555. package/lib/packageVersion.js +1 -1
  556. package/lib/packageVersion.js.map +1 -1
  557. package/lib/shared-tree/independentView.d.ts.map +1 -1
  558. package/lib/shared-tree/independentView.js +1 -1
  559. package/lib/shared-tree/independentView.js.map +1 -1
  560. package/lib/shared-tree/index.d.ts +1 -1
  561. package/lib/shared-tree/index.d.ts.map +1 -1
  562. package/lib/shared-tree/index.js.map +1 -1
  563. package/lib/shared-tree/schematizeTree.d.ts +4 -4
  564. package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
  565. package/lib/shared-tree/schematizeTree.js +3 -2
  566. package/lib/shared-tree/schematizeTree.js.map +1 -1
  567. package/lib/shared-tree/schematizingTreeView.d.ts +1 -5
  568. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  569. package/lib/shared-tree/schematizingTreeView.js +24 -38
  570. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  571. package/lib/shared-tree/sharedTree.d.ts +9 -3
  572. package/lib/shared-tree/sharedTree.d.ts.map +1 -1
  573. package/lib/shared-tree/sharedTree.js +4 -1
  574. package/lib/shared-tree/sharedTree.js.map +1 -1
  575. package/lib/shared-tree/sharedTreeChangeCodecs.d.ts +1 -0
  576. package/lib/shared-tree/sharedTreeChangeCodecs.d.ts.map +1 -1
  577. package/lib/shared-tree/sharedTreeChangeCodecs.js +8 -0
  578. package/lib/shared-tree/sharedTreeChangeCodecs.js.map +1 -1
  579. package/lib/shared-tree/sharedTreeChangeFamily.d.ts +4 -4
  580. package/lib/shared-tree/sharedTreeChangeFamily.d.ts.map +1 -1
  581. package/lib/shared-tree/sharedTreeChangeFamily.js +3 -3
  582. package/lib/shared-tree/sharedTreeChangeFamily.js.map +1 -1
  583. package/lib/shared-tree/sharedTreeEditBuilder.d.ts +16 -6
  584. package/lib/shared-tree/sharedTreeEditBuilder.d.ts.map +1 -1
  585. package/lib/shared-tree/sharedTreeEditBuilder.js +12 -6
  586. package/lib/shared-tree/sharedTreeEditBuilder.js.map +1 -1
  587. package/lib/shared-tree/treeCheckout.d.ts +13 -11
  588. package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
  589. package/lib/shared-tree/treeCheckout.js +59 -9
  590. package/lib/shared-tree/treeCheckout.js.map +1 -1
  591. package/lib/shared-tree-core/branch.d.ts +3 -2
  592. package/lib/shared-tree-core/branch.d.ts.map +1 -1
  593. package/lib/shared-tree-core/branch.js +4 -3
  594. package/lib/shared-tree-core/branch.js.map +1 -1
  595. package/lib/shared-tree-core/editManager.d.ts +2 -2
  596. package/lib/shared-tree-core/editManager.d.ts.map +1 -1
  597. package/lib/shared-tree-core/editManager.js +9 -9
  598. package/lib/shared-tree-core/editManager.js.map +1 -1
  599. package/lib/shared-tree-core/editManagerCodecs.d.ts +4 -0
  600. package/lib/shared-tree-core/editManagerCodecs.d.ts.map +1 -1
  601. package/lib/shared-tree-core/editManagerCodecs.js +8 -1
  602. package/lib/shared-tree-core/editManagerCodecs.js.map +1 -1
  603. package/lib/shared-tree-core/editManagerFormatCommons.d.ts +1 -0
  604. package/lib/shared-tree-core/editManagerFormatCommons.d.ts.map +1 -1
  605. package/lib/shared-tree-core/editManagerFormatCommons.js +6 -0
  606. package/lib/shared-tree-core/editManagerFormatCommons.js.map +1 -1
  607. package/lib/shared-tree-core/editManagerFormatV1toV4.d.ts +2 -2
  608. package/lib/shared-tree-core/editManagerFormatV1toV4.d.ts.map +1 -1
  609. package/lib/shared-tree-core/editManagerFormatV1toV4.js +1 -0
  610. package/lib/shared-tree-core/editManagerFormatV1toV4.js.map +1 -1
  611. package/lib/shared-tree-core/index.d.ts +2 -2
  612. package/lib/shared-tree-core/index.d.ts.map +1 -1
  613. package/lib/shared-tree-core/index.js +2 -2
  614. package/lib/shared-tree-core/index.js.map +1 -1
  615. package/lib/shared-tree-core/messageCodecV1ToV4.d.ts +1 -1
  616. package/lib/shared-tree-core/messageCodecV1ToV4.d.ts.map +1 -1
  617. package/lib/shared-tree-core/messageCodecV1ToV4.js.map +1 -1
  618. package/lib/shared-tree-core/messageCodecs.d.ts +4 -0
  619. package/lib/shared-tree-core/messageCodecs.d.ts.map +1 -1
  620. package/lib/shared-tree-core/messageCodecs.js +8 -1
  621. package/lib/shared-tree-core/messageCodecs.js.map +1 -1
  622. package/lib/shared-tree-core/messageFormat.d.ts +1 -0
  623. package/lib/shared-tree-core/messageFormat.d.ts.map +1 -1
  624. package/lib/shared-tree-core/messageFormat.js +6 -0
  625. package/lib/shared-tree-core/messageFormat.js.map +1 -1
  626. package/lib/shared-tree-core/messageFormatV1ToV4.d.ts +2 -2
  627. package/lib/shared-tree-core/messageFormatV1ToV4.d.ts.map +1 -1
  628. package/lib/shared-tree-core/messageFormatV1ToV4.js +1 -0
  629. package/lib/shared-tree-core/messageFormatV1ToV4.js.map +1 -1
  630. package/lib/shared-tree-core/sharedTreeCore.d.ts +1 -0
  631. package/lib/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
  632. package/lib/shared-tree-core/sharedTreeCore.js +1 -1
  633. package/lib/shared-tree-core/sharedTreeCore.js.map +1 -1
  634. package/lib/simple-tree/core/unhydratedFlexTree.d.ts +16 -12
  635. package/lib/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
  636. package/lib/simple-tree/core/unhydratedFlexTree.js +58 -8
  637. package/lib/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  638. package/lib/simple-tree/fieldSchema.d.ts +4 -4
  639. package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
  640. package/lib/simple-tree/fieldSchema.js.map +1 -1
  641. package/lib/simple-tree/index.d.ts +2 -2
  642. package/lib/simple-tree/index.d.ts.map +1 -1
  643. package/lib/simple-tree/index.js +1 -1
  644. package/lib/simple-tree/index.js.map +1 -1
  645. package/lib/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  646. package/lib/simple-tree/node-kinds/array/arrayNode.js +6 -4
  647. package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  648. package/lib/simple-tree/node-kinds/common.d.ts.map +1 -1
  649. package/lib/simple-tree/node-kinds/common.js +2 -2
  650. package/lib/simple-tree/node-kinds/common.js.map +1 -1
  651. package/lib/simple-tree/node-kinds/map/mapNode.js +2 -2
  652. package/lib/simple-tree/node-kinds/map/mapNode.js.map +1 -1
  653. package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  654. package/lib/simple-tree/node-kinds/object/objectNode.js +20 -20
  655. package/lib/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  656. package/lib/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
  657. package/lib/simple-tree/node-kinds/record/recordNode.js +4 -2
  658. package/lib/simple-tree/node-kinds/record/recordNode.js.map +1 -1
  659. package/lib/simple-tree/prepareForInsertion.d.ts +54 -47
  660. package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
  661. package/lib/simple-tree/prepareForInsertion.js +184 -125
  662. package/lib/simple-tree/prepareForInsertion.js.map +1 -1
  663. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +8 -3
  664. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  665. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +23 -10
  666. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  667. package/lib/treeFactory.d.ts.map +1 -1
  668. package/lib/treeFactory.js +13 -3
  669. package/lib/treeFactory.js.map +1 -1
  670. package/lib/util/index.d.ts +1 -1
  671. package/lib/util/index.d.ts.map +1 -1
  672. package/lib/util/index.js +1 -1
  673. package/lib/util/index.js.map +1 -1
  674. package/lib/util/rangeMap.d.ts +23 -11
  675. package/lib/util/rangeMap.d.ts.map +1 -1
  676. package/lib/util/rangeMap.js +41 -9
  677. package/lib/util/rangeMap.js.map +1 -1
  678. package/package.json +21 -21
  679. package/src/core/change-family/changeFamily.ts +5 -0
  680. package/src/core/change-family/index.ts +1 -0
  681. package/src/core/index.ts +4 -1
  682. package/src/core/rebase/changeRebaser.ts +6 -1
  683. package/src/core/rebase/index.ts +1 -0
  684. package/src/core/rebase/types.ts +4 -0
  685. package/src/core/rebase/utils.ts +31 -7
  686. package/src/core/tree/delta.ts +6 -0
  687. package/src/core/tree/detachedFieldIndex.ts +29 -1
  688. package/src/core/tree/detachedFieldIndexTypes.ts +5 -0
  689. package/src/core/tree/index.ts +13 -12
  690. package/src/core/tree/pathTree.ts +16 -4
  691. package/src/core/tree/visitDelta.ts +31 -11
  692. package/src/feature-libraries/changeAtomIdBTree.ts +28 -3
  693. package/src/feature-libraries/default-schema/defaultEditBuilder.ts +369 -127
  694. package/src/feature-libraries/default-schema/defaultFieldKinds.ts +13 -4
  695. package/src/feature-libraries/default-schema/index.ts +16 -5
  696. package/src/feature-libraries/default-schema/locationBasedEditBuilder.ts +231 -0
  697. package/src/feature-libraries/default-schema/mappedEditBuilder.ts +35 -9
  698. package/src/feature-libraries/deltaUtils.ts +6 -1
  699. package/src/feature-libraries/flex-tree/context.ts +17 -0
  700. package/src/feature-libraries/flex-tree/flexTreeTypes.ts +7 -8
  701. package/src/feature-libraries/flex-tree/lazyField.ts +65 -24
  702. package/src/feature-libraries/index.ts +22 -9
  703. package/src/feature-libraries/mitigatedChangeFamily.ts +3 -1
  704. package/src/feature-libraries/modular-schema/crossFieldQueries.ts +144 -47
  705. package/src/feature-libraries/modular-schema/fieldChangeHandler.ts +113 -58
  706. package/src/feature-libraries/modular-schema/genericFieldKind.ts +7 -18
  707. package/src/feature-libraries/modular-schema/index.ts +16 -16
  708. package/src/feature-libraries/modular-schema/modularChangeCodecV1.ts +623 -348
  709. package/src/feature-libraries/modular-schema/modularChangeCodecV2.ts +1 -0
  710. package/src/feature-libraries/modular-schema/modularChangeCodecV3.ts +649 -0
  711. package/src/feature-libraries/modular-schema/modularChangeCodecs.ts +14 -0
  712. package/src/feature-libraries/modular-schema/modularChangeFamily.ts +2694 -748
  713. package/src/feature-libraries/modular-schema/modularChangeFormatV1.ts +1 -0
  714. package/src/feature-libraries/modular-schema/modularChangeFormatV2.ts +1 -1
  715. package/src/feature-libraries/modular-schema/modularChangeFormatV3.ts +67 -0
  716. package/src/feature-libraries/modular-schema/modularChangeTypes.ts +62 -10
  717. package/src/feature-libraries/optional-field/optionalField.ts +359 -568
  718. package/src/feature-libraries/optional-field/optionalFieldChangeFormatV3.ts +45 -0
  719. package/src/feature-libraries/optional-field/optionalFieldChangeTypes.ts +31 -35
  720. package/src/feature-libraries/optional-field/optionalFieldCodecV2.ts +89 -35
  721. package/src/feature-libraries/optional-field/optionalFieldCodecV3.ts +94 -0
  722. package/src/feature-libraries/optional-field/optionalFieldCodecs.ts +5 -1
  723. package/src/feature-libraries/optional-field/requiredField.ts +15 -2
  724. package/src/feature-libraries/sequence-field/compose.ts +137 -522
  725. package/src/feature-libraries/sequence-field/helperTypes.ts +34 -19
  726. package/src/feature-libraries/sequence-field/invert.ts +102 -228
  727. package/src/feature-libraries/sequence-field/markQueue.ts +2 -2
  728. package/src/feature-libraries/sequence-field/moveEffectTable.ts +8 -195
  729. package/src/feature-libraries/sequence-field/rebase.ts +171 -207
  730. package/src/feature-libraries/sequence-field/replaceRevisions.ts +26 -52
  731. package/src/feature-libraries/sequence-field/sequenceFieldChangeHandler.ts +8 -3
  732. package/src/feature-libraries/sequence-field/sequenceFieldCodecV2.ts +677 -229
  733. package/src/feature-libraries/sequence-field/sequenceFieldCodecV3.ts +56 -70
  734. package/src/feature-libraries/sequence-field/sequenceFieldEditor.ts +28 -30
  735. package/src/feature-libraries/sequence-field/sequenceFieldToDelta.ts +21 -131
  736. package/src/feature-libraries/sequence-field/types.ts +40 -79
  737. package/src/feature-libraries/sequence-field/utils.ts +211 -370
  738. package/src/packageVersion.ts +1 -1
  739. package/src/shared-tree/independentView.ts +12 -6
  740. package/src/shared-tree/index.ts +3 -2
  741. package/src/shared-tree/schematizeTree.ts +21 -8
  742. package/src/shared-tree/schematizingTreeView.ts +38 -68
  743. package/src/shared-tree/sharedTree.ts +30 -15
  744. package/src/shared-tree/sharedTreeChangeCodecs.ts +8 -0
  745. package/src/shared-tree/sharedTreeChangeFamily.ts +7 -4
  746. package/src/shared-tree/sharedTreeEditBuilder.ts +43 -8
  747. package/src/shared-tree/treeCheckout.ts +93 -17
  748. package/src/shared-tree-core/branch.ts +8 -2
  749. package/src/shared-tree-core/editManager.ts +16 -2
  750. package/src/shared-tree-core/editManagerCodecs.ts +11 -1
  751. package/src/shared-tree-core/editManagerFormatCommons.ts +6 -0
  752. package/src/shared-tree-core/editManagerFormatV1toV4.ts +3 -1
  753. package/src/shared-tree-core/index.ts +2 -0
  754. package/src/shared-tree-core/messageCodecV1ToV4.ts +2 -1
  755. package/src/shared-tree-core/messageCodecs.ts +11 -1
  756. package/src/shared-tree-core/messageFormat.ts +6 -0
  757. package/src/shared-tree-core/messageFormatV1ToV4.ts +3 -1
  758. package/src/shared-tree-core/sharedTreeCore.ts +4 -1
  759. package/src/simple-tree/core/unhydratedFlexTree.ts +82 -35
  760. package/src/simple-tree/fieldSchema.ts +6 -4
  761. package/src/simple-tree/index.ts +2 -1
  762. package/src/simple-tree/node-kinds/array/arrayNode.ts +7 -5
  763. package/src/simple-tree/node-kinds/common.ts +2 -5
  764. package/src/simple-tree/node-kinds/map/mapNode.ts +4 -4
  765. package/src/simple-tree/node-kinds/object/objectNode.ts +26 -26
  766. package/src/simple-tree/node-kinds/record/recordNode.ts +10 -9
  767. package/src/simple-tree/prepareForInsertion.ts +342 -200
  768. package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +35 -15
  769. package/src/treeFactory.ts +16 -4
  770. package/src/util/index.ts +3 -0
  771. package/src/util/rangeMap.ts +68 -26
  772. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.d.ts +0 -9
  773. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.d.ts.map +0 -1
  774. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.js +0 -50
  775. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.js.map +0 -1
  776. package/docs/main/sequence-field/move-composition.md +0 -46
  777. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.d.ts +0 -9
  778. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.d.ts.map +0 -1
  779. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.js +0 -46
  780. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.js.map +0 -1
  781. package/src/feature-libraries/sequence-field/relevantRemovedRoots.ts +0 -57
@@ -5,11 +5,15 @@
5
5
 
6
6
  import { assert, unreachableCase } from "@fluidframework/core-utils/internal";
7
7
 
8
- import type { ChangeAtomId, RevisionMetadataSource, RevisionTag } from "../../core/index.js";
9
- import { type IdAllocator, type Mutable, brand } from "../../util/index.js";
10
8
  import {
11
- type CrossFieldManager,
12
- CrossFieldTarget,
9
+ areEqualChangeAtomIds,
10
+ type ChangeAtomId,
11
+ type RevisionMetadataSource,
12
+ type RevisionTag,
13
+ } from "../../core/index.js";
14
+ import type { IdAllocator, Mutable } from "../../util/index.js";
15
+ import {
16
+ type RebaseNodeManager,
13
17
  type NodeChangeRebaser,
14
18
  NodeAttachState,
15
19
  type NodeId,
@@ -18,16 +22,9 @@ import {
18
22
 
19
23
  import { MarkListFactory } from "./markListFactory.js";
20
24
  import { MarkQueue } from "./markQueue.js";
25
+ import type { NodeRangeQueryFunc } from "./moveEffectTable.js";
21
26
  import {
22
- type MoveEffect,
23
- type MoveEffectTable,
24
- getMoveEffect,
25
- isMoveIn,
26
- isMoveMark,
27
- isMoveOut,
28
- setMoveEffect,
29
- } from "./moveEffectTable.js";
30
- import {
27
+ type Attach,
31
28
  type CellId,
32
29
  type CellMark,
33
30
  type Changeset,
@@ -36,8 +33,6 @@ import {
36
33
  type MarkEffect,
37
34
  type MarkList,
38
35
  type MoveId,
39
- type MoveIn,
40
- type MoveOut,
41
36
  type NoopMark,
42
37
  NoopMarkType,
43
38
  } from "./types.js";
@@ -49,17 +44,18 @@ import {
49
44
  cloneMark,
50
45
  compareCellPositionsUsingTombstones,
51
46
  extractMarkEffect,
47
+ getAttachedRootId,
52
48
  getDetachOutputCellId,
53
- getEndpoint,
49
+ getDetachedRootId,
54
50
  getInputCellId,
55
- isAttachAndDetachEffect,
51
+ getOutputCellId,
52
+ isAttach,
56
53
  isDetach,
57
54
  isNewAttach,
58
55
  isRename,
59
56
  isTombstone,
60
57
  markEmptiesCells,
61
58
  markFillsCells,
62
- splitMarkEffect,
63
59
  withNodeChange,
64
60
  } from "./utils.js";
65
61
 
@@ -74,17 +70,10 @@ export function rebase(
74
70
  base: Changeset,
75
71
  rebaseChild: NodeChangeRebaser,
76
72
  genId: IdAllocator,
77
- manager: CrossFieldManager,
73
+ manager: RebaseNodeManager,
78
74
  revisionMetadata: RebaseRevisionMetadata,
79
75
  ): Changeset {
80
- return rebaseMarkList(
81
- change,
82
- base,
83
- revisionMetadata,
84
- rebaseChild,
85
- genId,
86
- manager as MoveEffectTable,
87
- );
76
+ return rebaseMarkList(change, base, revisionMetadata, rebaseChild, genId, manager);
88
77
  }
89
78
 
90
79
  function rebaseMarkList(
@@ -93,7 +82,7 @@ function rebaseMarkList(
93
82
  metadata: RebaseRevisionMetadata,
94
83
  rebaseChild: NodeChangeRebaser,
95
84
  genId: IdAllocator,
96
- moveEffects: CrossFieldManager<MoveEffect>,
85
+ moveEffects: RebaseNodeManager,
97
86
  ): MarkList {
98
87
  const factory = new MarkListFactory();
99
88
  const queue = new RebaseQueue(baseMarkList, currMarkList, metadata, moveEffects);
@@ -129,10 +118,28 @@ class RebaseQueue {
129
118
  baseMarks: Changeset,
130
119
  newMarks: Changeset,
131
120
  private readonly metadata: RevisionMetadataSource,
132
- private readonly moveEffects: MoveEffectTable,
121
+ private readonly moveEffects: RebaseNodeManager,
133
122
  ) {
134
- this.baseMarks = new MarkQueue(baseMarks, moveEffects);
135
- this.newMarks = new MarkQueue(newMarks, moveEffects);
123
+ const queryFunc: NodeRangeQueryFunc = (mark) => {
124
+ if (isAttach(mark)) {
125
+ return moveEffects.getNewChangesForBaseAttach(getAttachedRootId(mark), mark.count)
126
+ .length;
127
+ } else if (isDetach(mark)) {
128
+ return moveEffects.doesBaseAttachNodes(getDetachedRootId(mark), mark.count).length;
129
+ }
130
+
131
+ let count = mark.count;
132
+ if (mark.type === "Rename") {
133
+ count = moveEffects.getNewRenameForBaseRename(mark.idOverride, count).length;
134
+ }
135
+
136
+ return mark.cellId === undefined
137
+ ? count
138
+ : moveEffects.doesBaseAttachNodes(mark.cellId, count).length;
139
+ };
140
+
141
+ this.baseMarks = new MarkQueue(baseMarks, queryFunc);
142
+ this.newMarks = new MarkQueue(newMarks, (mark) => mark.count);
136
143
  this.baseMarksCellSources = cellSourcesFromMarks(baseMarks, getInputCellId);
137
144
  this.newMarksCellSources = cellSourcesFromMarks(newMarks, getInputCellId);
138
145
  }
@@ -243,12 +250,14 @@ class RebaseQueue {
243
250
  * @returns a mark which has the composite effect of `mark` and `effect`.
244
251
  */
245
252
  function addMovedMarkEffect(mark: Mark, effect: Detach): Mark {
246
- if (isMoveIn(mark) && isMoveOut(effect)) {
247
- return { ...mark, type: "Insert" };
248
- } else if (isRename(mark) && isMoveOut(effect)) {
249
- return { ...effect, count: mark.count, idOverride: mark.idOverride };
250
- } else if (isAttachAndDetachEffect(mark) && isMoveIn(mark.attach) && isMoveOut(effect)) {
251
- return { ...mark.detach, count: mark.count };
253
+ if (isAttach(mark) && isDetach(effect)) {
254
+ return { ...mark, type: "Attach" };
255
+ } else if (isRename(mark) && isDetach(effect)) {
256
+ const result = { ...effect, count: mark.count };
257
+ if (!areEqualChangeAtomIds(mark.idOverride, getDetachedRootId(effect))) {
258
+ result.detachCellId = mark.idOverride;
259
+ }
260
+ return result;
252
261
  } else if (isTombstone(mark)) {
253
262
  return { ...mark, ...effect };
254
263
  }
@@ -268,7 +277,7 @@ function rebaseMark(
268
277
  currMark: Mark,
269
278
  baseMark: Mark,
270
279
  rebaseChild: NodeChangeRebaser,
271
- moveEffects: MoveEffectTable,
280
+ moveEffects: RebaseNodeManager,
272
281
  ): Mark {
273
282
  const rebasedMark = rebaseNodeChange(cloneMark(currMark), baseMark, rebaseChild);
274
283
  const movedNodeChanges = getMovedChangesFromBaseMark(moveEffects, baseMark);
@@ -278,7 +287,6 @@ function rebaseMark(
278
287
  0x8dc /* Unexpected collision of new node changes */,
279
288
  );
280
289
  rebasedMark.changes = movedNodeChanges;
281
- moveEffects.onMoveIn(movedNodeChanges);
282
290
  }
283
291
 
284
292
  return rebaseMarkIgnoreChild(rebasedMark, baseMark, moveEffects);
@@ -287,7 +295,7 @@ function rebaseMark(
287
295
  function rebaseMarkIgnoreChild(
288
296
  currMark: Mark,
289
297
  baseMark: Mark,
290
- moveEffects: MoveEffectTable,
298
+ moveEffects: RebaseNodeManager,
291
299
  ): Mark {
292
300
  let rebasedMark: Mark;
293
301
  if (isDetach(baseMark)) {
@@ -300,95 +308,114 @@ function rebaseMarkIgnoreChild(
300
308
  0x69d /* A new attach should not be rebased over its cell being emptied */,
301
309
  );
302
310
  const baseCellId = getDetachOutputCellId(baseMark);
311
+ const baseDetachId = getDetachedRootId(baseMark);
303
312
 
304
- if (isMoveOut(baseMark)) {
305
- assert(isMoveMark(baseMark), 0x6f0 /* Only move marks have move IDs */);
306
- assert(
307
- !isNewAttach(currMark),
308
- 0x819 /* New attaches should not be rebased over moves */,
309
- );
310
- const { remains, follows } = separateEffectsForMove(extractMarkEffect(currMark));
311
- if (follows !== undefined) {
312
- sendEffectToDest(follows, moveEffects, getEndpoint(baseMark), baseMark.count);
313
- }
314
-
315
- if (currMark.changes !== undefined) {
316
- moveRebasedChanges(currMark.changes, moveEffects, getEndpoint(baseMark));
317
- }
318
- rebasedMark = { ...remains, count: baseMark.count };
319
- } else {
320
- rebasedMark = currMark;
321
- }
322
- rebasedMark = makeDetachedMark(rebasedMark, cloneCellId(baseCellId));
323
- } else if (markFillsCells(baseMark)) {
324
- rebasedMark = isAttachAndDetachEffect(currMark)
325
- ? withNodeChange({ ...currMark.detach, count: currMark.count }, currMark.changes)
326
- : withCellId(currMark, undefined);
327
- } else if (isAttachAndDetachEffect(baseMark)) {
328
- assert(
329
- baseMark.cellId !== undefined,
330
- 0x81a /* AttachAndDetach mark should target an empty cell */,
331
- );
332
- const halfRebasedMark = rebaseMarkIgnoreChild(
333
- currMark,
334
- { ...baseMark.attach, cellId: cloneCellId(baseMark.cellId), count: baseMark.count },
335
- moveEffects,
336
- );
337
- rebasedMark = rebaseMarkIgnoreChild(
338
- halfRebasedMark,
339
- { ...baseMark.detach, count: baseMark.count },
313
+ const { remains, follows } = separateEffectsForMove(
314
+ extractMarkEffect(currMark),
315
+ baseMark,
340
316
  moveEffects,
341
317
  );
318
+
319
+ moveRebasedChanges(moveEffects, baseDetachId, baseMark.count, currMark.changes, follows);
320
+ rebasedMark = { ...remains, count: baseMark.count };
321
+ return makeDetachedMark(rebasedMark, cloneCellId(baseCellId));
322
+ } else if (markFillsCells(baseMark)) {
323
+ return withCellId(currMark, undefined);
342
324
  } else if (isRename(baseMark)) {
343
- return withCellId(currMark, getDetachOutputCellId(baseMark));
325
+ if (currMark.type === "Rename") {
326
+ const doesBaseMoveAndAttach = moveEffects.doesBaseAttachNodes(
327
+ baseMark.idOverride,
328
+ baseMark.count,
329
+ ).value;
330
+
331
+ assert(baseMark.cellId !== undefined, "Rename should target empty cells");
332
+ const baseRootRename = moveEffects.getBaseRename(baseMark.cellId, baseMark.count).value;
333
+ const doesBaseMoveAndDetach =
334
+ baseRootRename !== undefined &&
335
+ !areEqualChangeAtomIds(baseRootRename, baseMark.idOverride);
336
+
337
+ if (doesBaseMoveAndAttach || doesBaseMoveAndDetach) {
338
+ // `newMark` represents a node-targeting rename.
339
+ // The base changeset has moved the node which was last detached from the cell,
340
+ // so we should remove the rename from this location.
341
+ return { cellId: baseMark.idOverride, count: baseMark.count };
342
+ }
343
+ }
344
+
345
+ const newRenameId = moveEffects.getNewRenameForBaseRename(
346
+ baseMark.idOverride,
347
+ baseMark.count,
348
+ ).value;
349
+
350
+ if (newRenameId !== undefined && currMark.type !== "Attach") {
351
+ return {
352
+ type: "Rename",
353
+ cellId: baseMark.idOverride,
354
+ count: baseMark.count,
355
+ idOverride: newRenameId,
356
+ };
357
+ }
358
+
359
+ return withCellId(currMark, getOutputCellId(baseMark));
344
360
  } else {
345
- rebasedMark = currMark;
361
+ return currMark;
346
362
  }
347
- return rebasedMark;
348
363
  }
349
364
 
350
365
  /**
351
366
  * Returns a pair of marks that represent the effects which should remain in place in the face of concurrent move,
352
367
  * and the effects that should be sent to the move destination.
353
368
  */
354
- function separateEffectsForMove(mark: MarkEffect): {
369
+ function separateEffectsForMove(
370
+ mark: MarkEffect,
371
+ baseMark: CellMark<Detach>,
372
+ nodeManager: RebaseNodeManager,
373
+ ): {
355
374
  remains?: MarkEffect;
356
375
  follows?: Detach;
357
376
  } {
358
377
  const type = mark.type;
359
378
  switch (type) {
360
- case "Remove":
361
- case "MoveOut": {
362
- // There are two scenarios that lead to a Detach mark having an idOverride:
363
- // 1. The detach is a rollback (the idOverride the original id that the cell had in the input context of the attach being rolled back).
364
- // 2. The detach has been composed with a Rename (the idOverride is the cell id in the output context of the rename).
365
- // Since rollbacks are never rebased, we can safely assume that the idOverride is due to a Rename (scenario #2).
366
- // While the detach must follow the node that it targets, the rename must remain in place because it targets the cell.
367
- if (mark.idOverride !== undefined) {
368
- const remains: MarkEffect = { type: "Rename", idOverride: mark.idOverride };
369
- const follows: Mutable<MarkEffect> = { ...mark };
370
- delete follows.idOverride;
371
- return { remains, follows };
372
- }
373
- return { follows: mark };
379
+ case NoopMarkType: {
380
+ return {};
374
381
  }
375
- case "AttachAndDetach": {
376
- return { follows: mark.detach, remains: mark.attach };
382
+ case "Detach": {
383
+ if (mark.cellRename !== undefined) {
384
+ return { remains: { type: "Rename", idOverride: mark.cellRename }, follows: mark };
385
+ }
386
+
387
+ const baseDetachId = getDetachedRootId(baseMark);
388
+ const outputCellId = getDetachOutputCellId(baseMark);
389
+ const doesBaseMoveNodes =
390
+ !areEqualChangeAtomIds(outputCellId, baseDetachId) ||
391
+ nodeManager.doesBaseAttachNodes(baseDetachId, baseMark.count).value;
392
+
393
+ // We should rename these cells unless the nodes are reattached elsewhere,
394
+ // in which case we will rename those cells instead.
395
+ const remains: MarkEffect = doesBaseMoveNodes
396
+ ? {}
397
+ : {
398
+ type: "Rename",
399
+ idOverride: getDetachOutputCellId(mark),
400
+ };
401
+
402
+ return { remains, follows: mark };
377
403
  }
378
- case "MoveIn":
379
404
  case "Rename": {
380
405
  return { remains: mark };
381
406
  }
382
- case NoopMarkType: {
383
- return {};
384
- }
385
- case "Insert": {
386
- const follows: MoveOut = {
387
- type: "MoveOut",
407
+ case "Attach": {
408
+ const follows: Mutable<Detach> = {
409
+ type: "Detach",
388
410
  id: mark.id,
389
411
  };
390
- const remains: MoveIn = {
391
- type: "MoveIn",
412
+
413
+ if (mark.detachCellId !== undefined) {
414
+ follows.detachCellId = mark.detachCellId;
415
+ }
416
+
417
+ const remains: Attach = {
418
+ type: "Attach",
392
419
  id: mark.id,
393
420
  };
394
421
  if (mark.revision !== undefined) {
@@ -403,70 +430,16 @@ function separateEffectsForMove(mark: MarkEffect): {
403
430
  }
404
431
  }
405
432
 
406
- // TODO: Reduce the duplication between this and other MoveEffect helpers
407
- function sendEffectToDest(
408
- markEffect: Detach,
409
- moveEffects: MoveEffectTable,
410
- { revision, localId: id }: ChangeAtomId,
411
- count: number,
412
- ): void {
413
- const effect = getMoveEffect(
414
- moveEffects,
415
- CrossFieldTarget.Destination,
416
- revision,
417
- id,
418
- count,
419
- false,
420
- );
421
- if (effect.length < count) {
422
- const [markEffect1, markEffect2] = splitMarkEffect(markEffect, effect.length);
423
- const newEffect =
424
- effect.value === undefined
425
- ? { movedMark: markEffect1 }
426
- : { ...effect.value, movedMark: markEffect1 };
427
- setMoveEffect(
428
- moveEffects,
429
- CrossFieldTarget.Destination,
430
- revision,
431
- id,
432
- effect.length,
433
- newEffect,
434
- );
435
- sendEffectToDest(
436
- markEffect2,
437
- moveEffects,
438
- { revision, localId: brand(id + effect.length) },
439
- count - effect.length,
440
- );
441
- } else {
442
- const newEffect: MoveEffect =
443
- effect.value === undefined
444
- ? { movedEffect: markEffect }
445
- : { ...effect.value, movedEffect: markEffect };
446
- setMoveEffect(moveEffects, CrossFieldTarget.Destination, revision, id, count, newEffect);
447
- }
448
- }
449
-
450
433
  function moveRebasedChanges(
451
- nodeChange: NodeId,
452
- moveEffects: MoveEffectTable,
453
- { revision, localId: id }: ChangeAtomId,
434
+ moveEffects: RebaseNodeManager,
435
+ baseId: ChangeAtomId,
436
+ count: number,
437
+ nodeChange: NodeId | undefined,
438
+ newDetach: Detach | undefined,
454
439
  ): void {
455
- const effect = getMoveEffect(
456
- moveEffects,
457
- CrossFieldTarget.Destination,
458
- revision,
459
- id,
460
- 1,
461
- false,
462
- ).value;
463
-
464
- const newEffect =
465
- effect === undefined
466
- ? { rebasedChanges: nodeChange }
467
- : { ...effect, rebasedChanges: nodeChange };
468
-
469
- setMoveEffect(moveEffects, CrossFieldTarget.Destination, revision, id, 1, newEffect);
440
+ const newId = newDetach === undefined ? undefined : getDetachedRootId(newDetach);
441
+ const detachCellId = newDetach?.detachCellId;
442
+ moveEffects.rebaseOverDetach(baseId, count, newId, nodeChange, detachCellId);
470
443
  }
471
444
 
472
445
  function rebaseNodeChange(
@@ -509,21 +482,12 @@ function withCellId<TMark extends Mark>(mark: TMark, cellId: CellId | undefined)
509
482
  }
510
483
 
511
484
  function getMovedEffectFromBaseMark(
512
- moveEffects: MoveEffectTable,
485
+ moveEffects: RebaseNodeManager,
513
486
  baseMark: Mark,
514
487
  ): Detach | undefined {
515
- if (isMoveIn(baseMark)) {
516
- return getMovedEffect(moveEffects, baseMark.revision, baseMark.id, baseMark.count);
517
- } else if (isAttachAndDetachEffect(baseMark) && isMoveIn(baseMark.attach)) {
518
- return getMovedEffect(
519
- moveEffects,
520
- baseMark.attach.revision,
521
- baseMark.attach.id,
522
- baseMark.count,
523
- );
524
- } else {
525
- return undefined;
526
- }
488
+ return isAttach(baseMark)
489
+ ? getMovedEffect(moveEffects, baseMark.revision, baseMark.id, baseMark.count)
490
+ : undefined;
527
491
  }
528
492
 
529
493
  // It is expected that the range from `id` to `id + count - 1` has the same move effect.
@@ -531,47 +495,47 @@ function getMovedEffectFromBaseMark(
531
495
  // to match the ranges in `moveEffects`.
532
496
  // TODO: Reduce the duplication between this and other MoveEffect helpers
533
497
  function getMovedEffect(
534
- moveEffects: MoveEffectTable,
498
+ moveEffects: RebaseNodeManager,
535
499
  revision: RevisionTag | undefined,
536
- id: MoveId,
500
+ localId: MoveId,
537
501
  count: number,
538
502
  ): Detach | undefined {
539
- const effect = getMoveEffect(moveEffects, CrossFieldTarget.Destination, revision, id, count);
540
- assert(effect.length === count, 0x6f3 /* Expected effect to cover entire mark */);
541
- const movedEffect = effect.value?.movedEffect;
542
- if (movedEffect === undefined) {
503
+ const entry = moveEffects.getNewChangesForBaseAttach({ revision, localId }, count);
504
+ assert(entry.length === count, 0x6f3 /* Expected effect to cover entire mark */);
505
+ const detachId = entry.value?.detachId;
506
+ if (detachId === undefined) {
507
+ assert(
508
+ entry.value?.cellRename === undefined,
509
+ "Cell detach should be accompanied by node detach",
510
+ );
543
511
  return undefined;
544
512
  }
545
- if (isMoveOut(movedEffect)) {
546
- moveEffects.moveKey(CrossFieldTarget.Source, movedEffect.revision, movedEffect.id, count);
513
+
514
+ const detach: Mutable<Detach> = {
515
+ type: "Detach",
516
+ revision: detachId.revision,
517
+ id: detachId.localId,
518
+ };
519
+ if (entry.value?.cellRename !== undefined) {
520
+ detach.detachCellId = entry.value.cellRename;
547
521
  }
548
- return movedEffect;
522
+
523
+ return detach;
549
524
  }
550
525
 
551
526
  function getMovedChangesFromBaseMark(
552
- moveEffects: MoveEffectTable,
527
+ moveEffects: RebaseNodeManager,
553
528
  baseMark: Mark,
554
529
  ): NodeId | undefined {
555
- if (isMoveIn(baseMark)) {
556
- return getMovedNodeChanges(moveEffects, baseMark.revision, baseMark.id, baseMark.count);
557
- } else if (isAttachAndDetachEffect(baseMark) && isMoveIn(baseMark.attach)) {
558
- return getMovedNodeChanges(
559
- moveEffects,
560
- baseMark.attach.revision,
561
- baseMark.attach.id,
562
- baseMark.count,
563
- );
564
- } else {
565
- return undefined;
566
- }
530
+ return isAttach(baseMark)
531
+ ? getMovedNodeChanges(moveEffects, baseMark.revision, baseMark.id)
532
+ : undefined;
567
533
  }
568
534
 
569
535
  function getMovedNodeChanges(
570
- moveEffects: MoveEffectTable,
536
+ moveEffects: RebaseNodeManager,
571
537
  revision: RevisionTag | undefined,
572
- id: MoveId,
573
- count: number,
538
+ localId: MoveId,
574
539
  ): NodeId | undefined {
575
- return getMoveEffect(moveEffects, CrossFieldTarget.Destination, revision, id, count).value
576
- ?.rebasedChanges;
540
+ return moveEffects.getNewChangesForBaseAttach({ revision, localId }, 1).value?.nodeChange;
577
541
  }
@@ -11,23 +11,19 @@ import {
11
11
  type RevisionReplacer,
12
12
  type RevisionTag,
13
13
  } from "../../core/index.js";
14
+ import type { Mutable } from "../../util/index.js";
14
15
 
15
- import type { MoveMarkEffect } from "./helperTypes.js";
16
16
  import { MarkListFactory } from "./markListFactory.js";
17
17
  import {
18
+ type Attach,
18
19
  type Changeset,
19
20
  type Detach,
20
- type HasMoveFields,
21
21
  type HasMoveId,
22
22
  type HasRevisionTag,
23
- type Insert,
24
23
  type Mark,
25
24
  type MarkEffect,
26
25
  NoopMarkType,
27
- type Remove,
28
- type Rename,
29
26
  } from "./types.js";
30
- import { isDetach, isRename } from "./utils.js";
31
27
 
32
28
  export function replaceRevisions(changeset: Changeset, replacer: RevisionReplacer): Changeset {
33
29
  const updatedMarks = new MarkListFactory();
@@ -40,84 +36,62 @@ export function replaceRevisions(changeset: Changeset, replacer: RevisionReplace
40
36
  }
41
37
 
42
38
  function updateMark(mark: Mark, replacer: RevisionReplacer): Mark {
43
- const updatedMark = { ...updateEffect(mark, mark.count, replacer) };
39
+ const updatedMark = { ...replaceEffectRevisions(mark, mark.count, replacer) };
44
40
  if (mark.cellId !== undefined) {
45
41
  updatedMark.cellId = replacer.getUpdatedAtomId(mark.cellId, mark.count);
46
42
  }
47
43
 
48
44
  if (mark.changes !== undefined) {
49
- updatedMark.changes = replacer.getUpdatedAtomId(mark.changes);
45
+ updatedMark.changes = replacer.getUpdatedAtomId(mark.changes, mark.count);
50
46
  }
51
47
 
52
48
  return updatedMark;
53
49
  }
54
50
 
55
- function updateEffect<TMark extends MarkEffect>(
56
- input: TMark,
51
+ function replaceEffectRevisions<TMark extends MarkEffect>(
52
+ mark: TMark,
57
53
  count: number,
58
54
  replacer: RevisionReplacer,
59
55
  ): TMark {
60
- const mark =
61
- isDetach(input) || isRename(input) ? updateIdOverride(input, count, replacer) : input;
62
56
  const type = mark.type;
63
57
  switch (type) {
64
- case "Rename":
65
58
  case NoopMarkType: {
66
59
  return mark;
67
60
  }
68
- case "AttachAndDetach": {
61
+ case "Attach": {
62
+ return updateRevisionAndId(mark as TMark & Attach, count, replacer);
63
+ }
64
+
65
+ case "Detach": {
66
+ return replaceDetachRevisions<TMark & Detach>(mark as Detach & TMark, count, replacer);
67
+ }
68
+ case "Rename": {
69
69
  return {
70
70
  ...mark,
71
- attach: updateEffect(mark.attach, count, replacer),
72
- detach: updateEffect(mark.detach, count, replacer),
71
+ idOverride: replacer.getUpdatedAtomId(mark.idOverride, count),
73
72
  };
74
73
  }
75
- case "MoveIn":
76
- case "MoveOut": {
77
- return updateMoveEffect<TMark & MoveMarkEffect>(
78
- // For some reason, TypeScript is not able to infer that `mark` cannot be a `NoopMark` here.
79
- mark as MoveMarkEffect,
80
- count,
81
- replacer,
82
- );
83
- }
84
- case "Insert":
85
- case "Remove": {
86
- return updateRevisionAndId(mark as (TMark & Insert) | (TMark & Remove), count, replacer);
87
- }
88
74
  default: {
89
75
  unreachableCase(type);
90
76
  }
91
77
  }
92
78
  }
93
79
 
94
- function updateIdOverride<TEffect extends Detach | Rename>(
95
- effect: TEffect,
80
+ function replaceDetachRevisions<TDetach extends Detach>(
81
+ detach: TDetach,
96
82
  count: number,
97
83
  replacer: RevisionReplacer,
98
- ): TEffect {
99
- if (effect.idOverride === undefined) {
100
- return effect;
84
+ ): TDetach {
85
+ const updated = updateRevisionAndId(detach, count, replacer) as Mutable<TDetach>;
86
+ if (updated.cellRename !== undefined) {
87
+ updated.cellRename = replacer.getUpdatedAtomId(updated.cellRename, count);
101
88
  }
102
- const idOverride = replacer.getUpdatedAtomId(effect.idOverride, count);
103
- return { ...effect, idOverride };
104
- }
105
89
 
106
- function updateMoveEffect<TEffect extends HasMoveFields>(
107
- effect: TEffect,
108
- count: number,
109
- replacer: RevisionReplacer,
110
- ): TEffect {
111
- return effect.finalEndpoint === undefined
112
- ? updateRevisionAndId(effect, count, replacer)
113
- : updateRevisionAndId(
114
- {
115
- ...effect,
116
- finalEndpoint: replacer.getUpdatedAtomId(effect.finalEndpoint, count),
117
- },
118
- count,
119
- replacer,
120
- );
90
+ if (updated.detachCellId !== undefined) {
91
+ updated.detachCellId = replacer.getUpdatedAtomId(updated.detachCellId, count);
92
+ }
93
+
94
+ return updated;
121
95
  }
122
96
 
123
97
  function updateRevisionAndId<T extends HasRevisionTag & HasMoveId>(
@@ -5,13 +5,18 @@
5
5
 
6
6
  import type { FieldChangeHandler } from "../modular-schema/index.js";
7
7
 
8
- import { relevantRemovedRoots } from "./relevantRemovedRoots.js";
9
8
  import { sequenceFieldChangeRebaser } from "./sequenceFieldChangeRebaser.js";
10
9
  import { sequenceFieldChangeCodecFactory } from "./sequenceFieldCodecs.js";
11
10
  import { type SequenceFieldEditor, sequenceFieldEditor } from "./sequenceFieldEditor.js";
12
11
  import { sequenceFieldToDelta } from "./sequenceFieldToDelta.js";
13
12
  import type { Changeset } from "./types.js";
14
- import { createEmpty, getCrossFieldKeys, getNestedChanges, isEmpty } from "./utils.js";
13
+ import {
14
+ createEmpty,
15
+ getCrossFieldKeys,
16
+ getDetachCellIds,
17
+ getNestedChanges,
18
+ isEmpty,
19
+ } from "./utils.js";
15
20
 
16
21
  export type SequenceFieldChangeHandler = FieldChangeHandler<Changeset, SequenceFieldEditor>;
17
22
 
@@ -20,9 +25,9 @@ export const sequenceFieldChangeHandler: SequenceFieldChangeHandler = {
20
25
  codecsFactory: sequenceFieldChangeCodecFactory,
21
26
  editor: sequenceFieldEditor,
22
27
  intoDelta: sequenceFieldToDelta,
23
- relevantRemovedRoots,
24
28
  isEmpty,
25
29
  getNestedChanges,
26
30
  createEmpty,
27
31
  getCrossFieldKeys,
32
+ getDetachCellIds,
28
33
  };