@fluidframework/tree 2.51.0-347100 → 2.52.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (609) hide show
  1. package/.eslintrc.cjs +3 -2
  2. package/.vscode/settings.json +0 -1
  3. package/CHANGELOG.md +92 -0
  4. package/api-report/tree.alpha.api.md +3 -2
  5. package/dist/codec/codec.d.ts +2 -1
  6. package/dist/codec/codec.d.ts.map +1 -1
  7. package/dist/codec/codec.js +4 -3
  8. package/dist/codec/codec.js.map +1 -1
  9. package/dist/core/index.d.ts +1 -1
  10. package/dist/core/index.d.ts.map +1 -1
  11. package/dist/core/index.js +3 -2
  12. package/dist/core/index.js.map +1 -1
  13. package/dist/core/rebase/index.d.ts +1 -1
  14. package/dist/core/rebase/index.d.ts.map +1 -1
  15. package/dist/core/rebase/index.js +2 -1
  16. package/dist/core/rebase/index.js.map +1 -1
  17. package/dist/core/rebase/types.d.ts +3 -1
  18. package/dist/core/rebase/types.d.ts.map +1 -1
  19. package/dist/core/rebase/types.js +2 -1
  20. package/dist/core/rebase/types.js.map +1 -1
  21. package/dist/core/schema-stored/schema.d.ts +1 -23
  22. package/dist/core/schema-stored/schema.d.ts.map +1 -1
  23. package/dist/core/schema-stored/schema.js +2 -2
  24. package/dist/core/schema-stored/schema.js.map +1 -1
  25. package/dist/core/tree/detachedFieldIndex.d.ts.map +1 -1
  26. package/dist/core/tree/detachedFieldIndex.js +2 -3
  27. package/dist/core/tree/detachedFieldIndex.js.map +1 -1
  28. package/dist/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
  29. package/dist/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
  30. package/dist/core/tree/detachedFieldIndexCodecCommon.js +68 -0
  31. package/dist/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
  32. package/dist/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
  33. package/dist/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
  34. package/dist/core/tree/detachedFieldIndexCodecV1.js +55 -0
  35. package/dist/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
  36. package/dist/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
  37. package/dist/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
  38. package/dist/core/tree/detachedFieldIndexCodecV2.js +49 -0
  39. package/dist/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
  40. package/dist/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
  41. package/dist/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
  42. package/dist/core/tree/detachedFieldIndexCodecs.js +26 -0
  43. package/dist/core/tree/detachedFieldIndexCodecs.js.map +1 -0
  44. package/dist/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
  45. package/dist/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
  46. package/dist/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +18 -13
  47. package/dist/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
  48. package/dist/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
  49. package/dist/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
  50. package/dist/core/tree/detachedFieldIndexFormatV1.js +12 -0
  51. package/dist/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
  52. package/dist/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
  53. package/dist/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
  54. package/dist/core/tree/detachedFieldIndexFormatV2.js +14 -0
  55. package/dist/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
  56. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
  57. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  58. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js +21 -21
  59. package/dist/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  60. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
  61. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  62. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
  63. package/dist/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  64. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
  65. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  66. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js +74 -61
  67. package/dist/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  68. package/dist/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
  69. package/dist/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
  70. package/dist/feature-libraries/chunked-forest/codec/format.js +18 -12
  71. package/dist/feature-libraries/chunked-forest/codec/format.js.map +1 -1
  72. package/{lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts → dist/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
  73. package/dist/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
  74. package/dist/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +23 -17
  75. package/dist/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
  76. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
  77. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  78. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +22 -22
  79. package/dist/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  80. package/dist/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
  81. package/dist/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
  82. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
  83. package/dist/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  84. package/dist/feature-libraries/default-schema/defaultFieldKinds.js +14 -2
  85. package/dist/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  86. package/dist/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
  87. package/dist/feature-libraries/default-schema/defaultSchema.js +0 -2
  88. package/dist/feature-libraries/default-schema/defaultSchema.js.map +1 -1
  89. package/dist/feature-libraries/default-schema/index.d.ts +1 -1
  90. package/dist/feature-libraries/default-schema/index.d.ts.map +1 -1
  91. package/dist/feature-libraries/default-schema/index.js +2 -2
  92. package/dist/feature-libraries/default-schema/index.js.map +1 -1
  93. package/dist/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
  94. package/dist/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  95. package/dist/feature-libraries/default-schema/schemaChecker.js +31 -26
  96. package/dist/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  97. package/dist/feature-libraries/index.d.ts +2 -3
  98. package/dist/feature-libraries/index.d.ts.map +1 -1
  99. package/dist/feature-libraries/index.js +3 -11
  100. package/dist/feature-libraries/index.js.map +1 -1
  101. package/dist/feature-libraries/modular-schema/comparison.d.ts +5 -6
  102. package/dist/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
  103. package/dist/feature-libraries/modular-schema/comparison.js +15 -19
  104. package/dist/feature-libraries/modular-schema/comparison.js.map +1 -1
  105. package/dist/feature-libraries/modular-schema/index.d.ts +0 -1
  106. package/dist/feature-libraries/modular-schema/index.d.ts.map +1 -1
  107. package/dist/feature-libraries/modular-schema/index.js +1 -8
  108. package/dist/feature-libraries/modular-schema/index.js.map +1 -1
  109. package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
  110. package/dist/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
  111. package/dist/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  112. package/dist/feature-libraries/object-forest/objectForest.js +2 -3
  113. package/dist/feature-libraries/object-forest/objectForest.js.map +1 -1
  114. package/dist/index.d.ts +1 -1
  115. package/dist/index.d.ts.map +1 -1
  116. package/dist/index.js +6 -2
  117. package/dist/index.js.map +1 -1
  118. package/dist/packageVersion.d.ts +1 -1
  119. package/dist/packageVersion.d.ts.map +1 -1
  120. package/dist/packageVersion.js +1 -1
  121. package/dist/packageVersion.js.map +1 -1
  122. package/dist/shared-tree/independentView.d.ts +8 -0
  123. package/dist/shared-tree/independentView.d.ts.map +1 -1
  124. package/dist/shared-tree/independentView.js +23 -11
  125. package/dist/shared-tree/independentView.js.map +1 -1
  126. package/dist/shared-tree/schematizeTree.d.ts +1 -1
  127. package/dist/shared-tree/schematizeTree.d.ts.map +1 -1
  128. package/dist/shared-tree/schematizeTree.js +5 -4
  129. package/dist/shared-tree/schematizeTree.js.map +1 -1
  130. package/dist/shared-tree/schematizingTreeView.d.ts +0 -1
  131. package/dist/shared-tree/schematizingTreeView.d.ts.map +1 -1
  132. package/dist/shared-tree/schematizingTreeView.js +7 -10
  133. package/dist/shared-tree/schematizingTreeView.js.map +1 -1
  134. package/dist/shared-tree/sharedTree.d.ts.map +1 -1
  135. package/dist/shared-tree/sharedTree.js +1 -29
  136. package/dist/shared-tree/sharedTree.js.map +1 -1
  137. package/dist/shared-tree/tree.js +1 -1
  138. package/dist/shared-tree/tree.js.map +1 -1
  139. package/dist/shared-tree/treeAlpha.d.ts +20 -6
  140. package/dist/shared-tree/treeAlpha.d.ts.map +1 -1
  141. package/dist/shared-tree/treeAlpha.js +9 -4
  142. package/dist/shared-tree/treeAlpha.js.map +1 -1
  143. package/dist/shared-tree/treeCheckout.d.ts +2 -1
  144. package/dist/shared-tree/treeCheckout.d.ts.map +1 -1
  145. package/dist/shared-tree/treeCheckout.js +33 -1
  146. package/dist/shared-tree/treeCheckout.js.map +1 -1
  147. package/dist/shared-tree-core/branch.d.ts.map +1 -1
  148. package/dist/shared-tree-core/branch.js +1 -1
  149. package/dist/shared-tree-core/branch.js.map +1 -1
  150. package/dist/simple-tree/api/conciseTree.d.ts +2 -2
  151. package/dist/simple-tree/api/conciseTree.d.ts.map +1 -1
  152. package/dist/simple-tree/api/conciseTree.js +6 -6
  153. package/dist/simple-tree/api/conciseTree.js.map +1 -1
  154. package/dist/simple-tree/api/configuration.d.ts +8 -2
  155. package/dist/simple-tree/api/configuration.d.ts.map +1 -1
  156. package/dist/simple-tree/api/configuration.js.map +1 -1
  157. package/dist/simple-tree/api/create.d.ts +8 -7
  158. package/dist/simple-tree/api/create.d.ts.map +1 -1
  159. package/dist/simple-tree/api/create.js +35 -22
  160. package/dist/simple-tree/api/create.js.map +1 -1
  161. package/dist/simple-tree/api/customTree.d.ts +25 -4
  162. package/dist/simple-tree/api/customTree.d.ts.map +1 -1
  163. package/dist/simple-tree/api/customTree.js +42 -16
  164. package/dist/simple-tree/api/customTree.js.map +1 -1
  165. package/dist/simple-tree/api/discrepancies.d.ts +98 -0
  166. package/dist/simple-tree/api/discrepancies.d.ts.map +1 -0
  167. package/dist/simple-tree/api/discrepancies.js +255 -0
  168. package/dist/simple-tree/api/discrepancies.js.map +1 -0
  169. package/dist/simple-tree/api/schemaCompatibilityTester.d.ts +8 -21
  170. package/dist/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
  171. package/dist/simple-tree/api/schemaCompatibilityTester.js +19 -169
  172. package/dist/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
  173. package/dist/simple-tree/api/schemaCreationUtilities.d.ts.map +1 -1
  174. package/dist/simple-tree/api/schemaCreationUtilities.js +2 -2
  175. package/dist/simple-tree/api/schemaCreationUtilities.js.map +1 -1
  176. package/dist/simple-tree/api/schemaFactory.d.ts +7 -4
  177. package/dist/simple-tree/api/schemaFactory.d.ts.map +1 -1
  178. package/dist/simple-tree/api/schemaFactory.js.map +1 -1
  179. package/dist/simple-tree/api/storedSchema.d.ts.map +1 -1
  180. package/dist/simple-tree/api/storedSchema.js +5 -1
  181. package/dist/simple-tree/api/storedSchema.js.map +1 -1
  182. package/dist/simple-tree/api/treeBeta.d.ts +2 -2
  183. package/dist/simple-tree/api/treeBeta.d.ts.map +1 -1
  184. package/dist/simple-tree/api/treeBeta.js +10 -4
  185. package/dist/simple-tree/api/treeBeta.js.map +1 -1
  186. package/dist/simple-tree/api/verboseTree.d.ts +2 -2
  187. package/dist/simple-tree/api/verboseTree.d.ts.map +1 -1
  188. package/dist/simple-tree/api/verboseTree.js +15 -15
  189. package/dist/simple-tree/api/verboseTree.js.map +1 -1
  190. package/dist/simple-tree/core/allowedTypes.d.ts +20 -4
  191. package/dist/simple-tree/core/allowedTypes.d.ts.map +1 -1
  192. package/dist/simple-tree/core/allowedTypes.js +45 -13
  193. package/dist/simple-tree/core/allowedTypes.js.map +1 -1
  194. package/dist/simple-tree/core/context.d.ts +13 -2
  195. package/dist/simple-tree/core/context.d.ts.map +1 -1
  196. package/dist/simple-tree/core/context.js +22 -9
  197. package/dist/simple-tree/core/context.js.map +1 -1
  198. package/dist/simple-tree/core/index.d.ts +2 -2
  199. package/dist/simple-tree/core/index.d.ts.map +1 -1
  200. package/dist/simple-tree/core/index.js +3 -1
  201. package/dist/simple-tree/core/index.js.map +1 -1
  202. package/dist/simple-tree/core/treeNodeKernel.d.ts +1 -1
  203. package/dist/simple-tree/core/treeNodeKernel.js +1 -1
  204. package/dist/simple-tree/core/treeNodeKernel.js.map +1 -1
  205. package/dist/simple-tree/core/treeNodeValid.d.ts +1 -1
  206. package/dist/simple-tree/core/treeNodeValid.d.ts.map +1 -1
  207. package/dist/simple-tree/core/treeNodeValid.js +8 -1
  208. package/dist/simple-tree/core/treeNodeValid.js.map +1 -1
  209. package/dist/simple-tree/core/walkSchema.d.ts +3 -0
  210. package/dist/simple-tree/core/walkSchema.d.ts.map +1 -1
  211. package/dist/simple-tree/core/walkSchema.js +2 -0
  212. package/dist/simple-tree/core/walkSchema.js.map +1 -1
  213. package/dist/simple-tree/createContext.d.ts +2 -0
  214. package/dist/simple-tree/createContext.d.ts.map +1 -1
  215. package/dist/simple-tree/createContext.js +3 -1
  216. package/dist/simple-tree/createContext.js.map +1 -1
  217. package/dist/simple-tree/fieldSchema.d.ts +1 -0
  218. package/dist/simple-tree/fieldSchema.d.ts.map +1 -1
  219. package/dist/simple-tree/fieldSchema.js +1 -0
  220. package/dist/simple-tree/fieldSchema.js.map +1 -1
  221. package/dist/simple-tree/index.d.ts +5 -4
  222. package/dist/simple-tree/index.d.ts.map +1 -1
  223. package/dist/simple-tree/index.js +8 -3
  224. package/dist/simple-tree/index.js.map +1 -1
  225. package/dist/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  226. package/dist/simple-tree/node-kinds/array/arrayNode.js +1 -1
  227. package/dist/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  228. package/dist/simple-tree/node-kinds/index.d.ts +1 -1
  229. package/dist/simple-tree/node-kinds/index.d.ts.map +1 -1
  230. package/dist/simple-tree/node-kinds/index.js +1 -2
  231. package/dist/simple-tree/node-kinds/index.js.map +1 -1
  232. package/dist/simple-tree/node-kinds/object/index.d.ts +1 -1
  233. package/dist/simple-tree/node-kinds/object/index.d.ts.map +1 -1
  234. package/dist/simple-tree/node-kinds/object/index.js +1 -2
  235. package/dist/simple-tree/node-kinds/object/index.js.map +1 -1
  236. package/dist/simple-tree/node-kinds/object/objectNode.d.ts +2 -7
  237. package/dist/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  238. package/dist/simple-tree/node-kinds/object/objectNode.js +4 -18
  239. package/dist/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  240. package/dist/simple-tree/prepareForInsertion.d.ts +5 -5
  241. package/dist/simple-tree/prepareForInsertion.d.ts.map +1 -1
  242. package/dist/simple-tree/prepareForInsertion.js +9 -3
  243. package/dist/simple-tree/prepareForInsertion.js.map +1 -1
  244. package/dist/simple-tree/toStoredSchema.d.ts +3 -0
  245. package/dist/simple-tree/toStoredSchema.d.ts.map +1 -1
  246. package/dist/simple-tree/toStoredSchema.js +3 -0
  247. package/dist/simple-tree/toStoredSchema.js.map +1 -1
  248. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
  249. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  250. package/dist/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  251. package/dist/simple-tree/walkFieldSchema.d.ts +1 -0
  252. package/dist/simple-tree/walkFieldSchema.d.ts.map +1 -1
  253. package/dist/simple-tree/walkFieldSchema.js +1 -0
  254. package/dist/simple-tree/walkFieldSchema.js.map +1 -1
  255. package/lib/codec/codec.d.ts +2 -1
  256. package/lib/codec/codec.d.ts.map +1 -1
  257. package/lib/codec/codec.js +4 -3
  258. package/lib/codec/codec.js.map +1 -1
  259. package/lib/core/index.d.ts +1 -1
  260. package/lib/core/index.d.ts.map +1 -1
  261. package/lib/core/index.js +1 -1
  262. package/lib/core/index.js.map +1 -1
  263. package/lib/core/rebase/index.d.ts +1 -1
  264. package/lib/core/rebase/index.d.ts.map +1 -1
  265. package/lib/core/rebase/index.js +1 -1
  266. package/lib/core/rebase/index.js.map +1 -1
  267. package/lib/core/rebase/types.d.ts +3 -1
  268. package/lib/core/rebase/types.d.ts.map +1 -1
  269. package/lib/core/rebase/types.js +1 -0
  270. package/lib/core/rebase/types.js.map +1 -1
  271. package/lib/core/schema-stored/schema.d.ts +1 -23
  272. package/lib/core/schema-stored/schema.d.ts.map +1 -1
  273. package/lib/core/schema-stored/schema.js +2 -2
  274. package/lib/core/schema-stored/schema.js.map +1 -1
  275. package/lib/core/tree/detachedFieldIndex.d.ts.map +1 -1
  276. package/lib/core/tree/detachedFieldIndex.js +2 -3
  277. package/lib/core/tree/detachedFieldIndex.js.map +1 -1
  278. package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts +17 -0
  279. package/lib/core/tree/detachedFieldIndexCodecCommon.d.ts.map +1 -0
  280. package/lib/core/tree/detachedFieldIndexCodecCommon.js +64 -0
  281. package/lib/core/tree/detachedFieldIndexCodecCommon.js.map +1 -0
  282. package/lib/core/tree/detachedFieldIndexCodecV1.d.ts +11 -0
  283. package/lib/core/tree/detachedFieldIndexCodecV1.d.ts.map +1 -0
  284. package/lib/core/tree/detachedFieldIndexCodecV1.js +51 -0
  285. package/lib/core/tree/detachedFieldIndexCodecV1.js.map +1 -0
  286. package/lib/core/tree/detachedFieldIndexCodecV2.d.ts +11 -0
  287. package/lib/core/tree/detachedFieldIndexCodecV2.d.ts.map +1 -0
  288. package/lib/core/tree/detachedFieldIndexCodecV2.js +45 -0
  289. package/lib/core/tree/detachedFieldIndexCodecV2.js.map +1 -0
  290. package/lib/core/tree/detachedFieldIndexCodecs.d.ts +11 -0
  291. package/lib/core/tree/detachedFieldIndexCodecs.d.ts.map +1 -0
  292. package/lib/core/tree/detachedFieldIndexCodecs.js +21 -0
  293. package/lib/core/tree/detachedFieldIndexCodecs.js.map +1 -0
  294. package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts +37 -0
  295. package/lib/core/tree/detachedFieldIndexFormatCommon.d.ts.map +1 -0
  296. package/lib/core/tree/{detachedFieldIndexFormat.js → detachedFieldIndexFormatCommon.js} +13 -10
  297. package/lib/core/tree/detachedFieldIndexFormatCommon.js.map +1 -0
  298. package/lib/core/tree/detachedFieldIndexFormatV1.d.ts +13 -0
  299. package/lib/core/tree/detachedFieldIndexFormatV1.d.ts.map +1 -0
  300. package/lib/core/tree/detachedFieldIndexFormatV1.js +9 -0
  301. package/lib/core/tree/detachedFieldIndexFormatV1.js.map +1 -0
  302. package/lib/core/tree/detachedFieldIndexFormatV2.d.ts +14 -0
  303. package/lib/core/tree/detachedFieldIndexFormatV2.d.ts.map +1 -0
  304. package/lib/core/tree/detachedFieldIndexFormatV2.js +11 -0
  305. package/lib/core/tree/detachedFieldIndexFormatV2.js.map +1 -0
  306. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts +9 -9
  307. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.d.ts.map +1 -1
  308. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js +19 -19
  309. package/lib/feature-libraries/chunked-forest/codec/chunkDecoding.js.map +1 -1
  310. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts +4 -2
  311. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.d.ts.map +1 -1
  312. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js +4 -4
  313. package/lib/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.js.map +1 -1
  314. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts +50 -31
  315. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.d.ts.map +1 -1
  316. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js +70 -57
  317. package/lib/feature-libraries/chunked-forest/codec/compressedEncode.js.map +1 -1
  318. package/lib/feature-libraries/chunked-forest/codec/format.d.ts +20 -14
  319. package/lib/feature-libraries/chunked-forest/codec/format.d.ts.map +1 -1
  320. package/lib/feature-libraries/chunked-forest/codec/format.js +17 -11
  321. package/lib/feature-libraries/chunked-forest/codec/format.js.map +1 -1
  322. package/{dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts → lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts} +20 -14
  323. package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.d.ts.map +1 -0
  324. package/lib/feature-libraries/chunked-forest/codec/{nodeShape.js → nodeEncoder.js} +21 -15
  325. package/lib/feature-libraries/chunked-forest/codec/nodeEncoder.js.map +1 -0
  326. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts +7 -7
  327. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.d.ts.map +1 -1
  328. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js +19 -19
  329. package/lib/feature-libraries/chunked-forest/codec/schemaBasedEncode.js.map +1 -1
  330. package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js +2 -2
  331. package/lib/feature-libraries/chunked-forest/codec/uncompressedEncode.js.map +1 -1
  332. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts +5 -1
  333. package/lib/feature-libraries/default-schema/defaultFieldKinds.d.ts.map +1 -1
  334. package/lib/feature-libraries/default-schema/defaultFieldKinds.js +14 -2
  335. package/lib/feature-libraries/default-schema/defaultFieldKinds.js.map +1 -1
  336. package/lib/feature-libraries/default-schema/defaultSchema.d.ts.map +1 -1
  337. package/lib/feature-libraries/default-schema/defaultSchema.js +0 -2
  338. package/lib/feature-libraries/default-schema/defaultSchema.js.map +1 -1
  339. package/lib/feature-libraries/default-schema/index.d.ts +1 -1
  340. package/lib/feature-libraries/default-schema/index.d.ts.map +1 -1
  341. package/lib/feature-libraries/default-schema/index.js +1 -1
  342. package/lib/feature-libraries/default-schema/index.js.map +1 -1
  343. package/lib/feature-libraries/default-schema/schemaChecker.d.ts +14 -4
  344. package/lib/feature-libraries/default-schema/schemaChecker.d.ts.map +1 -1
  345. package/lib/feature-libraries/default-schema/schemaChecker.js +29 -24
  346. package/lib/feature-libraries/default-schema/schemaChecker.js.map +1 -1
  347. package/lib/feature-libraries/index.d.ts +2 -3
  348. package/lib/feature-libraries/index.d.ts.map +1 -1
  349. package/lib/feature-libraries/index.js +2 -3
  350. package/lib/feature-libraries/index.js.map +1 -1
  351. package/lib/feature-libraries/modular-schema/comparison.d.ts +5 -6
  352. package/lib/feature-libraries/modular-schema/comparison.d.ts.map +1 -1
  353. package/lib/feature-libraries/modular-schema/comparison.js +14 -17
  354. package/lib/feature-libraries/modular-schema/comparison.js.map +1 -1
  355. package/lib/feature-libraries/modular-schema/index.d.ts +0 -1
  356. package/lib/feature-libraries/modular-schema/index.d.ts.map +1 -1
  357. package/lib/feature-libraries/modular-schema/index.js +0 -1
  358. package/lib/feature-libraries/modular-schema/index.js.map +1 -1
  359. package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts +9 -3
  360. package/lib/feature-libraries/modular-schema/modularChangeFormat.d.ts.map +1 -1
  361. package/lib/feature-libraries/object-forest/objectForest.d.ts.map +1 -1
  362. package/lib/feature-libraries/object-forest/objectForest.js +3 -4
  363. package/lib/feature-libraries/object-forest/objectForest.js.map +1 -1
  364. package/lib/index.d.ts +1 -1
  365. package/lib/index.d.ts.map +1 -1
  366. package/lib/index.js +2 -2
  367. package/lib/index.js.map +1 -1
  368. package/lib/packageVersion.d.ts +1 -1
  369. package/lib/packageVersion.d.ts.map +1 -1
  370. package/lib/packageVersion.js +1 -1
  371. package/lib/packageVersion.js.map +1 -1
  372. package/lib/shared-tree/independentView.d.ts +8 -0
  373. package/lib/shared-tree/independentView.d.ts.map +1 -1
  374. package/lib/shared-tree/independentView.js +21 -10
  375. package/lib/shared-tree/independentView.js.map +1 -1
  376. package/lib/shared-tree/schematizeTree.d.ts +1 -1
  377. package/lib/shared-tree/schematizeTree.d.ts.map +1 -1
  378. package/lib/shared-tree/schematizeTree.js +3 -2
  379. package/lib/shared-tree/schematizeTree.js.map +1 -1
  380. package/lib/shared-tree/schematizingTreeView.d.ts +0 -1
  381. package/lib/shared-tree/schematizingTreeView.d.ts.map +1 -1
  382. package/lib/shared-tree/schematizingTreeView.js +8 -11
  383. package/lib/shared-tree/schematizingTreeView.js.map +1 -1
  384. package/lib/shared-tree/sharedTree.d.ts.map +1 -1
  385. package/lib/shared-tree/sharedTree.js +2 -30
  386. package/lib/shared-tree/sharedTree.js.map +1 -1
  387. package/lib/shared-tree/tree.js +1 -1
  388. package/lib/shared-tree/tree.js.map +1 -1
  389. package/lib/shared-tree/treeAlpha.d.ts +20 -6
  390. package/lib/shared-tree/treeAlpha.d.ts.map +1 -1
  391. package/lib/shared-tree/treeAlpha.js +10 -5
  392. package/lib/shared-tree/treeAlpha.js.map +1 -1
  393. package/lib/shared-tree/treeCheckout.d.ts +2 -1
  394. package/lib/shared-tree/treeCheckout.d.ts.map +1 -1
  395. package/lib/shared-tree/treeCheckout.js +34 -2
  396. package/lib/shared-tree/treeCheckout.js.map +1 -1
  397. package/lib/shared-tree-core/branch.d.ts.map +1 -1
  398. package/lib/shared-tree-core/branch.js +1 -1
  399. package/lib/shared-tree-core/branch.js.map +1 -1
  400. package/lib/simple-tree/api/conciseTree.d.ts +2 -2
  401. package/lib/simple-tree/api/conciseTree.d.ts.map +1 -1
  402. package/lib/simple-tree/api/conciseTree.js +6 -6
  403. package/lib/simple-tree/api/conciseTree.js.map +1 -1
  404. package/lib/simple-tree/api/configuration.d.ts +8 -2
  405. package/lib/simple-tree/api/configuration.d.ts.map +1 -1
  406. package/lib/simple-tree/api/configuration.js.map +1 -1
  407. package/lib/simple-tree/api/create.d.ts +8 -7
  408. package/lib/simple-tree/api/create.d.ts.map +1 -1
  409. package/lib/simple-tree/api/create.js +38 -25
  410. package/lib/simple-tree/api/create.js.map +1 -1
  411. package/lib/simple-tree/api/customTree.d.ts +25 -4
  412. package/lib/simple-tree/api/customTree.d.ts.map +1 -1
  413. package/lib/simple-tree/api/customTree.js +43 -17
  414. package/lib/simple-tree/api/customTree.js.map +1 -1
  415. package/lib/simple-tree/api/discrepancies.d.ts +98 -0
  416. package/lib/simple-tree/api/discrepancies.d.ts.map +1 -0
  417. package/lib/simple-tree/api/discrepancies.js +250 -0
  418. package/lib/simple-tree/api/discrepancies.js.map +1 -0
  419. package/lib/simple-tree/api/schemaCompatibilityTester.d.ts +8 -21
  420. package/lib/simple-tree/api/schemaCompatibilityTester.d.ts.map +1 -1
  421. package/lib/simple-tree/api/schemaCompatibilityTester.js +19 -169
  422. package/lib/simple-tree/api/schemaCompatibilityTester.js.map +1 -1
  423. package/lib/simple-tree/api/schemaCreationUtilities.d.ts.map +1 -1
  424. package/lib/simple-tree/api/schemaCreationUtilities.js +2 -2
  425. package/lib/simple-tree/api/schemaCreationUtilities.js.map +1 -1
  426. package/lib/simple-tree/api/schemaFactory.d.ts +7 -4
  427. package/lib/simple-tree/api/schemaFactory.d.ts.map +1 -1
  428. package/lib/simple-tree/api/schemaFactory.js.map +1 -1
  429. package/lib/simple-tree/api/storedSchema.d.ts.map +1 -1
  430. package/lib/simple-tree/api/storedSchema.js +6 -2
  431. package/lib/simple-tree/api/storedSchema.js.map +1 -1
  432. package/lib/simple-tree/api/treeBeta.d.ts +2 -2
  433. package/lib/simple-tree/api/treeBeta.d.ts.map +1 -1
  434. package/lib/simple-tree/api/treeBeta.js +8 -2
  435. package/lib/simple-tree/api/treeBeta.js.map +1 -1
  436. package/lib/simple-tree/api/verboseTree.d.ts +2 -2
  437. package/lib/simple-tree/api/verboseTree.d.ts.map +1 -1
  438. package/lib/simple-tree/api/verboseTree.js +9 -9
  439. package/lib/simple-tree/api/verboseTree.js.map +1 -1
  440. package/lib/simple-tree/core/allowedTypes.d.ts +20 -4
  441. package/lib/simple-tree/core/allowedTypes.d.ts.map +1 -1
  442. package/lib/simple-tree/core/allowedTypes.js +42 -12
  443. package/lib/simple-tree/core/allowedTypes.js.map +1 -1
  444. package/lib/simple-tree/core/context.d.ts +13 -2
  445. package/lib/simple-tree/core/context.d.ts.map +1 -1
  446. package/lib/simple-tree/core/context.js +22 -9
  447. package/lib/simple-tree/core/context.js.map +1 -1
  448. package/lib/simple-tree/core/index.d.ts +2 -2
  449. package/lib/simple-tree/core/index.d.ts.map +1 -1
  450. package/lib/simple-tree/core/index.js +2 -2
  451. package/lib/simple-tree/core/index.js.map +1 -1
  452. package/lib/simple-tree/core/treeNodeKernel.d.ts +1 -1
  453. package/lib/simple-tree/core/treeNodeKernel.js +1 -1
  454. package/lib/simple-tree/core/treeNodeKernel.js.map +1 -1
  455. package/lib/simple-tree/core/treeNodeValid.d.ts +1 -1
  456. package/lib/simple-tree/core/treeNodeValid.d.ts.map +1 -1
  457. package/lib/simple-tree/core/treeNodeValid.js +8 -1
  458. package/lib/simple-tree/core/treeNodeValid.js.map +1 -1
  459. package/lib/simple-tree/core/walkSchema.d.ts +3 -0
  460. package/lib/simple-tree/core/walkSchema.d.ts.map +1 -1
  461. package/lib/simple-tree/core/walkSchema.js +2 -0
  462. package/lib/simple-tree/core/walkSchema.js.map +1 -1
  463. package/lib/simple-tree/createContext.d.ts +2 -0
  464. package/lib/simple-tree/createContext.d.ts.map +1 -1
  465. package/lib/simple-tree/createContext.js +3 -1
  466. package/lib/simple-tree/createContext.js.map +1 -1
  467. package/lib/simple-tree/fieldSchema.d.ts +1 -0
  468. package/lib/simple-tree/fieldSchema.d.ts.map +1 -1
  469. package/lib/simple-tree/fieldSchema.js +1 -0
  470. package/lib/simple-tree/fieldSchema.js.map +1 -1
  471. package/lib/simple-tree/index.d.ts +5 -4
  472. package/lib/simple-tree/index.d.ts.map +1 -1
  473. package/lib/simple-tree/index.js +5 -4
  474. package/lib/simple-tree/index.js.map +1 -1
  475. package/lib/simple-tree/node-kinds/array/arrayNode.d.ts.map +1 -1
  476. package/lib/simple-tree/node-kinds/array/arrayNode.js +1 -1
  477. package/lib/simple-tree/node-kinds/array/arrayNode.js.map +1 -1
  478. package/lib/simple-tree/node-kinds/index.d.ts +1 -1
  479. package/lib/simple-tree/node-kinds/index.d.ts.map +1 -1
  480. package/lib/simple-tree/node-kinds/index.js +1 -1
  481. package/lib/simple-tree/node-kinds/index.js.map +1 -1
  482. package/lib/simple-tree/node-kinds/object/index.d.ts +1 -1
  483. package/lib/simple-tree/node-kinds/object/index.d.ts.map +1 -1
  484. package/lib/simple-tree/node-kinds/object/index.js +1 -1
  485. package/lib/simple-tree/node-kinds/object/index.js.map +1 -1
  486. package/lib/simple-tree/node-kinds/object/objectNode.d.ts +2 -7
  487. package/lib/simple-tree/node-kinds/object/objectNode.d.ts.map +1 -1
  488. package/lib/simple-tree/node-kinds/object/objectNode.js +3 -16
  489. package/lib/simple-tree/node-kinds/object/objectNode.js.map +1 -1
  490. package/lib/simple-tree/prepareForInsertion.d.ts +5 -5
  491. package/lib/simple-tree/prepareForInsertion.d.ts.map +1 -1
  492. package/lib/simple-tree/prepareForInsertion.js +11 -5
  493. package/lib/simple-tree/prepareForInsertion.js.map +1 -1
  494. package/lib/simple-tree/toStoredSchema.d.ts +3 -0
  495. package/lib/simple-tree/toStoredSchema.d.ts.map +1 -1
  496. package/lib/simple-tree/toStoredSchema.js +3 -0
  497. package/lib/simple-tree/toStoredSchema.js.map +1 -1
  498. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts +2 -2
  499. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.d.ts.map +1 -1
  500. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js +1 -1
  501. package/lib/simple-tree/unhydratedFlexTreeFromInsertable.js.map +1 -1
  502. package/lib/simple-tree/walkFieldSchema.d.ts +1 -0
  503. package/lib/simple-tree/walkFieldSchema.d.ts.map +1 -1
  504. package/lib/simple-tree/walkFieldSchema.js +1 -0
  505. package/lib/simple-tree/walkFieldSchema.js.map +1 -1
  506. package/package.json +23 -23
  507. package/src/codec/codec.ts +4 -3
  508. package/src/core/index.ts +2 -0
  509. package/src/core/rebase/index.ts +2 -0
  510. package/src/core/rebase/types.ts +4 -0
  511. package/src/core/schema-stored/schema.ts +2 -26
  512. package/src/core/tree/detachedFieldIndex.ts +4 -6
  513. package/src/core/tree/detachedFieldIndexCodecCommon.ts +87 -0
  514. package/src/core/tree/{detachedFieldIndexCodec.ts → detachedFieldIndexCodecV1.ts} +22 -68
  515. package/src/core/tree/detachedFieldIndexCodecV2.ts +72 -0
  516. package/src/core/tree/detachedFieldIndexCodecs.ts +44 -0
  517. package/src/core/tree/{detachedFieldIndexFormat.ts → detachedFieldIndexFormatCommon.ts} +32 -23
  518. package/src/core/tree/detachedFieldIndexFormatV1.ts +15 -0
  519. package/src/core/tree/detachedFieldIndexFormatV2.ts +17 -0
  520. package/src/feature-libraries/chunked-forest/codec/README.md +1 -1
  521. package/src/feature-libraries/chunked-forest/codec/chunkDecoding.ts +25 -25
  522. package/src/feature-libraries/chunked-forest/codec/chunkDecodingGeneric.ts +10 -6
  523. package/src/feature-libraries/chunked-forest/codec/compressedEncode.ts +96 -73
  524. package/src/feature-libraries/chunked-forest/codec/format.ts +20 -14
  525. package/src/feature-libraries/chunked-forest/codec/{nodeShape.ts → nodeEncoder.ts} +23 -17
  526. package/src/feature-libraries/chunked-forest/codec/schemaBasedEncode.ts +34 -34
  527. package/src/feature-libraries/chunked-forest/codec/uncompressedEncode.ts +5 -5
  528. package/src/feature-libraries/default-schema/defaultFieldKinds.ts +10 -0
  529. package/src/feature-libraries/default-schema/defaultSchema.ts +0 -2
  530. package/src/feature-libraries/default-schema/index.ts +1 -1
  531. package/src/feature-libraries/default-schema/schemaChecker.ts +47 -30
  532. package/src/feature-libraries/index.ts +1 -18
  533. package/src/feature-libraries/modular-schema/comparison.ts +14 -33
  534. package/src/feature-libraries/modular-schema/index.ts +0 -17
  535. package/src/feature-libraries/object-forest/objectForest.ts +10 -6
  536. package/src/index.ts +5 -0
  537. package/src/packageVersion.ts +1 -1
  538. package/src/shared-tree/independentView.ts +45 -19
  539. package/src/shared-tree/schematizeTree.ts +3 -3
  540. package/src/shared-tree/schematizingTreeView.ts +17 -17
  541. package/src/shared-tree/sharedTree.ts +2 -42
  542. package/src/shared-tree/tree.ts +1 -1
  543. package/src/shared-tree/treeAlpha.ts +30 -18
  544. package/src/shared-tree/treeCheckout.ts +55 -11
  545. package/src/shared-tree-core/branch.ts +1 -6
  546. package/src/simple-tree/api/conciseTree.ts +9 -7
  547. package/src/simple-tree/api/configuration.ts +8 -2
  548. package/src/simple-tree/api/create.ts +49 -36
  549. package/src/simple-tree/api/customTree.ts +59 -20
  550. package/src/simple-tree/api/discrepancies.ts +473 -0
  551. package/src/simple-tree/api/schemaCompatibilityTester.ts +28 -242
  552. package/src/simple-tree/api/schemaCreationUtilities.ts +5 -2
  553. package/src/simple-tree/api/schemaFactory.ts +7 -4
  554. package/src/simple-tree/api/storedSchema.ts +6 -10
  555. package/src/simple-tree/api/treeBeta.ts +17 -4
  556. package/src/simple-tree/api/verboseTree.ts +17 -8
  557. package/src/simple-tree/core/allowedTypes.ts +54 -21
  558. package/src/simple-tree/core/context.ts +24 -22
  559. package/src/simple-tree/core/index.ts +2 -1
  560. package/src/simple-tree/core/treeNodeKernel.ts +1 -1
  561. package/src/simple-tree/core/treeNodeValid.ts +9 -2
  562. package/src/simple-tree/core/walkSchema.ts +3 -0
  563. package/src/simple-tree/createContext.ts +6 -1
  564. package/src/simple-tree/fieldSchema.ts +1 -0
  565. package/src/simple-tree/index.ts +6 -3
  566. package/src/simple-tree/node-kinds/array/arrayNode.ts +32 -19
  567. package/src/simple-tree/node-kinds/index.ts +1 -1
  568. package/src/simple-tree/node-kinds/object/index.ts +1 -1
  569. package/src/simple-tree/node-kinds/object/objectNode.ts +9 -27
  570. package/src/simple-tree/prepareForInsertion.ts +17 -9
  571. package/src/simple-tree/toStoredSchema.ts +3 -0
  572. package/src/simple-tree/unhydratedFlexTreeFromInsertable.ts +6 -2
  573. package/src/simple-tree/walkFieldSchema.ts +1 -0
  574. package/dist/core/tree/detachedFieldIndexCodec.d.ts +0 -11
  575. package/dist/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
  576. package/dist/core/tree/detachedFieldIndexCodec.js +0 -100
  577. package/dist/core/tree/detachedFieldIndexCodec.js.map +0 -1
  578. package/dist/core/tree/detachedFieldIndexFormat.d.ts +0 -33
  579. package/dist/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
  580. package/dist/core/tree/detachedFieldIndexFormat.js.map +0 -1
  581. package/dist/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
  582. package/dist/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
  583. package/dist/feature-libraries/initializeForest.d.ts +0 -18
  584. package/dist/feature-libraries/initializeForest.d.ts.map +0 -1
  585. package/dist/feature-libraries/initializeForest.js +0 -35
  586. package/dist/feature-libraries/initializeForest.js.map +0 -1
  587. package/dist/feature-libraries/modular-schema/discrepancies.d.ts +0 -174
  588. package/dist/feature-libraries/modular-schema/discrepancies.d.ts.map +0 -1
  589. package/dist/feature-libraries/modular-schema/discrepancies.js +0 -361
  590. package/dist/feature-libraries/modular-schema/discrepancies.js.map +0 -1
  591. package/lib/core/tree/detachedFieldIndexCodec.d.ts +0 -11
  592. package/lib/core/tree/detachedFieldIndexCodec.d.ts.map +0 -1
  593. package/lib/core/tree/detachedFieldIndexCodec.js +0 -96
  594. package/lib/core/tree/detachedFieldIndexCodec.js.map +0 -1
  595. package/lib/core/tree/detachedFieldIndexFormat.d.ts +0 -33
  596. package/lib/core/tree/detachedFieldIndexFormat.d.ts.map +0 -1
  597. package/lib/core/tree/detachedFieldIndexFormat.js.map +0 -1
  598. package/lib/feature-libraries/chunked-forest/codec/nodeShape.d.ts.map +0 -1
  599. package/lib/feature-libraries/chunked-forest/codec/nodeShape.js.map +0 -1
  600. package/lib/feature-libraries/initializeForest.d.ts +0 -18
  601. package/lib/feature-libraries/initializeForest.d.ts.map +0 -1
  602. package/lib/feature-libraries/initializeForest.js +0 -31
  603. package/lib/feature-libraries/initializeForest.js.map +0 -1
  604. package/lib/feature-libraries/modular-schema/discrepancies.d.ts +0 -174
  605. package/lib/feature-libraries/modular-schema/discrepancies.d.ts.map +0 -1
  606. package/lib/feature-libraries/modular-schema/discrepancies.js +0 -354
  607. package/lib/feature-libraries/modular-schema/discrepancies.js.map +0 -1
  608. package/src/feature-libraries/initializeForest.ts +0 -55
  609. package/src/feature-libraries/modular-schema/discrepancies.ts +0 -567
@@ -1,100 +0,0 @@
1
- "use strict";
2
- /*!
3
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
4
- * Licensed under the MIT License.
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.makeDetachedNodeToFieldCodec = void 0;
8
- const internal_1 = require("@fluidframework/core-utils/internal");
9
- const index_js_1 = require("../../codec/index.js");
10
- const index_js_2 = require("../../util/index.js");
11
- const detachedFieldIndexFormat_js_1 = require("./detachedFieldIndexFormat.js");
12
- class MajorCodec {
13
- constructor(revisionTagCodec, options, idCompressor) {
14
- this.revisionTagCodec = revisionTagCodec;
15
- this.options = options;
16
- this.idCompressor = idCompressor;
17
- }
18
- encode(major) {
19
- (0, internal_1.assert)(major !== undefined, 0x88e /* Unexpected undefined revision */);
20
- const id = this.revisionTagCodec.encode(major);
21
- /**
22
- * Preface: this codec is only used at summarization time (not for ops).
23
- * Note that the decode path must provide a session id in which to interpret the revision tag.
24
- * The revision associated with a detached root generally comes from the session which detaches that subtree,
25
- * which isn't generally the local session (nor is it available at decode time with the layering of the tree
26
- * package), despite decode using the local session id.
27
- *
28
- * This is made OK by enforcing that all ids on encode/decode are non-local, since local ids won't be interpretable
29
- * at decode time.
30
- * This assert is valid because the revision for an acked edit will have already been finalized, and a revision
31
- * for a local-only edit will be finalizable at summarization time (local edits can only occur on a summarizing client
32
- * if they're created while detached, and local ids made while detached are finalized before generating the attach summary).
33
- */
34
- (0, internal_1.assert)(id === "root" || id >= 0, 0x88f /* Expected final id on encode of detached field index revision */);
35
- return id;
36
- }
37
- decode(major) {
38
- (0, internal_1.assert)(major === "root" || major >= 0, 0x890 /* Expected final id on decode of detached field index revision */);
39
- return this.revisionTagCodec.decode(major, {
40
- originatorId: this.revisionTagCodec.localSessionId,
41
- idCompressor: this.idCompressor,
42
- revision: undefined,
43
- });
44
- }
45
- }
46
- function makeDetachedNodeToFieldCodec(revisionTagCodec, options, idCompressor) {
47
- const majorCodec = new MajorCodec(revisionTagCodec, options, idCompressor);
48
- return (0, index_js_1.makeVersionedValidatedCodec)(options, new Set([detachedFieldIndexFormat_js_1.version]), detachedFieldIndexFormat_js_1.Format, {
49
- encode: (data) => {
50
- const rootsForRevisions = [];
51
- for (const [major, innerMap] of data.data) {
52
- const encodedRevision = majorCodec.encode(major);
53
- const rootRanges = [];
54
- for (const [minor, detachedField] of innerMap) {
55
- rootRanges.push([minor, detachedField.root]);
56
- }
57
- if ((0, index_js_2.hasSingle)(rootRanges)) {
58
- const firstRootRange = rootRanges[0];
59
- const rootsForRevision = [
60
- encodedRevision,
61
- firstRootRange[0],
62
- firstRootRange[1],
63
- ];
64
- rootsForRevisions.push(rootsForRevision);
65
- }
66
- else {
67
- const rootsForRevision = [encodedRevision, rootRanges];
68
- rootsForRevisions.push(rootsForRevision);
69
- }
70
- }
71
- const encoded = {
72
- version: detachedFieldIndexFormat_js_1.version,
73
- data: rootsForRevisions,
74
- maxId: data.maxId,
75
- };
76
- return encoded;
77
- },
78
- decode: (parsed) => {
79
- const map = new Map();
80
- for (const rootsForRevision of parsed.data) {
81
- const innerMap = new Map();
82
- if (rootsForRevision.length === 2) {
83
- for (const [minor, root] of rootsForRevision[1]) {
84
- innerMap.set(minor, { root });
85
- }
86
- }
87
- else {
88
- innerMap.set(rootsForRevision[1], { root: rootsForRevision[2] });
89
- }
90
- map.set(majorCodec.decode(rootsForRevision[0]), innerMap);
91
- }
92
- return {
93
- data: map,
94
- maxId: parsed.maxId,
95
- };
96
- },
97
- });
98
- }
99
- exports.makeDetachedNodeToFieldCodec = makeDetachedNodeToFieldCodec;
100
- //# sourceMappingURL=detachedFieldIndexCodec.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"detachedFieldIndexCodec.js","sourceRoot":"","sources":["../../../src/core/tree/detachedFieldIndexCodec.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { assert } from \"@fluidframework/core-utils/internal\";\nimport type { IIdCompressor } from \"@fluidframework/id-compressor\";\n\nimport {\n\ttype ICodecOptions,\n\ttype IJsonCodec,\n\tmakeVersionedValidatedCodec,\n} from \"../../codec/index.js\";\nimport { hasSingle } from \"../../util/index.js\";\nimport type { EncodedRevisionTag, RevisionTagCodec, RevisionTag } from \"../rebase/index.js\";\n\nimport {\n\ttype EncodedRootsForRevision,\n\tFormat,\n\ttype RootRanges,\n\tversion,\n} from \"./detachedFieldIndexFormat.js\";\nimport type {\n\tDetachedField,\n\tDetachedFieldSummaryData,\n\tMajor,\n} from \"./detachedFieldIndexTypes.js\";\n\nclass MajorCodec implements IJsonCodec<Major> {\n\tpublic constructor(\n\t\tprivate readonly revisionTagCodec: RevisionTagCodec,\n\t\tprivate readonly options: ICodecOptions,\n\t\tprivate readonly idCompressor: IIdCompressor,\n\t) {}\n\n\tpublic encode(major: Major): EncodedRevisionTag {\n\t\tassert(major !== undefined, 0x88e /* Unexpected undefined revision */);\n\t\tconst id = this.revisionTagCodec.encode(major);\n\t\t/**\n\t\t * Preface: this codec is only used at summarization time (not for ops).\n\t\t * Note that the decode path must provide a session id in which to interpret the revision tag.\n\t\t * The revision associated with a detached root generally comes from the session which detaches that subtree,\n\t\t * which isn't generally the local session (nor is it available at decode time with the layering of the tree\n\t\t * package), despite decode using the local session id.\n\t\t *\n\t\t * This is made OK by enforcing that all ids on encode/decode are non-local, since local ids won't be interpretable\n\t\t * at decode time.\n\t\t * This assert is valid because the revision for an acked edit will have already been finalized, and a revision\n\t\t * for a local-only edit will be finalizable at summarization time (local edits can only occur on a summarizing client\n\t\t * if they're created while detached, and local ids made while detached are finalized before generating the attach summary).\n\t\t */\n\t\tassert(\n\t\t\tid === \"root\" || id >= 0,\n\t\t\t0x88f /* Expected final id on encode of detached field index revision */,\n\t\t);\n\t\treturn id;\n\t}\n\n\tpublic decode(major: EncodedRevisionTag): RevisionTag {\n\t\tassert(\n\t\t\tmajor === \"root\" || major >= 0,\n\t\t\t0x890 /* Expected final id on decode of detached field index revision */,\n\t\t);\n\t\treturn this.revisionTagCodec.decode(major, {\n\t\t\toriginatorId: this.revisionTagCodec.localSessionId,\n\t\t\tidCompressor: this.idCompressor,\n\t\t\trevision: undefined,\n\t\t});\n\t}\n}\n\nexport function makeDetachedNodeToFieldCodec(\n\trevisionTagCodec: RevisionTagCodec,\n\toptions: ICodecOptions,\n\tidCompressor: IIdCompressor,\n): IJsonCodec<DetachedFieldSummaryData, Format> {\n\tconst majorCodec = new MajorCodec(revisionTagCodec, options, idCompressor);\n\treturn makeVersionedValidatedCodec(options, new Set([version]), Format, {\n\t\tencode: (data: DetachedFieldSummaryData): Format => {\n\t\t\tconst rootsForRevisions: EncodedRootsForRevision[] = [];\n\t\t\tfor (const [major, innerMap] of data.data) {\n\t\t\t\tconst encodedRevision = majorCodec.encode(major);\n\t\t\t\tconst rootRanges: RootRanges = [];\n\t\t\t\tfor (const [minor, detachedField] of innerMap) {\n\t\t\t\t\trootRanges.push([minor, detachedField.root]);\n\t\t\t\t}\n\t\t\t\tif (hasSingle(rootRanges)) {\n\t\t\t\t\tconst firstRootRange = rootRanges[0];\n\t\t\t\t\tconst rootsForRevision: EncodedRootsForRevision = [\n\t\t\t\t\t\tencodedRevision,\n\t\t\t\t\t\tfirstRootRange[0],\n\t\t\t\t\t\tfirstRootRange[1],\n\t\t\t\t\t];\n\t\t\t\t\trootsForRevisions.push(rootsForRevision);\n\t\t\t\t} else {\n\t\t\t\t\tconst rootsForRevision: EncodedRootsForRevision = [encodedRevision, rootRanges];\n\t\t\t\t\trootsForRevisions.push(rootsForRevision);\n\t\t\t\t}\n\t\t\t}\n\t\t\tconst encoded: Format = {\n\t\t\t\tversion,\n\t\t\t\tdata: rootsForRevisions,\n\t\t\t\tmaxId: data.maxId,\n\t\t\t};\n\t\t\treturn encoded;\n\t\t},\n\t\tdecode: (parsed: Format): DetachedFieldSummaryData => {\n\t\t\tconst map = new Map();\n\t\t\tfor (const rootsForRevision of parsed.data) {\n\t\t\t\tconst innerMap = new Map<number, DetachedField>();\n\t\t\t\tif (rootsForRevision.length === 2) {\n\t\t\t\t\tfor (const [minor, root] of rootsForRevision[1]) {\n\t\t\t\t\t\tinnerMap.set(minor, { root });\n\t\t\t\t\t}\n\t\t\t\t} else {\n\t\t\t\t\tinnerMap.set(rootsForRevision[1], { root: rootsForRevision[2] });\n\t\t\t\t}\n\t\t\t\tmap.set(majorCodec.decode(rootsForRevision[0]), innerMap);\n\t\t\t}\n\t\t\treturn {\n\t\t\t\tdata: map,\n\t\t\t\tmaxId: parsed.maxId,\n\t\t\t};\n\t\t},\n\t});\n}\n"]}
@@ -1,33 +0,0 @@
1
- /*!
2
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
- * Licensed under the MIT License.
4
- */
5
- import { type Static } from "@sinclair/typebox";
6
- import type { ForestRootId } from "./detachedFieldIndexTypes.js";
7
- export declare const version = 1;
8
- /**
9
- * The ID of a detached node. Is not globally unique on.
10
- * A `RevisionTag` + `DetachId` pair is globally unique and eventually consistent across clients.
11
- */
12
- export declare const DetachId: import("@sinclair/typebox").TNumber;
13
- /**
14
- * A mapping from a range of the detached node IDs the corresponding range root IDs.
15
- * The detached node IDs need to be qualified with a revision (stored in the containing `EncodedRootsForRevision`).
16
- * Note: the length of the range (currently always 1) can be looked up in the forest.
17
- */
18
- export declare const RootRange: import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TNumber, import("@sinclair/typebox").TUnsafe<ForestRootId>]>;
19
- export type RootRange = Static<typeof RootRange>;
20
- export declare const RootRanges: import("@sinclair/typebox").TArray<import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TNumber, import("@sinclair/typebox").TUnsafe<ForestRootId>]>>;
21
- export type RootRanges = Static<typeof RootRanges>;
22
- /**
23
- * For all the roots detached in a revision, represents a mapping from the detached node ID to corresponding root ID.
24
- */
25
- export declare const EncodedRootsForRevision: import("@sinclair/typebox").TUnion<[import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TUnion<[import("@sinclair/typebox").TLiteral<"root">, import("@sinclair/typebox").TUnsafe<import("../../util/brand.js").Brand<import("@fluidframework/id-compressor").OpSpaceCompressedId, "EncodedRevisionTag">>]>, import("@sinclair/typebox").TArray<import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TNumber, import("@sinclair/typebox").TUnsafe<ForestRootId>]>>]>, import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TUnion<[import("@sinclair/typebox").TLiteral<"root">, import("@sinclair/typebox").TUnsafe<import("../../util/brand.js").Brand<import("@fluidframework/id-compressor").OpSpaceCompressedId, "EncodedRevisionTag">>]>, import("@sinclair/typebox").TNumber, import("@sinclair/typebox").TUnsafe<ForestRootId>]>]>;
26
- export type EncodedRootsForRevision = Static<typeof EncodedRootsForRevision>;
27
- export declare const Format: import("@sinclair/typebox").TObject<{
28
- version: import("@sinclair/typebox").TLiteral<1>;
29
- data: import("@sinclair/typebox").TArray<import("@sinclair/typebox").TUnion<[import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TUnion<[import("@sinclair/typebox").TLiteral<"root">, import("@sinclair/typebox").TUnsafe<import("../../util/brand.js").Brand<import("@fluidframework/id-compressor").OpSpaceCompressedId, "EncodedRevisionTag">>]>, import("@sinclair/typebox").TArray<import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TNumber, import("@sinclair/typebox").TUnsafe<ForestRootId>]>>]>, import("@sinclair/typebox").TTuple<[import("@sinclair/typebox").TUnion<[import("@sinclair/typebox").TLiteral<"root">, import("@sinclair/typebox").TUnsafe<import("../../util/brand.js").Brand<import("@fluidframework/id-compressor").OpSpaceCompressedId, "EncodedRevisionTag">>]>, import("@sinclair/typebox").TNumber, import("@sinclair/typebox").TUnsafe<ForestRootId>]>]>>;
30
- maxId: import("@sinclair/typebox").TUnsafe<ForestRootId>;
31
- }>;
32
- export type Format = Static<typeof Format>;
33
- //# sourceMappingURL=detachedFieldIndexFormat.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"detachedFieldIndexFormat.d.ts","sourceRoot":"","sources":["../../../src/core/tree/detachedFieldIndexFormat.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,KAAK,MAAM,EAAQ,MAAM,mBAAmB,CAAC;AAKtD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAEjE,eAAO,MAAM,OAAO,IAAM,CAAC;AAE3B;;;GAGG;AACH,eAAO,MAAM,QAAQ,qCAAiC,CAAC;AAQvD;;;;GAIG;AACH,eAAO,MAAM,SAAS,8HAKpB,CAAC;AACH,MAAM,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,SAAS,CAAC,CAAC;AAEjD,eAAO,MAAM,UAAU,kKAAwB,CAAC;AAChD,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,OAAO,UAAU,CAAC,CAAC;AAEnD;;GAEG;AACH,eAAO,MAAM,uBAAuB,80BAKlC,CAAC;AACH,MAAM,MAAM,uBAAuB,GAAG,MAAM,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAE7E,eAAO,MAAM,MAAM;;;;EAOlB,CAAC;AAEF,MAAM,MAAM,MAAM,GAAG,MAAM,CAAC,OAAO,MAAM,CAAC,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"detachedFieldIndexFormat.js","sourceRoot":"","sources":["../../../src/core/tree/detachedFieldIndexFormat.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,+CAAsD;AAEtD,kDAAwD;AACxD,iDAAuD;AAI1C,QAAA,OAAO,GAAG,GAAG,CAAC;AAE3B;;;GAGG;AACU,QAAA,QAAQ,GAAG,cAAI,CAAC,MAAM,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;AAEvD;;;GAGG;AACH,MAAM,kBAAkB,GAAG,IAAA,4BAAiB,EAAe,EAAE,OAAO,EAAE,CAAC,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,CAAC,CAAC;AAE3F;;;;GAIG;AACU,QAAA,SAAS,GAAG,cAAI,CAAC,KAAK,CAAC;IACnC,iCAAiC;IACjC,gBAAQ;IACR,6BAA6B;IAC7B,kBAAkB;CAClB,CAAC,CAAC;AAGU,QAAA,UAAU,GAAG,cAAI,CAAC,KAAK,CAAC,iBAAS,CAAC,CAAC;AAGhD;;GAEG;AACU,QAAA,uBAAuB,GAAG,cAAI,CAAC,KAAK,CAAC;IACjD,yEAAyE;IACzE,cAAI,CAAC,KAAK,CAAC,CAAC,4BAAiB,EAAE,kBAAU,CAAC,CAAC;IAC3C,mEAAmE;IACnE,cAAI,CAAC,KAAK,CAAC,CAAC,4BAAiB,EAAE,gBAAQ,EAAE,kBAAkB,CAAC,CAAC;CAC7D,CAAC,CAAC;AAGU,QAAA,MAAM,GAAG,cAAI,CAAC,MAAM,CAChC;IACC,OAAO,EAAE,cAAI,CAAC,OAAO,CAAC,eAAO,CAAC;IAC9B,IAAI,EAAE,cAAI,CAAC,KAAK,CAAC,+BAAuB,CAAC;IACzC,KAAK,EAAE,kBAAkB;CACzB,EACD,EAAE,oBAAoB,EAAE,KAAK,EAAE,CAC/B,CAAC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { type Static, Type } from \"@sinclair/typebox\";\n\nimport { brandedNumberType } from \"../../util/index.js\";\nimport { RevisionTagSchema } from \"../rebase/index.js\";\n\nimport type { ForestRootId } from \"./detachedFieldIndexTypes.js\";\n\nexport const version = 1.0;\n\n/**\n * The ID of a detached node. Is not globally unique on.\n * A `RevisionTag` + `DetachId` pair is globally unique and eventually consistent across clients.\n */\nexport const DetachId = Type.Number({ multipleOf: 1 });\n\n/**\n * The ID of a root node in the forest associated with the owning checkout. Is unique for that forest.\n * Is not consistent across clients.\n */\nconst ForestRootIdSchema = brandedNumberType<ForestRootId>({ minimum: -1, multipleOf: 1 });\n\n/**\n * A mapping from a range of the detached node IDs the corresponding range root IDs.\n * The detached node IDs need to be qualified with a revision (stored in the containing `EncodedRootsForRevision`).\n * Note: the length of the range (currently always 1) can be looked up in the forest.\n */\nexport const RootRange = Type.Tuple([\n\t// ID for the first detached node\n\tDetachId,\n\t// ID for the first root node\n\tForestRootIdSchema,\n]);\nexport type RootRange = Static<typeof RootRange>;\n\nexport const RootRanges = Type.Array(RootRange);\nexport type RootRanges = Static<typeof RootRanges>;\n\n/**\n * For all the roots detached in a revision, represents a mapping from the detached node ID to corresponding root ID.\n */\nexport const EncodedRootsForRevision = Type.Union([\n\t// Used to represent a revision in which more than one node were detached\n\tType.Tuple([RevisionTagSchema, RootRanges]),\n\t// Used to represent a revision in which a single node was detached\n\tType.Tuple([RevisionTagSchema, DetachId, ForestRootIdSchema]),\n]);\nexport type EncodedRootsForRevision = Static<typeof EncodedRootsForRevision>;\n\nexport const Format = Type.Object(\n\t{\n\t\tversion: Type.Literal(version),\n\t\tdata: Type.Array(EncodedRootsForRevision),\n\t\tmaxId: ForestRootIdSchema,\n\t},\n\t{ additionalProperties: false },\n);\n\nexport type Format = Static<typeof Format>;\n"]}
@@ -1 +0,0 @@
1
- {"version":3,"file":"nodeShape.d.ts","sourceRoot":"","sources":["../../../../src/feature-libraries/chunked-forest/codec/nodeShape.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAKH,OAAO,EAEN,KAAK,sBAAsB,EAC3B,KAAK,wBAAwB,EAG7B,MAAM,wBAAwB,CAAC;AAGhC,OAAO,KAAK,EAAE,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC5E,OAAO,EAAE,KAAK,YAAY,EAAmB,KAAK,EAAE,MAAM,2BAA2B,CAAC;AACtF,OAAO,EACN,KAAK,YAAY,EACjB,KAAK,YAAY,EACjB,KAAK,iBAAiB,EACtB,KAAK,WAAW,EAEhB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,KAAK,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAE3F,qBAAa,SAAU,SAAQ,KAAK,CAAC,iBAAiB,CAAE,YAAW,WAAW;aAQ5D,IAAI,EAAE,SAAS,GAAG,wBAAwB;aAC1C,KAAK,EAAE,iBAAiB;IACxC;;;;;;;;;;OAUG;aACa,wBAAwB,EAAE,SAAS,iBAAiB,EAAE;IACtE;;;OAGG;aACa,kBAAkB,EAAE,SAAS,GAAG,YAAY;IAzB7D;;;OAGG;IACH,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAgB;gBAGpC,IAAI,EAAE,SAAS,GAAG,wBAAwB,EAC1C,KAAK,EAAE,iBAAiB;IACxC;;;;;;;;;;OAUG;IACa,wBAAwB,EAAE,SAAS,iBAAiB,EAAE;IACtE;;;OAGG;IACa,kBAAkB,EAAE,SAAS,GAAG,YAAY;IAM7D,OAAO,CAAC,gBAAgB;IAajB,UAAU,CAChB,MAAM,EAAE,sBAAsB,EAC9B,KAAK,EAAE,YAAY,EACnB,YAAY,EAAE,YAAY,CAAC,iBAAiB,CAAC,GAC3C,IAAI;IAgCA,WAAW,CACjB,WAAW,EAAE,kBAAkB,CAAC,MAAM,CAAC,EACvC,MAAM,EAAE,kBAAkB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,GAClD,iBAAiB;IAWb,mCAAmC,CACzC,WAAW,EAAE,OAAO,CAAC,MAAM,CAAC,EAC5B,eAAe,EAAE,CAAC,KAAK,EAAE,KAAK,CAAC,iBAAiB,CAAC,KAAK,IAAI,GACxD,IAAI;IAeP,IAAW,KAAK,IAAI,SAAS,CAE5B;CACD;AAED,wBAAgB,iBAAiB,CAChC,aAAa,EAAE,SAAS,iBAAiB,EAAE,EAC3C,WAAW,EAAE,kBAAkB,CAAC,MAAM,CAAC,EACvC,MAAM,EAAE,kBAAkB,CAAC,KAAK,CAAC,iBAAiB,CAAC,CAAC,GAClD,iBAAiB,EAAE,GAAG,SAAS,CAUjC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"nodeShape.js","sourceRoot":"","sources":["../../../../src/feature-libraries/chunked-forest/codec/nodeShape.ts"],"names":[],"mappings":"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","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { assert, fail } from \"@fluidframework/core-utils/internal\";\nimport { isStableId } from \"@fluidframework/id-compressor/internal\";\n\nimport {\n\ttype FieldKey,\n\ttype ITreeCursorSynchronous,\n\ttype TreeNodeSchemaIdentifier,\n\tforEachField,\n\ttype Value,\n} from \"../../../core/index.js\";\nimport { brand } from \"../../../util/index.js\";\n\nimport type { Counter, DeduplicationTable } from \"./chunkCodecUtilities.js\";\nimport { type BufferFormat, IdentifierToken, Shape } from \"./chunkEncodingGeneric.js\";\nimport {\n\ttype EncoderCache,\n\ttype FieldEncoder,\n\ttype KeyedFieldEncoder,\n\ttype NodeEncoder,\n\tencodeValue,\n} from \"./compressedEncode.js\";\nimport type { EncodedChunkShape, EncodedFieldShape, EncodedValueShape } from \"./format.js\";\n\nexport class NodeShape extends Shape<EncodedChunkShape> implements NodeEncoder {\n\t/**\n\t * Set of keys for fields that are encoded using {@link NodeShape.specializedFieldEncoders}.\n\t * TODO: Ensure uniform chunks, encoding and identifier generation sort fields the same.\n\t */\n\tprivate readonly specializedFieldKeys: Set<FieldKey>;\n\n\tpublic constructor(\n\t\tpublic readonly type: undefined | TreeNodeSchemaIdentifier,\n\t\tpublic readonly value: EncodedValueShape,\n\t\t/**\n\t\t * Encoders for a specific set of fields, by key, in the order they will be encoded.\n\t\t * These are fields for which specialized encoding is provided as an optimization.\n\t\t * Using these for a given field instead of falling back to {@link NodeShape.specializedFieldEncoders} is often more efficient:\n\t\t * this avoids the need to explicitly include the key and shape in the encoded data for each node instance.\n\t\t * Instead, this information is here, and thus is encoded only once as part of the node shape.\n\t\t * These encoders will be used, even if the field they apply to is empty (which can add overhead for fields which are usually empty).\n\t\t *\n\t\t * Any fields not included here will be encoded using {@link NodeShape.otherFieldsEncoder}.\n\t\t * If {@link NodeShape.otherFieldsEncoder} is undefined, then this must handle all non-empty fields.\n\t\t */\n\t\tpublic readonly specializedFieldEncoders: readonly KeyedFieldEncoder[],\n\t\t/**\n\t\t * Encoder for all other fields that are not in {@link NodeShape.specializedFieldEncoders}. These fields must\n\t\t * be encoded after the specialized fields.\n\t\t */\n\t\tpublic readonly otherFieldsEncoder: undefined | FieldEncoder,\n\t) {\n\t\tsuper();\n\t\tthis.specializedFieldKeys = new Set(this.specializedFieldEncoders.map((f) => f.key));\n\t}\n\n\tprivate getValueToEncode(cursor: ITreeCursorSynchronous, cache: EncoderCache): Value {\n\t\tif (this.value === 0) {\n\t\t\tassert(typeof cursor.value === \"string\", 0x9aa /* identifier must be type string */);\n\t\t\tif (isStableId(cursor.value)) {\n\t\t\t\tconst sessionSpaceCompressedId = cache.idCompressor.tryRecompress(cursor.value);\n\t\t\t\tif (sessionSpaceCompressedId !== undefined) {\n\t\t\t\t\treturn cache.idCompressor.normalizeToOpSpace(sessionSpaceCompressedId);\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\treturn cursor.value;\n\t}\n\n\tpublic encodeNode(\n\t\tcursor: ITreeCursorSynchronous,\n\t\tcache: EncoderCache,\n\t\toutputBuffer: BufferFormat<EncodedChunkShape>,\n\t): void {\n\t\tif (this.type === undefined) {\n\t\t\toutputBuffer.push(new IdentifierToken(cursor.type));\n\t\t} else {\n\t\t\tassert(cursor.type === this.type, 0x741 /* type must match shape */);\n\t\t}\n\t\tencodeValue(this.getValueToEncode(cursor, cache), this.value, outputBuffer);\n\t\tfor (const fieldEncoder of this.specializedFieldEncoders) {\n\t\t\tcursor.enterField(brand(fieldEncoder.key));\n\t\t\tfieldEncoder.encoder.encodeField(cursor, cache, outputBuffer);\n\t\t\tcursor.exitField();\n\t\t}\n\n\t\tconst otherFieldsBuffer: BufferFormat<EncodedChunkShape> = [];\n\n\t\tforEachField(cursor, () => {\n\t\t\tconst key = cursor.getFieldKey();\n\t\t\tif (!this.specializedFieldKeys.has(key)) {\n\t\t\t\tassert(\n\t\t\t\t\tthis.otherFieldsEncoder !== undefined,\n\t\t\t\t\t0x742 /* had extra local fields when shape does not support them */,\n\t\t\t\t);\n\t\t\t\totherFieldsBuffer.push(new IdentifierToken(key));\n\t\t\t\tthis.otherFieldsEncoder.encodeField(cursor, cache, otherFieldsBuffer);\n\t\t\t}\n\t\t});\n\n\t\tif (this.otherFieldsEncoder !== undefined) {\n\t\t\toutputBuffer.push(otherFieldsBuffer);\n\t\t}\n\t}\n\n\tpublic encodeShape(\n\t\tidentifiers: DeduplicationTable<string>,\n\t\tshapes: DeduplicationTable<Shape<EncodedChunkShape>>,\n\t): EncodedChunkShape {\n\t\treturn {\n\t\t\tc: {\n\t\t\t\ttype: encodeOptionalIdentifier(this.type, identifiers),\n\t\t\t\tvalue: this.value,\n\t\t\t\tfields: encodeFieldShapes(this.specializedFieldEncoders, identifiers, shapes),\n\t\t\t\textraFields: encodeOptionalFieldShape(this.otherFieldsEncoder, shapes),\n\t\t\t},\n\t\t};\n\t}\n\n\tpublic countReferencedShapesAndIdentifiers(\n\t\tidentifiers: Counter<string>,\n\t\tshapeDiscovered: (shape: Shape<EncodedChunkShape>) => void,\n\t): void {\n\t\tif (this.type !== undefined) {\n\t\t\tidentifiers.add(this.type);\n\t\t}\n\n\t\tfor (const fieldEncoder of this.specializedFieldEncoders) {\n\t\t\tidentifiers.add(fieldEncoder.key);\n\t\t\tshapeDiscovered(fieldEncoder.encoder.shape);\n\t\t}\n\n\t\tif (this.otherFieldsEncoder !== undefined) {\n\t\t\tshapeDiscovered(this.otherFieldsEncoder.shape);\n\t\t}\n\t}\n\n\tpublic get shape(): NodeShape {\n\t\treturn this;\n\t}\n}\n\nexport function encodeFieldShapes(\n\tfieldEncoders: readonly KeyedFieldEncoder[],\n\tidentifiers: DeduplicationTable<string>,\n\tshapes: DeduplicationTable<Shape<EncodedChunkShape>>,\n): EncodedFieldShape[] | undefined {\n\tif (fieldEncoders.length === 0) {\n\t\treturn undefined;\n\t}\n\treturn fieldEncoders.map((fieldEncoder) => [\n\t\t// key\n\t\tencodeIdentifier(fieldEncoder.key, identifiers),\n\t\t// shape\n\t\tshapes.valueToIndex.get(fieldEncoder.encoder.shape) ?? fail(0xb50 /* missing shape */),\n\t]);\n}\n\nfunction encodeIdentifier(\n\tidentifier: string,\n\tidentifiers: DeduplicationTable<string>,\n): string | number {\n\treturn identifiers.valueToIndex.get(identifier) ?? identifier;\n}\n\nfunction encodeOptionalIdentifier(\n\tidentifier: string | undefined,\n\tidentifiers: DeduplicationTable<string>,\n): string | number | undefined {\n\treturn identifier === undefined ? undefined : encodeIdentifier(identifier, identifiers);\n}\n\nfunction encodeOptionalFieldShape(\n\tshape: FieldEncoder | undefined,\n\tshapes: DeduplicationTable<Shape<EncodedChunkShape>>,\n): number | undefined {\n\treturn shape === undefined ? undefined : dedupShape(shape.shape, shapes);\n}\n\nfunction dedupShape(\n\tshape: Shape<EncodedChunkShape>,\n\tshapes: DeduplicationTable<Shape<EncodedChunkShape>>,\n): number {\n\treturn shapes.valueToIndex.get(shape) ?? fail(0xb51 /* missing shape */);\n}\n"]}
@@ -1,18 +0,0 @@
1
- /*!
2
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
- * Licensed under the MIT License.
4
- */
5
- import type { IIdCompressor } from "@fluidframework/id-compressor";
6
- import { type IEditableForest, type ITreeCursorSynchronous, type RevisionTagCodec } from "../core/index.js";
7
- /**
8
- * Initializes the given forest with the given content.
9
- * @remarks The forest must be empty when this function is called.
10
- * This does not perform an edit in the typical sense.
11
- * Instead, it creates a delta expressing a creation and insertion of the `content` under the {@link rootFieldKey}, and then applies the delta to the forest.
12
- * If `visitAnchors` is enabled, then the delta will also be applied to the forest's {@link AnchorSet} (in which case there must be no existing anchors when this function is called).
13
- *
14
- * @remarks
15
- * This does not perform an edit: it updates the forest content as if there was an edit that did that.
16
- */
17
- export declare function initializeForest(forest: IEditableForest, content: ITreeCursorSynchronous, revisionTagCodec: RevisionTagCodec, idCompressor: IIdCompressor, visitAnchors?: boolean): void;
18
- //# sourceMappingURL=initializeForest.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"initializeForest.d.ts","sourceRoot":"","sources":["../../src/feature-libraries/initializeForest.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAA4B,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAE7F,OAAO,EAEN,KAAK,eAAe,EACpB,KAAK,sBAAsB,EAC3B,KAAK,gBAAgB,EAKrB,MAAM,kBAAkB,CAAC;AAE1B;;;;;;;;;GASG;AACH,wBAAgB,gBAAgB,CAC/B,MAAM,EAAE,eAAe,EACvB,OAAO,EAAE,sBAAsB,EAC/B,gBAAgB,EAAE,gBAAgB,EAClC,YAAY,EAAE,aAAa,EAC3B,YAAY,UAAQ,GAClB,IAAI,CAmBN"}
@@ -1,35 +0,0 @@
1
- "use strict";
2
- /*!
3
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
4
- * Licensed under the MIT License.
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.initializeForest = void 0;
8
- const internal_1 = require("@fluidframework/core-utils/internal");
9
- const index_js_1 = require("../core/index.js");
10
- /**
11
- * Initializes the given forest with the given content.
12
- * @remarks The forest must be empty when this function is called.
13
- * This does not perform an edit in the typical sense.
14
- * Instead, it creates a delta expressing a creation and insertion of the `content` under the {@link rootFieldKey}, and then applies the delta to the forest.
15
- * If `visitAnchors` is enabled, then the delta will also be applied to the forest's {@link AnchorSet} (in which case there must be no existing anchors when this function is called).
16
- *
17
- * @remarks
18
- * This does not perform an edit: it updates the forest content as if there was an edit that did that.
19
- */
20
- function initializeForest(forest, content, revisionTagCodec, idCompressor, visitAnchors = false) {
21
- (0, internal_1.assert)(forest.isEmpty, 0x747 /* forest must be empty */);
22
- const delta = (0, index_js_1.deltaForRootInitialization)(forest.chunkField(content));
23
- let visitor = forest.acquireVisitor();
24
- if (visitAnchors) {
25
- (0, internal_1.assert)(forest.anchors.isEmpty(), 0x9b7 /* anchor set must be empty */);
26
- const anchorVisitor = forest.anchors.acquireVisitor();
27
- visitor = (0, index_js_1.combineVisitors)([visitor, anchorVisitor]);
28
- }
29
- // any detached trees built here are immediately attached so the revision used here doesn't matter
30
- // we use a dummy revision to make correctness checks in the detached field index easier
31
- (0, index_js_1.visitDelta)(delta, visitor, (0, index_js_1.makeDetachedFieldIndex)("init", revisionTagCodec, idCompressor), 0);
32
- visitor.free();
33
- }
34
- exports.initializeForest = initializeForest;
35
- //# sourceMappingURL=initializeForest.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"initializeForest.js","sourceRoot":"","sources":["../../src/feature-libraries/initializeForest.ts"],"names":[],"mappings":";AAAA;;;GAGG;;;AAEH,kEAA6D;AAG7D,+CAS0B;AAE1B;;;;;;;;;GASG;AACH,SAAgB,gBAAgB,CAC/B,MAAuB,EACvB,OAA+B,EAC/B,gBAAkC,EAClC,YAA2B,EAC3B,YAAY,GAAG,KAAK;IAEpB,IAAA,iBAAM,EAAC,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,0BAA0B,CAAC,CAAC;IACzD,MAAM,KAAK,GAAc,IAAA,qCAA0B,EAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC;IAChF,IAAI,OAAO,GAAG,MAAM,CAAC,cAAc,EAAE,CAAC;IACtC,IAAI,YAAY,EAAE,CAAC;QAClB,IAAA,iBAAM,EAAC,MAAM,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,KAAK,CAAC,8BAA8B,CAAC,CAAC;QACvE,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC;QACtD,OAAO,GAAG,IAAA,0BAAe,EAAC,CAAC,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC;IACrD,CAAC;IAED,kGAAkG;IAClG,wFAAwF;IACxF,IAAA,qBAAU,EACT,KAAK,EACL,OAAO,EACP,IAAA,iCAAsB,EAAC,MAAM,EAAE,gBAAgB,EAAE,YAAY,CAAC,EAC9D,CAA6B,CAC7B,CAAC;IACF,OAAO,CAAC,IAAI,EAAE,CAAC;AAChB,CAAC;AAzBD,4CAyBC","sourcesContent":["/*!\n * Copyright (c) Microsoft Corporation and contributors. All rights reserved.\n * Licensed under the MIT License.\n */\n\nimport { assert } from \"@fluidframework/core-utils/internal\";\nimport type { SessionSpaceCompressedId, IIdCompressor } from \"@fluidframework/id-compressor\";\n\nimport {\n\ttype DeltaRoot,\n\ttype IEditableForest,\n\ttype ITreeCursorSynchronous,\n\ttype RevisionTagCodec,\n\tcombineVisitors,\n\tdeltaForRootInitialization,\n\tmakeDetachedFieldIndex,\n\tvisitDelta,\n} from \"../core/index.js\";\n\n/**\n * Initializes the given forest with the given content.\n * @remarks The forest must be empty when this function is called.\n * This does not perform an edit in the typical sense.\n * Instead, it creates a delta expressing a creation and insertion of the `content` under the {@link rootFieldKey}, and then applies the delta to the forest.\n * If `visitAnchors` is enabled, then the delta will also be applied to the forest's {@link AnchorSet} (in which case there must be no existing anchors when this function is called).\n *\n * @remarks\n * This does not perform an edit: it updates the forest content as if there was an edit that did that.\n */\nexport function initializeForest(\n\tforest: IEditableForest,\n\tcontent: ITreeCursorSynchronous,\n\trevisionTagCodec: RevisionTagCodec,\n\tidCompressor: IIdCompressor,\n\tvisitAnchors = false,\n): void {\n\tassert(forest.isEmpty, 0x747 /* forest must be empty */);\n\tconst delta: DeltaRoot = deltaForRootInitialization(forest.chunkField(content));\n\tlet visitor = forest.acquireVisitor();\n\tif (visitAnchors) {\n\t\tassert(forest.anchors.isEmpty(), 0x9b7 /* anchor set must be empty */);\n\t\tconst anchorVisitor = forest.anchors.acquireVisitor();\n\t\tvisitor = combineVisitors([visitor, anchorVisitor]);\n\t}\n\n\t// any detached trees built here are immediately attached so the revision used here doesn't matter\n\t// we use a dummy revision to make correctness checks in the detached field index easier\n\tvisitDelta(\n\t\tdelta,\n\t\tvisitor,\n\t\tmakeDetachedFieldIndex(\"init\", revisionTagCodec, idCompressor),\n\t\t0 as SessionSpaceCompressedId,\n\t);\n\tvisitor.free();\n}\n"]}
@@ -1,174 +0,0 @@
1
- /*!
2
- * Copyright (c) Microsoft Corporation and contributors. All rights reserved.
3
- * Licensed under the MIT License.
4
- */
5
- import { type FieldKey, type FieldKindIdentifier, type TreeNodeSchemaIdentifier, type TreeStoredSchema, type ValueSchema } from "../../core/index.js";
6
- /**
7
- * Discriminated union (keyed on `mismatch`) of discrepancies between a view and stored schema.
8
- * @remarks
9
- *
10
- * 1. FieldDiscrepancy
11
- *
12
- * `FieldDiscrepancy` represents the differences between two `TreeFieldStoredSchema` objects. It consists of
13
- * three types of incompatibilities:
14
- *
15
- * - FieldKindDiscrepancy: Indicates the differences in `FieldKindIdentifier` between two `TreeFieldStoredSchema`
16
- * objects (e.g., optional, required, sequence, etc.).
17
- * - AllowedTypesDiscrepancy: Indicates the differences in the allowed child types between the two schemas.
18
- * - ValueSchemaDiscrepancy: Specifically indicates the differences in the `ValueSchema` of two
19
- * `LeafNodeStoredSchema` objects.
20
- *
21
- * 2. NodeDiscrepancy
22
- *
23
- * `NodeDiscrepancy` represents the differences between two `TreeNodeStoredSchema` objects and includes:
24
- *
25
- * - NodeKindDiscrepancy: Indicates the differences in the types of `TreeNodeStoredSchema` (currently supports
26
- * `ObjectNodeStoredSchema`, `MapNodeStoredSchema`, and `LeafNodeStoredSchema`).
27
- * - NodeFieldsDiscrepancy: Indicates the `FieldDiscrepancy` of `TreeFieldStoredSchema` within two
28
- * `TreeNodeStoredSchema`. It includes an array of `FieldDiscrepancy` instances in the `differences` field.
29
- *
30
- * When comparing two nodes for compatibility, it only makes sense to compare their fields if the nodes are of
31
- * the same kind (map, object, leaf).
32
- *
33
- * 3. Discrepancy
34
- *
35
- * Discrepancy consists of both `NodeDiscrepancy` and `FieldDiscrepancy`, representing any kind of
36
- * schema differences. See {@link getAllowedContentDiscrepancies} for more details about how we process it
37
- * and the ordering.
38
- */
39
- export type Discrepancy = FieldDiscrepancy | NodeDiscrepancy;
40
- export type NodeDiscrepancy = NodeKindDiscrepancy | NodeFieldsDiscrepancy;
41
- /**
42
- * A discrepancy in the declaration of a field.
43
- */
44
- export type FieldDiscrepancy = AllowedTypeDiscrepancy | FieldKindDiscrepancy | ValueSchemaDiscrepancy;
45
- /**
46
- * Information about where a field discrepancy is located within a collection of schema.
47
- */
48
- export interface FieldDiscrepancyLocation {
49
- /**
50
- * The {@link TreeNodeSchemaIdentifier} that contains the discrepancy.
51
- *
52
- * Undefined iff the discrepancy is part of the root field schema.
53
- */
54
- identifier: TreeNodeSchemaIdentifier | undefined;
55
- /**
56
- * The {@link FieldKey} for the field that contains the discrepancy.
57
- * Undefined when:
58
- * - the discrepancy is part of the root field schema
59
- * - the discrepancy is for 'all fields' of a map node
60
- */
61
- fieldKey: FieldKey | undefined;
62
- }
63
- /**
64
- * A discrepancy in the allowed types of a field.
65
- *
66
- * @remarks
67
- * This reports the symmetric difference of allowed types in view/stored to enable more efficient checks for compatibility
68
- */
69
- export interface AllowedTypeDiscrepancy extends FieldDiscrepancyLocation {
70
- mismatch: "allowedTypes";
71
- /**
72
- * List of allowed type identifiers in viewed schema which are not allowed in stored schema
73
- */
74
- view: TreeNodeSchemaIdentifier[];
75
- /**
76
- * List of allowed type identifiers in stored schema which are not allowed in view schema
77
- */
78
- stored: TreeNodeSchemaIdentifier[];
79
- }
80
- export interface FieldKindDiscrepancy extends FieldDiscrepancyLocation {
81
- mismatch: "fieldKind";
82
- view: FieldKindIdentifier;
83
- stored: FieldKindIdentifier;
84
- }
85
- export interface ValueSchemaDiscrepancy {
86
- identifier: TreeNodeSchemaIdentifier;
87
- mismatch: "valueSchema";
88
- view: ValueSchema | undefined;
89
- stored: ValueSchema | undefined;
90
- }
91
- export interface NodeKindDiscrepancy {
92
- identifier: TreeNodeSchemaIdentifier;
93
- mismatch: "nodeKind";
94
- view: SchemaFactoryNodeKind | undefined;
95
- stored: SchemaFactoryNodeKind | undefined;
96
- }
97
- export interface NodeFieldsDiscrepancy {
98
- identifier: TreeNodeSchemaIdentifier;
99
- mismatch: "fields";
100
- differences: FieldDiscrepancy[];
101
- }
102
- type SchemaFactoryNodeKind = "object" | "leaf" | "map";
103
- /**
104
- * Finds and reports discrepancies between a view schema and a stored schema.
105
- *
106
- * See documentation on {@link Discrepancy} for details of possible discrepancies.
107
- * @remarks
108
- * This function does not attempt to distinguish between equivalent representations of a node/field involving extraneous never trees.
109
- * For example, a Forbidden field with allowed type set `[]` is equivalent to an optional field with allowed type set `[]`,
110
- * as well as an optional field with an allowed type set containing only unconstructable types.
111
- *
112
- * It is up to the caller to determine whether such discrepancies matter.
113
- */
114
- export declare function getAllowedContentDiscrepancies(view: TreeStoredSchema, stored: TreeStoredSchema): Iterable<Discrepancy>;
115
- /**
116
- * @remarks
117
- *
118
- * This function uses incompatibilities to determine if changes to a document schema are backward-compatible, i.e., it determines
119
- * whether the `view` schema allows a superset of the documents that the `stored` schema allows.
120
- * According to the policy of schema evolution, `isRepoSuperset` supports three types of changes:
121
- * 1. Adding an optional field to an object node.
122
- * 2. Expanding the set of allowed types for a field.
123
- * 3. Relaxing a field kind to a more general field kind.
124
- *
125
- * Notes: We expect isRepoSuperset to return consistent results with allowsRepoSuperset. However, currently there are some scenarios
126
- * where the inconsistency will occur:
127
- *
128
- * - Different Node Kinds: If a and b have different node kinds (e.g., a is an objectNodeSchema and b is a mapNodeSchema),
129
- * `isRepoSuperset` will determine that a can never be the superset of b. In contrast, `allowsRepoSuperset` will continue
130
- * validating internal fields.
131
- */
132
- export declare function isRepoSuperset(view: TreeStoredSchema, stored: TreeStoredSchema): boolean;
133
- /**
134
- * A linear extension of a partially-ordered set of `T`s. See:
135
- * https://en.wikipedia.org/wiki/Linear_extension
136
- *
137
- * The linear extension is represented as a lookup from each poset element to its index in the linear extension.
138
- */
139
- export type LinearExtension<T> = Map<T, number>;
140
- /**
141
- * A realizer for a partially-ordered set. See:
142
- * https://en.wikipedia.org/wiki/Order_dimension
143
- */
144
- export type Realizer<T> = LinearExtension<T>[];
145
- /**
146
- * A realizer for the partial order of field kind relaxability.
147
- *
148
- * It seems extremely likely that this partial order will remain dimension 2 over time (i.e. the set of allowed relaxations can be visualized
149
- * with a [dominance drawing](https://en.wikipedia.org/wiki/Dominance_drawing)), so this strategy allows efficient comarison between field kinds
150
- * without excessive casework.
151
- *
152
- * Hasse diagram for the partial order is shown below (lower fields can be relaxed to higher fields):
153
- * ```
154
- * sequence
155
- * |
156
- * optional
157
- * | \
158
- * required forbidden
159
- * |
160
- * identifier
161
- * ```
162
- */
163
- export declare const fieldRealizer: Realizer<FieldKindIdentifier>;
164
- export declare const PosetComparisonResult: {
165
- readonly Less: "<";
166
- readonly Greater: ">";
167
- readonly Equal: "=";
168
- readonly Incomparable: "||";
169
- };
170
- type PosetComparisonResult = (typeof PosetComparisonResult)[keyof typeof PosetComparisonResult];
171
- export declare function comparePosetElements<T>(a: T, b: T, realizer: Realizer<T>): PosetComparisonResult;
172
- export declare function posetLte<T>(a: T, b: T, realizer: Realizer<T>): boolean;
173
- export {};
174
- //# sourceMappingURL=discrepancies.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"discrepancies.d.ts","sourceRoot":"","sources":["../../../src/feature-libraries/modular-schema/discrepancies.ts"],"names":[],"mappings":"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"}