@fluid-experimental/tree 0.58.2002 → 0.58.3000-61081

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 (815) hide show
  1. package/README.md +9 -9
  2. package/dist/ChangeCompression.d.ts +39 -0
  3. package/dist/ChangeCompression.d.ts.map +1 -0
  4. package/dist/ChangeCompression.js +117 -0
  5. package/dist/ChangeCompression.js.map +1 -0
  6. package/{lib/default-edits/PersistedTypes.d.ts → dist/ChangeTypes.d.ts} +58 -100
  7. package/dist/ChangeTypes.d.ts.map +1 -0
  8. package/dist/{default-edits/PersistedTypes.js → ChangeTypes.js} +21 -76
  9. package/dist/ChangeTypes.js.map +1 -0
  10. package/dist/Checkout.d.ts +39 -27
  11. package/dist/Checkout.d.ts.map +1 -1
  12. package/dist/Checkout.js +59 -31
  13. package/dist/Checkout.js.map +1 -1
  14. package/dist/Common.d.ts +175 -38
  15. package/dist/Common.d.ts.map +1 -1
  16. package/dist/Common.js +240 -103
  17. package/dist/Common.js.map +1 -1
  18. package/dist/EagerCheckout.d.ts +24 -0
  19. package/dist/EagerCheckout.d.ts.map +1 -0
  20. package/dist/{BasicCheckout.js → EagerCheckout.js} +9 -6
  21. package/dist/EagerCheckout.js.map +1 -0
  22. package/dist/EditLog.d.ts +77 -63
  23. package/dist/EditLog.d.ts.map +1 -1
  24. package/dist/EditLog.js +85 -48
  25. package/dist/EditLog.js.map +1 -1
  26. package/dist/EditUtilities.d.ts +168 -0
  27. package/dist/EditUtilities.d.ts.map +1 -0
  28. package/dist/EditUtilities.js +373 -0
  29. package/dist/EditUtilities.js.map +1 -0
  30. package/dist/EventTypes.d.ts +73 -0
  31. package/dist/EventTypes.d.ts.map +1 -0
  32. package/dist/EventTypes.js +78 -0
  33. package/dist/EventTypes.js.map +1 -0
  34. package/dist/Forest.d.ts +29 -7
  35. package/dist/Forest.d.ts.map +1 -1
  36. package/dist/Forest.js +60 -36
  37. package/dist/Forest.js.map +1 -1
  38. package/dist/HistoryEditFactory.d.ts +20 -0
  39. package/dist/HistoryEditFactory.d.ts.map +1 -0
  40. package/dist/HistoryEditFactory.js +226 -0
  41. package/dist/HistoryEditFactory.js.map +1 -0
  42. package/dist/IdConversion.d.ts +12 -0
  43. package/dist/IdConversion.d.ts.map +1 -0
  44. package/dist/IdConversion.js +98 -0
  45. package/dist/IdConversion.js.map +1 -0
  46. package/dist/Identifiers.d.ts +89 -2
  47. package/dist/Identifiers.d.ts.map +1 -1
  48. package/dist/Identifiers.js +10 -0
  49. package/dist/Identifiers.js.map +1 -1
  50. package/dist/InitialTree.d.ts +2 -2
  51. package/dist/InitialTree.d.ts.map +1 -1
  52. package/dist/InitialTree.js +2 -1
  53. package/dist/InitialTree.js.map +1 -1
  54. package/dist/LazyCheckout.d.ts +28 -0
  55. package/dist/LazyCheckout.d.ts.map +1 -0
  56. package/dist/LazyCheckout.js +44 -0
  57. package/dist/LazyCheckout.js.map +1 -0
  58. package/dist/LogViewer.d.ts +130 -85
  59. package/dist/LogViewer.d.ts.map +1 -1
  60. package/dist/LogViewer.js +110 -85
  61. package/dist/LogViewer.js.map +1 -1
  62. package/dist/MergeHealth.d.ts +221 -0
  63. package/dist/MergeHealth.d.ts.map +1 -0
  64. package/dist/MergeHealth.js +263 -0
  65. package/dist/MergeHealth.js.map +1 -0
  66. package/dist/NodeIdUtilities.d.ts +90 -0
  67. package/dist/NodeIdUtilities.d.ts.map +1 -0
  68. package/dist/NodeIdUtilities.js +60 -0
  69. package/dist/NodeIdUtilities.js.map +1 -0
  70. package/dist/PayloadUtilities.d.ts +42 -0
  71. package/dist/PayloadUtilities.d.ts.map +1 -0
  72. package/dist/PayloadUtilities.js +114 -0
  73. package/dist/PayloadUtilities.js.map +1 -0
  74. package/dist/ReconciliationPath.d.ts +18 -13
  75. package/dist/ReconciliationPath.d.ts.map +1 -1
  76. package/dist/ReconciliationPath.js.map +1 -1
  77. package/dist/RevisionValueCache.d.ts +11 -2
  78. package/dist/RevisionValueCache.d.ts.map +1 -1
  79. package/dist/RevisionValueCache.js +2 -3
  80. package/dist/RevisionValueCache.js.map +1 -1
  81. package/dist/RevisionView.d.ts +83 -0
  82. package/dist/RevisionView.d.ts.map +1 -0
  83. package/dist/RevisionView.js +182 -0
  84. package/dist/RevisionView.js.map +1 -0
  85. package/dist/SerializationUtilities.d.ts +36 -0
  86. package/dist/SerializationUtilities.d.ts.map +1 -0
  87. package/dist/SerializationUtilities.js +102 -0
  88. package/dist/SerializationUtilities.js.map +1 -0
  89. package/dist/SharedTree.d.ts +400 -0
  90. package/dist/SharedTree.d.ts.map +1 -0
  91. package/dist/SharedTree.js +1064 -0
  92. package/dist/SharedTree.js.map +1 -0
  93. package/dist/SharedTreeEncoder.d.ts +102 -0
  94. package/dist/SharedTreeEncoder.d.ts.map +1 -0
  95. package/dist/SharedTreeEncoder.js +313 -0
  96. package/dist/SharedTreeEncoder.js.map +1 -0
  97. package/dist/StringInterner.d.ts +46 -0
  98. package/dist/StringInterner.d.ts.map +1 -0
  99. package/dist/StringInterner.js +61 -0
  100. package/dist/StringInterner.js.map +1 -0
  101. package/dist/Summary.d.ts +40 -0
  102. package/dist/Summary.d.ts.map +1 -0
  103. package/dist/Summary.js +23 -0
  104. package/dist/Summary.js.map +1 -0
  105. package/dist/SummaryBackCompatibility.d.ts +22 -22
  106. package/dist/SummaryBackCompatibility.d.ts.map +1 -1
  107. package/dist/SummaryBackCompatibility.js +30 -33
  108. package/dist/SummaryBackCompatibility.js.map +1 -1
  109. package/dist/SummaryTestUtilities.d.ts +31 -0
  110. package/dist/SummaryTestUtilities.d.ts.map +1 -0
  111. package/dist/SummaryTestUtilities.js +37 -0
  112. package/dist/SummaryTestUtilities.js.map +1 -0
  113. package/dist/Transaction.d.ts +53 -0
  114. package/dist/Transaction.d.ts.map +1 -0
  115. package/dist/Transaction.js +76 -0
  116. package/dist/Transaction.js.map +1 -0
  117. package/dist/TransactionInternal.d.ts +543 -0
  118. package/dist/TransactionInternal.d.ts.map +1 -0
  119. package/dist/TransactionInternal.js +622 -0
  120. package/dist/TransactionInternal.js.map +1 -0
  121. package/dist/TreeCompressor.d.ts +37 -0
  122. package/dist/TreeCompressor.d.ts.map +1 -0
  123. package/dist/TreeCompressor.js +132 -0
  124. package/dist/TreeCompressor.js.map +1 -0
  125. package/dist/TreeNodeHandle.d.ts +12 -18
  126. package/dist/TreeNodeHandle.d.ts.map +1 -1
  127. package/dist/TreeNodeHandle.js +13 -23
  128. package/dist/TreeNodeHandle.js.map +1 -1
  129. package/dist/TreeView.d.ts +166 -0
  130. package/dist/TreeView.d.ts.map +1 -0
  131. package/dist/TreeView.js +217 -0
  132. package/dist/TreeView.js.map +1 -0
  133. package/dist/TreeViewUtilities.d.ts +21 -0
  134. package/dist/TreeViewUtilities.d.ts.map +1 -0
  135. package/dist/TreeViewUtilities.js +77 -0
  136. package/dist/TreeViewUtilities.js.map +1 -0
  137. package/dist/{default-edits/UndoRedoHandler.d.ts → UndoRedoHandler.d.ts} +2 -2
  138. package/dist/UndoRedoHandler.d.ts.map +1 -0
  139. package/dist/{default-edits/UndoRedoHandler.js → UndoRedoHandler.js} +5 -9
  140. package/dist/UndoRedoHandler.js.map +1 -0
  141. package/dist/id-compressor/AppendOnlySortedMap.d.ts +127 -0
  142. package/dist/id-compressor/AppendOnlySortedMap.d.ts.map +1 -0
  143. package/dist/id-compressor/AppendOnlySortedMap.js +283 -0
  144. package/dist/id-compressor/AppendOnlySortedMap.js.map +1 -0
  145. package/dist/id-compressor/IdCompressor.d.ts +389 -0
  146. package/dist/id-compressor/IdCompressor.d.ts.map +1 -0
  147. package/dist/id-compressor/IdCompressor.js +1353 -0
  148. package/dist/id-compressor/IdCompressor.js.map +1 -0
  149. package/dist/id-compressor/IdRange.d.ts +11 -0
  150. package/dist/id-compressor/IdRange.d.ts.map +1 -0
  151. package/dist/id-compressor/IdRange.js +29 -0
  152. package/dist/id-compressor/IdRange.js.map +1 -0
  153. package/dist/id-compressor/NumericUuid.d.ts +63 -0
  154. package/dist/id-compressor/NumericUuid.d.ts.map +1 -0
  155. package/dist/id-compressor/NumericUuid.js +377 -0
  156. package/dist/id-compressor/NumericUuid.js.map +1 -0
  157. package/dist/id-compressor/index.d.ts +12 -0
  158. package/dist/id-compressor/index.d.ts.map +1 -0
  159. package/dist/id-compressor/index.js +26 -0
  160. package/dist/id-compressor/index.js.map +1 -0
  161. package/dist/id-compressor/persisted-types/0.0.1.d.ts +156 -0
  162. package/dist/id-compressor/persisted-types/0.0.1.d.ts.map +1 -0
  163. package/dist/id-compressor/persisted-types/0.0.1.js +7 -0
  164. package/dist/id-compressor/persisted-types/0.0.1.js.map +1 -0
  165. package/dist/id-compressor/persisted-types/index.d.ts +6 -0
  166. package/dist/id-compressor/persisted-types/index.d.ts.map +1 -0
  167. package/dist/id-compressor/persisted-types/index.js +18 -0
  168. package/dist/id-compressor/persisted-types/index.js.map +1 -0
  169. package/dist/index.d.ts +29 -9
  170. package/dist/index.d.ts.map +1 -1
  171. package/dist/index.js +50 -35
  172. package/dist/index.js.map +1 -1
  173. package/dist/persisted-types/0.0.2.d.ts +385 -0
  174. package/dist/persisted-types/0.0.2.d.ts.map +1 -0
  175. package/dist/persisted-types/0.0.2.js +113 -0
  176. package/dist/persisted-types/0.0.2.js.map +1 -0
  177. package/dist/persisted-types/0.1.1.d.ts +314 -0
  178. package/dist/persisted-types/0.1.1.d.ts.map +1 -0
  179. package/dist/persisted-types/0.1.1.js +153 -0
  180. package/dist/persisted-types/0.1.1.js.map +1 -0
  181. package/dist/persisted-types/index.d.ts +7 -0
  182. package/dist/persisted-types/index.d.ts.map +1 -0
  183. package/dist/persisted-types/index.js +20 -0
  184. package/dist/persisted-types/index.js.map +1 -0
  185. package/docs/0-1-1-Compression.md +228 -0
  186. package/docs/Breaking-Change-Migration.md +52 -0
  187. package/docs/Compression.md +2 -2
  188. package/docs/Telemetry.md +43 -0
  189. package/lib/ChangeCompression.d.ts +39 -0
  190. package/lib/ChangeCompression.d.ts.map +1 -0
  191. package/lib/ChangeCompression.js +111 -0
  192. package/lib/ChangeCompression.js.map +1 -0
  193. package/{dist/default-edits/PersistedTypes.d.ts → lib/ChangeTypes.d.ts} +58 -100
  194. package/lib/ChangeTypes.d.ts.map +1 -0
  195. package/lib/{default-edits/PersistedTypes.js → ChangeTypes.js} +15 -68
  196. package/lib/ChangeTypes.js.map +1 -0
  197. package/lib/Checkout.d.ts +39 -27
  198. package/lib/Checkout.d.ts.map +1 -1
  199. package/lib/Checkout.js +51 -23
  200. package/lib/Checkout.js.map +1 -1
  201. package/lib/Common.d.ts +175 -38
  202. package/lib/Common.d.ts.map +1 -1
  203. package/lib/Common.js +226 -101
  204. package/lib/Common.js.map +1 -1
  205. package/lib/EagerCheckout.d.ts +24 -0
  206. package/lib/EagerCheckout.d.ts.map +1 -0
  207. package/lib/{BasicCheckout.js → EagerCheckout.js} +7 -4
  208. package/lib/EagerCheckout.js.map +1 -0
  209. package/lib/EditLog.d.ts +77 -63
  210. package/lib/EditLog.d.ts.map +1 -1
  211. package/lib/EditLog.js +83 -47
  212. package/lib/EditLog.js.map +1 -1
  213. package/lib/EditUtilities.d.ts +168 -0
  214. package/lib/EditUtilities.d.ts.map +1 -0
  215. package/lib/EditUtilities.js +353 -0
  216. package/lib/EditUtilities.js.map +1 -0
  217. package/lib/EventTypes.d.ts +73 -0
  218. package/lib/EventTypes.d.ts.map +1 -0
  219. package/lib/EventTypes.js +75 -0
  220. package/lib/EventTypes.js.map +1 -0
  221. package/lib/Forest.d.ts +29 -7
  222. package/lib/Forest.d.ts.map +1 -1
  223. package/lib/Forest.js +58 -35
  224. package/lib/Forest.js.map +1 -1
  225. package/lib/HistoryEditFactory.d.ts +20 -0
  226. package/lib/HistoryEditFactory.d.ts.map +1 -0
  227. package/lib/{default-edits/HistoryEditFactory.js → HistoryEditFactory.js} +78 -39
  228. package/lib/HistoryEditFactory.js.map +1 -0
  229. package/lib/IdConversion.d.ts +12 -0
  230. package/lib/IdConversion.d.ts.map +1 -0
  231. package/lib/IdConversion.js +91 -0
  232. package/lib/IdConversion.js.map +1 -0
  233. package/lib/Identifiers.d.ts +89 -2
  234. package/lib/Identifiers.d.ts.map +1 -1
  235. package/lib/Identifiers.js +8 -1
  236. package/lib/Identifiers.js.map +1 -1
  237. package/lib/InitialTree.d.ts +2 -2
  238. package/lib/InitialTree.d.ts.map +1 -1
  239. package/lib/InitialTree.js +2 -1
  240. package/lib/InitialTree.js.map +1 -1
  241. package/lib/LazyCheckout.d.ts +28 -0
  242. package/lib/LazyCheckout.d.ts.map +1 -0
  243. package/lib/LazyCheckout.js +40 -0
  244. package/lib/LazyCheckout.js.map +1 -0
  245. package/lib/LogViewer.d.ts +130 -85
  246. package/lib/LogViewer.d.ts.map +1 -1
  247. package/lib/LogViewer.js +102 -77
  248. package/lib/LogViewer.js.map +1 -1
  249. package/lib/MergeHealth.d.ts +221 -0
  250. package/lib/MergeHealth.d.ts.map +1 -0
  251. package/lib/MergeHealth.js +258 -0
  252. package/lib/MergeHealth.js.map +1 -0
  253. package/lib/NodeIdUtilities.d.ts +90 -0
  254. package/lib/NodeIdUtilities.d.ts.map +1 -0
  255. package/lib/NodeIdUtilities.js +53 -0
  256. package/lib/NodeIdUtilities.js.map +1 -0
  257. package/lib/PayloadUtilities.d.ts +42 -0
  258. package/lib/PayloadUtilities.d.ts.map +1 -0
  259. package/lib/PayloadUtilities.js +110 -0
  260. package/lib/PayloadUtilities.js.map +1 -0
  261. package/lib/ReconciliationPath.d.ts +18 -13
  262. package/lib/ReconciliationPath.d.ts.map +1 -1
  263. package/lib/ReconciliationPath.js.map +1 -1
  264. package/lib/RevisionValueCache.d.ts +11 -2
  265. package/lib/RevisionValueCache.d.ts.map +1 -1
  266. package/lib/RevisionValueCache.js +2 -3
  267. package/lib/RevisionValueCache.js.map +1 -1
  268. package/lib/RevisionView.d.ts +83 -0
  269. package/lib/RevisionView.d.ts.map +1 -0
  270. package/lib/RevisionView.js +175 -0
  271. package/lib/RevisionView.js.map +1 -0
  272. package/lib/SerializationUtilities.d.ts +36 -0
  273. package/lib/SerializationUtilities.d.ts.map +1 -0
  274. package/lib/SerializationUtilities.js +95 -0
  275. package/lib/SerializationUtilities.js.map +1 -0
  276. package/lib/SharedTree.d.ts +400 -0
  277. package/lib/SharedTree.d.ts.map +1 -0
  278. package/lib/SharedTree.js +1059 -0
  279. package/lib/SharedTree.js.map +1 -0
  280. package/lib/SharedTreeEncoder.d.ts +102 -0
  281. package/lib/SharedTreeEncoder.d.ts.map +1 -0
  282. package/lib/SharedTreeEncoder.js +308 -0
  283. package/lib/SharedTreeEncoder.js.map +1 -0
  284. package/lib/StringInterner.d.ts +46 -0
  285. package/lib/StringInterner.d.ts.map +1 -0
  286. package/lib/StringInterner.js +57 -0
  287. package/lib/StringInterner.js.map +1 -0
  288. package/lib/Summary.d.ts +40 -0
  289. package/lib/Summary.d.ts.map +1 -0
  290. package/lib/Summary.js +19 -0
  291. package/lib/Summary.js.map +1 -0
  292. package/lib/SummaryBackCompatibility.d.ts +22 -22
  293. package/lib/SummaryBackCompatibility.d.ts.map +1 -1
  294. package/lib/SummaryBackCompatibility.js +29 -32
  295. package/lib/SummaryBackCompatibility.js.map +1 -1
  296. package/lib/SummaryTestUtilities.d.ts +31 -0
  297. package/lib/SummaryTestUtilities.d.ts.map +1 -0
  298. package/lib/SummaryTestUtilities.js +32 -0
  299. package/lib/SummaryTestUtilities.js.map +1 -0
  300. package/lib/Transaction.d.ts +53 -0
  301. package/lib/Transaction.d.ts.map +1 -0
  302. package/lib/Transaction.js +72 -0
  303. package/lib/Transaction.js.map +1 -0
  304. package/lib/TransactionInternal.d.ts +543 -0
  305. package/lib/TransactionInternal.d.ts.map +1 -0
  306. package/lib/TransactionInternal.js +618 -0
  307. package/lib/TransactionInternal.js.map +1 -0
  308. package/lib/TreeCompressor.d.ts +37 -0
  309. package/lib/TreeCompressor.d.ts.map +1 -0
  310. package/lib/TreeCompressor.js +128 -0
  311. package/lib/TreeCompressor.js.map +1 -0
  312. package/lib/TreeNodeHandle.d.ts +12 -18
  313. package/lib/TreeNodeHandle.d.ts.map +1 -1
  314. package/lib/TreeNodeHandle.js +14 -24
  315. package/lib/TreeNodeHandle.js.map +1 -1
  316. package/lib/TreeView.d.ts +166 -0
  317. package/lib/TreeView.d.ts.map +1 -0
  318. package/lib/TreeView.js +213 -0
  319. package/lib/TreeView.js.map +1 -0
  320. package/lib/TreeViewUtilities.d.ts +21 -0
  321. package/lib/TreeViewUtilities.d.ts.map +1 -0
  322. package/lib/TreeViewUtilities.js +71 -0
  323. package/lib/TreeViewUtilities.js.map +1 -0
  324. package/lib/{default-edits/UndoRedoHandler.d.ts → UndoRedoHandler.d.ts} +2 -2
  325. package/lib/UndoRedoHandler.d.ts.map +1 -0
  326. package/lib/{default-edits/UndoRedoHandler.js → UndoRedoHandler.js} +3 -7
  327. package/lib/UndoRedoHandler.js.map +1 -0
  328. package/lib/id-compressor/AppendOnlySortedMap.d.ts +127 -0
  329. package/lib/id-compressor/AppendOnlySortedMap.d.ts.map +1 -0
  330. package/lib/id-compressor/AppendOnlySortedMap.js +278 -0
  331. package/lib/id-compressor/AppendOnlySortedMap.js.map +1 -0
  332. package/lib/id-compressor/IdCompressor.d.ts +389 -0
  333. package/lib/id-compressor/IdCompressor.d.ts.map +1 -0
  334. package/lib/id-compressor/IdCompressor.js +1343 -0
  335. package/lib/id-compressor/IdCompressor.js.map +1 -0
  336. package/lib/id-compressor/IdRange.d.ts +11 -0
  337. package/lib/id-compressor/IdRange.d.ts.map +1 -0
  338. package/lib/id-compressor/IdRange.js +25 -0
  339. package/lib/id-compressor/IdRange.js.map +1 -0
  340. package/lib/id-compressor/NumericUuid.d.ts +63 -0
  341. package/lib/id-compressor/NumericUuid.d.ts.map +1 -0
  342. package/lib/id-compressor/NumericUuid.js +365 -0
  343. package/lib/id-compressor/NumericUuid.js.map +1 -0
  344. package/lib/id-compressor/index.d.ts +12 -0
  345. package/lib/id-compressor/index.d.ts.map +1 -0
  346. package/lib/id-compressor/index.js +12 -0
  347. package/lib/id-compressor/index.js.map +1 -0
  348. package/lib/id-compressor/persisted-types/0.0.1.d.ts +156 -0
  349. package/lib/id-compressor/persisted-types/0.0.1.d.ts.map +1 -0
  350. package/lib/{test/Snapshot.tests.d.ts → id-compressor/persisted-types/0.0.1.js} +1 -1
  351. package/lib/id-compressor/persisted-types/0.0.1.js.map +1 -0
  352. package/lib/id-compressor/persisted-types/index.d.ts +6 -0
  353. package/lib/id-compressor/persisted-types/index.d.ts.map +1 -0
  354. package/lib/id-compressor/persisted-types/index.js +6 -0
  355. package/lib/id-compressor/persisted-types/index.js.map +1 -0
  356. package/lib/index.d.ts +29 -9
  357. package/lib/index.d.ts.map +1 -1
  358. package/lib/index.js +23 -6
  359. package/lib/index.js.map +1 -1
  360. package/lib/persisted-types/0.0.2.d.ts +385 -0
  361. package/lib/persisted-types/0.0.2.d.ts.map +1 -0
  362. package/lib/persisted-types/0.0.2.js +110 -0
  363. package/lib/persisted-types/0.0.2.js.map +1 -0
  364. package/lib/persisted-types/0.1.1.d.ts +314 -0
  365. package/lib/persisted-types/0.1.1.d.ts.map +1 -0
  366. package/lib/persisted-types/0.1.1.js +150 -0
  367. package/lib/persisted-types/0.1.1.js.map +1 -0
  368. package/lib/persisted-types/index.d.ts +7 -0
  369. package/lib/persisted-types/index.d.ts.map +1 -0
  370. package/lib/persisted-types/index.js +8 -0
  371. package/lib/persisted-types/index.js.map +1 -0
  372. package/lib/test/AppendOnlySortedMap.tests.d.ts +6 -0
  373. package/lib/test/AppendOnlySortedMap.tests.d.ts.map +1 -0
  374. package/lib/test/AppendOnlySortedMap.tests.js +169 -0
  375. package/lib/test/AppendOnlySortedMap.tests.js.map +1 -0
  376. package/lib/test/{SnapshotUtilities.tests.d.ts → ChangeCompression.tests.d.ts} +1 -1
  377. package/lib/test/ChangeCompression.tests.d.ts.map +1 -0
  378. package/lib/test/ChangeCompression.tests.js +145 -0
  379. package/lib/test/ChangeCompression.tests.js.map +1 -0
  380. package/lib/test/Checkout.tests.d.ts +2 -3
  381. package/lib/test/Checkout.tests.d.ts.map +1 -1
  382. package/lib/test/Checkout.tests.js +126 -69
  383. package/lib/test/Checkout.tests.js.map +1 -1
  384. package/lib/test/Common.tests.js +60 -2
  385. package/lib/test/Common.tests.js.map +1 -1
  386. package/lib/test/{BasicCheckout.tests.d.ts → EagerCheckout.tests.d.ts} +1 -1
  387. package/lib/test/EagerCheckout.tests.d.ts.map +1 -0
  388. package/lib/test/EagerCheckout.tests.js +20 -0
  389. package/lib/test/EagerCheckout.tests.js.map +1 -0
  390. package/lib/test/Edit.tests.js +22 -14
  391. package/lib/test/Edit.tests.js.map +1 -1
  392. package/lib/test/{Anchors.glassBox.tests.d.ts → EditLog.perf.tests.d.ts} +1 -1
  393. package/lib/test/EditLog.perf.tests.d.ts.map +1 -0
  394. package/lib/test/EditLog.perf.tests.js +30 -0
  395. package/lib/test/EditLog.perf.tests.js.map +1 -0
  396. package/lib/test/EditLog.tests.js +10 -6
  397. package/lib/test/EditLog.tests.js.map +1 -1
  398. package/lib/test/EditUtilities.tests.d.ts +6 -0
  399. package/lib/test/EditUtilities.tests.d.ts.map +1 -0
  400. package/lib/test/EditUtilities.tests.js +503 -0
  401. package/lib/test/EditUtilities.tests.js.map +1 -0
  402. package/lib/test/Forest.perf.tests.d.ts +6 -0
  403. package/lib/test/Forest.perf.tests.d.ts.map +1 -0
  404. package/lib/test/Forest.perf.tests.js +133 -0
  405. package/lib/test/Forest.perf.tests.js.map +1 -0
  406. package/lib/test/Forest.tests.js +54 -27
  407. package/lib/test/Forest.tests.js.map +1 -1
  408. package/lib/test/GenericTransaction.tests.js +12 -3
  409. package/lib/test/GenericTransaction.tests.js.map +1 -1
  410. package/lib/test/HistoryEditFactory.tests.d.ts +6 -0
  411. package/lib/test/HistoryEditFactory.tests.d.ts.map +1 -0
  412. package/lib/test/HistoryEditFactory.tests.js +90 -0
  413. package/lib/test/HistoryEditFactory.tests.js.map +1 -0
  414. package/lib/test/IdCompressor.perf.tests.d.ts +6 -0
  415. package/lib/test/IdCompressor.perf.tests.d.ts.map +1 -0
  416. package/lib/test/IdCompressor.perf.tests.js +304 -0
  417. package/lib/test/IdCompressor.perf.tests.js.map +1 -0
  418. package/lib/test/IdCompressor.tests.d.ts +6 -0
  419. package/lib/test/IdCompressor.tests.d.ts.map +1 -0
  420. package/lib/test/IdCompressor.tests.js +1075 -0
  421. package/lib/test/IdCompressor.tests.js.map +1 -0
  422. package/lib/test/IdConversion.tests.d.ts +6 -0
  423. package/lib/test/IdConversion.tests.d.ts.map +1 -0
  424. package/lib/test/IdConversion.tests.js +36 -0
  425. package/lib/test/IdConversion.tests.js.map +1 -0
  426. package/lib/test/LazyCheckout.tests.d.ts +6 -0
  427. package/lib/test/LazyCheckout.tests.d.ts.map +1 -0
  428. package/lib/test/LazyCheckout.tests.js +22 -0
  429. package/lib/test/LazyCheckout.tests.js.map +1 -0
  430. package/lib/test/LogViewer.tests.js +269 -187
  431. package/lib/test/LogViewer.tests.js.map +1 -1
  432. package/lib/test/{SharedTreeWithAnchors.tests.d.ts → MergeHealthTelemetryHeartbeat.tests.d.ts} +1 -1
  433. package/lib/test/MergeHealthTelemetryHeartbeat.tests.d.ts.map +1 -0
  434. package/lib/test/MergeHealthTelemetryHeartbeat.tests.js +342 -0
  435. package/lib/test/MergeHealthTelemetryHeartbeat.tests.js.map +1 -0
  436. package/lib/test/NumericUuid.perf.tests.d.ts +6 -0
  437. package/lib/test/NumericUuid.perf.tests.d.ts.map +1 -0
  438. package/lib/test/NumericUuid.perf.tests.js +68 -0
  439. package/lib/test/NumericUuid.perf.tests.js.map +1 -0
  440. package/lib/test/NumericUuid.tests.d.ts +6 -0
  441. package/lib/test/NumericUuid.tests.d.ts.map +1 -0
  442. package/lib/test/NumericUuid.tests.js +191 -0
  443. package/lib/test/NumericUuid.tests.js.map +1 -0
  444. package/lib/test/RevisionView.tests.d.ts +6 -0
  445. package/lib/test/RevisionView.tests.d.ts.map +1 -0
  446. package/lib/test/RevisionView.tests.js +133 -0
  447. package/lib/test/RevisionView.tests.js.map +1 -0
  448. package/lib/test/SharedTree.perf.tests.d.ts +6 -0
  449. package/lib/test/SharedTree.perf.tests.d.ts.map +1 -0
  450. package/lib/test/SharedTree.perf.tests.js +39 -0
  451. package/lib/test/SharedTree.perf.tests.js.map +1 -0
  452. package/lib/test/SharedTree.tests.js +15 -3
  453. package/lib/test/SharedTree.tests.js.map +1 -1
  454. package/lib/test/StringInterner.tests.d.ts +6 -0
  455. package/lib/test/StringInterner.tests.d.ts.map +1 -0
  456. package/lib/test/StringInterner.tests.js +71 -0
  457. package/lib/test/StringInterner.tests.js.map +1 -0
  458. package/lib/test/Summary.tests.d.ts +8 -0
  459. package/lib/test/Summary.tests.d.ts.map +1 -0
  460. package/lib/test/Summary.tests.js +407 -0
  461. package/lib/test/Summary.tests.js.map +1 -0
  462. package/lib/test/Transaction.tests.js +76 -330
  463. package/lib/test/Transaction.tests.js.map +1 -1
  464. package/lib/test/TransactionInternal.tests.d.ts +6 -0
  465. package/lib/test/TransactionInternal.tests.d.ts.map +1 -0
  466. package/lib/test/TransactionInternal.tests.js +568 -0
  467. package/lib/test/TransactionInternal.tests.js.map +1 -0
  468. package/lib/test/TreeCompression.tests.d.ts +6 -0
  469. package/lib/test/TreeCompression.tests.d.ts.map +1 -0
  470. package/lib/test/TreeCompression.tests.js +292 -0
  471. package/lib/test/TreeCompression.tests.js.map +1 -0
  472. package/lib/test/TreeView.tests.d.ts +6 -0
  473. package/lib/test/TreeView.tests.d.ts.map +1 -0
  474. package/lib/test/TreeView.tests.js +147 -0
  475. package/lib/test/TreeView.tests.js.map +1 -0
  476. package/lib/test/UndoRedoHandler.tests.js +2 -2
  477. package/lib/test/UndoRedoHandler.tests.js.map +1 -1
  478. package/lib/test/Virtualization.tests.js +147 -62
  479. package/lib/test/Virtualization.tests.js.map +1 -1
  480. package/lib/test/fuzz/Generators.d.ts +19 -0
  481. package/lib/test/fuzz/Generators.d.ts.map +1 -0
  482. package/lib/test/fuzz/Generators.js +420 -0
  483. package/lib/test/fuzz/Generators.js.map +1 -0
  484. package/lib/test/fuzz/SharedTreeFuzzTests.d.ts +20 -0
  485. package/lib/test/fuzz/SharedTreeFuzzTests.d.ts.map +1 -0
  486. package/lib/test/fuzz/SharedTreeFuzzTests.js +200 -0
  487. package/lib/test/fuzz/SharedTreeFuzzTests.js.map +1 -0
  488. package/lib/test/fuzz/Types.d.ts +133 -0
  489. package/lib/test/fuzz/Types.d.ts.map +1 -0
  490. package/lib/test/{GenericTransactionWithAnchors.tests.d.ts → fuzz/Types.js} +2 -2
  491. package/lib/test/fuzz/Types.js.map +1 -0
  492. package/lib/test/utilities/IdCompressorTestUtilities.d.ts +180 -0
  493. package/lib/test/utilities/IdCompressorTestUtilities.d.ts.map +1 -0
  494. package/lib/test/utilities/IdCompressorTestUtilities.js +528 -0
  495. package/lib/test/utilities/IdCompressorTestUtilities.js.map +1 -0
  496. package/lib/test/utilities/MockTransaction.d.ts +26 -7
  497. package/lib/test/utilities/MockTransaction.d.ts.map +1 -1
  498. package/lib/test/utilities/MockTransaction.js +40 -11
  499. package/lib/test/utilities/MockTransaction.js.map +1 -1
  500. package/lib/test/utilities/PendingLocalStateTests.d.ts +12 -0
  501. package/lib/test/utilities/PendingLocalStateTests.d.ts.map +1 -0
  502. package/lib/test/utilities/PendingLocalStateTests.js +105 -0
  503. package/lib/test/utilities/PendingLocalStateTests.js.map +1 -0
  504. package/lib/test/utilities/SharedTreeTests.d.ts +3 -4
  505. package/lib/test/utilities/SharedTreeTests.d.ts.map +1 -1
  506. package/lib/test/utilities/SharedTreeTests.js +696 -439
  507. package/lib/test/utilities/SharedTreeTests.js.map +1 -1
  508. package/lib/test/utilities/SharedTreeVersioningTests.d.ts +11 -0
  509. package/lib/test/utilities/SharedTreeVersioningTests.d.ts.map +1 -0
  510. package/lib/test/utilities/SharedTreeVersioningTests.js +345 -0
  511. package/lib/test/utilities/SharedTreeVersioningTests.js.map +1 -0
  512. package/lib/test/utilities/SummaryLoadPerfTests.d.ts +10 -0
  513. package/lib/test/utilities/SummaryLoadPerfTests.d.ts.map +1 -0
  514. package/lib/test/utilities/SummaryLoadPerfTests.js +102 -0
  515. package/lib/test/utilities/SummaryLoadPerfTests.js.map +1 -0
  516. package/lib/test/utilities/SummarySizeTests.d.ts +11 -0
  517. package/lib/test/utilities/SummarySizeTests.d.ts.map +1 -0
  518. package/lib/test/utilities/SummarySizeTests.js +158 -0
  519. package/lib/test/utilities/SummarySizeTests.js.map +1 -0
  520. package/lib/test/utilities/TestCommon.d.ts +9 -0
  521. package/lib/test/utilities/TestCommon.d.ts.map +1 -0
  522. package/lib/test/utilities/TestCommon.js +13 -0
  523. package/lib/test/utilities/TestCommon.js.map +1 -0
  524. package/lib/test/utilities/TestNode.d.ts +140 -0
  525. package/lib/test/utilities/TestNode.d.ts.map +1 -0
  526. package/lib/test/utilities/TestNode.js +292 -0
  527. package/lib/test/utilities/TestNode.js.map +1 -0
  528. package/lib/test/utilities/TestUtilities.d.ts +84 -70
  529. package/lib/test/utilities/TestUtilities.d.ts.map +1 -1
  530. package/lib/test/utilities/TestUtilities.js +218 -143
  531. package/lib/test/utilities/TestUtilities.js.map +1 -1
  532. package/lib/test/utilities/UndoRedoTests.d.ts +4 -5
  533. package/lib/test/utilities/UndoRedoTests.d.ts.map +1 -1
  534. package/lib/test/utilities/UndoRedoTests.js +138 -149
  535. package/lib/test/utilities/UndoRedoTests.js.map +1 -1
  536. package/package.json +19 -14
  537. package/src/ChangeCompression.ts +159 -0
  538. package/src/{default-edits/PersistedTypes.ts → ChangeTypes.ts} +62 -120
  539. package/src/Checkout.ts +81 -52
  540. package/src/Common.ts +317 -117
  541. package/src/EagerCheckout.ts +38 -0
  542. package/src/EditLog.ts +153 -100
  543. package/src/EditUtilities.ts +559 -0
  544. package/src/EventTypes.ts +74 -0
  545. package/src/Forest.ts +81 -73
  546. package/src/{default-edits/HistoryEditFactory.ts → HistoryEditFactory.ts} +103 -53
  547. package/src/IdConversion.ts +125 -0
  548. package/src/Identifiers.ts +101 -1
  549. package/src/InitialTree.ts +5 -4
  550. package/src/LazyCheckout.ts +51 -0
  551. package/src/LogViewer.ts +242 -166
  552. package/src/MergeHealth.ts +447 -0
  553. package/src/NodeIdUtilities.ts +141 -0
  554. package/src/PayloadUtilities.ts +124 -0
  555. package/src/ReconciliationPath.ts +18 -13
  556. package/src/RevisionValueCache.ts +14 -5
  557. package/src/RevisionView.ts +252 -0
  558. package/src/SerializationUtilities.ts +130 -0
  559. package/src/SharedTree.ts +1448 -0
  560. package/src/SharedTreeEncoder.ts +493 -0
  561. package/src/StringInterner.ts +72 -0
  562. package/src/Summary.ts +48 -0
  563. package/src/SummaryBackCompatibility.ts +47 -57
  564. package/src/SummaryTestUtilities.ts +54 -0
  565. package/src/Transaction.ts +94 -0
  566. package/src/TransactionInternal.ts +1088 -0
  567. package/src/TreeCompressor.ts +222 -0
  568. package/src/TreeNodeHandle.ts +19 -32
  569. package/src/TreeView.ts +321 -0
  570. package/src/TreeViewUtilities.ts +77 -0
  571. package/src/{default-edits/UndoRedoHandler.ts → UndoRedoHandler.ts} +8 -13
  572. package/src/id-compressor/AppendOnlySortedMap.ts +325 -0
  573. package/src/id-compressor/IdCompressor.md +3 -0
  574. package/src/id-compressor/IdCompressor.ts +1848 -0
  575. package/src/id-compressor/IdRange.ts +33 -0
  576. package/src/id-compressor/NumericUuid.ts +414 -0
  577. package/src/id-compressor/index.ts +13 -0
  578. package/src/id-compressor/persisted-types/0.0.1.ts +179 -0
  579. package/src/id-compressor/persisted-types/README.md +3 -0
  580. package/src/id-compressor/persisted-types/index.ts +6 -0
  581. package/src/index.ts +119 -59
  582. package/src/persisted-types/0.0.2.ts +442 -0
  583. package/src/persisted-types/0.1.1.ts +476 -0
  584. package/src/persisted-types/README.md +22 -0
  585. package/src/persisted-types/index.ts +9 -0
  586. package/.mocharc.js +0 -41
  587. package/api/tree.api.md +0 -729
  588. package/dist/BasicCheckout.d.ts +0 -23
  589. package/dist/BasicCheckout.d.ts.map +0 -1
  590. package/dist/BasicCheckout.js.map +0 -1
  591. package/dist/Snapshot.d.ts +0 -198
  592. package/dist/Snapshot.d.ts.map +0 -1
  593. package/dist/Snapshot.js +0 -267
  594. package/dist/Snapshot.js.map +0 -1
  595. package/dist/SnapshotUtilities.d.ts +0 -29
  596. package/dist/SnapshotUtilities.d.ts.map +0 -1
  597. package/dist/SnapshotUtilities.js +0 -73
  598. package/dist/SnapshotUtilities.js.map +0 -1
  599. package/dist/anchored-edits/AnchorResolution.d.ts +0 -144
  600. package/dist/anchored-edits/AnchorResolution.d.ts.map +0 -1
  601. package/dist/anchored-edits/AnchorResolution.js +0 -162
  602. package/dist/anchored-edits/AnchorResolution.js.map +0 -1
  603. package/dist/anchored-edits/Factory.d.ts +0 -56
  604. package/dist/anchored-edits/Factory.d.ts.map +0 -1
  605. package/dist/anchored-edits/Factory.js +0 -79
  606. package/dist/anchored-edits/Factory.js.map +0 -1
  607. package/dist/anchored-edits/PersistedTypes.d.ts +0 -245
  608. package/dist/anchored-edits/PersistedTypes.d.ts.map +0 -1
  609. package/dist/anchored-edits/PersistedTypes.js +0 -131
  610. package/dist/anchored-edits/PersistedTypes.js.map +0 -1
  611. package/dist/anchored-edits/SharedTreeWithAnchors.d.ts +0 -120
  612. package/dist/anchored-edits/SharedTreeWithAnchors.d.ts.map +0 -1
  613. package/dist/anchored-edits/SharedTreeWithAnchors.js +0 -115
  614. package/dist/anchored-edits/SharedTreeWithAnchors.js.map +0 -1
  615. package/dist/anchored-edits/TransactionWithAnchors.d.ts +0 -28
  616. package/dist/anchored-edits/TransactionWithAnchors.d.ts.map +0 -1
  617. package/dist/anchored-edits/TransactionWithAnchors.js +0 -36
  618. package/dist/anchored-edits/TransactionWithAnchors.js.map +0 -1
  619. package/dist/anchored-edits/index.d.ts +0 -10
  620. package/dist/anchored-edits/index.d.ts.map +0 -1
  621. package/dist/anchored-edits/index.js +0 -34
  622. package/dist/anchored-edits/index.js.map +0 -1
  623. package/dist/default-edits/EditUtilities.d.ts +0 -57
  624. package/dist/default-edits/EditUtilities.d.ts.map +0 -1
  625. package/dist/default-edits/EditUtilities.js +0 -192
  626. package/dist/default-edits/EditUtilities.js.map +0 -1
  627. package/dist/default-edits/Factory.d.ts +0 -56
  628. package/dist/default-edits/Factory.d.ts.map +0 -1
  629. package/dist/default-edits/Factory.js +0 -79
  630. package/dist/default-edits/Factory.js.map +0 -1
  631. package/dist/default-edits/HistoryEditFactory.d.ts +0 -19
  632. package/dist/default-edits/HistoryEditFactory.d.ts.map +0 -1
  633. package/dist/default-edits/HistoryEditFactory.js +0 -187
  634. package/dist/default-edits/HistoryEditFactory.js.map +0 -1
  635. package/dist/default-edits/PersistedTypes.d.ts.map +0 -1
  636. package/dist/default-edits/PersistedTypes.js.map +0 -1
  637. package/dist/default-edits/SharedTree.d.ts +0 -111
  638. package/dist/default-edits/SharedTree.d.ts.map +0 -1
  639. package/dist/default-edits/SharedTree.js +0 -124
  640. package/dist/default-edits/SharedTree.js.map +0 -1
  641. package/dist/default-edits/Summary.d.ts +0 -15
  642. package/dist/default-edits/Summary.d.ts.map +0 -1
  643. package/dist/default-edits/Summary.js +0 -35
  644. package/dist/default-edits/Summary.js.map +0 -1
  645. package/dist/default-edits/Transaction.d.ts +0 -41
  646. package/dist/default-edits/Transaction.d.ts.map +0 -1
  647. package/dist/default-edits/Transaction.js +0 -225
  648. package/dist/default-edits/Transaction.js.map +0 -1
  649. package/dist/default-edits/UndoRedoHandler.d.ts.map +0 -1
  650. package/dist/default-edits/UndoRedoHandler.js.map +0 -1
  651. package/dist/default-edits/index.d.ts +0 -13
  652. package/dist/default-edits/index.d.ts.map +0 -1
  653. package/dist/default-edits/index.js +0 -41
  654. package/dist/default-edits/index.js.map +0 -1
  655. package/dist/generic/GenericEditUtilities.d.ts +0 -26
  656. package/dist/generic/GenericEditUtilities.d.ts.map +0 -1
  657. package/dist/generic/GenericEditUtilities.js +0 -45
  658. package/dist/generic/GenericEditUtilities.js.map +0 -1
  659. package/dist/generic/GenericSharedTree.d.ts +0 -221
  660. package/dist/generic/GenericSharedTree.d.ts.map +0 -1
  661. package/dist/generic/GenericSharedTree.js +0 -447
  662. package/dist/generic/GenericSharedTree.js.map +0 -1
  663. package/dist/generic/GenericTransaction.d.ts +0 -87
  664. package/dist/generic/GenericTransaction.d.ts.map +0 -1
  665. package/dist/generic/GenericTransaction.js +0 -144
  666. package/dist/generic/GenericTransaction.js.map +0 -1
  667. package/dist/generic/PersistedTypes.d.ts +0 -194
  668. package/dist/generic/PersistedTypes.d.ts.map +0 -1
  669. package/dist/generic/PersistedTypes.js +0 -42
  670. package/dist/generic/PersistedTypes.js.map +0 -1
  671. package/dist/generic/Summary.d.ts +0 -63
  672. package/dist/generic/Summary.d.ts.map +0 -1
  673. package/dist/generic/Summary.js +0 -64
  674. package/dist/generic/Summary.js.map +0 -1
  675. package/dist/generic/index.d.ts +0 -10
  676. package/dist/generic/index.d.ts.map +0 -1
  677. package/dist/generic/index.js +0 -26
  678. package/dist/generic/index.js.map +0 -1
  679. package/lib/BasicCheckout.d.ts +0 -23
  680. package/lib/BasicCheckout.d.ts.map +0 -1
  681. package/lib/BasicCheckout.js.map +0 -1
  682. package/lib/Snapshot.d.ts +0 -198
  683. package/lib/Snapshot.d.ts.map +0 -1
  684. package/lib/Snapshot.js +0 -263
  685. package/lib/Snapshot.js.map +0 -1
  686. package/lib/SnapshotUtilities.d.ts +0 -29
  687. package/lib/SnapshotUtilities.d.ts.map +0 -1
  688. package/lib/SnapshotUtilities.js +0 -67
  689. package/lib/SnapshotUtilities.js.map +0 -1
  690. package/lib/anchored-edits/AnchorResolution.d.ts +0 -144
  691. package/lib/anchored-edits/AnchorResolution.d.ts.map +0 -1
  692. package/lib/anchored-edits/AnchorResolution.js +0 -152
  693. package/lib/anchored-edits/AnchorResolution.js.map +0 -1
  694. package/lib/anchored-edits/Factory.d.ts +0 -56
  695. package/lib/anchored-edits/Factory.d.ts.map +0 -1
  696. package/lib/anchored-edits/Factory.js +0 -74
  697. package/lib/anchored-edits/Factory.js.map +0 -1
  698. package/lib/anchored-edits/PersistedTypes.d.ts +0 -245
  699. package/lib/anchored-edits/PersistedTypes.d.ts.map +0 -1
  700. package/lib/anchored-edits/PersistedTypes.js +0 -128
  701. package/lib/anchored-edits/PersistedTypes.js.map +0 -1
  702. package/lib/anchored-edits/SharedTreeWithAnchors.d.ts +0 -120
  703. package/lib/anchored-edits/SharedTreeWithAnchors.d.ts.map +0 -1
  704. package/lib/anchored-edits/SharedTreeWithAnchors.js +0 -110
  705. package/lib/anchored-edits/SharedTreeWithAnchors.js.map +0 -1
  706. package/lib/anchored-edits/TransactionWithAnchors.d.ts +0 -28
  707. package/lib/anchored-edits/TransactionWithAnchors.d.ts.map +0 -1
  708. package/lib/anchored-edits/TransactionWithAnchors.js +0 -32
  709. package/lib/anchored-edits/TransactionWithAnchors.js.map +0 -1
  710. package/lib/anchored-edits/index.d.ts +0 -10
  711. package/lib/anchored-edits/index.d.ts.map +0 -1
  712. package/lib/anchored-edits/index.js +0 -11
  713. package/lib/anchored-edits/index.js.map +0 -1
  714. package/lib/default-edits/EditUtilities.d.ts +0 -57
  715. package/lib/default-edits/EditUtilities.d.ts.map +0 -1
  716. package/lib/default-edits/EditUtilities.js +0 -181
  717. package/lib/default-edits/EditUtilities.js.map +0 -1
  718. package/lib/default-edits/Factory.d.ts +0 -56
  719. package/lib/default-edits/Factory.d.ts.map +0 -1
  720. package/lib/default-edits/Factory.js +0 -74
  721. package/lib/default-edits/Factory.js.map +0 -1
  722. package/lib/default-edits/HistoryEditFactory.d.ts +0 -19
  723. package/lib/default-edits/HistoryEditFactory.d.ts.map +0 -1
  724. package/lib/default-edits/HistoryEditFactory.js.map +0 -1
  725. package/lib/default-edits/PersistedTypes.d.ts.map +0 -1
  726. package/lib/default-edits/PersistedTypes.js.map +0 -1
  727. package/lib/default-edits/SharedTree.d.ts +0 -111
  728. package/lib/default-edits/SharedTree.d.ts.map +0 -1
  729. package/lib/default-edits/SharedTree.js +0 -100
  730. package/lib/default-edits/SharedTree.js.map +0 -1
  731. package/lib/default-edits/Summary.d.ts +0 -15
  732. package/lib/default-edits/Summary.d.ts.map +0 -1
  733. package/lib/default-edits/Summary.js +0 -31
  734. package/lib/default-edits/Summary.js.map +0 -1
  735. package/lib/default-edits/Transaction.d.ts +0 -41
  736. package/lib/default-edits/Transaction.d.ts.map +0 -1
  737. package/lib/default-edits/Transaction.js +0 -221
  738. package/lib/default-edits/Transaction.js.map +0 -1
  739. package/lib/default-edits/UndoRedoHandler.d.ts.map +0 -1
  740. package/lib/default-edits/UndoRedoHandler.js.map +0 -1
  741. package/lib/default-edits/index.d.ts +0 -13
  742. package/lib/default-edits/index.d.ts.map +0 -1
  743. package/lib/default-edits/index.js +0 -14
  744. package/lib/default-edits/index.js.map +0 -1
  745. package/lib/generic/GenericEditUtilities.d.ts +0 -26
  746. package/lib/generic/GenericEditUtilities.d.ts.map +0 -1
  747. package/lib/generic/GenericEditUtilities.js +0 -38
  748. package/lib/generic/GenericEditUtilities.js.map +0 -1
  749. package/lib/generic/GenericSharedTree.d.ts +0 -221
  750. package/lib/generic/GenericSharedTree.d.ts.map +0 -1
  751. package/lib/generic/GenericSharedTree.js +0 -443
  752. package/lib/generic/GenericSharedTree.js.map +0 -1
  753. package/lib/generic/GenericTransaction.d.ts +0 -87
  754. package/lib/generic/GenericTransaction.d.ts.map +0 -1
  755. package/lib/generic/GenericTransaction.js +0 -140
  756. package/lib/generic/GenericTransaction.js.map +0 -1
  757. package/lib/generic/PersistedTypes.d.ts +0 -194
  758. package/lib/generic/PersistedTypes.d.ts.map +0 -1
  759. package/lib/generic/PersistedTypes.js +0 -39
  760. package/lib/generic/PersistedTypes.js.map +0 -1
  761. package/lib/generic/Summary.d.ts +0 -63
  762. package/lib/generic/Summary.d.ts.map +0 -1
  763. package/lib/generic/Summary.js +0 -58
  764. package/lib/generic/Summary.js.map +0 -1
  765. package/lib/generic/index.d.ts +0 -10
  766. package/lib/generic/index.d.ts.map +0 -1
  767. package/lib/generic/index.js +0 -11
  768. package/lib/generic/index.js.map +0 -1
  769. package/lib/test/Anchors.glassBox.tests.d.ts.map +0 -1
  770. package/lib/test/Anchors.glassBox.tests.js +0 -410
  771. package/lib/test/Anchors.glassBox.tests.js.map +0 -1
  772. package/lib/test/BasicCheckout.tests.d.ts.map +0 -1
  773. package/lib/test/BasicCheckout.tests.js +0 -8
  774. package/lib/test/BasicCheckout.tests.js.map +0 -1
  775. package/lib/test/GenericTransactionWithAnchors.tests.d.ts.map +0 -1
  776. package/lib/test/GenericTransactionWithAnchors.tests.js +0 -25
  777. package/lib/test/GenericTransactionWithAnchors.tests.js.map +0 -1
  778. package/lib/test/SharedTreeWithAnchors.tests.d.ts.map +0 -1
  779. package/lib/test/SharedTreeWithAnchors.tests.js +0 -420
  780. package/lib/test/SharedTreeWithAnchors.tests.js.map +0 -1
  781. package/lib/test/Snapshot.tests.d.ts.map +0 -1
  782. package/lib/test/Snapshot.tests.js +0 -96
  783. package/lib/test/Snapshot.tests.js.map +0 -1
  784. package/lib/test/SnapshotUtilities.tests.d.ts.map +0 -1
  785. package/lib/test/SnapshotUtilities.tests.js +0 -168
  786. package/lib/test/SnapshotUtilities.tests.js.map +0 -1
  787. package/lib/test/undoRedoStackManager.d.ts +0 -26
  788. package/lib/test/undoRedoStackManager.d.ts.map +0 -1
  789. package/lib/test/undoRedoStackManager.js +0 -176
  790. package/lib/test/undoRedoStackManager.js.map +0 -1
  791. package/lib/test/utilities/SummaryFormatCompatibilityTests.d.ts +0 -13
  792. package/lib/test/utilities/SummaryFormatCompatibilityTests.d.ts.map +0 -1
  793. package/lib/test/utilities/SummaryFormatCompatibilityTests.js +0 -154
  794. package/lib/test/utilities/SummaryFormatCompatibilityTests.js.map +0 -1
  795. package/src/BasicCheckout.ts +0 -34
  796. package/src/Snapshot.ts +0 -363
  797. package/src/SnapshotUtilities.ts +0 -88
  798. package/src/anchored-edits/AnchorResolution.ts +0 -442
  799. package/src/anchored-edits/Factory.ts +0 -94
  800. package/src/anchored-edits/PersistedTypes.ts +0 -310
  801. package/src/anchored-edits/SharedTreeWithAnchors.ts +0 -200
  802. package/src/anchored-edits/TransactionWithAnchors.ts +0 -39
  803. package/src/anchored-edits/index.ts +0 -21
  804. package/src/default-edits/EditUtilities.ts +0 -220
  805. package/src/default-edits/Factory.ts +0 -94
  806. package/src/default-edits/SharedTree.ts +0 -174
  807. package/src/default-edits/Summary.ts +0 -44
  808. package/src/default-edits/Transaction.ts +0 -262
  809. package/src/default-edits/index.ts +0 -29
  810. package/src/generic/GenericEditUtilities.ts +0 -46
  811. package/src/generic/GenericSharedTree.ts +0 -593
  812. package/src/generic/GenericTransaction.ts +0 -194
  813. package/src/generic/PersistedTypes.ts +0 -221
  814. package/src/generic/Summary.ts +0 -113
  815. package/src/generic/index.ts +0 -41
@@ -0,0 +1,618 @@
1
+ /*!
2
+ * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
+ * Licensed under the MIT License.
4
+ */
5
+ import { assert, copyPropertyIfDefined, fail, Result } from './Common';
6
+ import { isDetachedSequenceId } from './Identifiers';
7
+ import { rangeFromStableRange } from './TreeViewUtilities';
8
+ import { ChangeTypeInternal, ConstraintEffect, EditStatus, } from './persisted-types';
9
+ import { detachRange, insertIntoTrait, validateStablePlace, validateStableRange, PlaceValidationResult, RangeValidationResultKind, } from './EditUtilities';
10
+ /**
11
+ * A mutable transaction for applying sequences of changes to a TreeView.
12
+ * Allows viewing the intermediate states.
13
+ *
14
+ * Contains necessary state to apply changes within an edit to a TreeView.
15
+ *
16
+ * May have any number of changes applied to make up the edit.
17
+ * Use `close` to complete the transaction, returning the array of changes and an EditingResult showing the
18
+ * results of applying the changes as an Edit to the initial TreeView (passed to the constructor).
19
+ *
20
+ * No data outside the Transaction is modified by Transaction:
21
+ * the results from `close` must be used to actually submit an `Edit`.
22
+ */
23
+ export class GenericTransaction {
24
+ /**
25
+ * Create and open an edit of the provided `TreeView`. After applying 0 or more changes, this editor should be closed via `close()`.
26
+ * @param view - the `TreeView` at which this edit begins. The first change will be applied against this view.
27
+ */
28
+ constructor(view, policy) {
29
+ this.isOpen = true;
30
+ this.before = view;
31
+ this.policy = policy;
32
+ this.state = {
33
+ view: view.openForTransaction(),
34
+ status: EditStatus.Applied,
35
+ changes: [],
36
+ steps: [],
37
+ };
38
+ }
39
+ /**
40
+ * The most up-to-date `TreeView` for this edit. This is the state of the tree after all changes applied so far.
41
+ */
42
+ get view() {
43
+ return this.state.view;
44
+ }
45
+ /**
46
+ * The status code of the most recent attempted change.
47
+ */
48
+ get status() {
49
+ return this.state.status;
50
+ }
51
+ /**
52
+ * The status code of the most recent attempted change.
53
+ */
54
+ get changes() {
55
+ return this.state.changes;
56
+ }
57
+ /**
58
+ * The status code of the most recent attempted change.
59
+ */
60
+ get steps() {
61
+ return this.state.steps;
62
+ }
63
+ /** @returns the final `EditStatus` and `TreeView` after all changes are applied. */
64
+ close() {
65
+ assert(this.isOpen, 'transaction has already been closed');
66
+ this.isOpen = false;
67
+ if (this.state.status === EditStatus.Applied) {
68
+ const validation = this.policy.validateOnClose(this.state);
69
+ if (Result.isOk(validation)) {
70
+ if (validation.result !== this.view) {
71
+ this.state = Object.assign(Object.assign({}, this.state), { view: validation.result });
72
+ }
73
+ return {
74
+ status: EditStatus.Applied,
75
+ steps: this.steps,
76
+ changes: this.changes,
77
+ before: this.before,
78
+ after: this.view.close(),
79
+ };
80
+ }
81
+ this.state = Object.assign(Object.assign({}, this.state), validation.error);
82
+ return Object.assign(Object.assign({}, validation.error), { steps: this.steps, changes: this.changes, before: this.before });
83
+ }
84
+ return {
85
+ status: this.state.status,
86
+ failure: this.state.failure,
87
+ steps: this.steps,
88
+ changes: this.changes,
89
+ before: this.before,
90
+ };
91
+ }
92
+ /**
93
+ * A helper to apply a sequence of changes. Changes will be applied one after the other. If a change fails to apply,
94
+ * the remaining changes in `changes` will be ignored.
95
+ * @param changes - the sequence of changes to apply.
96
+ * @param path - the reconciliation path for the first change.
97
+ * @returns this
98
+ */
99
+ applyChanges(changes, path = []) {
100
+ const iter = changes[Symbol.iterator]();
101
+ const firsChangeInternal = iter.next().value;
102
+ let iterResult = iter.next();
103
+ if (iterResult.done === true) {
104
+ for (const change of changes) {
105
+ if (this.applyChange(change, path).status !== EditStatus.Applied) {
106
+ return this;
107
+ }
108
+ }
109
+ return this;
110
+ }
111
+ if (this.applyChange(firsChangeInternal, path).status !== EditStatus.Applied) {
112
+ return this;
113
+ }
114
+ const ongoingEdit = {
115
+ 0: this.steps[this.steps.length - 1],
116
+ before: this.view,
117
+ after: this.view,
118
+ length: 1,
119
+ };
120
+ /**
121
+ * We use a Proxy instead of `{ ...path, ...objectWithOngoingEdit }` to avoid eagerly demanding all parts of the path, which may
122
+ * require extensive computation.
123
+ */
124
+ const pathWithOngoingEdit = new Proxy(path, {
125
+ get: (target, prop) => {
126
+ if (prop === 'length') {
127
+ return target.length + 1;
128
+ }
129
+ return prop === String(target.length) ? ongoingEdit : target[prop];
130
+ },
131
+ });
132
+ while (iterResult.done !== true) {
133
+ if (this.applyChange(iterResult.value, pathWithOngoingEdit).status !== EditStatus.Applied) {
134
+ return this;
135
+ }
136
+ ongoingEdit[ongoingEdit.length] = this.steps[this.steps.length - 1];
137
+ ongoingEdit.length += 1;
138
+ ongoingEdit.after = this.view;
139
+ iterResult = iter.next();
140
+ }
141
+ return this;
142
+ }
143
+ /**
144
+ * Attempt to apply the given change as part of this edit. This method should not be called if a previous change in this edit failed to
145
+ * apply.
146
+ * @param change - the change to apply
147
+ * @param path - the reconciliation path for the change.
148
+ * @returns this
149
+ */
150
+ applyChange(change, path = []) {
151
+ assert(this.isOpen, 'Editor must be open to apply changes.');
152
+ if (this.state.status !== EditStatus.Applied) {
153
+ fail('Cannot apply change to an edit unless all previous changes have applied');
154
+ }
155
+ const resolutionResult = this.policy.tryResolveChange(this.state, change, path);
156
+ if (Result.isError(resolutionResult)) {
157
+ this.state = Object.assign(Object.assign({}, this.state), resolutionResult.error);
158
+ return this;
159
+ }
160
+ const resolvedChange = resolutionResult.result;
161
+ const changeResult = this.policy.dispatchChange(this.state, resolvedChange);
162
+ if (Result.isOk(changeResult)) {
163
+ this.state = {
164
+ status: EditStatus.Applied,
165
+ view: changeResult.result,
166
+ changes: this.changes.concat(change),
167
+ steps: this.steps.concat({ resolvedChange, after: changeResult.result }),
168
+ };
169
+ }
170
+ else {
171
+ this.state = Object.assign(Object.assign({}, this.state), changeResult.error);
172
+ }
173
+ return this;
174
+ }
175
+ }
176
+ /**
177
+ * A mutable transaction for applying sequences of changes to a TreeView.
178
+ * Allows viewing the intermediate states.
179
+ *
180
+ * Contains necessary state to apply changes within an edit to a TreeView.
181
+ *
182
+ * May have any number of changes applied to make up the edit.
183
+ * Use `close` to complete the transaction, returning the array of changes and an EditingResult showing the
184
+ * results of applying the changes as an Edit to the initial TreeView (passed to the constructor).
185
+ *
186
+ * No data outside the Transaction is modified by Transaction:
187
+ * the results from `close` must be used to actually submit an `Edit`.
188
+ * @public
189
+ */
190
+ export var TransactionInternal;
191
+ (function (TransactionInternal) {
192
+ /**
193
+ * Makes a new {@link GenericTransaction} that follows the {@link TransactionInternal.Policy} policy.
194
+ */
195
+ function factory(view) {
196
+ return new GenericTransaction(view, new Policy());
197
+ }
198
+ TransactionInternal.factory = factory;
199
+ /**
200
+ * The policy followed by a {@link TransactionInternal}.
201
+ */
202
+ class Policy {
203
+ constructor() {
204
+ /**
205
+ * Maps detached sequences of nodes to their NodeIds
206
+ */
207
+ this.detached = new Map();
208
+ }
209
+ /**
210
+ * Resolves change with Result.Ok
211
+ *
212
+ * @param state - Unused
213
+ * @param change - Change to resolve
214
+ * @returns Result.Ok which contains change
215
+ */
216
+ tryResolveChange(state, change) {
217
+ return Result.ok(change);
218
+ }
219
+ /**
220
+ * Validates the transaction when it is closed
221
+ *
222
+ * @param state - Current state
223
+ * @returns a {@link ChangeResult} containing either the change result or a Failure
224
+ */
225
+ validateOnClose(state) {
226
+ // Making the policy choice that storing a detached sequences in an edit but not using it is an error.
227
+ return this.detached.size !== 0
228
+ ? Result.error({
229
+ status: EditStatus.Malformed,
230
+ failure: {
231
+ kind: FailureKind.UnusedDetachedSequence,
232
+ sequenceId: this.detached.keys().next().value,
233
+ },
234
+ })
235
+ : Result.ok(state.view);
236
+ }
237
+ /**
238
+ * Applies a given change
239
+ *
240
+ * @param state - Current state
241
+ * @param change - Change to apply
242
+ * @returns a {@link ChangeResult} containing either the change result or a Failure
243
+ */
244
+ dispatchChange(state, change) {
245
+ switch (change.type) {
246
+ case ChangeTypeInternal.Build:
247
+ return this.applyBuild(state, change);
248
+ case ChangeTypeInternal.Insert:
249
+ return this.applyInsert(state, change);
250
+ case ChangeTypeInternal.Detach:
251
+ return this.applyDetach(state, change);
252
+ case ChangeTypeInternal.Constraint:
253
+ return this.applyConstraint(state, change);
254
+ case ChangeTypeInternal.SetValue:
255
+ return this.applySetValue(state, change);
256
+ default:
257
+ return fail('Attempted to apply unsupported change');
258
+ }
259
+ }
260
+ applyBuild(state, change) {
261
+ if (this.detached.has(change.destination)) {
262
+ return Result.error({
263
+ status: EditStatus.Malformed,
264
+ failure: {
265
+ kind: FailureKind.DetachedSequenceIdAlreadyInUse,
266
+ change,
267
+ sequenceId: change.destination,
268
+ },
269
+ });
270
+ }
271
+ let idAlreadyPresent;
272
+ let duplicateIdInBuild;
273
+ let invalidId;
274
+ let detachedSequenceNotFound;
275
+ const map = new Map();
276
+ const newIds = this.createViewNodesForTree(change.source, (id, viewNode) => {
277
+ if (map.has(id)) {
278
+ duplicateIdInBuild = id;
279
+ return true;
280
+ }
281
+ if (state.view.hasNode(viewNode.identifier)) {
282
+ idAlreadyPresent = id;
283
+ return true;
284
+ }
285
+ map.set(id, viewNode);
286
+ return false;
287
+ }, (detachedId) => {
288
+ detachedSequenceNotFound = detachedId;
289
+ });
290
+ if (idAlreadyPresent !== undefined) {
291
+ return Result.error({
292
+ status: EditStatus.Invalid,
293
+ failure: { kind: FailureKind.IdAlreadyInUse, change, id: idAlreadyPresent },
294
+ });
295
+ }
296
+ if (duplicateIdInBuild !== undefined) {
297
+ return Result.error({
298
+ status: EditStatus.Malformed,
299
+ failure: { kind: FailureKind.DuplicateIdInBuild, change, id: duplicateIdInBuild },
300
+ });
301
+ }
302
+ if (invalidId !== undefined) {
303
+ return Result.error({
304
+ status: EditStatus.Invalid,
305
+ failure: { kind: FailureKind.UnknownId, change, id: invalidId },
306
+ });
307
+ }
308
+ if (detachedSequenceNotFound !== undefined) {
309
+ return Result.error({
310
+ status: EditStatus.Malformed,
311
+ failure: {
312
+ kind: FailureKind.DetachedSequenceNotFound,
313
+ change,
314
+ sequenceId: detachedSequenceNotFound,
315
+ },
316
+ });
317
+ }
318
+ const view = state.view.addNodes(map.values());
319
+ this.detached.set(change.destination, newIds !== null && newIds !== void 0 ? newIds : fail('Unhandled failure case in Transaction.createViewNodesForTree'));
320
+ return Result.ok(view);
321
+ }
322
+ applyInsert(state, change) {
323
+ const source = this.detached.get(change.source);
324
+ if (source === undefined) {
325
+ return Result.error({
326
+ status: EditStatus.Malformed,
327
+ failure: {
328
+ kind: FailureKind.DetachedSequenceNotFound,
329
+ change,
330
+ sequenceId: change.source,
331
+ },
332
+ });
333
+ }
334
+ const validatedDestination = validateStablePlace(state.view, change.destination);
335
+ if (validatedDestination.result !== PlaceValidationResult.Valid) {
336
+ return Result.error({
337
+ status: validatedDestination.result === PlaceValidationResult.Malformed
338
+ ? EditStatus.Malformed
339
+ : EditStatus.Invalid,
340
+ failure: {
341
+ kind: FailureKind.BadPlace,
342
+ change,
343
+ place: change.destination,
344
+ placeFailure: validatedDestination.result,
345
+ },
346
+ });
347
+ }
348
+ this.detached.delete(change.source);
349
+ const view = insertIntoTrait(state.view, source, validatedDestination);
350
+ return Result.ok(view);
351
+ }
352
+ applyDetach(state, change) {
353
+ const validatedSource = validateStableRange(state.view, change.source);
354
+ if (validatedSource.result !== RangeValidationResultKind.Valid) {
355
+ return Result.error({
356
+ status: validatedSource.result === RangeValidationResultKind.PlacesInDifferentTraits ||
357
+ validatedSource.result === RangeValidationResultKind.Inverted ||
358
+ validatedSource.result.placeFailure !== PlaceValidationResult.Malformed
359
+ ? EditStatus.Invalid
360
+ : EditStatus.Malformed,
361
+ failure: {
362
+ kind: FailureKind.BadRange,
363
+ change,
364
+ range: change.source,
365
+ rangeFailure: validatedSource.result,
366
+ },
367
+ });
368
+ }
369
+ const result = detachRange(state.view, validatedSource);
370
+ let modifiedView = result.view;
371
+ const { detached } = result;
372
+ // Store or dispose detached
373
+ if (change.destination !== undefined) {
374
+ if (this.detached.has(change.destination)) {
375
+ return Result.error({
376
+ status: EditStatus.Malformed,
377
+ failure: {
378
+ kind: FailureKind.DetachedSequenceIdAlreadyInUse,
379
+ change,
380
+ sequenceId: change.destination,
381
+ },
382
+ });
383
+ }
384
+ this.detached.set(change.destination, detached);
385
+ }
386
+ else {
387
+ modifiedView = modifiedView.deleteNodes(detached);
388
+ }
389
+ return Result.ok(modifiedView);
390
+ }
391
+ applyConstraint(state, change) {
392
+ // TODO: Implement identityHash and contentHash
393
+ assert(change.identityHash === undefined, 'identityHash constraint is not implemented');
394
+ assert(change.contentHash === undefined, 'contentHash constraint is not implemented');
395
+ const validatedChange = validateStableRange(state.view, change.toConstrain);
396
+ if (validatedChange.result !== RangeValidationResultKind.Valid) {
397
+ return validatedChange.result !== RangeValidationResultKind.PlacesInDifferentTraits &&
398
+ validatedChange.result !== RangeValidationResultKind.Inverted &&
399
+ validatedChange.result.placeFailure !== PlaceValidationResult.Malformed
400
+ ? change.effect === ConstraintEffect.ValidRetry
401
+ ? Result.ok(state.view)
402
+ : Result.error({
403
+ status: EditStatus.Invalid,
404
+ failure: {
405
+ kind: FailureKind.ConstraintViolation,
406
+ constraint: change,
407
+ violation: {
408
+ kind: ConstraintViolationKind.BadRange,
409
+ rangeFailure: validatedChange.result,
410
+ },
411
+ },
412
+ })
413
+ : Result.error({
414
+ status: EditStatus.Malformed,
415
+ failure: {
416
+ kind: FailureKind.ConstraintViolation,
417
+ constraint: change,
418
+ violation: {
419
+ kind: ConstraintViolationKind.BadRange,
420
+ rangeFailure: validatedChange.result,
421
+ },
422
+ },
423
+ });
424
+ }
425
+ const { start, end } = rangeFromStableRange(state.view, validatedChange);
426
+ const startIndex = state.view.findIndexWithinTrait(start);
427
+ const endIndex = state.view.findIndexWithinTrait(end);
428
+ if (change.length !== undefined && change.length !== endIndex - startIndex) {
429
+ return Result.error({
430
+ status: EditStatus.Invalid,
431
+ failure: {
432
+ kind: FailureKind.ConstraintViolation,
433
+ constraint: change,
434
+ violation: {
435
+ kind: ConstraintViolationKind.BadLength,
436
+ actual: endIndex - startIndex,
437
+ },
438
+ },
439
+ });
440
+ }
441
+ if (change.parentNode !== undefined && change.parentNode !== end.trait.parent) {
442
+ return Result.error({
443
+ status: EditStatus.Invalid,
444
+ failure: {
445
+ kind: FailureKind.ConstraintViolation,
446
+ constraint: change,
447
+ violation: {
448
+ kind: ConstraintViolationKind.BadParent,
449
+ actual: change.parentNode,
450
+ },
451
+ },
452
+ });
453
+ }
454
+ if (change.label !== undefined && change.label !== end.trait.label) {
455
+ return Result.error({
456
+ status: EditStatus.Invalid,
457
+ failure: {
458
+ kind: FailureKind.ConstraintViolation,
459
+ constraint: change,
460
+ violation: {
461
+ kind: ConstraintViolationKind.BadLabel,
462
+ actual: end.trait.label,
463
+ },
464
+ },
465
+ });
466
+ }
467
+ return Result.ok(state.view);
468
+ }
469
+ applySetValue(state, change) {
470
+ if (!state.view.hasNode(change.nodeToModify)) {
471
+ return Result.error({
472
+ status: EditStatus.Invalid,
473
+ failure: { kind: FailureKind.UnknownId, change, id: change.nodeToModify },
474
+ });
475
+ }
476
+ const newView = state.view.setNodeValue(change.nodeToModify, change.payload);
477
+ return Result.ok(newView);
478
+ }
479
+ /**
480
+ * Generates tree view nodes from the supplied edit nodes.
481
+ * Invokes onCreateNode for each new node, and halts creation early if it returns true.
482
+ * Invokes onInvalidDetachedId and halts early for any invalid detached IDs referenced in the edit node sequence.
483
+ * @returns all the top-level node IDs in `sequence` (both from nodes and from detached sequences).
484
+ */
485
+ createViewNodesForTree(sequence, onCreateNode, onInvalidDetachedId) {
486
+ const topLevelIds = [];
487
+ const unprocessed = [];
488
+ for (const buildNode of sequence) {
489
+ if (isDetachedSequenceId(buildNode)) {
490
+ const detachedIds = this.getDetachedNodeIds(buildNode, onInvalidDetachedId);
491
+ if (detachedIds === undefined) {
492
+ return undefined;
493
+ }
494
+ topLevelIds.push(...detachedIds);
495
+ }
496
+ else {
497
+ unprocessed.push(buildNode);
498
+ topLevelIds.push(buildNode.identifier);
499
+ }
500
+ }
501
+ while (unprocessed.length > 0) {
502
+ const node = unprocessed.pop();
503
+ assert(node !== undefined && !isDetachedSequenceId(node));
504
+ const traits = new Map();
505
+ // eslint-disable-next-line no-restricted-syntax
506
+ for (const key in node.traits) {
507
+ if (Object.prototype.hasOwnProperty.call(node.traits, key)) {
508
+ const children = node.traits[key];
509
+ if (children.length > 0) {
510
+ const childIds = [];
511
+ for (const child of children) {
512
+ if (isDetachedSequenceId(child)) {
513
+ const detachedIds = this.getDetachedNodeIds(child, onInvalidDetachedId);
514
+ if (detachedIds === undefined) {
515
+ return undefined;
516
+ }
517
+ childIds.push(...detachedIds);
518
+ }
519
+ else {
520
+ childIds.push(child.identifier);
521
+ unprocessed.push(child);
522
+ }
523
+ }
524
+ traits.set(key, childIds);
525
+ }
526
+ }
527
+ }
528
+ const newNode = {
529
+ identifier: node.identifier,
530
+ definition: node.definition,
531
+ traits,
532
+ };
533
+ copyPropertyIfDefined(node, newNode, 'payload');
534
+ if (onCreateNode(node.identifier, newNode)) {
535
+ return undefined;
536
+ }
537
+ }
538
+ return topLevelIds;
539
+ }
540
+ getDetachedNodeIds(detachedId, onInvalidDetachedId) {
541
+ // Retrieve the detached sequence from the void.
542
+ const detachedNodeIds = this.detached.get(detachedId);
543
+ if (detachedNodeIds === undefined) {
544
+ onInvalidDetachedId(detachedId);
545
+ return undefined;
546
+ }
547
+ // Since we have retrieved the sequence, remove it from the void to prevent a second tree from multi-parenting it later
548
+ this.detached.delete(detachedId);
549
+ return detachedNodeIds;
550
+ }
551
+ }
552
+ TransactionInternal.Policy = Policy;
553
+ /**
554
+ * The kinds of failures that a transaction might encounter.
555
+ */
556
+ let FailureKind;
557
+ (function (FailureKind) {
558
+ /**
559
+ * Transaction has an unused DetachedSequenceId
560
+ */
561
+ FailureKind["UnusedDetachedSequence"] = "UnusedDetachedSequence";
562
+ /**
563
+ * Transaction has a build operation using an already in use DetachedSequenceID.
564
+ */
565
+ FailureKind["DetachedSequenceIdAlreadyInUse"] = "DetachedSequenceIdAlreadyInUse";
566
+ /**
567
+ * Transaction tries to operate on an unknown DetachedSequenceID
568
+ */
569
+ FailureKind["DetachedSequenceNotFound"] = "DetachedSequenceNotFound";
570
+ /**
571
+ * Transaction has a build which uses a duplicated NodeId
572
+ */
573
+ FailureKind["DuplicateIdInBuild"] = "DuplicateIdInBuild";
574
+ /**
575
+ * Transaction tries to build a node using an ID which is already used in the current state
576
+ */
577
+ FailureKind["IdAlreadyInUse"] = "IdAlreadyInUse";
578
+ /**
579
+ * Transaction tries to set value of an unknown node
580
+ */
581
+ FailureKind["UnknownId"] = "UnknownId";
582
+ /**
583
+ * Transaction tries to insert in an invalid Place
584
+ */
585
+ FailureKind["BadPlace"] = "BadPlace";
586
+ /**
587
+ * Transaction tries to detach an invalid Range
588
+ */
589
+ FailureKind["BadRange"] = "BadRange";
590
+ /**
591
+ * Transaction has an invalid constraint
592
+ */
593
+ FailureKind["ConstraintViolation"] = "ConstraintViolation";
594
+ })(FailureKind = TransactionInternal.FailureKind || (TransactionInternal.FailureKind = {}));
595
+ /**
596
+ * Enum of possible kinds of constraint violations that can be encountered
597
+ */
598
+ let ConstraintViolationKind;
599
+ (function (ConstraintViolationKind) {
600
+ /**
601
+ * The constraint failed because it applies to an invalid range
602
+ */
603
+ ConstraintViolationKind["BadRange"] = "BadRange";
604
+ /**
605
+ * The constraint failed because the length prescribed by the constraint does not match the length of range being constrained
606
+ */
607
+ ConstraintViolationKind["BadLength"] = "BadLength";
608
+ /**
609
+ * The constraint failed because the parent prescribed by the constraint does not match the actual parent of the range being constrained
610
+ */
611
+ ConstraintViolationKind["BadParent"] = "BadParent";
612
+ /**
613
+ * The constraint failed because the trait label prescribed by the constraint does not match the actual trait label of the range being constrained
614
+ */
615
+ ConstraintViolationKind["BadLabel"] = "BadLabel";
616
+ })(ConstraintViolationKind = TransactionInternal.ConstraintViolationKind || (TransactionInternal.ConstraintViolationKind = {}));
617
+ })(TransactionInternal || (TransactionInternal = {}));
618
+ //# sourceMappingURL=TransactionInternal.js.map