automerge-rb 0.1.1

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 (481) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE.txt +22 -0
  3. data/README.md +175 -0
  4. data/ext/automerge_ext/automerge_ext.c +1805 -0
  5. data/ext/automerge_ext/extconf.rb +132 -0
  6. data/lib/automerge/version.rb +6 -0
  7. data/lib/automerge.rb +110 -0
  8. data/rust-toolchain.toml +4 -0
  9. data/vendor/automerge-rust/Cargo.lock +1909 -0
  10. data/vendor/automerge-rust/Cargo.toml +15 -0
  11. data/vendor/automerge-rust/automerge/Cargo.toml +78 -0
  12. data/vendor/automerge-rust/automerge/README.md +5 -0
  13. data/vendor/automerge-rust/automerge/benches/load_save.rs +102 -0
  14. data/vendor/automerge-rust/automerge/benches/map.rs +260 -0
  15. data/vendor/automerge-rust/automerge/benches/range.rs +37 -0
  16. data/vendor/automerge-rust/automerge/benches/sync.rs +95 -0
  17. data/vendor/automerge-rust/automerge/examples/README.md +7 -0
  18. data/vendor/automerge-rust/automerge/examples/quickstart.rs +57 -0
  19. data/vendor/automerge-rust/automerge/examples/watch.rs +94 -0
  20. data/vendor/automerge-rust/automerge/fuzz/Cargo.toml +29 -0
  21. data/vendor/automerge-rust/automerge/fuzz/fuzz_targets/load.rs +37 -0
  22. data/vendor/automerge-rust/automerge/src/autocommit.rs +1286 -0
  23. data/vendor/automerge-rust/automerge/src/automerge/current_state.rs +546 -0
  24. data/vendor/automerge-rust/automerge/src/automerge/tests.rs +2023 -0
  25. data/vendor/automerge-rust/automerge/src/automerge.rs +2071 -0
  26. data/vendor/automerge-rust/automerge/src/autoserde.rs +128 -0
  27. data/vendor/automerge-rust/automerge/src/change.rs +357 -0
  28. data/vendor/automerge-rust/automerge/src/change_graph.rs +1215 -0
  29. data/vendor/automerge-rust/automerge/src/change_queue.rs +46 -0
  30. data/vendor/automerge-rust/automerge/src/clock.rs +206 -0
  31. data/vendor/automerge-rust/automerge/src/columnar/column_range/boolean.rs +83 -0
  32. data/vendor/automerge-rust/automerge/src/columnar/column_range/delta.rs +148 -0
  33. data/vendor/automerge-rust/automerge/src/columnar/column_range/generic/group.rs +138 -0
  34. data/vendor/automerge-rust/automerge/src/columnar/column_range/generic/simple.rs +76 -0
  35. data/vendor/automerge-rust/automerge/src/columnar/column_range/generic.rs +93 -0
  36. data/vendor/automerge-rust/automerge/src/columnar/column_range/key.rs +272 -0
  37. data/vendor/automerge-rust/automerge/src/columnar/column_range/obj_id.rs +202 -0
  38. data/vendor/automerge-rust/automerge/src/columnar/column_range/opid_list.rs +329 -0
  39. data/vendor/automerge-rust/automerge/src/columnar/column_range/raw.rs +38 -0
  40. data/vendor/automerge-rust/automerge/src/columnar/column_range/rle.rs +216 -0
  41. data/vendor/automerge-rust/automerge/src/columnar/column_range/value.rs +547 -0
  42. data/vendor/automerge-rust/automerge/src/columnar/column_range.rs +17 -0
  43. data/vendor/automerge-rust/automerge/src/columnar/encoding/boolean.rs +197 -0
  44. data/vendor/automerge-rust/automerge/src/columnar/encoding/col_error.rs +88 -0
  45. data/vendor/automerge-rust/automerge/src/columnar/encoding/column_decoder.rs +133 -0
  46. data/vendor/automerge-rust/automerge/src/columnar/encoding/decodable_impls.rs +175 -0
  47. data/vendor/automerge-rust/automerge/src/columnar/encoding/delta.rs +96 -0
  48. data/vendor/automerge-rust/automerge/src/columnar/encoding/encodable_impls.rs +200 -0
  49. data/vendor/automerge-rust/automerge/src/columnar/encoding/leb128.rs +82 -0
  50. data/vendor/automerge-rust/automerge/src/columnar/encoding/properties.rs +178 -0
  51. data/vendor/automerge-rust/automerge/src/columnar/encoding/raw.rs +101 -0
  52. data/vendor/automerge-rust/automerge/src/columnar/encoding/rle.rs +239 -0
  53. data/vendor/automerge-rust/automerge/src/columnar/encoding.rs +67 -0
  54. data/vendor/automerge-rust/automerge/src/columnar/splice_error.rs +47 -0
  55. data/vendor/automerge-rust/automerge/src/columnar.rs +14 -0
  56. data/vendor/automerge-rust/automerge/src/convert.rs +112 -0
  57. data/vendor/automerge-rust/automerge/src/cursor.rs +296 -0
  58. data/vendor/automerge-rust/automerge/src/decoding.rs +475 -0
  59. data/vendor/automerge-rust/automerge/src/error.rs +159 -0
  60. data/vendor/automerge-rust/automerge/src/exid.rs +238 -0
  61. data/vendor/automerge-rust/automerge/src/hydrate/list.rs +140 -0
  62. data/vendor/automerge-rust/automerge/src/hydrate/map.rs +132 -0
  63. data/vendor/automerge-rust/automerge/src/hydrate/tests.rs +40 -0
  64. data/vendor/automerge-rust/automerge/src/hydrate/text.rs +89 -0
  65. data/vendor/automerge-rust/automerge/src/hydrate.rs +368 -0
  66. data/vendor/automerge-rust/automerge/src/indexed_cache.rs +113 -0
  67. data/vendor/automerge-rust/automerge/src/iter/doc.rs +603 -0
  68. data/vendor/automerge-rust/automerge/src/iter/keys.rs +93 -0
  69. data/vendor/automerge-rust/automerge/src/iter/list_range.rs +433 -0
  70. data/vendor/automerge-rust/automerge/src/iter/map_range.rs +316 -0
  71. data/vendor/automerge-rust/automerge/src/iter/spans.rs +601 -0
  72. data/vendor/automerge-rust/automerge/src/iter/tools.rs +427 -0
  73. data/vendor/automerge-rust/automerge/src/iter/values.rs +36 -0
  74. data/vendor/automerge-rust/automerge/src/iter.rs +25 -0
  75. data/vendor/automerge-rust/automerge/src/legacy/mod.rs +364 -0
  76. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/actor_id.rs +25 -0
  77. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/change_hash.rs +29 -0
  78. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/element_id.rs +27 -0
  79. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/mod.rs +31 -0
  80. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/object_id.rs +36 -0
  81. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/op.rs +668 -0
  82. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/op_type.rs +26 -0
  83. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/opid.rs +25 -0
  84. data/vendor/automerge-rust/automerge/src/legacy/serde_impls/scalar_value.rs +63 -0
  85. data/vendor/automerge-rust/automerge/src/legacy/utility_impls/element_id.rs +66 -0
  86. data/vendor/automerge-rust/automerge/src/legacy/utility_impls/key.rs +49 -0
  87. data/vendor/automerge-rust/automerge/src/legacy/utility_impls/mod.rs +4 -0
  88. data/vendor/automerge-rust/automerge/src/legacy/utility_impls/object_id.rs +74 -0
  89. data/vendor/automerge-rust/automerge/src/legacy/utility_impls/opid.rs +68 -0
  90. data/vendor/automerge-rust/automerge/src/lib.rs +315 -0
  91. data/vendor/automerge-rust/automerge/src/marks.rs +478 -0
  92. data/vendor/automerge-rust/automerge/src/op_set2/change/batch.rs +2002 -0
  93. data/vendor/automerge-rust/automerge/src/op_set2/change/collector.rs +974 -0
  94. data/vendor/automerge-rust/automerge/src/op_set2/change.rs +332 -0
  95. data/vendor/automerge-rust/automerge/src/op_set2/columns.rs +714 -0
  96. data/vendor/automerge-rust/automerge/src/op_set2/meta.rs +174 -0
  97. data/vendor/automerge-rust/automerge/src/op_set2/op.rs +1363 -0
  98. data/vendor/automerge-rust/automerge/src/op_set2/op_set/elems.rs +43 -0
  99. data/vendor/automerge-rust/automerge/src/op_set2/op_set/found_op.rs +60 -0
  100. data/vendor/automerge-rust/automerge/src/op_set2/op_set/index.rs +197 -0
  101. data/vendor/automerge-rust/automerge/src/op_set2/op_set/insert.rs +179 -0
  102. data/vendor/automerge-rust/automerge/src/op_set2/op_set/mark_index.rs +292 -0
  103. data/vendor/automerge-rust/automerge/src/op_set2/op_set/marks.rs +86 -0
  104. data/vendor/automerge-rust/automerge/src/op_set2/op_set/op_iter.rs +1295 -0
  105. data/vendor/automerge-rust/automerge/src/op_set2/op_set/op_query.rs +82 -0
  106. data/vendor/automerge-rust/automerge/src/op_set2/op_set/top_op.rs +50 -0
  107. data/vendor/automerge-rust/automerge/src/op_set2/op_set/visible.rs +290 -0
  108. data/vendor/automerge-rust/automerge/src/op_set2/op_set.rs +1793 -0
  109. data/vendor/automerge-rust/automerge/src/op_set2/parents.rs +133 -0
  110. data/vendor/automerge-rust/automerge/src/op_set2/skip_list.rs +714 -0
  111. data/vendor/automerge-rust/automerge/src/op_set2/types.rs +769 -0
  112. data/vendor/automerge-rust/automerge/src/op_set2.rs +18 -0
  113. data/vendor/automerge-rust/automerge/src/patches/patch.rs +95 -0
  114. data/vendor/automerge-rust/automerge/src/patches/patch_builder.rs +382 -0
  115. data/vendor/automerge-rust/automerge/src/patches/patch_log.rs +584 -0
  116. data/vendor/automerge-rust/automerge/src/patches.rs +7 -0
  117. data/vendor/automerge-rust/automerge/src/query/list_state.rs +230 -0
  118. data/vendor/automerge-rust/automerge/src/query/seek_mark.rs +142 -0
  119. data/vendor/automerge-rust/automerge/src/read.rs +326 -0
  120. data/vendor/automerge-rust/automerge/src/sequence_tree.rs +662 -0
  121. data/vendor/automerge-rust/automerge/src/storage/bundle/builder.rs +942 -0
  122. data/vendor/automerge-rust/automerge/src/storage/bundle/error.rs +42 -0
  123. data/vendor/automerge-rust/automerge/src/storage/bundle/meta.rs +23 -0
  124. data/vendor/automerge-rust/automerge/src/storage/bundle/storage.rs +146 -0
  125. data/vendor/automerge-rust/automerge/src/storage/bundle.rs +210 -0
  126. data/vendor/automerge-rust/automerge/src/storage/change/change_actors.rs +311 -0
  127. data/vendor/automerge-rust/automerge/src/storage/change/change_op_columns.rs +621 -0
  128. data/vendor/automerge-rust/automerge/src/storage/change/compressed.rs +51 -0
  129. data/vendor/automerge-rust/automerge/src/storage/change/op_with_change_actors.rs +1 -0
  130. data/vendor/automerge-rust/automerge/src/storage/change.rs +523 -0
  131. data/vendor/automerge-rust/automerge/src/storage/chunk.rs +312 -0
  132. data/vendor/automerge-rust/automerge/src/storage/columns/column.rs +42 -0
  133. data/vendor/automerge-rust/automerge/src/storage/columns/column_builder.rs +199 -0
  134. data/vendor/automerge-rust/automerge/src/storage/columns/column_specification.rs +340 -0
  135. data/vendor/automerge-rust/automerge/src/storage/columns/raw_column.rs +286 -0
  136. data/vendor/automerge-rust/automerge/src/storage/columns.rs +355 -0
  137. data/vendor/automerge-rust/automerge/src/storage/document/compression.rs +362 -0
  138. data/vendor/automerge-rust/automerge/src/storage/document.rs +411 -0
  139. data/vendor/automerge-rust/automerge/src/storage/load/change_collector.rs +15 -0
  140. data/vendor/automerge-rust/automerge/src/storage/load.rs +136 -0
  141. data/vendor/automerge-rust/automerge/src/storage/parse/leb128.rs +302 -0
  142. data/vendor/automerge-rust/automerge/src/storage/parse.rs +619 -0
  143. data/vendor/automerge-rust/automerge/src/storage/save/document.rs +27 -0
  144. data/vendor/automerge-rust/automerge/src/storage.rs +26 -0
  145. data/vendor/automerge-rust/automerge/src/sync/bloom.rs +161 -0
  146. data/vendor/automerge-rust/automerge/src/sync/message_builder.rs +118 -0
  147. data/vendor/automerge-rust/automerge/src/sync/state.rs +214 -0
  148. data/vendor/automerge-rust/automerge/src/sync/v1_compat_test/bloom.rs +162 -0
  149. data/vendor/automerge-rust/automerge/src/sync/v1_compat_test/mod.rs +625 -0
  150. data/vendor/automerge-rust/automerge/src/sync/v1_compat_test/state.rs +120 -0
  151. data/vendor/automerge-rust/automerge/src/sync.rs +2482 -0
  152. data/vendor/automerge-rust/automerge/src/text_diff/LICENSE +201 -0
  153. data/vendor/automerge-rust/automerge/src/text_diff/myers.rs +332 -0
  154. data/vendor/automerge-rust/automerge/src/text_diff/replace.rs +139 -0
  155. data/vendor/automerge-rust/automerge/src/text_diff/utils.rs +119 -0
  156. data/vendor/automerge-rust/automerge/src/text_diff.rs +515 -0
  157. data/vendor/automerge-rust/automerge/src/text_value.rs +276 -0
  158. data/vendor/automerge-rust/automerge/src/transaction/commit.rs +34 -0
  159. data/vendor/automerge-rust/automerge/src/transaction/inner.rs +1403 -0
  160. data/vendor/automerge-rust/automerge/src/transaction/manual_transaction.rs +147 -0
  161. data/vendor/automerge-rust/automerge/src/transaction/owned_transaction.rs +266 -0
  162. data/vendor/automerge-rust/automerge/src/transaction/result.rs +21 -0
  163. data/vendor/automerge-rust/automerge/src/transaction/transactable.rs +203 -0
  164. data/vendor/automerge-rust/automerge/src/transaction.rs +513 -0
  165. data/vendor/automerge-rust/automerge/src/types.rs +749 -0
  166. data/vendor/automerge-rust/automerge/src/validation.rs +29 -0
  167. data/vendor/automerge-rust/automerge/src/value.rs +763 -0
  168. data/vendor/automerge-rust/automerge/tests/batch_insert.rs +1034 -0
  169. data/vendor/automerge-rust/automerge/tests/block_tests.rs +887 -0
  170. data/vendor/automerge-rust/automerge/tests/convert_string_to_text.rs +72 -0
  171. data/vendor/automerge-rust/automerge/tests/diff_marks.rs +1508 -0
  172. data/vendor/automerge-rust/automerge/tests/fixtures/64bit_obj_id_change.automerge +0 -0
  173. data/vendor/automerge-rust/automerge/tests/fixtures/64bit_obj_id_doc.automerge +0 -0
  174. data/vendor/automerge-rust/automerge/tests/fixtures/counter_value_has_incorrect_meta.automerge +0 -0
  175. data/vendor/automerge-rust/automerge/tests/fixtures/counter_value_is_ok.automerge +0 -0
  176. data/vendor/automerge-rust/automerge/tests/fixtures/counter_value_is_overlong.automerge +0 -0
  177. data/vendor/automerge-rust/automerge/tests/fixtures/two_change_chunks.automerge +0 -0
  178. data/vendor/automerge-rust/automerge/tests/fixtures/two_change_chunks_compressed.automerge +0 -0
  179. data/vendor/automerge-rust/automerge/tests/fixtures/two_change_chunks_out_of_order.automerge +0 -0
  180. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/action-is-48.automerge +0 -0
  181. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/crash-da39a3ee5e6b4b0d3255bfef95601890afd80709 +0 -0
  182. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/incorrect_max_op.automerge +0 -0
  183. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/invalid_deflate_stream.automerge +0 -0
  184. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/missing_actor.automerge +0 -0
  185. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/overflow_in_length.automerge +0 -0
  186. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/too_many_deps.automerge +0 -0
  187. data/vendor/automerge-rust/automerge/tests/fuzz-crashers/too_many_ops.automerge +0 -0
  188. data/vendor/automerge-rust/automerge/tests/test.rs +2668 -0
  189. data/vendor/automerge-rust/automerge/tests/test_mark_patches.rs +41 -0
  190. data/vendor/automerge-rust/automerge/tests/test_save_load_orphans.rs +84 -0
  191. data/vendor/automerge-rust/automerge/tests/text.rs +1098 -0
  192. data/vendor/automerge-rust/automerge/tests/text_encoding.rs +640 -0
  193. data/vendor/automerge-rust/automerge-c/CMakeLists.txt +439 -0
  194. data/vendor/automerge-rust/automerge-c/Cargo.toml +22 -0
  195. data/vendor/automerge-rust/automerge-c/README.md +233 -0
  196. data/vendor/automerge-rust/automerge-c/build.rs +21 -0
  197. data/vendor/automerge-rust/automerge-c/cbindgen.toml +48 -0
  198. data/vendor/automerge-rust/automerge-c/cmake/Cargo.toml.in +22 -0
  199. data/vendor/automerge-rust/automerge-c/cmake/automerge-c-config.cmake.in +99 -0
  200. data/vendor/automerge-rust/automerge-c/cmake/cbindgen.toml.in +48 -0
  201. data/vendor/automerge-rust/automerge-c/cmake/config.h.in +58 -0
  202. data/vendor/automerge-rust/automerge-c/cmake/enum-string-functions-gen.cmake +183 -0
  203. data/vendor/automerge-rust/automerge-c/cmake/file-regex-replace.cmake +33 -0
  204. data/vendor/automerge-rust/automerge-c/cmake/file-touch.cmake +35 -0
  205. data/vendor/automerge-rust/automerge-c/docs/CMakeLists.txt +39 -0
  206. data/vendor/automerge-rust/automerge-c/docs/img/brandmark.png +0 -0
  207. data/vendor/automerge-rust/automerge-c/examples/CMakeLists.txt +42 -0
  208. data/vendor/automerge-rust/automerge-c/examples/README.md +9 -0
  209. data/vendor/automerge-rust/automerge-c/examples/quickstart.c +131 -0
  210. data/vendor/automerge-rust/automerge-c/include/automerge-c/utils/result.h +30 -0
  211. data/vendor/automerge-rust/automerge-c/include/automerge-c/utils/stack.h +130 -0
  212. data/vendor/automerge-rust/automerge-c/include/automerge-c/utils/stack_callback_data.h +53 -0
  213. data/vendor/automerge-rust/automerge-c/include/automerge-c/utils/string.h +29 -0
  214. data/vendor/automerge-rust/automerge-c/src/actor_id.rs +193 -0
  215. data/vendor/automerge-rust/automerge-c/src/byte_span.rs +227 -0
  216. data/vendor/automerge-rust/automerge-c/src/change.rs +356 -0
  217. data/vendor/automerge-rust/automerge-c/src/cursor.rs +168 -0
  218. data/vendor/automerge-rust/automerge-c/src/doc/list.rs +636 -0
  219. data/vendor/automerge-rust/automerge-c/src/doc/map.rs +556 -0
  220. data/vendor/automerge-rust/automerge-c/src/doc/mark.rs +296 -0
  221. data/vendor/automerge-rust/automerge-c/src/doc/utils.rs +46 -0
  222. data/vendor/automerge-rust/automerge-c/src/doc.rs +1009 -0
  223. data/vendor/automerge-rust/automerge-c/src/index.rs +84 -0
  224. data/vendor/automerge-rust/automerge-c/src/item.rs +2177 -0
  225. data/vendor/automerge-rust/automerge-c/src/items.rs +401 -0
  226. data/vendor/automerge-rust/automerge-c/src/lib.rs +11 -0
  227. data/vendor/automerge-rust/automerge-c/src/obj.rs +216 -0
  228. data/vendor/automerge-rust/automerge-c/src/result.rs +653 -0
  229. data/vendor/automerge-rust/automerge-c/src/sync/have.rs +42 -0
  230. data/vendor/automerge-rust/automerge-c/src/sync/message.rs +146 -0
  231. data/vendor/automerge-rust/automerge-c/src/sync/state.rs +262 -0
  232. data/vendor/automerge-rust/automerge-c/src/sync.rs +7 -0
  233. data/vendor/automerge-rust/automerge-c/src/utils/result.c +33 -0
  234. data/vendor/automerge-rust/automerge-c/src/utils/stack.c +106 -0
  235. data/vendor/automerge-rust/automerge-c/src/utils/stack_callback_data.c +9 -0
  236. data/vendor/automerge-rust/automerge-c/src/utils/string.c +46 -0
  237. data/vendor/automerge-rust/automerge-c/test/CMakeLists.txt +67 -0
  238. data/vendor/automerge-rust/automerge-c/test/actor_id_tests.c +140 -0
  239. data/vendor/automerge-rust/automerge-c/test/base_state.c +17 -0
  240. data/vendor/automerge-rust/automerge-c/test/base_state.h +39 -0
  241. data/vendor/automerge-rust/automerge-c/test/byte_span_tests.c +119 -0
  242. data/vendor/automerge-rust/automerge-c/test/cmocka_utils.c +91 -0
  243. data/vendor/automerge-rust/automerge-c/test/cmocka_utils.h +42 -0
  244. data/vendor/automerge-rust/automerge-c/test/cursor_tests.c +263 -0
  245. data/vendor/automerge-rust/automerge-c/test/doc_state.c +27 -0
  246. data/vendor/automerge-rust/automerge-c/test/doc_state.h +17 -0
  247. data/vendor/automerge-rust/automerge-c/test/doc_tests.c +335 -0
  248. data/vendor/automerge-rust/automerge-c/test/enum_string_tests.c +148 -0
  249. data/vendor/automerge-rust/automerge-c/test/files/brave-ape-49.automerge +0 -0
  250. data/vendor/automerge-rust/automerge-c/test/item_tests.c +313 -0
  251. data/vendor/automerge-rust/automerge-c/test/list_tests.c +544 -0
  252. data/vendor/automerge-rust/automerge-c/test/macro_utils.c +38 -0
  253. data/vendor/automerge-rust/automerge-c/test/macro_utils.h +23 -0
  254. data/vendor/automerge-rust/automerge-c/test/main.c +33 -0
  255. data/vendor/automerge-rust/automerge-c/test/map_tests.c +1610 -0
  256. data/vendor/automerge-rust/automerge-c/test/mark_tests.c +124 -0
  257. data/vendor/automerge-rust/automerge-c/test/ported_wasm/basic_tests.c +1642 -0
  258. data/vendor/automerge-rust/automerge-c/test/ported_wasm/cursor_tests.c +108 -0
  259. data/vendor/automerge-rust/automerge-c/test/ported_wasm/suite.c +17 -0
  260. data/vendor/automerge-rust/automerge-c/test/ported_wasm/sync_tests.c +1280 -0
  261. data/vendor/automerge-rust/automerge-c/test/str_utils.c +15 -0
  262. data/vendor/automerge-rust/automerge-c/test/str_utils.h +17 -0
  263. data/vendor/automerge-rust/automerge-test/Cargo.toml +17 -0
  264. data/vendor/automerge-rust/automerge-test/README.md +3 -0
  265. data/vendor/automerge-rust/automerge-test/src/lib.rs +487 -0
  266. data/vendor/automerge-rust/hexane/CHANGELOG.md +34 -0
  267. data/vendor/automerge-rust/hexane/Cargo.toml +47 -0
  268. data/vendor/automerge-rust/hexane/README.md +292 -0
  269. data/vendor/automerge-rust/hexane/RESULTS.txt +20 -0
  270. data/vendor/automerge-rust/hexane/TODO +18 -0
  271. data/vendor/automerge-rust/hexane/benches/insert.rs +82 -0
  272. data/vendor/automerge-rust/hexane/benches/seek.rs +77 -0
  273. data/vendor/automerge-rust/hexane/benches/splice.rs +82 -0
  274. data/vendor/automerge-rust/hexane/src/aggregate.rs +288 -0
  275. data/vendor/automerge-rust/hexane/src/boolean.rs +478 -0
  276. data/vendor/automerge-rust/hexane/src/columndata.rs +2540 -0
  277. data/vendor/automerge-rust/hexane/src/cursor.rs +756 -0
  278. data/vendor/automerge-rust/hexane/src/delta.rs +793 -0
  279. data/vendor/automerge-rust/hexane/src/encoder.rs +639 -0
  280. data/vendor/automerge-rust/hexane/src/leb128.rs +82 -0
  281. data/vendor/automerge-rust/hexane/src/lib.rs +95 -0
  282. data/vendor/automerge-rust/hexane/src/pack.rs +325 -0
  283. data/vendor/automerge-rust/hexane/src/raw.rs +314 -0
  284. data/vendor/automerge-rust/hexane/src/rle.rs +928 -0
  285. data/vendor/automerge-rust/hexane/src/slab/tree.rs +1373 -0
  286. data/vendor/automerge-rust/hexane/src/slab/writer.rs +535 -0
  287. data/vendor/automerge-rust/hexane/src/slab.rs +224 -0
  288. data/vendor/automerge-rust/hexane/src/test.rs +108 -0
  289. data/vendor/bundle/ruby/3.3.0/bin/rake +29 -0
  290. data/vendor/bundle/ruby/3.3.0/bin/rake-compiler +29 -0
  291. data/vendor/bundle/ruby/3.3.0/bin/rake-compiler-dock +29 -0
  292. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/History.rdoc +1732 -0
  293. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/Manifest.txt +32 -0
  294. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/README.rdoc +845 -0
  295. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/Rakefile +97 -0
  296. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/design_rationale.rb +54 -0
  297. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/hoe/minitest.rb +30 -0
  298. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/assertions.rb +850 -0
  299. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/autorun.rb +6 -0
  300. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/benchmark.rb +452 -0
  301. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/compress.rb +94 -0
  302. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/error_on_warning.rb +11 -0
  303. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/expectations.rb +321 -0
  304. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/hell.rb +11 -0
  305. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/manual_plugins.rb +16 -0
  306. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/mock.rb +327 -0
  307. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/parallel.rb +72 -0
  308. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/pride.rb +4 -0
  309. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/pride_plugin.rb +135 -0
  310. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/spec.rb +353 -0
  311. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/test.rb +238 -0
  312. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/test_task.rb +324 -0
  313. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest/unit.rb +42 -0
  314. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/lib/minitest.rb +1250 -0
  315. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/metametameta.rb +150 -0
  316. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_assertions.rb +1677 -0
  317. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_benchmark.rb +137 -0
  318. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_mock.rb +1213 -0
  319. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_reporter.rb +437 -0
  320. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_spec.rb +1159 -0
  321. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_test.rb +1374 -0
  322. data/vendor/bundle/ruby/3.3.0/gems/minitest-5.27.0/test/minitest/test_minitest_test_task.rb +57 -0
  323. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/History.rdoc +2454 -0
  324. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/MIT-LICENSE +21 -0
  325. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/README.rdoc +155 -0
  326. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/command_line_usage.rdoc +171 -0
  327. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/example/Rakefile1 +38 -0
  328. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/example/Rakefile2 +35 -0
  329. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/example/a.c +6 -0
  330. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/example/b.c +6 -0
  331. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/example/main.c +11 -0
  332. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/glossary.rdoc +42 -0
  333. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/jamis.rb +592 -0
  334. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/proto_rake.rdoc +127 -0
  335. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/rake.1 +156 -0
  336. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/rakefile.rdoc +635 -0
  337. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/doc/rational.rdoc +151 -0
  338. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/exe/rake +27 -0
  339. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/application.rb +847 -0
  340. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/backtrace.rb +25 -0
  341. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/clean.rb +78 -0
  342. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/cloneable.rb +17 -0
  343. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/cpu_counter.rb +122 -0
  344. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/default_loader.rb +15 -0
  345. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/dsl_definition.rb +196 -0
  346. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/early_time.rb +22 -0
  347. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/ext/core.rb +26 -0
  348. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/ext/string.rb +176 -0
  349. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/file_creation_task.rb +25 -0
  350. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/file_list.rb +435 -0
  351. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/file_task.rb +58 -0
  352. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/file_utils.rb +137 -0
  353. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/file_utils_ext.rb +135 -0
  354. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/invocation_chain.rb +57 -0
  355. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/invocation_exception_mixin.rb +17 -0
  356. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/late_time.rb +18 -0
  357. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/linked_list.rb +112 -0
  358. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/loaders/makefile.rb +54 -0
  359. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/multi_task.rb +14 -0
  360. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/name_space.rb +38 -0
  361. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/options.rb +31 -0
  362. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/packagetask.rb +222 -0
  363. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/phony.rb +16 -0
  364. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/private_reader.rb +21 -0
  365. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/promise.rb +100 -0
  366. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/pseudo_status.rb +30 -0
  367. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/rake_module.rb +67 -0
  368. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/rake_test_loader.rb +27 -0
  369. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/rule_recursion_overflow_error.rb +20 -0
  370. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/scope.rb +43 -0
  371. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/task.rb +434 -0
  372. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/task_argument_error.rb +8 -0
  373. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/task_arguments.rb +113 -0
  374. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/task_manager.rb +333 -0
  375. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/tasklib.rb +12 -0
  376. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/testtask.rb +192 -0
  377. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/thread_history_display.rb +49 -0
  378. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/thread_pool.rb +157 -0
  379. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/trace_output.rb +23 -0
  380. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/version.rb +10 -0
  381. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake/win32.rb +17 -0
  382. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/lib/rake.rb +69 -0
  383. data/vendor/bundle/ruby/3.3.0/gems/rake-13.4.2/rake.gemspec +102 -0
  384. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/Gemfile +8 -0
  385. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/History.md +695 -0
  386. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/LICENSE.txt +20 -0
  387. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/README.md +476 -0
  388. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/Rakefile +15 -0
  389. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/appveyor.yml +22 -0
  390. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/bin/rake-compiler +24 -0
  391. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/cucumber.yml +4 -0
  392. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/compile.feature +79 -0
  393. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/cross-compile.feature +23 -0
  394. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/cross-package-multi.feature +15 -0
  395. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/cross-package.feature +14 -0
  396. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/java-compile.feature +22 -0
  397. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/java-no-native-compile.feature +33 -0
  398. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/java-package.feature +24 -0
  399. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/package.feature +40 -0
  400. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/step_definitions/compilation.rb +70 -0
  401. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/step_definitions/cross_compilation.rb +27 -0
  402. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/step_definitions/execution.rb +52 -0
  403. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/step_definitions/folders.rb +32 -0
  404. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/step_definitions/gem.rb +46 -0
  405. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/step_definitions/java_compilation.rb +7 -0
  406. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/support/env.rb +10 -0
  407. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/support/file_template_helpers.rb +137 -0
  408. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/support/generator_helpers.rb +123 -0
  409. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/features/support/platform_extension_helpers.rb +27 -0
  410. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/lib/rake/baseextensiontask.rb +90 -0
  411. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/lib/rake/compiler_config.rb +38 -0
  412. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/lib/rake/extensioncompiler.rb +51 -0
  413. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/lib/rake/extensiontask.rb +589 -0
  414. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/lib/rake/javaextensiontask.rb +321 -0
  415. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/tasks/bin/cross-ruby.rake +189 -0
  416. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/tasks/bootstrap.rake +11 -0
  417. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/tasks/common.rake +10 -0
  418. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/tasks/cucumber.rake +23 -0
  419. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/tasks/gem.rake +15 -0
  420. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-1.3.1/tasks/rspec.rake +9 -0
  421. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/CHANGELOG.md +446 -0
  422. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/CONTRIBUTING.md +109 -0
  423. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/Dockerfile.jruby +79 -0
  424. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/Dockerfile.mri.erb +282 -0
  425. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/Gemfile +8 -0
  426. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/LICENSE.txt +22 -0
  427. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/README.md +447 -0
  428. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/Rakefile +246 -0
  429. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/bin/rake-compiler-dock +18 -0
  430. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/buildkitd.toml +2 -0
  431. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/gem_helper.rb +54 -0
  432. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/mk_i686.rb +18 -0
  433. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/mk_musl_cross.sh +37 -0
  434. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/mk_osxcross.sh +45 -0
  435. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/mk_pkg_config.sh +24 -0
  436. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/parallel_docker_build.rb +169 -0
  437. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/patches/rake-compiler-1.3.1/0004-Enable-build-of-static-libruby.patch +38 -0
  438. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/patches/rake-compiler-1.3.1/0005-build-miniruby-first.patch +16 -0
  439. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/patches/rake-compiler-1.3.1/0006-ruby-4-rubyspec-capiext.patch +16 -0
  440. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/rcd-env.sh +6 -0
  441. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/runas +7 -0
  442. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/sigfw.c +45 -0
  443. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/strip_wrapper_codesign +17 -0
  444. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/strip_wrapper_vbox +30 -0
  445. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/build/sudoers +1 -0
  446. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/lib/rake_compiler_dock/colors.rb +43 -0
  447. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/lib/rake_compiler_dock/docker_check.rb +356 -0
  448. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/lib/rake_compiler_dock/predefined_user_group.rb +5 -0
  449. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/lib/rake_compiler_dock/starter.rb +206 -0
  450. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/lib/rake_compiler_dock/version.rb +4 -0
  451. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/lib/rake_compiler_dock.rb +151 -0
  452. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/mingw64-ucrt/Dockerfile +66 -0
  453. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/mingw64-ucrt/README.md +14 -0
  454. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/mingw64-ucrt/binutils-mingw-w64-ignore-check-errors.patch +13 -0
  455. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/mingw64-ucrt/gcc-mingw-w64-only-c-c++.patch +13 -0
  456. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/mingw64-ucrt/mingw-w64-enable-ucrt.patch +22 -0
  457. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/rake-compiler-dock.gemspec +34 -0
  458. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/env/Dockerfile.alpine +17 -0
  459. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/env/Dockerfile.debian +24 -0
  460. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/fixtures/mig_test_rpc.defs +8 -0
  461. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/Gemfile +11 -0
  462. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/Rakefile +97 -0
  463. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/ext/java/RcdTestExtService.java +19 -0
  464. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/ext/java/RubyRcdTest.java +16 -0
  465. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/ext/mri/extconf.rb +111 -0
  466. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/ext/mri/rcd_test_ext.c +65 -0
  467. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/ext/mri/rcd_test_ext.h +11 -0
  468. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/lib/rcd_test.rb +6 -0
  469. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/rcd_test.gemspec +28 -0
  470. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/rcd_test/test/test_basic.rb +49 -0
  471. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/test_environment_variables.rb +108 -0
  472. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/test_mig.rb +18 -0
  473. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/test_parallel_docker_build.rb +95 -0
  474. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/test_rubygems_plugins.rb +12 -0
  475. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/test_starter.rb +158 -0
  476. data/vendor/bundle/ruby/3.3.0/gems/rake-compiler-dock-1.12.0/test/test_versions.rb +82 -0
  477. data/vendor/bundle/ruby/3.3.0/specifications/minitest-5.27.0.gemspec +32 -0
  478. data/vendor/bundle/ruby/3.3.0/specifications/rake-13.4.2.gemspec +26 -0
  479. data/vendor/bundle/ruby/3.3.0/specifications/rake-compiler-1.3.1.gemspec +33 -0
  480. data/vendor/bundle/ruby/3.3.0/specifications/rake-compiler-dock-1.12.0.gemspec +28 -0
  481. metadata +584 -0
@@ -0,0 +1,1215 @@
1
+ use std::borrow::Cow;
2
+ use std::cmp::Ordering;
3
+ use std::collections::{BTreeSet, HashMap};
4
+ use std::num::NonZeroU32;
5
+ use std::ops::Add;
6
+
7
+ use hexane::{
8
+ ColGroupIter, ColumnCursor, ColumnData, ColumnDataIter, DeltaCursor, PackError, StrCursor,
9
+ UIntCursor,
10
+ };
11
+
12
+ use crate::storage::BundleMetadata;
13
+ use crate::{
14
+ clock::{Clock, SeqClock},
15
+ error::AutomergeError,
16
+ op_set2::{change::BuildChangeMetadata, ActorCursor, ActorIdx, MetaCursor, ValueMeta},
17
+ storage::columns::compression::Uncompressed,
18
+ storage::columns::BadColumnLayout,
19
+ storage::document::ReconstructError as LoadError,
20
+ storage::{Columns, Document, RawColumn, RawColumns},
21
+ types::OpId,
22
+ Change, ChangeHash,
23
+ };
24
+
25
+ /// The graph of changes
26
+ ///
27
+ /// This is a sort of adjacency list based representation, except that instead of using linked
28
+ /// lists, we keep all the edges and nodes in two vecs and reference them by index which plays nice
29
+ /// with the cache
30
+
31
+ #[derive(Debug, PartialEq, Default, Clone)]
32
+ pub(crate) struct ChangeGraph {
33
+ edges: Vec<Edge>,
34
+ hashes: Vec<ChangeHash>,
35
+ actors: Vec<ActorIdx>,
36
+ parents: Vec<Option<EdgeIdx>>,
37
+ seq: Vec<u32>,
38
+ max_ops: Vec<u32>,
39
+ max_op: u32,
40
+ num_ops: ColumnData<UIntCursor>,
41
+ timestamps: ColumnData<DeltaCursor>,
42
+ messages: ColumnData<StrCursor>,
43
+ extra_bytes_meta: ColumnData<MetaCursor>,
44
+ extra_bytes_raw: Vec<u8>,
45
+ heads: BTreeSet<ChangeHash>,
46
+ nodes_by_hash: HashMap<ChangeHash, NodeIdx>,
47
+ clock_cache: HashMap<NodeIdx, SeqClock>,
48
+ seq_index: Vec<Vec<NodeIdx>>,
49
+ }
50
+
51
+ pub(crate) struct ChangeGraphCols(ChangeGraph);
52
+
53
+ const CACHE_STEP: u32 = 16;
54
+
55
+ #[derive(Hash, Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord)]
56
+ struct NodeIdx(u32);
57
+
58
+ impl Add<usize> for NodeIdx {
59
+ type Output = Self;
60
+
61
+ fn add(self, other: usize) -> Self {
62
+ NodeIdx(self.0 + other as u32)
63
+ }
64
+ }
65
+
66
+ #[derive(Clone, Copy, Debug, PartialEq, Eq, PartialOrd, Ord)]
67
+ struct EdgeIdx(NonZeroU32);
68
+
69
+ impl EdgeIdx {
70
+ fn new(value: usize) -> Self {
71
+ EdgeIdx(NonZeroU32::new(value as u32 + 1).unwrap())
72
+ }
73
+ fn get(&self) -> usize {
74
+ self.0.get() as usize - 1
75
+ }
76
+ }
77
+
78
+ #[derive(PartialEq, Debug, Clone)]
79
+ struct Edge {
80
+ // Edges are always child -> parent so we only store the target, the child is implicit
81
+ // as you get the edge from the child
82
+ target: NodeIdx,
83
+ next: Option<EdgeIdx>,
84
+ }
85
+
86
+ impl ChangeGraph {
87
+ pub(crate) fn new(num_actors: usize) -> Self {
88
+ Self {
89
+ edges: Vec::new(),
90
+ nodes_by_hash: HashMap::new(),
91
+ hashes: Vec::new(),
92
+ actors: Vec::new(),
93
+ max_ops: Vec::new(),
94
+ max_op: 0,
95
+ num_ops: ColumnData::new(),
96
+ seq: Vec::new(),
97
+ parents: Vec::new(),
98
+ messages: ColumnData::new(),
99
+ timestamps: ColumnData::new(),
100
+ extra_bytes_meta: ColumnData::new(),
101
+ extra_bytes_raw: Vec::new(),
102
+ heads: BTreeSet::new(),
103
+ clock_cache: HashMap::new(),
104
+ seq_index: vec![vec![]; num_actors],
105
+ }
106
+ }
107
+
108
+ pub(crate) fn all_actor_ids(&self) -> impl Iterator<Item = usize> + '_ {
109
+ self.seq_index.iter().enumerate().map(|(i, _)| i)
110
+ }
111
+
112
+ pub(crate) fn actor_ids(&self) -> impl Iterator<Item = usize> + '_ {
113
+ self.seq_index
114
+ .iter()
115
+ .enumerate()
116
+ .filter_map(|(i, v)| if !v.is_empty() { Some(i) } else { None })
117
+ }
118
+
119
+ pub(crate) fn unused_actors(&self) -> impl Iterator<Item = usize> + '_ {
120
+ self.seq_index
121
+ .iter()
122
+ .enumerate()
123
+ .filter_map(|(i, v)| if v.is_empty() { Some(i) } else { None })
124
+ }
125
+
126
+ pub(crate) fn heads(&self) -> impl Iterator<Item = ChangeHash> + '_ {
127
+ self.heads.iter().cloned()
128
+ }
129
+
130
+ pub(crate) fn head_indexes(&self) -> impl Iterator<Item = u64> + '_ {
131
+ self.heads
132
+ .iter()
133
+ .map(|h| self.nodes_by_hash.get(h).unwrap().0 as u64)
134
+ }
135
+
136
+ pub(crate) fn num_actors(&self) -> usize {
137
+ self.seq_index.len()
138
+ }
139
+
140
+ pub(crate) fn insert_actor(&mut self, idx: usize) {
141
+ if self.seq_index.len() != idx {
142
+ for actor_index in &mut self.actors {
143
+ if actor_index.0 >= idx as u32 {
144
+ actor_index.0 += 1;
145
+ }
146
+ }
147
+ }
148
+ for clock in self.clock_cache.values_mut() {
149
+ clock.rewrite_with_new_actor(idx)
150
+ }
151
+ self.seq_index.insert(idx, vec![]);
152
+ }
153
+
154
+ pub(crate) fn remove_actor(&mut self, idx: usize) {
155
+ for actor_index in &mut self.actors {
156
+ if actor_index.0 > idx as u32 {
157
+ actor_index.0 -= 1;
158
+ }
159
+ }
160
+ if self.seq_index.get(idx).is_some() {
161
+ assert!(self.seq_index[idx].is_empty());
162
+ self.seq_index.remove(idx);
163
+ }
164
+ for clock in &mut self.clock_cache.values_mut() {
165
+ clock.remove_actor(idx)
166
+ }
167
+ }
168
+
169
+ pub(crate) fn len(&self) -> usize {
170
+ self.actors.len()
171
+ }
172
+
173
+ pub(crate) fn is_empty(&self) -> bool {
174
+ self.actors.is_empty()
175
+ }
176
+
177
+ pub(crate) fn hash_to_index(&self, hash: &ChangeHash) -> Option<usize> {
178
+ self.nodes_by_hash.get(hash).map(|n| n.0 as usize)
179
+ }
180
+
181
+ pub(crate) fn index_to_hash(&self, index: usize) -> Option<&ChangeHash> {
182
+ self.hashes.get(index)
183
+ }
184
+
185
+ pub(crate) fn max_op(&self) -> u64 {
186
+ self.max_op as u64
187
+ }
188
+
189
+ pub(crate) fn max_op_for_actor(&mut self, actor_index: usize) -> u64 {
190
+ self.seq_index
191
+ .get(actor_index)
192
+ .and_then(|s| s.last())
193
+ .and_then(|index| self.max_ops.get(index.0 as usize).cloned())
194
+ .unwrap_or(0) as u64
195
+ }
196
+
197
+ pub(crate) fn seq_for_actor(&self, actor: usize) -> u64 {
198
+ self.seq_index
199
+ .get(actor)
200
+ .map(|v| v.len() as u64)
201
+ .unwrap_or(0)
202
+ }
203
+
204
+ fn deps_iter(&self) -> impl Iterator<Item = NodeIdx> + '_ {
205
+ self.node_ids().flat_map(|n| self.parents(n))
206
+ }
207
+
208
+ fn num_deps(&self) -> impl Iterator<Item = usize> + '_ {
209
+ self.node_ids().map(|n| self.parents(n).count())
210
+ }
211
+
212
+ fn node_ids(&self) -> impl Iterator<Item = NodeIdx> {
213
+ let end = self.hashes.len() as u32;
214
+ (0..end).map(NodeIdx)
215
+ }
216
+
217
+ pub(crate) fn encode(&self, out: &mut Vec<u8>) -> RawColumns<Uncompressed> {
218
+ use ids::*;
219
+
220
+ let actor_iter = self.actors.iter().map(as_actor);
221
+ let actor = ActorCursor::encode_unless_empty(out, actor_iter);
222
+
223
+ let seq_iter = self.seq.iter().map(as_seq);
224
+ let seq = DeltaCursor::encode_unless_empty(out, seq_iter);
225
+
226
+ let max_op_iter = self.max_ops.iter().map(as_max_op);
227
+ let max_op = DeltaCursor::encode_unless_empty(out, max_op_iter);
228
+
229
+ let time = self.timestamps.save_to_unless_empty(out);
230
+
231
+ let message = self.messages.save_to_unless_empty(out);
232
+
233
+ let num_deps_iter = self.num_deps().map(as_num_deps);
234
+ let num_deps = UIntCursor::encode_unless_empty(out, num_deps_iter);
235
+
236
+ let deps_iter = self.deps_iter().map(as_deps);
237
+ let deps = DeltaCursor::encode_unless_empty(out, deps_iter);
238
+
239
+ // FIXME - we could eliminate this column if empty but meta isnt all null
240
+ let meta = self.extra_bytes_meta.save_to_unless_empty(out);
241
+ let raw = out.len()..out.len() + self.extra_bytes_raw.len();
242
+ out.extend(&self.extra_bytes_raw);
243
+
244
+ [
245
+ RawColumn::new(ACTOR_COL_SPEC, actor),
246
+ RawColumn::new(SEQ_COL_SPEC, seq),
247
+ RawColumn::new(MAX_OP_COL_SPEC, max_op),
248
+ RawColumn::new(TIME_COL_SPEC, time),
249
+ RawColumn::new(MESSAGE_COL_SPEC, message),
250
+ RawColumn::new(DEPS_COUNT_COL_SPEC, num_deps),
251
+ RawColumn::new(DEPS_VAL_COL_SPEC, deps),
252
+ RawColumn::new(EXTRA_META_COL_SPEC, meta),
253
+ RawColumn::new(EXTRA_VAL_COL_SPEC, raw),
254
+ ]
255
+ .into_iter()
256
+ .collect()
257
+ }
258
+
259
+ pub(crate) fn validate(
260
+ bytes: usize,
261
+ cols: &RawColumns<Uncompressed>,
262
+ ) -> Result<RawColumns<Uncompressed>, BadColumnLayout> {
263
+ use ids::*;
264
+ let _ = Columns::parse2(bytes, cols.iter())?;
265
+ Ok(cols
266
+ .iter()
267
+ .filter(|col| {
268
+ matches!(
269
+ col.spec(),
270
+ ACTOR_COL_SPEC
271
+ | SEQ_COL_SPEC
272
+ | MAX_OP_COL_SPEC
273
+ | TIME_COL_SPEC
274
+ | MESSAGE_COL_SPEC
275
+ | DEPS_COUNT_COL_SPEC
276
+ | DEPS_VAL_COL_SPEC
277
+ | EXTRA_META_COL_SPEC
278
+ | EXTRA_VAL_COL_SPEC
279
+ )
280
+ })
281
+ .cloned()
282
+ .collect())
283
+ }
284
+
285
+ pub(crate) fn opid_to_hash(&self, id: OpId) -> Option<ChangeHash> {
286
+ let actor_indices = self.seq_index.get(id.actor())?;
287
+ let counter = id.counter();
288
+ let index = actor_indices
289
+ .binary_search_by(|n| {
290
+ let i = n.0 as usize;
291
+ let num_ops = *self.num_ops.get(i).flatten().unwrap_or_default();
292
+ let max_op = self.max_ops[i];
293
+ let start = max_op as u64 - num_ops + 1;
294
+ if counter < start {
295
+ Ordering::Greater
296
+ } else if (max_op as u64) < counter {
297
+ Ordering::Less
298
+ } else {
299
+ Ordering::Equal
300
+ }
301
+ })
302
+ .ok()?;
303
+ let node_idx = actor_indices[index];
304
+ self.hashes.get(node_idx.0 as usize).cloned()
305
+ }
306
+
307
+ pub(crate) fn deps_for_hash(&self, hash: &ChangeHash) -> impl Iterator<Item = ChangeHash> + '_ {
308
+ let node_idx = self.nodes_by_hash.get(hash);
309
+ let mut edge_idx = node_idx.and_then(|n| self.parents[n.0 as usize]);
310
+ std::iter::from_fn(move || {
311
+ let this_edge_idx = edge_idx?;
312
+ let edge = &self.edges[this_edge_idx.get()];
313
+ edge_idx = edge.next;
314
+ let hash = self.hashes[edge.target.0 as usize];
315
+ Some(hash)
316
+ })
317
+ }
318
+
319
+ pub(crate) fn has_change(&self, hash: &ChangeHash) -> bool {
320
+ self.nodes_by_hash.contains_key(hash)
321
+ }
322
+
323
+ pub(crate) fn get_bundle_metadata<I>(
324
+ &self,
325
+ hashes: I,
326
+ ) -> impl Iterator<Item = Result<BundleMetadata<'_>, MissingDep>>
327
+ where
328
+ I: IntoIterator<Item = ChangeHash>,
329
+ {
330
+ hashes.into_iter().map(|hash| {
331
+ let index = self
332
+ .nodes_by_hash
333
+ .get(&hash)
334
+ .cloned()
335
+ .ok_or(MissingDep(hash))?;
336
+ let i = index.0 as usize;
337
+ let actor = self.actors[i].into();
338
+ let timestamp = *self.timestamps.get(i).flatten().unwrap_or_default();
339
+ let max_op = self.max_ops[i] as u64;
340
+ let num_ops = *self.num_ops.get(i).flatten().unwrap_or_default();
341
+ let message = self.messages.get(i).flatten();
342
+
343
+ // FIXME - this needs a test
344
+ let meta = self.extra_bytes_meta.get_with_acc(i).unwrap();
345
+ let meta_range =
346
+ meta.acc.as_usize()..(meta.acc.as_usize() + meta.item.unwrap().length());
347
+ let extra = Cow::Borrowed(&self.extra_bytes_raw[meta_range]);
348
+
349
+ let deps = self
350
+ .parents(index)
351
+ .map(|p| self.hashes[p.0 as usize])
352
+ .collect::<Vec<_>>();
353
+
354
+ let start_op = max_op - num_ops + 1;
355
+ let seq = self.seq[i] as u64;
356
+ Ok(BundleMetadata {
357
+ hash,
358
+ actor,
359
+ seq,
360
+ start_op,
361
+ max_op,
362
+ timestamp,
363
+ message,
364
+ extra,
365
+ deps,
366
+ builder: i,
367
+ })
368
+ })
369
+ }
370
+
371
+ pub(crate) fn get_build_metadata<I>(
372
+ &self,
373
+ hashes: I,
374
+ ) -> Result<Vec<BuildChangeMetadata<'_>>, MissingDep>
375
+ where
376
+ I: IntoIterator<Item = ChangeHash>,
377
+ {
378
+ let indexes: Vec<_> = hashes
379
+ .into_iter()
380
+ .map(|hash| {
381
+ self.nodes_by_hash
382
+ .get(&hash)
383
+ .cloned()
384
+ .ok_or(MissingDep(hash))
385
+ })
386
+ .collect::<Result<_, _>>()?;
387
+
388
+ Ok(self.get_build_metadata_for_indexes(indexes))
389
+ }
390
+
391
+ pub(crate) fn iter(&self) -> ChangeIter<'_> {
392
+ ChangeIter {
393
+ index: 0,
394
+ actors: self.actors.iter(),
395
+ seq: self.seq.iter(),
396
+ max_ops: self.max_ops.iter(),
397
+ num_ops: self.num_ops.iter(),
398
+ timestamps: self.timestamps.iter(),
399
+ messages: self.messages.iter(),
400
+ extra_bytes_meta: self.extra_bytes_meta.iter().with_acc(),
401
+ graph: self,
402
+ }
403
+ }
404
+
405
+ fn get_build_metadata_for_indexes<I>(&self, indexes: I) -> Vec<BuildChangeMetadata<'_>>
406
+ where
407
+ I: IntoIterator<Item = NodeIdx>,
408
+ {
409
+ let changes = indexes
410
+ .into_iter()
411
+ .map(|index| {
412
+ let i = index.0 as usize;
413
+ let actor = self.actors[i].into();
414
+ let timestamp = *self.timestamps.get(i).flatten().unwrap_or_default();
415
+ let max_op = self.max_ops[i] as u64;
416
+ let num_ops = *self.num_ops.get(i).flatten().unwrap_or_default();
417
+ let message = self.messages.get(i).flatten();
418
+
419
+ // FIXME - this needs a test
420
+ let meta = self.extra_bytes_meta.get_with_acc(i).unwrap();
421
+ let meta_range =
422
+ meta.acc.as_usize()..(meta.acc.as_usize() + meta.item.unwrap().length());
423
+ let extra = Cow::Borrowed(&self.extra_bytes_raw[meta_range]);
424
+
425
+ let deps = self.parents(index).map(|p| p.0 as u64).collect::<Vec<_>>();
426
+ let start_op = max_op - num_ops + 1;
427
+ let seq = self.seq[i] as u64;
428
+ BuildChangeMetadata {
429
+ actor,
430
+ seq,
431
+ start_op,
432
+ max_op,
433
+ timestamp,
434
+ message,
435
+ extra,
436
+ deps,
437
+ builder: i,
438
+ }
439
+ })
440
+ .collect();
441
+ changes
442
+ }
443
+
444
+ fn get_build_indexes(&self, clock: SeqClock) -> Vec<NodeIdx> {
445
+ let mut change_indexes: Vec<NodeIdx> = Vec::new();
446
+ // walk the state from the given deps clock and add them into the vec
447
+ for (actor_index, actor_changes) in self.seq_index.iter().enumerate() {
448
+ if let Some(seq) = clock.get_for_actor(&actor_index) {
449
+ // find the change in this actors sequence of changes that corresponds to the max_op
450
+ // recorded for them in the clock
451
+ change_indexes.extend(&actor_changes[seq.get() as usize..]);
452
+ } else {
453
+ change_indexes.extend(&actor_changes[..]);
454
+ }
455
+ }
456
+
457
+ // ensure the changes are still in sorted order
458
+ change_indexes.sort_unstable();
459
+
460
+ change_indexes
461
+ }
462
+
463
+ pub(crate) fn get_hashes(&self, have_deps: &[ChangeHash]) -> Cow<'_, [ChangeHash]> {
464
+ if have_deps.is_empty() {
465
+ Cow::Borrowed(&self.hashes)
466
+ } else {
467
+ let clock = self.seq_clock_for_heads(have_deps);
468
+ Cow::Owned(
469
+ self.get_build_indexes(clock)
470
+ .into_iter()
471
+ .filter_map(|node| self.hashes.get(node.0 as usize))
472
+ .copied()
473
+ .collect(),
474
+ )
475
+ }
476
+ }
477
+
478
+ pub(crate) fn get_build_metadata_clock(
479
+ &self,
480
+ have_deps: &[ChangeHash],
481
+ ) -> Vec<BuildChangeMetadata<'_>> {
482
+ let clock = self.seq_clock_for_heads(have_deps);
483
+ let change_indexes = self.get_build_indexes(clock);
484
+ self.get_build_metadata_for_indexes(change_indexes)
485
+ }
486
+
487
+ pub(crate) fn get_hash_for_actor_seq(
488
+ &self,
489
+ actor: usize,
490
+ seq: u64,
491
+ ) -> Result<ChangeHash, AutomergeError> {
492
+ self.seq_index
493
+ .get(actor)
494
+ .and_then(|v| v.get(seq as usize - 1))
495
+ .and_then(|i| self.hashes.get(i.0 as usize))
496
+ .ok_or(AutomergeError::InvalidSeq(seq))
497
+ .copied()
498
+ }
499
+
500
+ fn update_heads(&mut self, change: &Change) {
501
+ for d in change.deps() {
502
+ self.heads.remove(d);
503
+ }
504
+ self.heads.insert(change.hash());
505
+ }
506
+
507
+ pub(crate) fn add_nodes<
508
+ 'a,
509
+ I: Iterator<Item = (&'a Change, usize)> + ExactSizeIterator + Clone,
510
+ >(
511
+ &mut self,
512
+ iter: I,
513
+ ) {
514
+ self.actors
515
+ .extend(iter.clone().map(|(_, a)| ActorIdx::from(a)));
516
+ self.seq.extend(iter.clone().map(|(c, _)| c.seq() as u32));
517
+ self.max_ops
518
+ .extend(iter.clone().map(|(c, _)| c.max_op() as u32));
519
+ self.num_ops
520
+ .extend(iter.clone().map(|(c, _)| c.len() as u64));
521
+ self.timestamps
522
+ .extend(iter.clone().map(|(c, _)| c.timestamp()));
523
+ self.messages
524
+ .extend(iter.clone().map(|(c, _)| c.message().cloned()));
525
+ self.extra_bytes_meta
526
+ .extend(iter.clone().map(|(c, _)| ValueMeta::from(c.extra_bytes())));
527
+ self.parents.extend(std::iter::repeat_n(None, iter.len()));
528
+ for (c, _) in iter {
529
+ self.extra_bytes_raw.extend_from_slice(c.extra_bytes());
530
+ }
531
+ }
532
+
533
+ fn add_changes<'a, I: Iterator<Item = (&'a Change, usize)> + ExactSizeIterator + Clone>(
534
+ &mut self,
535
+ iter: I,
536
+ ) -> Result<(), MissingDep> {
537
+ let node = NodeIdx(self.hashes.len() as u32);
538
+
539
+ self.add_nodes(iter.clone());
540
+
541
+ for (i, (change, actor)) in iter.enumerate() {
542
+ let node_idx = node + i;
543
+ let hash = change.hash();
544
+ self.max_op = std::cmp::max(self.max_op, change.max_op() as u32);
545
+ self.hashes.push(hash);
546
+ debug_assert!(!self.nodes_by_hash.contains_key(&hash));
547
+ self.nodes_by_hash.insert(hash, node_idx);
548
+ self.update_heads(change);
549
+
550
+ assert!(actor < self.seq_index.len());
551
+ assert_eq!(self.seq_index[actor].len() + 1, change.seq() as usize);
552
+ self.seq_index[actor].push(node_idx);
553
+
554
+ for parent_hash in change.deps().iter() {
555
+ self.add_parent(node_idx, parent_hash);
556
+ }
557
+
558
+ if (node_idx + 1).0 % CACHE_STEP == 0 {
559
+ self.cache_clock(node_idx);
560
+ }
561
+ }
562
+ Ok(())
563
+ }
564
+
565
+ pub(crate) fn add_change(&mut self, change: &Change, actor: usize) -> Result<(), MissingDep> {
566
+ let hash = change.hash();
567
+
568
+ if self.nodes_by_hash.contains_key(&hash) {
569
+ return Ok(());
570
+ }
571
+
572
+ for h in change.deps().iter() {
573
+ if !self.nodes_by_hash.contains_key(h) {
574
+ return Err(MissingDep(*h));
575
+ }
576
+ }
577
+
578
+ self.add_changes([(change, actor)].into_iter())
579
+ }
580
+
581
+ fn cache_clock(&mut self, node_idx: NodeIdx) -> SeqClock {
582
+ let mut clock = SeqClock::new(self.num_actors());
583
+ let mut to_visit = BTreeSet::from([node_idx]);
584
+
585
+ self.calculate_clock_inner(&mut clock, &mut to_visit, CACHE_STEP as usize * 2);
586
+
587
+ for n in to_visit {
588
+ let sub = self.cache_clock(n);
589
+ SeqClock::merge(&mut clock, &sub);
590
+ }
591
+
592
+ self.clock_cache.insert(node_idx, clock.clone());
593
+
594
+ clock
595
+ }
596
+
597
+ fn add_parent(&mut self, child_idx: NodeIdx, parent_hash: &ChangeHash) {
598
+ debug_assert!(self.nodes_by_hash.contains_key(parent_hash));
599
+ let parent_idx = *self.nodes_by_hash.get(parent_hash).unwrap();
600
+ let new_edge_idx = EdgeIdx::new(self.edges.len());
601
+ self.edges.push(Edge {
602
+ target: parent_idx,
603
+ next: None,
604
+ });
605
+
606
+ let child = &mut self.parents[child_idx.0 as usize];
607
+ if let Some(edge_idx) = child {
608
+ let mut edge = &mut self.edges[edge_idx.get()];
609
+ while let Some(next) = edge.next {
610
+ edge = &mut self.edges[next.get()];
611
+ }
612
+ edge.next = Some(new_edge_idx);
613
+ } else {
614
+ *child = Some(new_edge_idx);
615
+ }
616
+ }
617
+
618
+ pub(crate) fn deps(&self, hash: &ChangeHash) -> impl Iterator<Item = ChangeHash> + '_ {
619
+ let mut iter = self.nodes_by_hash.get(hash).map(|node| self.parents(*node));
620
+ std::iter::from_fn(move || {
621
+ let next = iter.as_mut()?.next()?;
622
+ self.hashes.get(next.0 as usize).copied()
623
+ })
624
+ }
625
+
626
+ fn parents(&self, node_idx: NodeIdx) -> impl Iterator<Item = NodeIdx> + '_ {
627
+ let mut edge_idx = self.parents[node_idx.0 as usize];
628
+ std::iter::from_fn(move || {
629
+ let this_edge_idx = edge_idx?;
630
+ let edge = &self.edges[this_edge_idx.get()];
631
+ edge_idx = edge.next;
632
+ Some(edge.target)
633
+ })
634
+ }
635
+
636
+ fn heads_to_nodes(&self, heads: &[ChangeHash]) -> Vec<NodeIdx> {
637
+ heads
638
+ .iter()
639
+ .filter_map(|h| self.nodes_by_hash.get(h))
640
+ .copied()
641
+ .collect()
642
+ }
643
+
644
+ pub(crate) fn clock_for_heads(&self, heads: &[ChangeHash]) -> Clock {
645
+ let nodes = self.heads_to_nodes(heads);
646
+ self.calculate_clock(nodes)
647
+ .iter()
648
+ .map(|(actor, seq)| {
649
+ self.seq_index
650
+ .get(actor)
651
+ .and_then(|v| v.get(seq?.get() as usize - 1))
652
+ .and_then(|i| self.max_ops.get(i.0 as usize))
653
+ .copied()
654
+ })
655
+ .collect()
656
+ }
657
+
658
+ pub(crate) fn seq_clock_for_heads(&self, heads: &[ChangeHash]) -> SeqClock {
659
+ let nodes = self.heads_to_nodes(heads);
660
+ self.calculate_clock(nodes)
661
+ }
662
+
663
+ fn clock_data_for(&self, idx: NodeIdx) -> Option<u32> {
664
+ Some(*self.seq.get(idx.0 as usize)?)
665
+ }
666
+
667
+ fn calculate_clock(&self, nodes: Vec<NodeIdx>) -> SeqClock {
668
+ let mut clock = SeqClock::new(self.num_actors());
669
+ let mut to_visit = nodes.into_iter().collect::<BTreeSet<_>>();
670
+
671
+ self.calculate_clock_inner(&mut clock, &mut to_visit, usize::MAX);
672
+
673
+ assert!(to_visit.is_empty());
674
+
675
+ clock
676
+ }
677
+
678
+ fn calculate_clock_inner(
679
+ &self,
680
+ clock: &mut SeqClock,
681
+ to_visit: &mut BTreeSet<NodeIdx>,
682
+ limit: usize,
683
+ ) {
684
+ let mut visited = BTreeSet::new();
685
+
686
+ while let Some(idx) = to_visit.pop_last() {
687
+ assert!(!visited.contains(&idx));
688
+ assert!(visited.len() <= self.hashes.len());
689
+ visited.insert(idx);
690
+
691
+ let actor = self.actors[idx.0 as usize];
692
+ let data = self.clock_data_for(idx);
693
+ clock.include(actor.into(), data);
694
+
695
+ if let Some(cached) = self.clock_cache.get(&idx) {
696
+ SeqClock::merge(clock, cached);
697
+ } else {
698
+ to_visit.extend(self.parents(idx).filter(|p| !visited.contains(p)));
699
+ if visited.len() > limit {
700
+ break;
701
+ }
702
+ }
703
+ }
704
+ }
705
+
706
+ pub(crate) fn remove_ancestors(
707
+ &self,
708
+ changes: &mut BTreeSet<ChangeHash>,
709
+ heads: &[ChangeHash],
710
+ ) {
711
+ let nodes = self.heads_to_nodes(heads);
712
+ self.traverse_ancestors(nodes, |idx| {
713
+ let hash = &self.hashes[idx.0 as usize];
714
+ changes.remove(hash);
715
+ true
716
+ });
717
+ }
718
+
719
+ fn traverse_ancestors<F: FnMut(NodeIdx) -> bool>(&self, mut to_visit: Vec<NodeIdx>, mut f: F) {
720
+ let mut visited = BTreeSet::new();
721
+
722
+ while let Some(idx) = to_visit.pop() {
723
+ if visited.contains(&idx) {
724
+ continue;
725
+ } else {
726
+ visited.insert(idx);
727
+ }
728
+ if f(idx) {
729
+ to_visit.extend(self.parents(idx));
730
+ }
731
+ }
732
+ }
733
+ }
734
+
735
+ impl ChangeGraphCols {
736
+ pub(crate) fn len(&self) -> usize {
737
+ self.0.len()
738
+ }
739
+
740
+ pub(crate) fn iter(&self) -> ChangeIter<'_> {
741
+ self.0.iter()
742
+ }
743
+
744
+ pub(crate) fn finalize(self, changes: &[Change]) -> ChangeGraph {
745
+ let mut graph = self.0;
746
+ debug_assert_eq!(changes.len(), graph.len());
747
+ debug_assert!(graph.hashes.is_empty());
748
+
749
+ for c in changes {
750
+ let hash = c.hash();
751
+ let node_idx = NodeIdx(graph.hashes.len() as u32);
752
+ graph.nodes_by_hash.insert(hash, node_idx);
753
+ graph.hashes.push(hash)
754
+ }
755
+
756
+ for n in 0..(graph.len() as u32) {
757
+ if (n + 1) % CACHE_STEP == 0 {
758
+ graph.cache_clock(NodeIdx(n));
759
+ }
760
+ }
761
+
762
+ graph
763
+ }
764
+
765
+ pub(crate) fn load(doc: &Document<'_>) -> Result<Self, LoadError> {
766
+ use ids::*;
767
+
768
+ let num_actors = doc.actors().len();
769
+ let meta = doc.change_meta();
770
+ let bytes = doc.change_bytes();
771
+
772
+ let actor_bytes = meta.bytes(ACTOR_COL_SPEC, bytes);
773
+ let seq_bytes = meta.bytes(SEQ_COL_SPEC, bytes);
774
+ let max_op_bytes = meta.bytes(MAX_OP_COL_SPEC, bytes);
775
+ let time_bytes = meta.bytes(TIME_COL_SPEC, bytes);
776
+ let message_bytes = meta.bytes(MESSAGE_COL_SPEC, bytes);
777
+ let deps_count_bytes = meta.bytes(DEPS_COUNT_COL_SPEC, bytes);
778
+ let deps_val_bytes = meta.bytes(DEPS_VAL_COL_SPEC, bytes);
779
+ let extra_meta_bytes = meta.bytes(EXTRA_META_COL_SPEC, bytes);
780
+
781
+ let extra_bytes_raw = meta.bytes(EXTRA_VAL_COL_SPEC, bytes).to_vec();
782
+
783
+ let actors = to_vec(ActorCursor::iter(actor_bytes))?;
784
+ let max_ops = to_u32_vec(DeltaCursor::iter(max_op_bytes))?;
785
+ let max_op = max_ops.iter().copied().max().unwrap_or(0);
786
+ let seq = to_u32_vec(DeltaCursor::iter(seq_bytes))?;
787
+
788
+ if let Some(a) = actors.iter().copied().map(usize::from).max() {
789
+ if a >= num_actors {
790
+ return Err(LoadError::InvalidActorId(a));
791
+ }
792
+ }
793
+
794
+ let len = actors.len();
795
+
796
+ let timestamps = ColumnData::load_unless_empty(time_bytes, len)?;
797
+ let messages = ColumnData::load_unless_empty(message_bytes, len)?;
798
+ let extra_bytes_meta = ColumnData::load_unless_empty(extra_meta_bytes, len)?;
799
+
800
+ if max_ops.len() != len {
801
+ return Err(LoadError::InvalidColumnLength(MAX_OP_COL_SPEC));
802
+ }
803
+ if seq.len() != len {
804
+ return Err(LoadError::InvalidColumnLength(SEQ_COL_SPEC));
805
+ }
806
+ if timestamps.len() != len {
807
+ return Err(LoadError::InvalidColumnLength(TIME_COL_SPEC));
808
+ }
809
+ if messages.len() != len {
810
+ return Err(LoadError::InvalidColumnLength(MESSAGE_COL_SPEC));
811
+ }
812
+
813
+ let mut seq_index = vec![vec![]; num_actors];
814
+ for (i, actor) in actors.iter().enumerate() {
815
+ let actor = actor.0 as usize;
816
+ seq_index[actor].push(NodeIdx(i as u32));
817
+ }
818
+
819
+ let mut parents = Vec::with_capacity(len);
820
+ let mut edges = vec![];
821
+
822
+ let deps_count = UIntCursor::iter(deps_count_bytes).map(to_u32);
823
+ let mut deps_val = DeltaCursor::iter(deps_val_bytes).map(to_u32);
824
+
825
+ let mut num_ops = Vec::with_capacity(len);
826
+ for (i, d) in deps_count.enumerate() {
827
+ let d = d? as usize;
828
+ if d == 0 {
829
+ num_ops.push(max_ops[i] as u64);
830
+ parents.push(None);
831
+ continue;
832
+ }
833
+
834
+ parents.push(Some(EdgeIdx::new(edges.len())));
835
+ let mut last_max_op = 0;
836
+ for e in 0..d {
837
+ let dep = deps_val.next();
838
+ let dep = dep.ok_or(LoadError::InvalidColumnLength(DEPS_VAL_COL_SPEC))??;
839
+ let target = NodeIdx(dep);
840
+ let next = EdgeIdx::new(edges.len() + 1);
841
+ let next = if e + 1 == d { None } else { Some(next) };
842
+ last_max_op = std::cmp::max(last_max_op, max_ops[dep as usize]);
843
+ edges.push(Edge { target, next })
844
+ }
845
+ if last_max_op > max_ops[i] {
846
+ return Err(LoadError::InvalidMaxOp);
847
+ }
848
+ num_ops.push(max_ops[i] as u64 - last_max_op as u64);
849
+ }
850
+ let num_ops = num_ops.into_iter().collect();
851
+
852
+ let heads = doc.heads().iter().copied().collect();
853
+
854
+ if parents.len() != len {
855
+ return Err(LoadError::InvalidColumnLength(DEPS_COUNT_COL_SPEC));
856
+ }
857
+
858
+ // blank - to be filled out later
859
+ let clock_cache = HashMap::default();
860
+ let hashes = vec![];
861
+ let nodes_by_hash = HashMap::new();
862
+
863
+ Ok(ChangeGraphCols(ChangeGraph {
864
+ edges,
865
+ hashes,
866
+ actors,
867
+ parents,
868
+ seq,
869
+ max_ops,
870
+ max_op,
871
+ num_ops,
872
+ timestamps,
873
+ messages,
874
+ extra_bytes_meta,
875
+ extra_bytes_raw,
876
+ heads,
877
+ nodes_by_hash,
878
+ clock_cache,
879
+ seq_index,
880
+ }))
881
+ }
882
+ }
883
+
884
+ fn as_num_deps(num: usize) -> Option<Cow<'static, u64>> {
885
+ Some(Cow::Owned(num as u64))
886
+ }
887
+
888
+ fn as_seq(seq: &u32) -> Option<Cow<'_, i64>> {
889
+ Some(Cow::Owned(*seq as i64))
890
+ }
891
+
892
+ fn as_actor(actor_index: &ActorIdx) -> Option<Cow<'_, ActorIdx>> {
893
+ Some(Cow::Borrowed(actor_index))
894
+ }
895
+
896
+ fn as_max_op(m: &u32) -> Option<Cow<'_, i64>> {
897
+ Some(Cow::Owned(*m as i64))
898
+ }
899
+
900
+ fn as_deps(n: NodeIdx) -> Option<Cow<'static, i64>> {
901
+ Some(Cow::Owned(n.0 as i64))
902
+ }
903
+
904
+ #[derive(Debug, thiserror::Error)]
905
+ #[error("attempted to derive a clock for a change with dependencies we don't have")]
906
+ pub struct MissingDep(ChangeHash);
907
+
908
+ #[cfg(test)]
909
+ mod tests {
910
+ use std::{
911
+ collections::BTreeMap,
912
+ time::{SystemTime, UNIX_EPOCH},
913
+ };
914
+
915
+ use crate::{
916
+ op_set2::{change::build_change, op_set::ResolvedAction, OpSet, TxOp},
917
+ types::{ObjMeta, OpId, OpType},
918
+ ActorId, TextEncoding,
919
+ };
920
+
921
+ use super::*;
922
+
923
+ #[test]
924
+ fn clock_by_heads() {
925
+ let mut builder = TestGraphBuilder::new();
926
+ let actor1 = builder.actor();
927
+ let actor2 = builder.actor();
928
+ let actor3 = builder.actor();
929
+ let change1 = builder.change(&actor1, 10, &[]);
930
+ let change2 = builder.change(&actor2, 20, &[change1]);
931
+ let change3 = builder.change(&actor3, 30, &[change1]);
932
+ let change4 = builder.change(&actor1, 10, &[change2, change3]);
933
+ let graph = builder.build();
934
+
935
+ // todo - why 4?
936
+ let mut expected_clock = SeqClock::new(3);
937
+ expected_clock.include(builder.index(&actor1), Some(2));
938
+ expected_clock.include(builder.index(&actor2), Some(1));
939
+ expected_clock.include(builder.index(&actor3), Some(1));
940
+
941
+ let clock = graph.seq_clock_for_heads(&[change4]);
942
+ assert_eq!(clock, expected_clock);
943
+ }
944
+
945
+ #[test]
946
+ fn remove_ancestors() {
947
+ let mut builder = TestGraphBuilder::new();
948
+ let actor1 = builder.actor();
949
+ let actor2 = builder.actor();
950
+ let actor3 = builder.actor();
951
+ let change1 = builder.change(&actor1, 10, &[]);
952
+ let change2 = builder.change(&actor2, 20, &[change1]);
953
+ let change3 = builder.change(&actor3, 30, &[change1]);
954
+ let change4 = builder.change(&actor1, 10, &[change2, change3]);
955
+ let graph = builder.build();
956
+
957
+ let mut changes = vec![change1, change2, change3, change4]
958
+ .into_iter()
959
+ .collect::<BTreeSet<_>>();
960
+ let heads = vec![change2];
961
+ graph.remove_ancestors(&mut changes, &heads);
962
+
963
+ let expected_changes = vec![change3, change4].into_iter().collect::<BTreeSet<_>>();
964
+
965
+ assert_eq!(changes, expected_changes);
966
+ }
967
+
968
+ struct TestGraphBuilder {
969
+ actors: Vec<ActorId>,
970
+ changes: Vec<Change>,
971
+ graph: ChangeGraph,
972
+ seqs_by_actor: BTreeMap<ActorId, u64>,
973
+ }
974
+
975
+ impl TestGraphBuilder {
976
+ fn new() -> Self {
977
+ TestGraphBuilder {
978
+ actors: Vec::new(),
979
+ changes: Vec::new(),
980
+ graph: ChangeGraph::new(0),
981
+ seqs_by_actor: BTreeMap::new(),
982
+ }
983
+ }
984
+
985
+ fn actor(&mut self) -> ActorId {
986
+ let actor = ActorId::random();
987
+ self.graph.insert_actor(self.actors.len());
988
+ self.actors.push(actor.clone());
989
+ actor
990
+ }
991
+
992
+ fn index(&self, actor: &ActorId) -> usize {
993
+ self.actors.iter().position(|a| a == actor).unwrap()
994
+ }
995
+
996
+ /// Create a change with `num_new_ops` and `parents` for `actor`
997
+ ///
998
+ /// The `start_op` and `seq` of the change will be computed from the
999
+ /// previous changes for the same actor.
1000
+ fn change(
1001
+ &mut self,
1002
+ actor: &ActorId,
1003
+ num_new_ops: usize,
1004
+ parents: &[ChangeHash],
1005
+ ) -> ChangeHash {
1006
+ let osd = OpSet::from_actors(self.actors.clone(), TextEncoding::platform_default());
1007
+
1008
+ let start_op = parents
1009
+ .iter()
1010
+ .map(|c| {
1011
+ self.changes
1012
+ .iter()
1013
+ .find(|change| change.hash() == *c)
1014
+ .unwrap()
1015
+ .max_op()
1016
+ })
1017
+ .max()
1018
+ .unwrap_or(0)
1019
+ + 1;
1020
+
1021
+ let actor_idx = self.index(actor);
1022
+ let ops = (0..num_new_ops)
1023
+ .map(|opnum| {
1024
+ TxOp::map(
1025
+ OpId::new(start_op + opnum as u64, actor_idx),
1026
+ ObjMeta::root(),
1027
+ 0,
1028
+ ResolvedAction::VisibleUpdate(OpType::Put("value".into())),
1029
+ "key".to_string(),
1030
+ vec![],
1031
+ )
1032
+ })
1033
+ .collect::<Vec<_>>();
1034
+
1035
+ let timestamp = SystemTime::now()
1036
+ .duration_since(UNIX_EPOCH)
1037
+ .unwrap()
1038
+ .as_millis() as i64;
1039
+ let seq = self.seqs_by_actor.entry(actor.clone()).or_insert(1);
1040
+ let meta = BuildChangeMetadata {
1041
+ actor: actor_idx,
1042
+ builder: 0,
1043
+ deps: parents
1044
+ .iter()
1045
+ .map(|h| self.graph.hash_to_index(h).unwrap() as u64)
1046
+ .collect(),
1047
+ seq: *seq,
1048
+ max_op: start_op + ops.len() as u64 - 1,
1049
+ start_op,
1050
+ timestamp,
1051
+ message: None,
1052
+ extra: Cow::Owned(vec![]),
1053
+ };
1054
+ let change = Change::new(build_change(&ops, &meta, &self.graph, &osd.actors));
1055
+ *seq = seq.checked_add(1).unwrap();
1056
+ let hash = change.hash();
1057
+ self.graph.add_change(&change, actor_idx).unwrap();
1058
+ self.changes.push(change);
1059
+ hash
1060
+ }
1061
+
1062
+ fn build(&self) -> ChangeGraph {
1063
+ let mut graph = ChangeGraph::new(self.actors.len());
1064
+ for change in &self.changes {
1065
+ let actor_idx = self.index(change.actor_id());
1066
+ graph.add_change(change, actor_idx).unwrap();
1067
+ }
1068
+ graph
1069
+ }
1070
+ }
1071
+ }
1072
+
1073
+ fn to_vec<'a, I, T>(iter: I) -> Result<Vec<T>, PackError>
1074
+ where
1075
+ I: Iterator<Item = Result<Option<Cow<'a, T>>, PackError>>,
1076
+ T: Copy + Default + 'a,
1077
+ {
1078
+ iter.map(squish).collect()
1079
+ }
1080
+
1081
+ fn squish<T>(i: Result<Option<Cow<'_, T>>, PackError>) -> Result<T, PackError>
1082
+ where
1083
+ T: Copy + Default,
1084
+ {
1085
+ match i {
1086
+ Err(e) => Err(e),
1087
+ Ok(Some(i)) => Ok(*i),
1088
+ Ok(None) => Ok(T::default()),
1089
+ }
1090
+ }
1091
+
1092
+ fn to_u32<T>(i: Result<Option<Cow<'_, T>>, PackError>) -> Result<u32, PackError>
1093
+ where
1094
+ T: TryInto<u32> + Copy + Default,
1095
+ {
1096
+ match i {
1097
+ Err(e) => Err(e),
1098
+ Ok(Some(i)) => Ok((*i).try_into().unwrap_or(0)),
1099
+ Ok(None) => Ok(0),
1100
+ }
1101
+ }
1102
+
1103
+ fn to_u32_vec<'a, I, T>(iter: I) -> Result<Vec<u32>, PackError>
1104
+ where
1105
+ I: Iterator<Item = Result<Option<Cow<'a, T>>, PackError>>,
1106
+ T: TryInto<u32> + Copy + Default + 'a,
1107
+ {
1108
+ iter.map(to_u32).collect()
1109
+ }
1110
+
1111
+ pub(crate) struct ChangeIter<'a> {
1112
+ index: usize,
1113
+ actors: std::slice::Iter<'a, ActorIdx>,
1114
+ seq: std::slice::Iter<'a, u32>,
1115
+ max_ops: std::slice::Iter<'a, u32>,
1116
+ num_ops: ColumnDataIter<'a, UIntCursor>,
1117
+ timestamps: ColumnDataIter<'a, DeltaCursor>,
1118
+ messages: ColumnDataIter<'a, StrCursor>,
1119
+ extra_bytes_meta: ColGroupIter<'a, MetaCursor>,
1120
+ graph: &'a ChangeGraph,
1121
+ }
1122
+
1123
+ impl<'a> Iterator for ChangeIter<'a> {
1124
+ type Item = BuildChangeMetadata<'a>;
1125
+
1126
+ fn next(&mut self) -> Option<Self::Item> {
1127
+ let i = self.index;
1128
+ self.index += 1;
1129
+ let actor = (*self.actors.next()?).into();
1130
+ let seq = *self.seq.next()? as u64;
1131
+ let max_op = *self.max_ops.next()? as u64;
1132
+ let num_ops = *self.num_ops.next().flatten().unwrap_or_default();
1133
+ let timestamp = *self.timestamps.next().flatten().unwrap_or_default();
1134
+ let message = self.messages.next().flatten();
1135
+ let start_op = max_op - num_ops + 1;
1136
+
1137
+ let meta = self.extra_bytes_meta.next()?;
1138
+ let meta_range = meta.acc.as_usize()..(meta.acc.as_usize() + meta.item.unwrap().length());
1139
+ let extra = Cow::Borrowed(&self.graph.extra_bytes_raw[meta_range]);
1140
+ let deps = self
1141
+ .graph
1142
+ .parents(NodeIdx(i as u32))
1143
+ .map(|n| n.0 as u64)
1144
+ .collect();
1145
+ Some(BuildChangeMetadata {
1146
+ actor,
1147
+ seq,
1148
+ start_op,
1149
+ max_op,
1150
+ timestamp,
1151
+ message,
1152
+ extra,
1153
+ deps,
1154
+ builder: 0,
1155
+ })
1156
+ }
1157
+
1158
+ fn nth(&mut self, n: usize) -> Option<Self::Item> {
1159
+ let i = self.index + n;
1160
+ self.index += n + 1;
1161
+
1162
+ let actor = (*self.actors.nth(n)?).into();
1163
+ let seq = *self.seq.nth(n)? as u64;
1164
+ let max_op = *self.max_ops.nth(0)? as u64;
1165
+ let num_ops = *self.num_ops.nth(0).flatten().unwrap_or_default();
1166
+ let timestamp = *self.timestamps.nth(0).flatten().unwrap_or_default();
1167
+ let message = self.messages.nth(0).flatten();
1168
+ let start_op = max_op - num_ops + 1;
1169
+
1170
+ let meta = self.extra_bytes_meta.shift_acc(0)?;
1171
+ let meta_range = meta.acc.as_usize()..(meta.acc.as_usize() + meta.item.unwrap().length());
1172
+ let extra = Cow::Borrowed(&self.graph.extra_bytes_raw[meta_range]);
1173
+
1174
+ let deps = self
1175
+ .graph
1176
+ .parents(NodeIdx(i as u32))
1177
+ .map(|n| n.0 as u64)
1178
+ .collect();
1179
+
1180
+ Some(BuildChangeMetadata {
1181
+ actor,
1182
+ seq,
1183
+ start_op,
1184
+ max_op,
1185
+ timestamp,
1186
+ message,
1187
+ extra,
1188
+ deps,
1189
+ builder: 0,
1190
+ })
1191
+ }
1192
+ }
1193
+
1194
+ #[rustfmt::skip]
1195
+ pub(crate) mod ids {
1196
+ use crate::storage::{columns::ColumnId, ColumnSpec};
1197
+
1198
+ const ACTOR_COL_ID: ColumnId = ColumnId::new(0);
1199
+ const SEQ_COL_ID: ColumnId = ColumnId::new(0);
1200
+ const MAX_OP_COL_ID: ColumnId = ColumnId::new(1);
1201
+ const TIME_COL_ID: ColumnId = ColumnId::new(2);
1202
+ const MESSAGE_COL_ID: ColumnId = ColumnId::new(3);
1203
+ const DEPS_COL_ID: ColumnId = ColumnId::new(4);
1204
+ const EXTRA_COL_ID: ColumnId = ColumnId::new(5);
1205
+
1206
+ pub(super) const ACTOR_COL_SPEC: ColumnSpec = ColumnSpec::new_actor(ACTOR_COL_ID);
1207
+ pub(super) const SEQ_COL_SPEC: ColumnSpec = ColumnSpec::new_delta(SEQ_COL_ID);
1208
+ pub(super) const MAX_OP_COL_SPEC: ColumnSpec = ColumnSpec::new_delta(MAX_OP_COL_ID);
1209
+ pub(super) const TIME_COL_SPEC: ColumnSpec = ColumnSpec::new_delta(TIME_COL_ID);
1210
+ pub(super) const MESSAGE_COL_SPEC: ColumnSpec = ColumnSpec::new_string(MESSAGE_COL_ID);
1211
+ pub(super) const DEPS_COUNT_COL_SPEC: ColumnSpec = ColumnSpec::new_group(DEPS_COL_ID);
1212
+ pub(super) const DEPS_VAL_COL_SPEC: ColumnSpec = ColumnSpec::new_delta(DEPS_COL_ID);
1213
+ pub(super) const EXTRA_META_COL_SPEC: ColumnSpec = ColumnSpec::new_value_metadata(EXTRA_COL_ID);
1214
+ pub(super) const EXTRA_VAL_COL_SPEC: ColumnSpec = ColumnSpec::new_value(EXTRA_COL_ID);
1215
+ }