@fluidframework/tree 2.80.0 → 2.81.0-374083

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 (914) hide show
  1. package/api-report/tree.alpha.api.md +43 -7
  2. package/dist/alpha.d.ts +5 -0
  3. package/dist/core/change-family/changeFamily.d.ts +4 -1
  4. package/dist/core/change-family/changeFamily.d.ts.map +1 -1
  5. package/dist/core/change-family/changeFamily.js.map +1 -1
  6. package/dist/core/change-family/index.d.ts +1 -1
  7. package/dist/core/change-family/index.d.ts.map +1 -1
  8. package/dist/core/change-family/index.js.map +1 -1
  9. package/dist/core/index.d.ts +3 -3
  10. package/dist/core/index.d.ts.map +1 -1
  11. package/dist/core/index.js +6 -4
  12. package/dist/core/index.js.map +1 -1
  13. package/dist/core/rebase/changeRebaser.d.ts +6 -1
  14. package/dist/core/rebase/changeRebaser.d.ts.map +1 -1
  15. package/dist/core/rebase/changeRebaser.js.map +1 -1
  16. package/dist/core/rebase/index.d.ts +1 -1
  17. package/dist/core/rebase/index.d.ts.map +1 -1
  18. package/dist/core/rebase/index.js +2 -1
  19. package/dist/core/rebase/index.js.map +1 -1
  20. package/dist/core/rebase/types.d.ts +46 -8
  21. package/dist/core/rebase/types.d.ts.map +1 -1
  22. package/dist/core/rebase/types.js +5 -1
  23. package/dist/core/rebase/types.js.map +1 -1
  24. package/dist/core/rebase/utils.d.ts.map +1 -1
  25. package/dist/core/rebase/utils.js +30 -8
  26. package/dist/core/rebase/utils.js.map +1 -1
  27. package/dist/core/tree/anchorSet.js +1 -0
  28. package/dist/core/tree/anchorSet.js.map +1 -1
  29. package/dist/core/tree/detachedFieldIndex.d.ts +6 -0
  30. package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
  31. package/dist/core/tree/detachedFieldIndex.js +9 -0
  32. package/dist/core/tree/detachedFieldIndex.js.map +1 -1
  33. package/dist/core/tree/index.d.ts +1 -1
  34. package/dist/core/tree/index.d.ts.map +1 -1
  35. package/dist/core/tree/index.js +4 -3
  36. package/dist/core/tree/index.js.map +1 -1
  37. package/dist/core/tree/pathTree.d.ts +11 -3
  38. package/dist/core/tree/pathTree.d.ts.map +1 -1
  39. package/dist/core/tree/pathTree.js +14 -2
  40. package/dist/core/tree/pathTree.js.map +1 -1
  41. package/dist/core/tree/visitDelta.d.ts.map +1 -1
  42. package/dist/core/tree/visitDelta.js +3 -2
  43. package/dist/core/tree/visitDelta.js.map +1 -1
  44. package/dist/core/tree/visitorUtils.d.ts.map +1 -1
  45. package/dist/core/tree/visitorUtils.js +58 -18
  46. package/dist/core/tree/visitorUtils.js.map +1 -1
  47. package/dist/feature-libraries/changeAtomIdBTree.d.ts +10 -4
  48. package/dist/feature-libraries/changeAtomIdBTree.d.ts.map +1 -1
  49. package/dist/feature-libraries/changeAtomIdBTree.js +16 -2
  50. package/dist/feature-libraries/changeAtomIdBTree.js.map +1 -1
  51. package/dist/feature-libraries/chunked-forest/basicChunk.d.ts.map +1 -1
  52. package/dist/feature-libraries/chunked-forest/basicChunk.js +7 -0
  53. package/dist/feature-libraries/chunked-forest/basicChunk.js.map +1 -1
  54. package/dist/feature-libraries/chunked-forest/chunkTree.d.ts.map +1 -1
  55. package/dist/feature-libraries/chunked-forest/chunkTree.js +4 -1
  56. package/dist/feature-libraries/chunked-forest/chunkTree.js.map +1 -1
  57. package/dist/feature-libraries/chunked-forest/chunkedForest.d.ts.map +1 -1
  58. package/dist/feature-libraries/chunked-forest/chunkedForest.js +3 -1
  59. package/dist/feature-libraries/chunked-forest/chunkedForest.js.map +1 -1
  60. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js +1 -0
  61. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  62. package/dist/feature-libraries/default-schema/defaultEditBuilder.d.ts +93 -44
  63. package/dist/feature-libraries/default-schema/defaultEditBuilder.d.ts.map +1 -1
  64. package/dist/feature-libraries/default-schema/defaultEditBuilder.js +238 -69
  65. package/dist/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
  66. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts +1 -1
  67. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  68. package/dist/feature-libraries/default-schema/defaultFieldKinds.js +11 -2
  69. package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  70. package/dist/feature-libraries/default-schema/index.d.ts +2 -1
  71. package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
  72. package/dist/feature-libraries/default-schema/index.js +5 -2
  73. package/dist/feature-libraries/default-schema/index.js.map +1 -1
  74. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.d.ts +38 -0
  75. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.d.ts.map +1 -0
  76. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.js +132 -0
  77. package/dist/feature-libraries/default-schema/locationBasedEditBuilder.js.map +1 -0
  78. package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts +7 -6
  79. package/dist/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
  80. package/dist/feature-libraries/default-schema/mappedEditBuilder.js +15 -0
  81. package/dist/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
  82. package/dist/feature-libraries/deltaUtils.d.ts +1 -0
  83. package/dist/feature-libraries/deltaUtils.d.ts.map +1 -1
  84. package/dist/feature-libraries/deltaUtils.js +6 -1
  85. package/dist/feature-libraries/deltaUtils.js.map +1 -1
  86. package/dist/feature-libraries/flex-tree/context.d.ts +9 -0
  87. package/dist/feature-libraries/flex-tree/context.d.ts.map +1 -1
  88. package/dist/feature-libraries/flex-tree/context.js +6 -0
  89. package/dist/feature-libraries/flex-tree/context.js.map +1 -1
  90. package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts +6 -6
  91. package/dist/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
  92. package/dist/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
  93. package/dist/feature-libraries/flex-tree/lazyField.d.ts +8 -7
  94. package/dist/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
  95. package/dist/feature-libraries/flex-tree/lazyField.js +40 -9
  96. package/dist/feature-libraries/flex-tree/lazyField.js.map +1 -1
  97. package/dist/feature-libraries/forest-summary/forestSummarizer.d.ts.map +1 -1
  98. package/dist/feature-libraries/forest-summary/forestSummarizer.js +3 -1
  99. package/dist/feature-libraries/forest-summary/forestSummarizer.js.map +1 -1
  100. package/dist/feature-libraries/index.d.ts +3 -3
  101. package/dist/feature-libraries/index.d.ts.map +1 -1
  102. package/dist/feature-libraries/index.js +8 -3
  103. package/dist/feature-libraries/index.js.map +1 -1
  104. package/dist/feature-libraries/mapTreeCursor.d.ts.map +1 -1
  105. package/dist/feature-libraries/mapTreeCursor.js +1 -0
  106. package/dist/feature-libraries/mapTreeCursor.js.map +1 -1
  107. package/dist/feature-libraries/mitigatedChangeFamily.d.ts.map +1 -1
  108. package/dist/feature-libraries/mitigatedChangeFamily.js +2 -2
  109. package/dist/feature-libraries/mitigatedChangeFamily.js.map +1 -1
  110. package/dist/feature-libraries/modular-schema/crossFieldQueries.d.ts +97 -21
  111. package/dist/feature-libraries/modular-schema/crossFieldQueries.d.ts.map +1 -1
  112. package/dist/feature-libraries/modular-schema/crossFieldQueries.js +4 -7
  113. package/dist/feature-libraries/modular-schema/crossFieldQueries.js.map +1 -1
  114. package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts +20 -51
  115. package/dist/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
  116. package/dist/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
  117. package/dist/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
  118. package/dist/feature-libraries/modular-schema/genericFieldKind.js +3 -9
  119. package/dist/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
  120. package/dist/feature-libraries/modular-schema/index.d.ts +4 -4
  121. package/dist/feature-libraries/modular-schema/index.d.ts.map +1 -1
  122. package/dist/feature-libraries/modular-schema/index.js +2 -2
  123. package/dist/feature-libraries/modular-schema/index.js.map +1 -1
  124. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.d.ts +11 -28
  125. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.d.ts.map +1 -1
  126. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.js +255 -161
  127. package/dist/feature-libraries/modular-schema/modularChangeCodecV1.js.map +1 -1
  128. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.d.ts +15 -0
  129. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.d.ts.map +1 -0
  130. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.js +393 -0
  131. package/dist/feature-libraries/modular-schema/modularChangeCodecV3.js.map +1 -0
  132. package/dist/feature-libraries/modular-schema/modularChangeCodecs.d.ts.map +1 -1
  133. package/dist/feature-libraries/modular-schema/modularChangeCodecs.js +8 -1
  134. package/dist/feature-libraries/modular-schema/modularChangeCodecs.js.map +1 -1
  135. package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts +48 -20
  136. package/dist/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
  137. package/dist/feature-libraries/modular-schema/modularChangeFamily.js +1350 -476
  138. package/dist/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
  139. package/dist/feature-libraries/modular-schema/modularChangeFormatV1.d.ts.map +1 -1
  140. package/dist/feature-libraries/modular-schema/modularChangeFormatV1.js.map +1 -1
  141. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.d.ts +146 -0
  142. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.d.ts.map +1 -0
  143. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.js +32 -0
  144. package/dist/feature-libraries/modular-schema/modularChangeFormatV3.js.map +1 -0
  145. package/dist/feature-libraries/modular-schema/modularChangeTypes.d.ts +47 -11
  146. package/dist/feature-libraries/modular-schema/modularChangeTypes.d.ts.map +1 -1
  147. package/dist/feature-libraries/modular-schema/modularChangeTypes.js +3 -3
  148. package/dist/feature-libraries/modular-schema/modularChangeTypes.js.map +1 -1
  149. package/dist/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  150. package/dist/feature-libraries/object-forest/objectForest.js +3 -1
  151. package/dist/feature-libraries/object-forest/objectForest.js.map +1 -1
  152. package/dist/feature-libraries/optional-field/index.d.ts +2 -2
  153. package/dist/feature-libraries/optional-field/index.d.ts.map +1 -1
  154. package/dist/feature-libraries/optional-field/index.js +1 -2
  155. package/dist/feature-libraries/optional-field/index.js.map +1 -1
  156. package/dist/feature-libraries/optional-field/optionalField.d.ts +5 -26
  157. package/dist/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
  158. package/dist/feature-libraries/optional-field/optionalField.js +221 -443
  159. package/dist/feature-libraries/optional-field/optionalField.js.map +1 -1
  160. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts +23 -0
  161. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts.map +1 -0
  162. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.js +31 -0
  163. package/dist/feature-libraries/optional-field/optionalFieldChangeFormatV3.js.map +1 -0
  164. package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts +24 -33
  165. package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts.map +1 -1
  166. package/dist/feature-libraries/optional-field/optionalFieldChangeTypes.js.map +1 -1
  167. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.d.ts +1 -1
  168. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.d.ts.map +1 -1
  169. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.js +57 -28
  170. package/dist/feature-libraries/optional-field/optionalFieldCodecV2.js.map +1 -1
  171. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.d.ts +12 -0
  172. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.d.ts.map +1 -0
  173. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.js +57 -0
  174. package/dist/feature-libraries/optional-field/optionalFieldCodecV3.js.map +1 -0
  175. package/dist/feature-libraries/optional-field/optionalFieldCodecs.d.ts.map +1 -1
  176. package/dist/feature-libraries/optional-field/optionalFieldCodecs.js +5 -1
  177. package/dist/feature-libraries/optional-field/optionalFieldCodecs.js.map +1 -1
  178. package/dist/feature-libraries/sequence-field/compose.d.ts +6 -7
  179. package/dist/feature-libraries/sequence-field/compose.d.ts.map +1 -1
  180. package/dist/feature-libraries/sequence-field/compose.js +83 -259
  181. package/dist/feature-libraries/sequence-field/compose.js.map +1 -1
  182. package/dist/feature-libraries/sequence-field/helperTypes.d.ts +14 -10
  183. package/dist/feature-libraries/sequence-field/helperTypes.d.ts.map +1 -1
  184. package/dist/feature-libraries/sequence-field/helperTypes.js.map +1 -1
  185. package/dist/feature-libraries/sequence-field/index.d.ts +2 -3
  186. package/dist/feature-libraries/sequence-field/index.d.ts.map +1 -1
  187. package/dist/feature-libraries/sequence-field/index.js +1 -3
  188. package/dist/feature-libraries/sequence-field/index.js.map +1 -1
  189. package/dist/feature-libraries/sequence-field/invert.d.ts +3 -3
  190. package/dist/feature-libraries/sequence-field/invert.d.ts.map +1 -1
  191. package/dist/feature-libraries/sequence-field/invert.js +65 -167
  192. package/dist/feature-libraries/sequence-field/invert.js.map +1 -1
  193. package/dist/feature-libraries/sequence-field/markQueue.d.ts +2 -2
  194. package/dist/feature-libraries/sequence-field/markQueue.d.ts.map +1 -1
  195. package/dist/feature-libraries/sequence-field/markQueue.js.map +1 -1
  196. package/dist/feature-libraries/sequence-field/moveEffectTable.d.ts +4 -56
  197. package/dist/feature-libraries/sequence-field/moveEffectTable.d.ts.map +1 -1
  198. package/dist/feature-libraries/sequence-field/moveEffectTable.js +7 -90
  199. package/dist/feature-libraries/sequence-field/moveEffectTable.js.map +1 -1
  200. package/dist/feature-libraries/sequence-field/rebase.d.ts +3 -3
  201. package/dist/feature-libraries/sequence-field/rebase.d.ts.map +1 -1
  202. package/dist/feature-libraries/sequence-field/rebase.js +107 -114
  203. package/dist/feature-libraries/sequence-field/rebase.js.map +1 -1
  204. package/dist/feature-libraries/sequence-field/replaceRevisions.d.ts.map +1 -1
  205. package/dist/feature-libraries/sequence-field/replaceRevisions.js +18 -31
  206. package/dist/feature-libraries/sequence-field/replaceRevisions.js.map +1 -1
  207. package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.d.ts.map +1 -1
  208. package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.js +0 -2
  209. package/dist/feature-libraries/sequence-field/sequenceFieldChangeHandler.js.map +1 -1
  210. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts +22 -4
  211. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts.map +1 -1
  212. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.js +365 -187
  213. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV2.js.map +1 -1
  214. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.d.ts.map +1 -1
  215. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.js +20 -62
  216. package/dist/feature-libraries/sequence-field/sequenceFieldCodecV3.js.map +1 -1
  217. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.d.ts +2 -2
  218. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.d.ts.map +1 -1
  219. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.js +10 -10
  220. package/dist/feature-libraries/sequence-field/sequenceFieldEditor.js.map +1 -1
  221. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts +3 -2
  222. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts.map +1 -1
  223. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.js +14 -109
  224. package/dist/feature-libraries/sequence-field/sequenceFieldToDelta.js.map +1 -1
  225. package/dist/feature-libraries/sequence-field/types.d.ts +30 -59
  226. package/dist/feature-libraries/sequence-field/types.d.ts.map +1 -1
  227. package/dist/feature-libraries/sequence-field/types.js.map +1 -1
  228. package/dist/feature-libraries/sequence-field/utils.d.ts +15 -24
  229. package/dist/feature-libraries/sequence-field/utils.d.ts.map +1 -1
  230. package/dist/feature-libraries/sequence-field/utils.js +116 -305
  231. package/dist/feature-libraries/sequence-field/utils.js.map +1 -1
  232. package/dist/index.d.ts +3 -2
  233. package/dist/index.d.ts.map +1 -1
  234. package/dist/index.js +4 -1
  235. package/dist/index.js.map +1 -1
  236. package/dist/packageVersion.d.ts +1 -1
  237. package/dist/packageVersion.d.ts.map +1 -1
  238. package/dist/packageVersion.js +1 -1
  239. package/dist/packageVersion.js.map +1 -1
  240. package/dist/shared-tree/index.d.ts +1 -1
  241. package/dist/shared-tree/index.d.ts.map +1 -1
  242. package/dist/shared-tree/index.js.map +1 -1
  243. package/dist/shared-tree/schematizeTree.d.ts +4 -4
  244. package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
  245. package/dist/shared-tree/schematizeTree.js +2 -1
  246. package/dist/shared-tree/schematizeTree.js.map +1 -1
  247. package/dist/shared-tree/schematizingTreeView.d.ts +1 -5
  248. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  249. package/dist/shared-tree/schematizingTreeView.js +38 -35
  250. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  251. package/dist/shared-tree/sharedTree.d.ts +9 -3
  252. package/dist/shared-tree/sharedTree.d.ts.map +1 -1
  253. package/dist/shared-tree/sharedTree.js +11 -0
  254. package/dist/shared-tree/sharedTree.js.map +1 -1
  255. package/dist/shared-tree/sharedTreeChangeCodecs.d.ts +1 -1
  256. package/dist/shared-tree/sharedTreeChangeCodecs.d.ts.map +1 -1
  257. package/dist/shared-tree/sharedTreeChangeCodecs.js +1 -0
  258. package/dist/shared-tree/sharedTreeChangeCodecs.js.map +1 -1
  259. package/dist/shared-tree/sharedTreeChangeEnricher.d.ts.map +1 -1
  260. package/dist/shared-tree/sharedTreeChangeEnricher.js +1 -1
  261. package/dist/shared-tree/sharedTreeChangeEnricher.js.map +1 -1
  262. package/dist/shared-tree/sharedTreeChangeFamily.d.ts +5 -5
  263. package/dist/shared-tree/sharedTreeChangeFamily.d.ts.map +1 -1
  264. package/dist/shared-tree/sharedTreeChangeFamily.js +10 -4
  265. package/dist/shared-tree/sharedTreeChangeFamily.js.map +1 -1
  266. package/dist/shared-tree/sharedTreeEditBuilder.d.ts +16 -6
  267. package/dist/shared-tree/sharedTreeEditBuilder.d.ts.map +1 -1
  268. package/dist/shared-tree/sharedTreeEditBuilder.js +14 -7
  269. package/dist/shared-tree/sharedTreeEditBuilder.js.map +1 -1
  270. package/dist/shared-tree/treeCheckout.d.ts +9 -10
  271. package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
  272. package/dist/shared-tree/treeCheckout.js +63 -8
  273. package/dist/shared-tree/treeCheckout.js.map +1 -1
  274. package/dist/shared-tree-core/branch.d.ts +3 -2
  275. package/dist/shared-tree-core/branch.d.ts.map +1 -1
  276. package/dist/shared-tree-core/branch.js +9 -4
  277. package/dist/shared-tree-core/branch.js.map +1 -1
  278. package/dist/shared-tree-core/editManager.d.ts +2 -2
  279. package/dist/shared-tree-core/editManager.d.ts.map +1 -1
  280. package/dist/shared-tree-core/editManager.js +20 -14
  281. package/dist/shared-tree-core/editManager.js.map +1 -1
  282. package/dist/shared-tree-core/editManagerCodecs.d.ts +4 -0
  283. package/dist/shared-tree-core/editManagerCodecs.d.ts.map +1 -1
  284. package/dist/shared-tree-core/editManagerCodecs.js +10 -2
  285. package/dist/shared-tree-core/editManagerCodecs.js.map +1 -1
  286. package/dist/shared-tree-core/editManagerFormatCommons.d.ts +1 -0
  287. package/dist/shared-tree-core/editManagerFormatCommons.d.ts.map +1 -1
  288. package/dist/shared-tree-core/editManagerFormatCommons.js +6 -0
  289. package/dist/shared-tree-core/editManagerFormatCommons.js.map +1 -1
  290. package/dist/shared-tree-core/editManagerFormatV1toV4.d.ts +2 -2
  291. package/dist/shared-tree-core/editManagerFormatV1toV4.d.ts.map +1 -1
  292. package/dist/shared-tree-core/editManagerFormatV1toV4.js +1 -0
  293. package/dist/shared-tree-core/editManagerFormatV1toV4.js.map +1 -1
  294. package/dist/shared-tree-core/index.d.ts +2 -2
  295. package/dist/shared-tree-core/index.d.ts.map +1 -1
  296. package/dist/shared-tree-core/index.js +3 -1
  297. package/dist/shared-tree-core/index.js.map +1 -1
  298. package/dist/shared-tree-core/messageCodecV1ToV4.d.ts +1 -1
  299. package/dist/shared-tree-core/messageCodecV1ToV4.d.ts.map +1 -1
  300. package/dist/shared-tree-core/messageCodecV1ToV4.js.map +1 -1
  301. package/dist/shared-tree-core/messageCodecs.d.ts +4 -0
  302. package/dist/shared-tree-core/messageCodecs.d.ts.map +1 -1
  303. package/dist/shared-tree-core/messageCodecs.js +10 -2
  304. package/dist/shared-tree-core/messageCodecs.js.map +1 -1
  305. package/dist/shared-tree-core/messageFormat.d.ts +1 -0
  306. package/dist/shared-tree-core/messageFormat.d.ts.map +1 -1
  307. package/dist/shared-tree-core/messageFormat.js +6 -0
  308. package/dist/shared-tree-core/messageFormat.js.map +1 -1
  309. package/dist/shared-tree-core/messageFormatV1ToV4.d.ts +2 -2
  310. package/dist/shared-tree-core/messageFormatV1ToV4.d.ts.map +1 -1
  311. package/dist/shared-tree-core/messageFormatV1ToV4.js +1 -0
  312. package/dist/shared-tree-core/messageFormatV1ToV4.js.map +1 -1
  313. package/dist/shared-tree-core/sharedTreeCore.d.ts +1 -0
  314. package/dist/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
  315. package/dist/shared-tree-core/sharedTreeCore.js +1 -1
  316. package/dist/shared-tree-core/sharedTreeCore.js.map +1 -1
  317. package/dist/simple-tree/api/index.d.ts +1 -1
  318. package/dist/simple-tree/api/index.d.ts.map +1 -1
  319. package/dist/simple-tree/api/index.js +2 -1
  320. package/dist/simple-tree/api/index.js.map +1 -1
  321. package/dist/simple-tree/api/schemaFactoryAlpha.js +1 -1
  322. package/dist/simple-tree/api/schemaFactoryAlpha.js.map +1 -1
  323. package/dist/simple-tree/api/schemaFactoryBeta.js +1 -1
  324. package/dist/simple-tree/api/schemaFactoryBeta.js.map +1 -1
  325. package/dist/simple-tree/api/simpleSchemaToJsonSchema.js +4 -4
  326. package/dist/simple-tree/api/simpleSchemaToJsonSchema.js.map +1 -1
  327. package/dist/simple-tree/api/snapshotCompatibilityChecker.d.ts +244 -0
  328. package/dist/simple-tree/api/snapshotCompatibilityChecker.d.ts.map +1 -1
  329. package/dist/simple-tree/api/snapshotCompatibilityChecker.js +297 -1
  330. package/dist/simple-tree/api/snapshotCompatibilityChecker.js.map +1 -1
  331. package/dist/simple-tree/api/tree.d.ts +3 -1
  332. package/dist/simple-tree/api/tree.d.ts.map +1 -1
  333. package/dist/simple-tree/api/tree.js.map +1 -1
  334. package/dist/simple-tree/core/treeNodeKernel.d.ts.map +1 -1
  335. package/dist/simple-tree/core/treeNodeKernel.js +6 -2
  336. package/dist/simple-tree/core/treeNodeKernel.js.map +1 -1
  337. package/dist/simple-tree/core/unhydratedFlexTree.d.ts +15 -15
  338. package/dist/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
  339. package/dist/simple-tree/core/unhydratedFlexTree.js +59 -8
  340. package/dist/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  341. package/dist/simple-tree/fieldSchema.d.ts +4 -4
  342. package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
  343. package/dist/simple-tree/fieldSchema.js.map +1 -1
  344. package/dist/simple-tree/index.d.ts +3 -3
  345. package/dist/simple-tree/index.d.ts.map +1 -1
  346. package/dist/simple-tree/index.js +4 -3
  347. package/dist/simple-tree/index.js.map +1 -1
  348. package/dist/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  349. package/dist/simple-tree/node-kinds/array/arrayNode.js +7 -5
  350. package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  351. package/dist/simple-tree/node-kinds/common.d.ts.map +1 -1
  352. package/dist/simple-tree/node-kinds/common.js +1 -1
  353. package/dist/simple-tree/node-kinds/common.js.map +1 -1
  354. package/dist/simple-tree/node-kinds/map/mapNode.js +2 -2
  355. package/dist/simple-tree/node-kinds/map/mapNode.js.map +1 -1
  356. package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  357. package/dist/simple-tree/node-kinds/object/objectNode.js +19 -19
  358. package/dist/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  359. package/dist/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
  360. package/dist/simple-tree/node-kinds/record/recordNode.js +4 -2
  361. package/dist/simple-tree/node-kinds/record/recordNode.js.map +1 -1
  362. package/dist/simple-tree/prepareForInsertion.d.ts +54 -47
  363. package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
  364. package/dist/simple-tree/prepareForInsertion.js +184 -126
  365. package/dist/simple-tree/prepareForInsertion.js.map +1 -1
  366. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +13 -4
  367. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  368. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js +31 -13
  369. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  370. package/dist/text/index.d.ts +6 -0
  371. package/dist/text/index.d.ts.map +1 -0
  372. package/dist/text/index.js +10 -0
  373. package/dist/text/index.js.map +1 -0
  374. package/dist/text/textDomain.d.ts +138 -0
  375. package/dist/text/textDomain.d.ts.map +1 -0
  376. package/dist/text/textDomain.js +121 -0
  377. package/dist/text/textDomain.js.map +1 -0
  378. package/dist/treeFactory.d.ts.map +1 -1
  379. package/dist/treeFactory.js +12 -2
  380. package/dist/treeFactory.js.map +1 -1
  381. package/dist/util/bTreeUtils.d.ts +12 -4
  382. package/dist/util/bTreeUtils.d.ts.map +1 -1
  383. package/dist/util/bTreeUtils.js +14 -18
  384. package/dist/util/bTreeUtils.js.map +1 -1
  385. package/dist/util/index.d.ts +1 -1
  386. package/dist/util/index.d.ts.map +1 -1
  387. package/dist/util/index.js +2 -1
  388. package/dist/util/index.js.map +1 -1
  389. package/dist/util/nestedMap.js +12 -12
  390. package/dist/util/nestedMap.js.map +1 -1
  391. package/dist/util/rangeMap.d.ts +24 -12
  392. package/dist/util/rangeMap.d.ts.map +1 -1
  393. package/dist/util/rangeMap.js +46 -6
  394. package/dist/util/rangeMap.js.map +1 -1
  395. package/docs/user-facing/merge-semantics.md +3 -2
  396. package/eslint.config.mts +4 -32
  397. package/lib/alpha.d.ts +5 -0
  398. package/lib/core/change-family/changeFamily.d.ts +4 -1
  399. package/lib/core/change-family/changeFamily.d.ts.map +1 -1
  400. package/lib/core/change-family/changeFamily.js.map +1 -1
  401. package/lib/core/change-family/index.d.ts +1 -1
  402. package/lib/core/change-family/index.d.ts.map +1 -1
  403. package/lib/core/change-family/index.js.map +1 -1
  404. package/lib/core/index.d.ts +3 -3
  405. package/lib/core/index.d.ts.map +1 -1
  406. package/lib/core/index.js +2 -2
  407. package/lib/core/index.js.map +1 -1
  408. package/lib/core/rebase/changeRebaser.d.ts +6 -1
  409. package/lib/core/rebase/changeRebaser.d.ts.map +1 -1
  410. package/lib/core/rebase/changeRebaser.js.map +1 -1
  411. package/lib/core/rebase/index.d.ts +1 -1
  412. package/lib/core/rebase/index.d.ts.map +1 -1
  413. package/lib/core/rebase/index.js +1 -1
  414. package/lib/core/rebase/index.js.map +1 -1
  415. package/lib/core/rebase/types.d.ts +46 -8
  416. package/lib/core/rebase/types.d.ts.map +1 -1
  417. package/lib/core/rebase/types.js +3 -0
  418. package/lib/core/rebase/types.js.map +1 -1
  419. package/lib/core/rebase/utils.d.ts.map +1 -1
  420. package/lib/core/rebase/utils.js +30 -8
  421. package/lib/core/rebase/utils.js.map +1 -1
  422. package/lib/core/tree/anchorSet.js +1 -0
  423. package/lib/core/tree/anchorSet.js.map +1 -1
  424. package/lib/core/tree/detachedFieldIndex.d.ts +6 -0
  425. package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
  426. package/lib/core/tree/detachedFieldIndex.js +10 -1
  427. package/lib/core/tree/detachedFieldIndex.js.map +1 -1
  428. package/lib/core/tree/index.d.ts +1 -1
  429. package/lib/core/tree/index.d.ts.map +1 -1
  430. package/lib/core/tree/index.js +1 -1
  431. package/lib/core/tree/index.js.map +1 -1
  432. package/lib/core/tree/pathTree.d.ts +11 -3
  433. package/lib/core/tree/pathTree.d.ts.map +1 -1
  434. package/lib/core/tree/pathTree.js +12 -1
  435. package/lib/core/tree/pathTree.js.map +1 -1
  436. package/lib/core/tree/visitDelta.d.ts.map +1 -1
  437. package/lib/core/tree/visitDelta.js +3 -2
  438. package/lib/core/tree/visitDelta.js.map +1 -1
  439. package/lib/core/tree/visitorUtils.d.ts.map +1 -1
  440. package/lib/core/tree/visitorUtils.js +58 -18
  441. package/lib/core/tree/visitorUtils.js.map +1 -1
  442. package/lib/feature-libraries/changeAtomIdBTree.d.ts +10 -4
  443. package/lib/feature-libraries/changeAtomIdBTree.d.ts.map +1 -1
  444. package/lib/feature-libraries/changeAtomIdBTree.js +14 -1
  445. package/lib/feature-libraries/changeAtomIdBTree.js.map +1 -1
  446. package/lib/feature-libraries/chunked-forest/basicChunk.d.ts.map +1 -1
  447. package/lib/feature-libraries/chunked-forest/basicChunk.js +8 -1
  448. package/lib/feature-libraries/chunked-forest/basicChunk.js.map +1 -1
  449. package/lib/feature-libraries/chunked-forest/chunkTree.d.ts.map +1 -1
  450. package/lib/feature-libraries/chunked-forest/chunkTree.js +4 -1
  451. package/lib/feature-libraries/chunked-forest/chunkTree.js.map +1 -1
  452. package/lib/feature-libraries/chunked-forest/chunkedForest.d.ts.map +1 -1
  453. package/lib/feature-libraries/chunked-forest/chunkedForest.js +3 -1
  454. package/lib/feature-libraries/chunked-forest/chunkedForest.js.map +1 -1
  455. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js +1 -0
  456. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  457. package/lib/feature-libraries/default-schema/defaultEditBuilder.d.ts +93 -44
  458. package/lib/feature-libraries/default-schema/defaultEditBuilder.d.ts.map +1 -1
  459. package/lib/feature-libraries/default-schema/defaultEditBuilder.js +236 -70
  460. package/lib/feature-libraries/default-schema/defaultEditBuilder.js.map +1 -1
  461. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts +1 -1
  462. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  463. package/lib/feature-libraries/default-schema/defaultFieldKinds.js +11 -2
  464. package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  465. package/lib/feature-libraries/default-schema/index.d.ts +2 -1
  466. package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
  467. package/lib/feature-libraries/default-schema/index.js +2 -1
  468. package/lib/feature-libraries/default-schema/index.js.map +1 -1
  469. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.d.ts +38 -0
  470. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.d.ts.map +1 -0
  471. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.js +128 -0
  472. package/lib/feature-libraries/default-schema/locationBasedEditBuilder.js.map +1 -0
  473. package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts +7 -6
  474. package/lib/feature-libraries/default-schema/mappedEditBuilder.d.ts.map +1 -1
  475. package/lib/feature-libraries/default-schema/mappedEditBuilder.js +15 -0
  476. package/lib/feature-libraries/default-schema/mappedEditBuilder.js.map +1 -1
  477. package/lib/feature-libraries/deltaUtils.d.ts +1 -0
  478. package/lib/feature-libraries/deltaUtils.d.ts.map +1 -1
  479. package/lib/feature-libraries/deltaUtils.js +5 -1
  480. package/lib/feature-libraries/deltaUtils.js.map +1 -1
  481. package/lib/feature-libraries/flex-tree/context.d.ts +9 -0
  482. package/lib/feature-libraries/flex-tree/context.d.ts.map +1 -1
  483. package/lib/feature-libraries/flex-tree/context.js +6 -0
  484. package/lib/feature-libraries/flex-tree/context.js.map +1 -1
  485. package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts +6 -6
  486. package/lib/feature-libraries/flex-tree/flexTreeTypes.d.ts.map +1 -1
  487. package/lib/feature-libraries/flex-tree/flexTreeTypes.js.map +1 -1
  488. package/lib/feature-libraries/flex-tree/lazyField.d.ts +8 -7
  489. package/lib/feature-libraries/flex-tree/lazyField.d.ts.map +1 -1
  490. package/lib/feature-libraries/flex-tree/lazyField.js +41 -10
  491. package/lib/feature-libraries/flex-tree/lazyField.js.map +1 -1
  492. package/lib/feature-libraries/forest-summary/forestSummarizer.d.ts.map +1 -1
  493. package/lib/feature-libraries/forest-summary/forestSummarizer.js +3 -1
  494. package/lib/feature-libraries/forest-summary/forestSummarizer.js.map +1 -1
  495. package/lib/feature-libraries/index.d.ts +3 -3
  496. package/lib/feature-libraries/index.d.ts.map +1 -1
  497. package/lib/feature-libraries/index.js +2 -2
  498. package/lib/feature-libraries/index.js.map +1 -1
  499. package/lib/feature-libraries/mapTreeCursor.d.ts.map +1 -1
  500. package/lib/feature-libraries/mapTreeCursor.js +2 -1
  501. package/lib/feature-libraries/mapTreeCursor.js.map +1 -1
  502. package/lib/feature-libraries/mitigatedChangeFamily.d.ts.map +1 -1
  503. package/lib/feature-libraries/mitigatedChangeFamily.js +2 -2
  504. package/lib/feature-libraries/mitigatedChangeFamily.js.map +1 -1
  505. package/lib/feature-libraries/modular-schema/crossFieldQueries.d.ts +97 -21
  506. package/lib/feature-libraries/modular-schema/crossFieldQueries.d.ts.map +1 -1
  507. package/lib/feature-libraries/modular-schema/crossFieldQueries.js +3 -5
  508. package/lib/feature-libraries/modular-schema/crossFieldQueries.js.map +1 -1
  509. package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts +20 -51
  510. package/lib/feature-libraries/modular-schema/fieldChangeHandler.d.ts.map +1 -1
  511. package/lib/feature-libraries/modular-schema/fieldChangeHandler.js.map +1 -1
  512. package/lib/feature-libraries/modular-schema/genericFieldKind.d.ts.map +1 -1
  513. package/lib/feature-libraries/modular-schema/genericFieldKind.js +3 -9
  514. package/lib/feature-libraries/modular-schema/genericFieldKind.js.map +1 -1
  515. package/lib/feature-libraries/modular-schema/index.d.ts +4 -4
  516. package/lib/feature-libraries/modular-schema/index.d.ts.map +1 -1
  517. package/lib/feature-libraries/modular-schema/index.js +2 -2
  518. package/lib/feature-libraries/modular-schema/index.js.map +1 -1
  519. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.d.ts +11 -28
  520. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.d.ts.map +1 -1
  521. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.js +247 -143
  522. package/lib/feature-libraries/modular-schema/modularChangeCodecV1.js.map +1 -1
  523. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.d.ts +15 -0
  524. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.d.ts.map +1 -0
  525. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.js +389 -0
  526. package/lib/feature-libraries/modular-schema/modularChangeCodecV3.js.map +1 -0
  527. package/lib/feature-libraries/modular-schema/modularChangeCodecs.d.ts.map +1 -1
  528. package/lib/feature-libraries/modular-schema/modularChangeCodecs.js +8 -1
  529. package/lib/feature-libraries/modular-schema/modularChangeCodecs.js.map +1 -1
  530. package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts +48 -20
  531. package/lib/feature-libraries/modular-schema/modularChangeFamily.d.ts.map +1 -1
  532. package/lib/feature-libraries/modular-schema/modularChangeFamily.js +1344 -479
  533. package/lib/feature-libraries/modular-schema/modularChangeFamily.js.map +1 -1
  534. package/lib/feature-libraries/modular-schema/modularChangeFormatV1.d.ts.map +1 -1
  535. package/lib/feature-libraries/modular-schema/modularChangeFormatV1.js.map +1 -1
  536. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.d.ts +146 -0
  537. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.d.ts.map +1 -0
  538. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.js +29 -0
  539. package/lib/feature-libraries/modular-schema/modularChangeFormatV3.js.map +1 -0
  540. package/lib/feature-libraries/modular-schema/modularChangeTypes.d.ts +47 -11
  541. package/lib/feature-libraries/modular-schema/modularChangeTypes.d.ts.map +1 -1
  542. package/lib/feature-libraries/modular-schema/modularChangeTypes.js +1 -1
  543. package/lib/feature-libraries/modular-schema/modularChangeTypes.js.map +1 -1
  544. package/lib/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  545. package/lib/feature-libraries/object-forest/objectForest.js +3 -1
  546. package/lib/feature-libraries/object-forest/objectForest.js.map +1 -1
  547. package/lib/feature-libraries/optional-field/index.d.ts +2 -2
  548. package/lib/feature-libraries/optional-field/index.d.ts.map +1 -1
  549. package/lib/feature-libraries/optional-field/index.js +1 -1
  550. package/lib/feature-libraries/optional-field/index.js.map +1 -1
  551. package/lib/feature-libraries/optional-field/optionalField.d.ts +5 -26
  552. package/lib/feature-libraries/optional-field/optionalField.d.ts.map +1 -1
  553. package/lib/feature-libraries/optional-field/optionalField.js +221 -441
  554. package/lib/feature-libraries/optional-field/optionalField.js.map +1 -1
  555. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts +23 -0
  556. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.d.ts.map +1 -0
  557. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.js +27 -0
  558. package/lib/feature-libraries/optional-field/optionalFieldChangeFormatV3.js.map +1 -0
  559. package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts +24 -33
  560. package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.d.ts.map +1 -1
  561. package/lib/feature-libraries/optional-field/optionalFieldChangeTypes.js.map +1 -1
  562. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.d.ts +1 -1
  563. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.d.ts.map +1 -1
  564. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.js +55 -26
  565. package/lib/feature-libraries/optional-field/optionalFieldCodecV2.js.map +1 -1
  566. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.d.ts +12 -0
  567. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.d.ts.map +1 -0
  568. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.js +53 -0
  569. package/lib/feature-libraries/optional-field/optionalFieldCodecV3.js.map +1 -0
  570. package/lib/feature-libraries/optional-field/optionalFieldCodecs.d.ts.map +1 -1
  571. package/lib/feature-libraries/optional-field/optionalFieldCodecs.js +5 -1
  572. package/lib/feature-libraries/optional-field/optionalFieldCodecs.js.map +1 -1
  573. package/lib/feature-libraries/sequence-field/compose.d.ts +6 -7
  574. package/lib/feature-libraries/sequence-field/compose.d.ts.map +1 -1
  575. package/lib/feature-libraries/sequence-field/compose.js +85 -261
  576. package/lib/feature-libraries/sequence-field/compose.js.map +1 -1
  577. package/lib/feature-libraries/sequence-field/helperTypes.d.ts +14 -10
  578. package/lib/feature-libraries/sequence-field/helperTypes.d.ts.map +1 -1
  579. package/lib/feature-libraries/sequence-field/helperTypes.js.map +1 -1
  580. package/lib/feature-libraries/sequence-field/index.d.ts +2 -3
  581. package/lib/feature-libraries/sequence-field/index.d.ts.map +1 -1
  582. package/lib/feature-libraries/sequence-field/index.js +0 -1
  583. package/lib/feature-libraries/sequence-field/index.js.map +1 -1
  584. package/lib/feature-libraries/sequence-field/invert.d.ts +3 -3
  585. package/lib/feature-libraries/sequence-field/invert.d.ts.map +1 -1
  586. package/lib/feature-libraries/sequence-field/invert.js +67 -169
  587. package/lib/feature-libraries/sequence-field/invert.js.map +1 -1
  588. package/lib/feature-libraries/sequence-field/markQueue.d.ts +2 -2
  589. package/lib/feature-libraries/sequence-field/markQueue.d.ts.map +1 -1
  590. package/lib/feature-libraries/sequence-field/markQueue.js.map +1 -1
  591. package/lib/feature-libraries/sequence-field/moveEffectTable.d.ts +4 -56
  592. package/lib/feature-libraries/sequence-field/moveEffectTable.d.ts.map +1 -1
  593. package/lib/feature-libraries/sequence-field/moveEffectTable.js +6 -84
  594. package/lib/feature-libraries/sequence-field/moveEffectTable.js.map +1 -1
  595. package/lib/feature-libraries/sequence-field/rebase.d.ts +3 -3
  596. package/lib/feature-libraries/sequence-field/rebase.d.ts.map +1 -1
  597. package/lib/feature-libraries/sequence-field/rebase.js +109 -116
  598. package/lib/feature-libraries/sequence-field/rebase.js.map +1 -1
  599. package/lib/feature-libraries/sequence-field/replaceRevisions.d.ts.map +1 -1
  600. package/lib/feature-libraries/sequence-field/replaceRevisions.js +18 -31
  601. package/lib/feature-libraries/sequence-field/replaceRevisions.js.map +1 -1
  602. package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.d.ts.map +1 -1
  603. package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.js +0 -2
  604. package/lib/feature-libraries/sequence-field/sequenceFieldChangeHandler.js.map +1 -1
  605. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts +22 -4
  606. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.d.ts.map +1 -1
  607. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.js +356 -182
  608. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV2.js.map +1 -1
  609. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.d.ts.map +1 -1
  610. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.js +21 -63
  611. package/lib/feature-libraries/sequence-field/sequenceFieldCodecV3.js.map +1 -1
  612. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.d.ts +2 -2
  613. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.d.ts.map +1 -1
  614. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.js +10 -10
  615. package/lib/feature-libraries/sequence-field/sequenceFieldEditor.js.map +1 -1
  616. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts +3 -2
  617. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.d.ts.map +1 -1
  618. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.js +14 -109
  619. package/lib/feature-libraries/sequence-field/sequenceFieldToDelta.js.map +1 -1
  620. package/lib/feature-libraries/sequence-field/types.d.ts +30 -59
  621. package/lib/feature-libraries/sequence-field/types.d.ts.map +1 -1
  622. package/lib/feature-libraries/sequence-field/types.js.map +1 -1
  623. package/lib/feature-libraries/sequence-field/utils.d.ts +15 -24
  624. package/lib/feature-libraries/sequence-field/utils.d.ts.map +1 -1
  625. package/lib/feature-libraries/sequence-field/utils.js +112 -298
  626. package/lib/feature-libraries/sequence-field/utils.js.map +1 -1
  627. package/lib/index.d.ts +3 -2
  628. package/lib/index.d.ts.map +1 -1
  629. package/lib/index.js +2 -1
  630. package/lib/index.js.map +1 -1
  631. package/lib/packageVersion.d.ts +1 -1
  632. package/lib/packageVersion.d.ts.map +1 -1
  633. package/lib/packageVersion.js +1 -1
  634. package/lib/packageVersion.js.map +1 -1
  635. package/lib/shared-tree/index.d.ts +1 -1
  636. package/lib/shared-tree/index.d.ts.map +1 -1
  637. package/lib/shared-tree/index.js.map +1 -1
  638. package/lib/shared-tree/schematizeTree.d.ts +4 -4
  639. package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
  640. package/lib/shared-tree/schematizeTree.js +3 -2
  641. package/lib/shared-tree/schematizeTree.js.map +1 -1
  642. package/lib/shared-tree/schematizingTreeView.d.ts +1 -5
  643. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  644. package/lib/shared-tree/schematizingTreeView.js +41 -38
  645. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  646. package/lib/shared-tree/sharedTree.d.ts +9 -3
  647. package/lib/shared-tree/sharedTree.d.ts.map +1 -1
  648. package/lib/shared-tree/sharedTree.js +11 -0
  649. package/lib/shared-tree/sharedTree.js.map +1 -1
  650. package/lib/shared-tree/sharedTreeChangeCodecs.d.ts +1 -1
  651. package/lib/shared-tree/sharedTreeChangeCodecs.d.ts.map +1 -1
  652. package/lib/shared-tree/sharedTreeChangeCodecs.js +1 -0
  653. package/lib/shared-tree/sharedTreeChangeCodecs.js.map +1 -1
  654. package/lib/shared-tree/sharedTreeChangeEnricher.d.ts.map +1 -1
  655. package/lib/shared-tree/sharedTreeChangeEnricher.js +2 -2
  656. package/lib/shared-tree/sharedTreeChangeEnricher.js.map +1 -1
  657. package/lib/shared-tree/sharedTreeChangeFamily.d.ts +5 -5
  658. package/lib/shared-tree/sharedTreeChangeFamily.d.ts.map +1 -1
  659. package/lib/shared-tree/sharedTreeChangeFamily.js +11 -5
  660. package/lib/shared-tree/sharedTreeChangeFamily.js.map +1 -1
  661. package/lib/shared-tree/sharedTreeEditBuilder.d.ts +16 -6
  662. package/lib/shared-tree/sharedTreeEditBuilder.d.ts.map +1 -1
  663. package/lib/shared-tree/sharedTreeEditBuilder.js +12 -6
  664. package/lib/shared-tree/sharedTreeEditBuilder.js.map +1 -1
  665. package/lib/shared-tree/treeCheckout.d.ts +9 -10
  666. package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
  667. package/lib/shared-tree/treeCheckout.js +66 -11
  668. package/lib/shared-tree/treeCheckout.js.map +1 -1
  669. package/lib/shared-tree-core/branch.d.ts +3 -2
  670. package/lib/shared-tree-core/branch.d.ts.map +1 -1
  671. package/lib/shared-tree-core/branch.js +9 -4
  672. package/lib/shared-tree-core/branch.js.map +1 -1
  673. package/lib/shared-tree-core/editManager.d.ts +2 -2
  674. package/lib/shared-tree-core/editManager.d.ts.map +1 -1
  675. package/lib/shared-tree-core/editManager.js +20 -14
  676. package/lib/shared-tree-core/editManager.js.map +1 -1
  677. package/lib/shared-tree-core/editManagerCodecs.d.ts +4 -0
  678. package/lib/shared-tree-core/editManagerCodecs.d.ts.map +1 -1
  679. package/lib/shared-tree-core/editManagerCodecs.js +8 -1
  680. package/lib/shared-tree-core/editManagerCodecs.js.map +1 -1
  681. package/lib/shared-tree-core/editManagerFormatCommons.d.ts +1 -0
  682. package/lib/shared-tree-core/editManagerFormatCommons.d.ts.map +1 -1
  683. package/lib/shared-tree-core/editManagerFormatCommons.js +6 -0
  684. package/lib/shared-tree-core/editManagerFormatCommons.js.map +1 -1
  685. package/lib/shared-tree-core/editManagerFormatV1toV4.d.ts +2 -2
  686. package/lib/shared-tree-core/editManagerFormatV1toV4.d.ts.map +1 -1
  687. package/lib/shared-tree-core/editManagerFormatV1toV4.js +1 -0
  688. package/lib/shared-tree-core/editManagerFormatV1toV4.js.map +1 -1
  689. package/lib/shared-tree-core/index.d.ts +2 -2
  690. package/lib/shared-tree-core/index.d.ts.map +1 -1
  691. package/lib/shared-tree-core/index.js +2 -2
  692. package/lib/shared-tree-core/index.js.map +1 -1
  693. package/lib/shared-tree-core/messageCodecV1ToV4.d.ts +1 -1
  694. package/lib/shared-tree-core/messageCodecV1ToV4.d.ts.map +1 -1
  695. package/lib/shared-tree-core/messageCodecV1ToV4.js.map +1 -1
  696. package/lib/shared-tree-core/messageCodecs.d.ts +4 -0
  697. package/lib/shared-tree-core/messageCodecs.d.ts.map +1 -1
  698. package/lib/shared-tree-core/messageCodecs.js +8 -1
  699. package/lib/shared-tree-core/messageCodecs.js.map +1 -1
  700. package/lib/shared-tree-core/messageFormat.d.ts +1 -0
  701. package/lib/shared-tree-core/messageFormat.d.ts.map +1 -1
  702. package/lib/shared-tree-core/messageFormat.js +6 -0
  703. package/lib/shared-tree-core/messageFormat.js.map +1 -1
  704. package/lib/shared-tree-core/messageFormatV1ToV4.d.ts +2 -2
  705. package/lib/shared-tree-core/messageFormatV1ToV4.d.ts.map +1 -1
  706. package/lib/shared-tree-core/messageFormatV1ToV4.js +1 -0
  707. package/lib/shared-tree-core/messageFormatV1ToV4.js.map +1 -1
  708. package/lib/shared-tree-core/sharedTreeCore.d.ts +1 -0
  709. package/lib/shared-tree-core/sharedTreeCore.d.ts.map +1 -1
  710. package/lib/shared-tree-core/sharedTreeCore.js +1 -1
  711. package/lib/shared-tree-core/sharedTreeCore.js.map +1 -1
  712. package/lib/simple-tree/api/index.d.ts +1 -1
  713. package/lib/simple-tree/api/index.d.ts.map +1 -1
  714. package/lib/simple-tree/api/index.js +1 -1
  715. package/lib/simple-tree/api/index.js.map +1 -1
  716. package/lib/simple-tree/api/schemaFactoryAlpha.js +1 -1
  717. package/lib/simple-tree/api/schemaFactoryAlpha.js.map +1 -1
  718. package/lib/simple-tree/api/schemaFactoryBeta.js +1 -1
  719. package/lib/simple-tree/api/schemaFactoryBeta.js.map +1 -1
  720. package/lib/simple-tree/api/simpleSchemaToJsonSchema.js +4 -4
  721. package/lib/simple-tree/api/simpleSchemaToJsonSchema.js.map +1 -1
  722. package/lib/simple-tree/api/snapshotCompatibilityChecker.d.ts +244 -0
  723. package/lib/simple-tree/api/snapshotCompatibilityChecker.d.ts.map +1 -1
  724. package/lib/simple-tree/api/snapshotCompatibilityChecker.js +270 -0
  725. package/lib/simple-tree/api/snapshotCompatibilityChecker.js.map +1 -1
  726. package/lib/simple-tree/api/tree.d.ts +3 -1
  727. package/lib/simple-tree/api/tree.d.ts.map +1 -1
  728. package/lib/simple-tree/api/tree.js.map +1 -1
  729. package/lib/simple-tree/core/treeNodeKernel.d.ts.map +1 -1
  730. package/lib/simple-tree/core/treeNodeKernel.js +6 -2
  731. package/lib/simple-tree/core/treeNodeKernel.js.map +1 -1
  732. package/lib/simple-tree/core/unhydratedFlexTree.d.ts +15 -15
  733. package/lib/simple-tree/core/unhydratedFlexTree.d.ts.map +1 -1
  734. package/lib/simple-tree/core/unhydratedFlexTree.js +58 -8
  735. package/lib/simple-tree/core/unhydratedFlexTree.js.map +1 -1
  736. package/lib/simple-tree/fieldSchema.d.ts +4 -4
  737. package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
  738. package/lib/simple-tree/fieldSchema.js.map +1 -1
  739. package/lib/simple-tree/index.d.ts +3 -3
  740. package/lib/simple-tree/index.d.ts.map +1 -1
  741. package/lib/simple-tree/index.js +2 -2
  742. package/lib/simple-tree/index.js.map +1 -1
  743. package/lib/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  744. package/lib/simple-tree/node-kinds/array/arrayNode.js +8 -6
  745. package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  746. package/lib/simple-tree/node-kinds/common.d.ts.map +1 -1
  747. package/lib/simple-tree/node-kinds/common.js +2 -2
  748. package/lib/simple-tree/node-kinds/common.js.map +1 -1
  749. package/lib/simple-tree/node-kinds/map/mapNode.js +2 -2
  750. package/lib/simple-tree/node-kinds/map/mapNode.js.map +1 -1
  751. package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  752. package/lib/simple-tree/node-kinds/object/objectNode.js +20 -20
  753. package/lib/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  754. package/lib/simple-tree/node-kinds/record/recordNode.d.ts.map +1 -1
  755. package/lib/simple-tree/node-kinds/record/recordNode.js +4 -2
  756. package/lib/simple-tree/node-kinds/record/recordNode.js.map +1 -1
  757. package/lib/simple-tree/prepareForInsertion.d.ts +54 -47
  758. package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
  759. package/lib/simple-tree/prepareForInsertion.js +184 -125
  760. package/lib/simple-tree/prepareForInsertion.js.map +1 -1
  761. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +13 -4
  762. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  763. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +28 -11
  764. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  765. package/lib/text/index.d.ts +6 -0
  766. package/lib/text/index.d.ts.map +1 -0
  767. package/lib/text/index.js +6 -0
  768. package/lib/text/index.js.map +1 -0
  769. package/lib/text/textDomain.d.ts +138 -0
  770. package/lib/text/textDomain.d.ts.map +1 -0
  771. package/lib/text/textDomain.js +118 -0
  772. package/lib/text/textDomain.js.map +1 -0
  773. package/lib/treeFactory.d.ts.map +1 -1
  774. package/lib/treeFactory.js +13 -3
  775. package/lib/treeFactory.js.map +1 -1
  776. package/lib/util/bTreeUtils.d.ts +12 -4
  777. package/lib/util/bTreeUtils.d.ts.map +1 -1
  778. package/lib/util/bTreeUtils.js +15 -19
  779. package/lib/util/bTreeUtils.js.map +1 -1
  780. package/lib/util/index.d.ts +1 -1
  781. package/lib/util/index.d.ts.map +1 -1
  782. package/lib/util/index.js +1 -1
  783. package/lib/util/index.js.map +1 -1
  784. package/lib/util/nestedMap.js +12 -12
  785. package/lib/util/nestedMap.js.map +1 -1
  786. package/lib/util/rangeMap.d.ts +24 -12
  787. package/lib/util/rangeMap.d.ts.map +1 -1
  788. package/lib/util/rangeMap.js +44 -5
  789. package/lib/util/rangeMap.js.map +1 -1
  790. package/package.json +25 -25
  791. package/src/core/change-family/changeFamily.ts +5 -0
  792. package/src/core/change-family/index.ts +1 -0
  793. package/src/core/index.ts +6 -1
  794. package/src/core/rebase/changeRebaser.ts +6 -1
  795. package/src/core/rebase/index.ts +3 -0
  796. package/src/core/rebase/types.ts +65 -21
  797. package/src/core/rebase/utils.ts +39 -11
  798. package/src/core/tree/anchorSet.ts +1 -0
  799. package/src/core/tree/detachedFieldIndex.ts +17 -1
  800. package/src/core/tree/index.ts +2 -1
  801. package/src/core/tree/pathTree.ts +16 -4
  802. package/src/core/tree/visitDelta.ts +6 -2
  803. package/src/core/tree/visitorUtils.ts +55 -19
  804. package/src/feature-libraries/changeAtomIdBTree.ts +37 -5
  805. package/src/feature-libraries/chunked-forest/basicChunk.ts +7 -1
  806. package/src/feature-libraries/chunked-forest/chunkTree.ts +6 -1
  807. package/src/feature-libraries/chunked-forest/chunkedForest.ts +3 -1
  808. package/src/feature-libraries/chunked-forest/codec/compressedEncode.ts +1 -0
  809. package/src/feature-libraries/default-schema/defaultEditBuilder.ts +399 -127
  810. package/src/feature-libraries/default-schema/defaultFieldKinds.ts +13 -5
  811. package/src/feature-libraries/default-schema/index.ts +17 -5
  812. package/src/feature-libraries/default-schema/locationBasedEditBuilder.ts +188 -0
  813. package/src/feature-libraries/default-schema/mappedEditBuilder.ts +35 -9
  814. package/src/feature-libraries/deltaUtils.ts +6 -1
  815. package/src/feature-libraries/flex-tree/context.ts +17 -0
  816. package/src/feature-libraries/flex-tree/flexTreeTypes.ts +7 -8
  817. package/src/feature-libraries/flex-tree/lazyField.ts +68 -25
  818. package/src/feature-libraries/forest-summary/forestSummarizer.ts +3 -1
  819. package/src/feature-libraries/index.ts +22 -8
  820. package/src/feature-libraries/mapTreeCursor.ts +2 -1
  821. package/src/feature-libraries/mitigatedChangeFamily.ts +3 -1
  822. package/src/feature-libraries/modular-schema/crossFieldQueries.ts +142 -44
  823. package/src/feature-libraries/modular-schema/fieldChangeHandler.ts +32 -58
  824. package/src/feature-libraries/modular-schema/genericFieldKind.ts +6 -18
  825. package/src/feature-libraries/modular-schema/index.ts +16 -15
  826. package/src/feature-libraries/modular-schema/modularChangeCodecV1.ts +560 -351
  827. package/src/feature-libraries/modular-schema/modularChangeCodecV3.ts +760 -0
  828. package/src/feature-libraries/modular-schema/modularChangeCodecs.ts +14 -1
  829. package/src/feature-libraries/modular-schema/modularChangeFamily.ts +2620 -782
  830. package/src/feature-libraries/modular-schema/modularChangeFormatV1.ts +1 -0
  831. package/src/feature-libraries/modular-schema/modularChangeFormatV3.ts +62 -0
  832. package/src/feature-libraries/modular-schema/modularChangeTypes.ts +58 -11
  833. package/src/feature-libraries/object-forest/objectForest.ts +3 -1
  834. package/src/feature-libraries/optional-field/index.ts +1 -3
  835. package/src/feature-libraries/optional-field/optionalField.ts +318 -562
  836. package/src/feature-libraries/optional-field/optionalFieldChangeFormatV3.ts +45 -0
  837. package/src/feature-libraries/optional-field/optionalFieldChangeTypes.ts +24 -38
  838. package/src/feature-libraries/optional-field/optionalFieldCodecV2.ts +89 -35
  839. package/src/feature-libraries/optional-field/optionalFieldCodecV3.ts +94 -0
  840. package/src/feature-libraries/optional-field/optionalFieldCodecs.ts +5 -1
  841. package/src/feature-libraries/sequence-field/compose.ts +139 -522
  842. package/src/feature-libraries/sequence-field/helperTypes.ts +34 -19
  843. package/src/feature-libraries/sequence-field/index.ts +0 -9
  844. package/src/feature-libraries/sequence-field/invert.ts +103 -228
  845. package/src/feature-libraries/sequence-field/markQueue.ts +2 -2
  846. package/src/feature-libraries/sequence-field/moveEffectTable.ts +8 -195
  847. package/src/feature-libraries/sequence-field/rebase.ts +169 -205
  848. package/src/feature-libraries/sequence-field/replaceRevisions.ts +25 -47
  849. package/src/feature-libraries/sequence-field/sequenceFieldChangeHandler.ts +0 -2
  850. package/src/feature-libraries/sequence-field/sequenceFieldCodecV2.ts +648 -228
  851. package/src/feature-libraries/sequence-field/sequenceFieldCodecV3.ts +56 -70
  852. package/src/feature-libraries/sequence-field/sequenceFieldEditor.ts +25 -27
  853. package/src/feature-libraries/sequence-field/sequenceFieldToDelta.ts +19 -129
  854. package/src/feature-libraries/sequence-field/types.ts +34 -64
  855. package/src/feature-libraries/sequence-field/utils.ts +139 -353
  856. package/src/index.ts +7 -0
  857. package/src/packageVersion.ts +1 -1
  858. package/src/shared-tree/index.ts +3 -2
  859. package/src/shared-tree/schematizeTree.ts +21 -8
  860. package/src/shared-tree/schematizingTreeView.ts +56 -70
  861. package/src/shared-tree/sharedTree.ts +20 -3
  862. package/src/shared-tree/sharedTreeChangeCodecs.ts +5 -1
  863. package/src/shared-tree/sharedTreeChangeEnricher.ts +2 -0
  864. package/src/shared-tree/sharedTreeChangeFamily.ts +15 -5
  865. package/src/shared-tree/sharedTreeEditBuilder.ts +39 -8
  866. package/src/shared-tree/treeCheckout.ts +95 -24
  867. package/src/shared-tree-core/branch.ts +13 -3
  868. package/src/shared-tree-core/editManager.ts +42 -28
  869. package/src/shared-tree-core/editManagerCodecs.ts +11 -1
  870. package/src/shared-tree-core/editManagerFormatCommons.ts +6 -0
  871. package/src/shared-tree-core/editManagerFormatV1toV4.ts +3 -1
  872. package/src/shared-tree-core/index.ts +2 -0
  873. package/src/shared-tree-core/messageCodecV1ToV4.ts +2 -1
  874. package/src/shared-tree-core/messageCodecs.ts +11 -1
  875. package/src/shared-tree-core/messageFormat.ts +6 -0
  876. package/src/shared-tree-core/messageFormatV1ToV4.ts +3 -1
  877. package/src/shared-tree-core/sharedTreeCore.ts +4 -1
  878. package/src/simple-tree/api/index.ts +3 -0
  879. package/src/simple-tree/api/schemaFactoryAlpha.ts +1 -1
  880. package/src/simple-tree/api/schemaFactoryBeta.ts +1 -1
  881. package/src/simple-tree/api/simpleSchemaToJsonSchema.ts +4 -4
  882. package/src/simple-tree/api/snapshotCompatibilityChecker.ts +501 -0
  883. package/src/simple-tree/api/tree.ts +3 -1
  884. package/src/simple-tree/core/treeNodeKernel.ts +6 -2
  885. package/src/simple-tree/core/unhydratedFlexTree.ts +87 -36
  886. package/src/simple-tree/fieldSchema.ts +6 -4
  887. package/src/simple-tree/index.ts +5 -1
  888. package/src/simple-tree/node-kinds/array/arrayNode.ts +9 -7
  889. package/src/simple-tree/node-kinds/common.ts +2 -5
  890. package/src/simple-tree/node-kinds/map/mapNode.ts +4 -4
  891. package/src/simple-tree/node-kinds/object/objectNode.ts +26 -26
  892. package/src/simple-tree/node-kinds/record/recordNode.ts +10 -9
  893. package/src/simple-tree/prepareForInsertion.ts +343 -201
  894. package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +43 -15
  895. package/src/text/README.md +8 -0
  896. package/src/text/index.ts +6 -0
  897. package/src/text/textDomain.ts +199 -0
  898. package/src/treeFactory.ts +14 -4
  899. package/src/util/bTreeUtils.ts +33 -22
  900. package/src/util/index.ts +3 -0
  901. package/src/util/nestedMap.ts +12 -12
  902. package/src/util/rangeMap.ts +72 -18
  903. package/.eslintrc.cjs +0 -125
  904. package/assertTagging.config.mjs +0 -14
  905. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.d.ts +0 -9
  906. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.d.ts.map +0 -1
  907. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.js +0 -50
  908. package/dist/feature-libraries/sequence-field/relevantRemovedRoots.js.map +0 -1
  909. package/docs/main/sequence-field/move-composition.md +0 -46
  910. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.d.ts +0 -9
  911. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.d.ts.map +0 -1
  912. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.js +0 -46
  913. package/lib/feature-libraries/sequence-field/relevantRemovedRoots.js.map +0 -1
  914. package/src/feature-libraries/sequence-field/relevantRemovedRoots.ts +0 -57
@@ -6,71 +6,55 @@
6
6
  import { assert, unreachableCase, fail } from "@fluidframework/core-utils/internal";
7
7
 
8
8
  import {
9
+ areEqualChangeAtomIdOpts,
10
+ areEqualChangeAtomIds,
9
11
  type ChangeAtomId,
10
12
  type RevisionMetadataSource,
11
13
  type RevisionTag,
12
- offsetChangeAtomId,
13
14
  } from "../../core/index.js";
14
15
  import type { IdAllocator } from "../../util/index.js";
15
- import {
16
- type CrossFieldManager,
17
- CrossFieldTarget,
18
- type NodeChangeComposer,
19
- type NodeId,
16
+ import type {
17
+ ComposeNodeManager,
18
+ NodeChangeComposer,
19
+ NodeId,
20
20
  } from "../modular-schema/index.js";
21
21
 
22
- import type { MoveMarkEffect } from "./helperTypes.js";
23
22
  import { MarkListFactory } from "./markListFactory.js";
24
23
  import { MarkQueue } from "./markQueue.js";
25
- import {
26
- type MoveEffect,
27
- type MoveEffectTable,
28
- getCrossFieldTargetFromMove,
29
- getMoveEffect,
30
- getMoveIn,
31
- isMoveIn,
32
- isMoveMark,
33
- isMoveOut,
34
- setMoveEffect,
35
- } from "./moveEffectTable.js";
36
- import {
37
- type Attach,
38
- type CellMark,
39
- type Changeset,
40
- type Detach,
41
- type Mark,
42
- type MarkEffect,
43
- type MarkList,
44
- type MoveId,
45
- type NoopMark,
46
- NoopMarkType,
24
+ import type { NodeRangeQueryFunc } from "./moveEffectTable.js";
25
+ import type {
26
+ CellMark,
27
+ Changeset,
28
+ Detach,
29
+ Mark,
30
+ MarkEffect,
31
+ MarkList,
32
+ NoopMark,
47
33
  } from "./types.js";
48
34
  import {
49
35
  CellOrder,
50
36
  areEqualCellIds,
51
37
  areInputCellsEmpty,
52
38
  areOutputCellsEmpty,
53
- asAttachAndDetach,
54
39
  cellSourcesFromMarks,
55
40
  compareCellPositionsUsingTombstones,
56
41
  extractMarkEffect,
57
- getEndpoint,
42
+ getAttachedRootId,
43
+ getDetachOutputCellId,
44
+ getDetachedRootId,
58
45
  getInputCellId,
46
+ getMovedNodeId,
59
47
  getOutputCellId,
60
48
  isAttach,
61
- isAttachAndDetachEffect,
62
49
  isDetach,
63
- isImpactfulCellRename,
64
50
  isNewAttach,
65
51
  isNoopMark,
52
+ isPin,
66
53
  isRename,
67
54
  markEmptiesCells,
68
- markFillsCells,
69
55
  markHasCellEffect,
70
56
  normalizeCellRename,
71
- settleMark,
72
57
  withNodeChange,
73
- withRevision,
74
58
  } from "./utils.js";
75
59
 
76
60
  /**
@@ -90,63 +74,25 @@ export function compose(
90
74
  change2: Changeset,
91
75
  composeChild: NodeChangeComposer,
92
76
  _genId: IdAllocator,
93
- manager: CrossFieldManager,
77
+ manager: ComposeNodeManager,
94
78
  revisionMetadata: RevisionMetadataSource,
95
79
  ): Changeset {
96
- return composeMarkLists(
97
- change1,
98
- change2,
99
- composeChild,
100
- manager as MoveEffectTable,
101
- revisionMetadata,
102
- );
80
+ return composeMarkLists(change1, change2, composeChild, manager, revisionMetadata);
103
81
  }
104
82
 
105
83
  function composeMarkLists(
106
84
  baseMarkList: MarkList,
107
85
  newMarkList: MarkList,
108
86
  composeChild: NodeChangeComposer,
109
- moveEffects: MoveEffectTable,
87
+ moveEffects: ComposeNodeManager,
110
88
  revisionMetadata: RevisionMetadataSource,
111
89
  ): MarkList {
112
90
  const factory = new MarkListFactory();
113
91
  const queue = new ComposeQueue(baseMarkList, newMarkList, moveEffects, revisionMetadata);
114
92
  while (!queue.isEmpty()) {
115
93
  const { baseMark, newMark } = queue.pop();
116
- if (newMark === undefined) {
117
- assert(
118
- baseMark !== undefined,
119
- 0x4db /* Non-empty queue should not return two undefined marks */,
120
- );
121
- factory.push(
122
- composeMark(baseMark, moveEffects, (node: NodeId) =>
123
- composeChildChanges(node, undefined, composeChild),
124
- ),
125
- );
126
- } else {
127
- // We only compose changesets that will not be further rebased.
128
- // It is therefore safe to remove any intentions that have no impact in the context they apply to.
129
- const settledNewMark = settleMark(newMark);
130
- if (baseMark === undefined) {
131
- factory.push(
132
- composeMark(settledNewMark, moveEffects, (node: NodeId) =>
133
- composeChildChanges(undefined, node, composeChild),
134
- ),
135
- );
136
- } else {
137
- // Past this point, we are guaranteed that `settledNewMark` and `baseMark` have the same length and
138
- // start at the same location in the revision after the base changes.
139
- // They therefore refer to the same range for that revision.
140
- const settledBaseMark = settleMark(baseMark);
141
- const composedMark = composeMarks(
142
- settledBaseMark,
143
- settledNewMark,
144
- composeChild,
145
- moveEffects,
146
- );
147
- factory.push(composedMark);
148
- }
149
- }
94
+ const composedMark = composeMarks(baseMark, newMark, composeChild, moveEffects);
95
+ factory.push(composedMark);
150
96
  }
151
97
 
152
98
  return factory.list;
@@ -165,206 +111,77 @@ function composeMarks(
165
111
  baseMark: Mark,
166
112
  newMark: Mark,
167
113
  composeChild: NodeChangeComposer,
168
- moveEffects: MoveEffectTable,
114
+ moveEffects: ComposeNodeManager,
169
115
  ): Mark {
170
116
  const nodeChange = handleNodeChanges(baseMark, newMark, composeChild, moveEffects);
171
-
172
- return withUpdatedEndpoint(
173
- withNodeChange(composeMarksIgnoreChild(baseMark, newMark, moveEffects), nodeChange),
174
- baseMark.count,
175
- moveEffects,
176
- );
117
+ return withNodeChange(composeMarksIgnoreChild(baseMark, newMark, moveEffects), nodeChange);
177
118
  }
178
119
 
179
120
  function composeMarksIgnoreChild(
180
121
  baseMark: Mark,
181
122
  newMark: Mark,
182
- moveEffects: MoveEffectTable,
123
+ moveEffects: ComposeNodeManager,
183
124
  ): Mark {
184
125
  if (isNoopMark(baseMark)) {
185
126
  return newMark;
186
127
  } else if (isNoopMark(newMark)) {
187
- return baseMark;
128
+ return updateBaseMarkId(moveEffects, baseMark);
188
129
  }
189
130
 
190
131
  if (isRename(baseMark) && isRename(newMark)) {
132
+ if (areEqualChangeAtomIdOpts(baseMark.cellId, newMark.idOverride)) {
133
+ return createNoopMark(baseMark.count, undefined, baseMark.cellId);
134
+ }
191
135
  return { ...baseMark, idOverride: newMark.idOverride };
192
136
  } else if (isRename(baseMark)) {
137
+ assert(isAttach(newMark), 0x9f1 /* Unexpected mark type */);
193
138
  assert(
194
- isAttach(newMark) || isAttachAndDetachEffect(newMark),
195
- 0x9f1 /* Unexpected mark type */,
139
+ baseMark.cellId !== undefined && newMark.cellId !== undefined,
140
+ "Expected marks to target an empty cell",
196
141
  );
197
142
  return { ...newMark, cellId: baseMark.cellId };
198
143
  } else if (isRename(newMark)) {
199
- assert(
200
- isDetach(baseMark) || isAttachAndDetachEffect(baseMark),
201
- 0x9f2 /* Unexpected mark type */,
202
- );
203
- return isDetach(baseMark)
204
- ? { ...baseMark, idOverride: newMark.idOverride }
205
- : { ...baseMark, detach: { ...baseMark.detach, idOverride: newMark.idOverride } };
144
+ assert(isDetach(baseMark), 0x9f2 /* Unexpected mark type */);
145
+ return updateBaseMarkId(moveEffects, { ...baseMark, cellRename: newMark.idOverride });
206
146
  }
207
147
 
208
- if (isImpactfulCellRename(newMark)) {
209
- const newAttachAndDetach = asAttachAndDetach(newMark);
210
- assert(
211
- newAttachAndDetach.cellId !== undefined,
212
- 0x9f3 /* Impactful cell rename must target empty cell */,
148
+ if (!markHasCellEffect(baseMark)) {
149
+ assert(baseMark.type === "Insert", "Expected baseMark to be a pin");
150
+
151
+ // `newMark` can be either a remove or another pin.
152
+ // A pin is treated as a detach and attach, so we call `composeAttachDetach` in either case.
153
+ moveEffects.composeAttachDetach(
154
+ getAttachedRootId(baseMark),
155
+ {
156
+ revision: newMark.revision,
157
+ localId: newMark.id,
158
+ },
159
+ baseMark.count,
213
160
  );
214
- const newDetachRevision = newAttachAndDetach.detach.revision;
215
- if (markEmptiesCells(baseMark)) {
216
- // baseMark is a detach which cancels with the attach portion of the AttachAndDetach,
217
- // so we are just left with the detach portion of the AttachAndDetach.
218
- const newDetach: CellMark<Detach> = {
219
- ...newAttachAndDetach.detach,
220
- count: baseMark.count,
221
- };
222
-
223
- if (isMoveIn(newAttachAndDetach.attach) && isMoveOut(newAttachAndDetach.detach)) {
224
- assert(isMoveOut(baseMark), 0x808 /* Unexpected mark type */);
225
-
226
- // The base changeset and new changeset both move these nodes.
227
- // Call the original position of the nodes A, the position after the base changeset is applied B,
228
- // and the position after the new changeset is applied C.
229
- // The new changeset moves the nodes from B, temporarily returns them to A, and then moves them to C.
230
- // The composition of the base and new changesets will be a move directly from A to C,
231
- // since the move from A to B cancels out with the return from B to A.
232
- // This if-block is handling marks at A.
233
- // When we compose the marks at B we will link the start of the base move (A to B)
234
- // with the end of the new move (B to C).
235
- // Because we are replacing the mark representing the start of the move with the new changeset's
236
- // move-out from A, we update the base move-in at B to consider that its start point.
237
- const newDetachId = {
238
- revision: newDetachRevision,
239
- localId: newAttachAndDetach.detach.id,
240
- };
241
-
242
- setTruncatedEndpointForInner(
243
- moveEffects,
244
- CrossFieldTarget.Destination,
245
- getEndpoint(baseMark),
246
- baseMark.count,
247
- newDetachId,
248
- );
249
-
250
- const newEndpoint = getComposedEndpoint(
251
- moveEffects,
252
- CrossFieldTarget.Source,
253
- baseMark.revision,
254
- baseMark.id,
255
- baseMark.count,
256
- );
257
161
 
258
- if (newEndpoint !== undefined) {
259
- changeFinalEndpoint(newDetach as MoveMarkEffect, newEndpoint);
260
- setTruncatedEndpoint(
261
- moveEffects,
262
- CrossFieldTarget.Destination,
263
- newEndpoint,
264
- baseMark.count,
265
- newDetachId,
266
- );
162
+ const pinId = getAttachedRootId(baseMark);
163
+ return newMark.type === "Remove"
164
+ ? {
165
+ ...newMark,
166
+ detachCellId: baseMark.detachCellId ?? pinId,
167
+ cellRename: getDetachOutputCellId(newMark),
267
168
  }
268
- }
269
-
270
- return newDetach;
271
- }
272
-
273
- if (isImpactfulCellRename(baseMark)) {
274
- assert(
275
- baseMark.cellId !== undefined,
276
- 0x9f4 /* Impactful cell rename must target empty cell */,
277
- );
278
- const baseAttachAndDetach = asAttachAndDetach(baseMark);
279
- const newOutputId = getOutputCellId(newAttachAndDetach);
280
-
281
- const originalAttach = { ...baseAttachAndDetach.attach };
282
- const finalDetach = { ...newAttachAndDetach.detach };
283
-
284
- handleMovePivot(baseMark.count, originalAttach, finalDetach, moveEffects);
285
-
286
- if (areEqualCellIds(newOutputId, baseAttachAndDetach.cellId)) {
287
- return { count: baseAttachAndDetach.count, cellId: baseAttachAndDetach.cellId };
288
- }
289
-
290
- // `newMark`'s attach portion cancels with `baseMark`'s detach portion.
291
- const detachRevision = finalDetach.revision;
292
- if (detachRevision !== undefined) {
293
- finalDetach.revision = detachRevision;
294
- }
295
-
296
- return normalizeCellRename(baseMark.cellId, baseMark.count, originalAttach, finalDetach);
297
- }
298
-
299
- return normalizeCellRename(
300
- newAttachAndDetach.cellId,
301
- newAttachAndDetach.count,
302
- newAttachAndDetach.attach,
303
- newAttachAndDetach.detach,
304
- );
305
- }
306
- if (isImpactfulCellRename(baseMark)) {
307
- const baseAttachAndDetach = asAttachAndDetach(baseMark);
308
- if (markFillsCells(newMark)) {
309
- const originalAttach = withRevision(
310
- {
311
- ...baseAttachAndDetach.attach,
312
- cellId: baseAttachAndDetach.cellId,
313
- count: baseAttachAndDetach.count,
314
- },
315
- baseAttachAndDetach.attach.revision,
169
+ : newMark;
170
+ } else if (!markHasCellEffect(newMark)) {
171
+ if (isAttach(newMark) && isAttach(baseMark)) {
172
+ // When composing two inserts, the second insert (which is a pin) should take precedence.
173
+ // We treat the pin as a detach and reattach.
174
+ moveEffects.composeAttachDetach(
175
+ getAttachedRootId(baseMark),
176
+ getAttachedRootId(newMark),
177
+ baseMark.count,
316
178
  );
317
179
 
318
- if (isMoveIn(baseAttachAndDetach.attach) && isMoveOut(baseAttachAndDetach.detach)) {
319
- assert(isMoveIn(newMark), 0x809 /* Unexpected mark type */);
320
-
321
- const originalAttachId = {
322
- revision: baseAttachAndDetach.attach.revision,
323
- localId: baseAttachAndDetach.attach.id,
324
- };
325
-
326
- setTruncatedEndpointForInner(
327
- moveEffects,
328
- CrossFieldTarget.Source,
329
- getEndpoint(newMark),
330
- baseAttachAndDetach.count,
331
- originalAttachId,
332
- );
333
-
334
- const newEndpoint = getComposedEndpoint(
335
- moveEffects,
336
- CrossFieldTarget.Destination,
337
- newMark.revision,
338
- newMark.id,
339
- newMark.count,
340
- );
341
-
342
- if (newEndpoint !== undefined) {
343
- changeFinalEndpoint(originalAttach as MoveMarkEffect, newEndpoint);
344
- setTruncatedEndpoint(
345
- moveEffects,
346
- CrossFieldTarget.Source,
347
- newEndpoint,
348
- baseMark.count,
349
- originalAttachId,
350
- );
351
- }
352
- }
353
-
354
- return originalAttach;
355
- } else {
356
- // Other mark types have been handled by previous conditional branches.
357
- assert(newMark.type === NoopMarkType, 0x80a /* Unexpected mark type */);
358
- return baseMark;
180
+ const composed = { cellId: baseMark.cellId, ...newMark };
181
+ delete composed.detachCellId;
182
+ return composed;
359
183
  }
360
- }
361
-
362
- if (!markHasCellEffect(baseMark) && !markHasCellEffect(newMark)) {
363
- return createNoopMark(newMark.count, undefined, getInputCellId(baseMark));
364
- } else if (!markHasCellEffect(baseMark)) {
365
- return newMark;
366
- } else if (!markHasCellEffect(newMark)) {
367
- return baseMark;
184
+ return updateBaseMarkId(moveEffects, baseMark);
368
185
  } else if (areInputCellsEmpty(baseMark)) {
369
186
  assert(isDetach(newMark), 0x71c /* Unexpected mark type */);
370
187
  assert(isAttach(baseMark), 0x71d /* Expected generative mark */);
@@ -372,7 +189,11 @@ function composeMarksIgnoreChild(
372
189
  const attach = extractMarkEffect(baseMark);
373
190
  const detach = extractMarkEffect(newMark);
374
191
 
375
- handleMovePivot(baseMark.count, attach, detach, moveEffects);
192
+ moveEffects.composeAttachDetach(
193
+ getAttachedRootId(baseMark),
194
+ getDetachedRootId(newMark),
195
+ baseMark.count,
196
+ );
376
197
 
377
198
  if (areEqualCellIds(getOutputCellId(newMark), baseMark.cellId)) {
378
199
  // The output and input cell IDs are the same, so this mark has no effect.
@@ -380,74 +201,45 @@ function composeMarksIgnoreChild(
380
201
  }
381
202
  return normalizeCellRename(baseMark.cellId, baseMark.count, attach, detach);
382
203
  } else {
383
- const length = baseMark.count;
384
- return createNoopMark(length, undefined);
385
- }
386
- }
387
-
388
- /**
389
- * Checks if `baseAttach` and `newDetach` are both moves, and if so updates their move endpoints as appropriate,
390
- * and removes their `finalEndpoint` endpoint fields. Note that can mutate `baseAttach` and `newDetach`.
391
- * If the effects are not both moves this function does nothing.
392
- * @param count - The number of cells targeted
393
- * @param baseAttach - The base attach effect at this location
394
- * @param newDetach - The new detach effect at this location
395
- */
396
- function handleMovePivot(
397
- count: number,
398
- baseAttach: Attach,
399
- newDetach: Detach,
400
- moveEffects: MoveEffectTable,
401
- ): void {
402
- if (isMoveIn(baseAttach) && isMoveOut(newDetach)) {
403
- const finalSource = getEndpoint(baseAttach);
404
- const finalDest = getEndpoint(newDetach);
405
-
406
- setEndpoint(moveEffects, CrossFieldTarget.Source, finalSource, count, finalDest);
407
-
408
- const truncatedEndpoint1 = getTruncatedEndpointForInner(
409
- moveEffects,
410
- CrossFieldTarget.Destination,
411
- baseAttach.revision,
412
- baseAttach.id,
413
- count,
414
- );
415
-
416
- if (truncatedEndpoint1 !== undefined) {
417
- setTruncatedEndpoint(
418
- moveEffects,
419
- CrossFieldTarget.Destination,
420
- finalDest,
421
- count,
422
- truncatedEndpoint1,
423
- );
204
+ assert(baseMark.type === "Remove", "Unexpected mark type");
205
+ assert(newMark.type === "Insert", "Unexpected mark type");
206
+ const detachId = getDetachedRootId(baseMark);
207
+ const attachId = getAttachedRootId(newMark);
208
+
209
+ // Note that we cannot assert that this returns true,
210
+ // as it may not be until a second pass that MCF can tell that this is a reattach of the same node.
211
+ moveEffects.composeDetachAttach(detachId, attachId, baseMark.count, true);
212
+
213
+ // The composition has no net effect but we preserve the second change's intention to pin the nodes here.
214
+ const composedMark = { ...newMark };
215
+ delete composedMark.cellId;
216
+ const baseDetachCellId = baseMark.detachCellId ?? detachId;
217
+ if (!areEqualChangeAtomIds(baseDetachCellId, attachId)) {
218
+ composedMark.detachCellId = baseDetachCellId;
424
219
  }
425
220
 
426
- setEndpoint(moveEffects, CrossFieldTarget.Destination, finalDest, count, finalSource);
427
-
428
- const truncatedEndpoint2 = getTruncatedEndpointForInner(
429
- moveEffects,
430
- CrossFieldTarget.Source,
431
- newDetach.revision,
432
- newDetach.id,
433
- count,
434
- );
221
+ return composedMark;
222
+ }
223
+ }
435
224
 
436
- if (truncatedEndpoint2 !== undefined) {
437
- setTruncatedEndpoint(
438
- moveEffects,
439
- CrossFieldTarget.Source,
440
- finalSource,
441
- count,
442
- truncatedEndpoint2,
443
- );
225
+ function updateBaseMarkId(moveEffects: ComposeNodeManager, baseMark: Mark): Mark {
226
+ if (isDetach(baseMark)) {
227
+ const baseDetachId = getDetachedRootId(baseMark);
228
+ const updatedDetachId = getUpdatedDetachId(moveEffects, baseMark);
229
+ if (
230
+ updatedDetachId !== undefined &&
231
+ !areEqualChangeAtomIds(updatedDetachId, baseDetachId)
232
+ ) {
233
+ return {
234
+ ...baseMark,
235
+ revision: updatedDetachId.revision,
236
+ id: updatedDetachId.localId,
237
+ detachCellId: baseMark.detachCellId ?? baseDetachId,
238
+ };
444
239
  }
445
-
446
- // The `finalEndpoint` field of AttachAndDetach move effect pairs is not used,
447
- // so we remove it as a normalization.
448
- delete baseAttach.finalEndpoint;
449
- delete newDetach.finalEndpoint;
450
240
  }
241
+
242
+ return baseMark;
451
243
  }
452
244
 
453
245
  function createNoopMark(
@@ -470,18 +262,21 @@ function handleNodeChanges(
470
262
  baseMark: Mark,
471
263
  newMark: Mark,
472
264
  composeChild: NodeChangeComposer,
473
- moveEffects: MoveEffectTable,
265
+ moveEffects: ComposeNodeManager,
474
266
  ): NodeId | undefined {
475
- if (newMark.changes !== undefined) {
476
- const baseSource = getMoveIn(baseMark);
477
-
478
- // TODO: Make sure composeChild is not called twice on the node changes.
479
- if (baseSource !== undefined) {
480
- setModifyAfter(moveEffects, getEndpoint(baseSource), newMark.changes);
481
- return undefined;
482
- }
267
+ if (
268
+ newMark.changes !== undefined &&
269
+ baseMark.type === "Insert" &&
270
+ baseMark.cellId !== undefined
271
+ ) {
272
+ moveEffects.sendNewChangesToBaseSourceLocation(
273
+ getAttachedRootId(baseMark),
274
+ newMark.changes,
275
+ );
276
+ return undefined;
483
277
  }
484
278
 
279
+ // TODO: Make sure composeChild is not called twice on the node changes.
485
280
  return composeChildChanges(baseMark.changes, newMark.changes, composeChild);
486
281
  }
487
282
 
@@ -497,16 +292,6 @@ function composeChildChanges(
497
292
  return composeChild(baseChange, newChange);
498
293
  }
499
294
 
500
- function composeMark<TMark extends Mark>(
501
- mark: TMark,
502
- moveEffects: MoveEffectTable,
503
- composeChild: (node: NodeId) => NodeId | undefined,
504
- ): TMark {
505
- const nodeChanges = mark.changes === undefined ? undefined : composeChild(mark.changes);
506
- const updatedMark = withUpdatedEndpoint(mark, mark.count, moveEffects);
507
- return withNodeChange(updatedMark, nodeChanges);
508
- }
509
-
510
295
  export class ComposeQueue {
511
296
  private readonly baseMarks: MarkQueue;
512
297
  private readonly newMarks: MarkQueue;
@@ -516,11 +301,16 @@ export class ComposeQueue {
516
301
  public constructor(
517
302
  baseMarks: Changeset,
518
303
  newMarks: Changeset,
519
- private readonly moveEffects: MoveEffectTable,
304
+ private readonly moveEffects: ComposeNodeManager,
520
305
  private readonly revisionMetadata: RevisionMetadataSource,
521
306
  ) {
522
- this.baseMarks = new MarkQueue(baseMarks, moveEffects);
523
- this.newMarks = new MarkQueue(newMarks, moveEffects);
307
+ const queryFunc: NodeRangeQueryFunc = (mark) =>
308
+ isDetach(mark) || isPin(mark)
309
+ ? moveEffects.getNewChangesForBaseDetach(getMovedNodeId(mark), mark.count).length
310
+ : mark.count;
311
+
312
+ this.baseMarks = new MarkQueue(baseMarks, queryFunc);
313
+ this.newMarks = new MarkQueue(newMarks, (mark) => mark.count);
524
314
  this.baseMarksCellSources = cellSourcesFromMarks(baseMarks, getOutputCellId);
525
315
  this.newMarksCellSources = cellSourcesFromMarks(newMarks, getInputCellId);
526
316
  }
@@ -533,7 +323,7 @@ export class ComposeQueue {
533
323
  const baseMark = this.baseMarks.peek();
534
324
  const newMark = this.newMarks.peek();
535
325
  if (baseMark === undefined && newMark === undefined) {
536
- return {};
326
+ fail("Should not pop when queue is empty");
537
327
  } else if (baseMark === undefined) {
538
328
  return this.dequeueNew();
539
329
  } else if (newMark === undefined) {
@@ -589,10 +379,6 @@ export class ComposeQueue {
589
379
  private dequeueBase(length: number = Number.POSITIVE_INFINITY): ComposeMarks {
590
380
  const baseMark = this.baseMarks.dequeueUpTo(length);
591
381
  const movedChanges = getMovedChangesFromMark(this.moveEffects, baseMark);
592
- if (movedChanges !== undefined) {
593
- this.moveEffects.onMoveIn(movedChanges);
594
- }
595
-
596
382
  const newMark = createNoopMark(baseMark.count, movedChanges, getOutputCellId(baseMark));
597
383
  return { baseMark, newMark };
598
384
  }
@@ -637,195 +423,26 @@ export class ComposeQueue {
637
423
  }
638
424
 
639
425
  interface ComposeMarks {
640
- baseMark?: Mark;
641
- newMark?: Mark;
426
+ baseMark: Mark;
427
+ newMark: Mark;
642
428
  }
643
429
 
644
430
  function getMovedChangesFromMark(
645
- moveEffects: MoveEffectTable,
431
+ moveEffects: ComposeNodeManager,
646
432
  markEffect: MarkEffect,
647
433
  ): NodeId | undefined {
648
- if (isAttachAndDetachEffect(markEffect)) {
649
- return getMovedChangesFromMark(moveEffects, markEffect.detach);
650
- }
651
- if (!isMoveOut(markEffect)) {
434
+ if (!isDetach(markEffect)) {
652
435
  return undefined;
653
436
  }
654
437
 
655
- return getModifyAfter(moveEffects, markEffect.revision, markEffect.id);
656
- }
657
-
658
- // It is expected that the range from `id` to `id + count - 1` has the same move effect.
659
- // The call sites to this function are making queries about a mark which has already been split by a `MarkQueue`
660
- // to match the ranges in `moveEffects`.
661
- // TODO: Reduce the duplication between this and other MoveEffect helpers
662
- function getModifyAfter(
663
- moveEffects: MoveEffectTable,
664
- revision: RevisionTag | undefined,
665
- id: MoveId,
666
- ): NodeId | undefined {
667
- const target = CrossFieldTarget.Source;
668
- const effect = getMoveEffect(moveEffects, target, revision, id, 1);
669
-
670
- if (effect.value?.modifyAfter !== undefined) {
671
- return effect.value.modifyAfter;
672
- }
673
-
674
- return undefined;
675
- }
676
-
677
- // TODO: Reduce the duplication between this and other MoveEffect helpers
678
- function setModifyAfter(
679
- moveEffects: MoveEffectTable,
680
- { revision, localId: id }: ChangeAtomId,
681
- modifyAfter: NodeId,
682
- ): void {
683
- const target = CrossFieldTarget.Source;
684
- const count = 1;
685
- const effect = getMoveEffect(moveEffects, target, revision, id, count, false);
686
- const newEffect: MoveEffect =
687
- effect.value === undefined ? { modifyAfter } : { ...effect.value, modifyAfter };
688
- setMoveEffect(moveEffects, target, revision, id, count, newEffect);
689
- }
690
-
691
- function setEndpoint(
692
- moveEffects: MoveEffectTable,
693
- target: CrossFieldTarget,
694
- id: ChangeAtomId,
695
- count: number,
696
- endpoint: ChangeAtomId,
697
- ): void {
698
- const effect = getMoveEffect(moveEffects, target, id.revision, id.localId, count, false);
699
- const newEffect = effect.value === undefined ? { endpoint } : { ...effect.value, endpoint };
700
- setMoveEffect(moveEffects, target, id.revision, id.localId, effect.length, newEffect);
701
-
702
- const remainingCount = count - effect.length;
703
- if (remainingCount > 0) {
704
- setEndpoint(
705
- moveEffects,
706
- target,
707
- offsetChangeAtomId(id, effect.length),
708
- remainingCount,
709
- offsetChangeAtomId(endpoint, effect.length),
710
- );
711
- }
712
- }
713
-
714
- function setTruncatedEndpoint(
715
- moveEffects: MoveEffectTable,
716
- target: CrossFieldTarget,
717
- id: ChangeAtomId,
718
- count: number,
719
- truncatedEndpoint: ChangeAtomId,
720
- ): void {
721
- const effect = getMoveEffect(moveEffects, target, id.revision, id.localId, count);
722
- const newEffect =
723
- effect.value === undefined
724
- ? { truncatedEndpoint }
725
- : { ...effect.value, truncatedEndpoint };
726
-
727
- setMoveEffect(moveEffects, target, id.revision, id.localId, effect.length, newEffect);
728
-
729
- const remainingCount = count - effect.length;
730
- if (remainingCount > 0) {
731
- setTruncatedEndpoint(
732
- moveEffects,
733
- target,
734
- offsetChangeAtomId(id, effect.length),
735
- remainingCount,
736
- offsetChangeAtomId(truncatedEndpoint, effect.length),
737
- );
738
- }
739
- }
740
-
741
- function setTruncatedEndpointForInner(
742
- moveEffects: MoveEffectTable,
743
- target: CrossFieldTarget,
744
- id: ChangeAtomId,
745
- count: number,
746
- truncatedEndpointForInner: ChangeAtomId,
747
- ): void {
748
- const effect = getMoveEffect(moveEffects, target, id.revision, id.localId, count);
749
- const newEffect =
750
- effect.value === undefined
751
- ? { truncatedEndpointForInner }
752
- : { ...effect.value, truncatedEndpointForInner };
753
- setMoveEffect(moveEffects, target, id.revision, id.localId, effect.length, newEffect);
754
-
755
- const remainingCount = count - effect.length;
756
- if (remainingCount > 0) {
757
- setTruncatedEndpointForInner(
758
- moveEffects,
759
- target,
760
- offsetChangeAtomId(id, effect.length),
761
- remainingCount,
762
- offsetChangeAtomId(truncatedEndpointForInner, effect.length),
763
- );
764
- }
765
- }
766
-
767
- function withUpdatedEndpoint<TMark extends MarkEffect>(
768
- mark: TMark,
769
- count: number,
770
- effects: MoveEffectTable,
771
- ): TMark {
772
- if (isAttachAndDetachEffect(mark)) {
773
- return {
774
- ...mark,
775
- attach: withUpdatedEndpoint(mark.attach, count, effects),
776
- detach: withUpdatedEndpoint(mark.detach, count, effects),
777
- };
778
- }
779
-
780
- if (!isMoveMark(mark)) {
781
- return mark;
782
- }
783
- const finalDest = getComposedEndpoint(
784
- effects,
785
- getCrossFieldTargetFromMove(mark),
786
- mark.revision,
787
- mark.id,
788
- count,
789
- );
790
-
791
- if (finalDest === undefined) {
792
- return mark;
793
- }
794
-
795
- const output = { ...mark };
796
- changeFinalEndpoint(output, finalDest);
797
-
798
- return output;
799
- }
800
-
801
- function changeFinalEndpoint(mark: MoveMarkEffect, endpoint: ChangeAtomId): void {
802
- if (areEqualCellIds(endpoint, { revision: mark.revision, localId: mark.id })) {
803
- delete mark.finalEndpoint;
804
- } else {
805
- mark.finalEndpoint = endpoint;
806
- }
807
- }
808
-
809
- function getComposedEndpoint(
810
- moveEffects: MoveEffectTable,
811
- target: CrossFieldTarget,
812
- revision: RevisionTag | undefined,
813
- id: MoveId,
814
- count: number,
815
- ): ChangeAtomId | undefined {
816
- const effect = getMoveEffect(moveEffects, target, revision, id, count);
817
- assert(effect.length === count, 0x815 /* Expected effect to cover entire mark */);
818
- return effect.value?.truncatedEndpoint ?? effect.value?.endpoint;
438
+ return moveEffects.getNewChangesForBaseDetach(getDetachedRootId(markEffect), 1).value
439
+ ?.nodeChange;
819
440
  }
820
441
 
821
- function getTruncatedEndpointForInner(
822
- moveEffects: MoveEffectTable,
823
- target: CrossFieldTarget,
824
- revision: RevisionTag | undefined,
825
- id: MoveId,
826
- count: number,
442
+ function getUpdatedDetachId(
443
+ manager: ComposeNodeManager,
444
+ mark: CellMark<Detach>,
827
445
  ): ChangeAtomId | undefined {
828
- const effect = getMoveEffect(moveEffects, target, revision, id, count);
829
- assert(effect.length === count, 0x934 /* Expected effect to cover entire mark */);
830
- return effect.value?.truncatedEndpointForInner;
446
+ return manager.getNewChangesForBaseDetach(getDetachedRootId(mark), mark.count).value
447
+ ?.detachId;
831
448
  }