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,1793 @@
1
+ use super::parents::Parents;
2
+ use crate::clock::{Clock, ClockRange};
3
+ use crate::exid::ExId;
4
+ use crate::iter::tools::{MergeIter, SkipIter, SkipWrap};
5
+ use crate::marks::{MarkSet, RichTextQueryState};
6
+ use crate::storage::columns::BadColumnLayout;
7
+ use crate::storage::{columns::compression::Uncompressed, ColumnSpec, Document, RawColumns};
8
+ use crate::types;
9
+ use crate::types::{
10
+ ActorId, ElemId, Export, Exportable, ObjId, ObjMeta, ObjType, OpId, Prop, SequenceType,
11
+ TextEncoding,
12
+ };
13
+ use crate::AutomergeError;
14
+
15
+ use super::op::{Op, OpLike, SuccCursors, SuccInsert};
16
+
17
+ use super::columns::Columns;
18
+
19
+ use super::types::{Action, ActorCursor, ActorIdx, KeyRef, MarkData, OpType, ScalarValue};
20
+
21
+ use hexane::{BooleanCursor, ColumnDataIter, PackError, Run, StrCursor, UIntCursor};
22
+
23
+ use std::borrow::Cow;
24
+ use std::cmp::Ordering;
25
+ use std::num::NonZeroUsize;
26
+ use std::ops::{Range, RangeBounds};
27
+ use std::sync::Arc;
28
+
29
+ mod found_op;
30
+ mod index;
31
+ mod insert;
32
+ mod mark_index;
33
+ mod marks;
34
+ mod op_iter;
35
+ mod op_query;
36
+ mod top_op;
37
+ mod visible;
38
+
39
+ pub(crate) use index::{IndexBuilder, ObjIndex, ObjInfo};
40
+
41
+ pub(crate) use crate::iter::{Keys, ListRange, MapRange, SpansInternal};
42
+
43
+ pub(crate) use found_op::OpsFoundIter;
44
+ pub(crate) use insert::InsertQuery;
45
+ pub(crate) use mark_index::{MarkIndexBuilder, MarkIndexColumn};
46
+ pub(crate) use marks::{MarkIter, NoMarkIter};
47
+ pub(crate) use op_iter::{
48
+ ActionIter, ActionValueIter, CtrWalker, InsertIter, KeyIter, MarkInfoIter, ObjIdIter, OpIdIter,
49
+ OpIter, ReadOpError, SuccIterIter, SuccWalker, ValueIter,
50
+ };
51
+ pub(crate) use op_query::{OpQuery, OpQueryTerm};
52
+ pub(crate) use top_op::TopOpIter;
53
+ pub(crate) use visible::{VisIter, VisibleOpIter};
54
+
55
+ pub(crate) type InsertAcc<'a> = hexane::ColAccIter<'a, BooleanCursor>;
56
+
57
+ #[derive(Debug, Clone)]
58
+ pub(crate) struct OpSet {
59
+ pub(crate) actors: Vec<ActorId>,
60
+ pub(crate) obj_info: ObjIndex,
61
+ cols: Columns,
62
+ pub(crate) text_encoding: TextEncoding,
63
+ }
64
+
65
+ #[derive(Debug, Clone)]
66
+ pub(crate) struct OpSetCheckpoint(OpSet);
67
+
68
+ impl OpSet {
69
+ #[cfg(test)]
70
+ pub(crate) fn debug_cmp(&self, other: &Self) {
71
+ self.cols.debug_cmp(&other.cols)
72
+ }
73
+
74
+ pub(crate) fn save_checkpoint(&self) -> OpSetCheckpoint {
75
+ OpSetCheckpoint(self.clone())
76
+ }
77
+
78
+ pub(crate) fn load_checkpoint(&mut self, mut checkpoint: OpSetCheckpoint) {
79
+ std::mem::swap(&mut checkpoint.0, self);
80
+ }
81
+
82
+ #[cfg(test)]
83
+ pub(crate) fn from_actors(actors: Vec<ActorId>, encoding: TextEncoding) -> Self {
84
+ OpSet {
85
+ actors,
86
+ cols: Columns::default(),
87
+ obj_info: ObjIndex::default(),
88
+ text_encoding: encoding,
89
+ }
90
+ }
91
+
92
+ pub(crate) fn dump(&self) {
93
+ log!("OpSet");
94
+ log!(" len: {}", self.len());
95
+ log!(" actors: {:?}", self.actors);
96
+ self.cols.dump();
97
+ }
98
+
99
+ pub(crate) fn parents(&self, obj: ObjId, clock: Option<Clock>) -> Parents<'_> {
100
+ Parents {
101
+ obj,
102
+ ops: self,
103
+ clock,
104
+ }
105
+ }
106
+
107
+ pub(crate) fn index_builder(&self) -> IndexBuilder {
108
+ IndexBuilder::new(self, self.text_encoding)
109
+ }
110
+
111
+ pub(crate) fn reset_top(&mut self, range: Range<usize>) {
112
+ let top = self.cols.index.top.iter_range(range.clone());
113
+ let vis = self.cols.index.visible.iter_range(range.clone());
114
+
115
+ // convert Option<Cow<'_,bool>> into bool :(
116
+ let top = top.map(|b| b.as_deref().copied().unwrap_or(false));
117
+ let vis = vis.map(|b| b.as_deref().copied().unwrap_or(false));
118
+
119
+ let mut conflicts = vec![];
120
+ let mut expose = None;
121
+ let mut last_t = None;
122
+ for (i, (v, t)) in vis.zip(top).enumerate() {
123
+ if t {
124
+ assert!(v);
125
+ if let Some(n) = last_t {
126
+ conflicts.push(n);
127
+ }
128
+ last_t = Some(i);
129
+ expose = None;
130
+ } else if v {
131
+ if let Some(n) = last_t {
132
+ conflicts.push(n);
133
+ }
134
+ last_t = None;
135
+ expose = Some(i);
136
+ }
137
+ }
138
+
139
+ for n in conflicts {
140
+ self.conflict(range.start + n)
141
+ }
142
+
143
+ if let Some(n) = expose {
144
+ self.expose(range.start + n)
145
+ }
146
+ }
147
+
148
+ pub(crate) fn conflict(&mut self, pos: usize) {
149
+ self.cols.index.top.splice(pos, 1, [false]);
150
+ }
151
+
152
+ pub(crate) fn expose(&mut self, pos: usize) {
153
+ self.cols.index.top.splice(pos, 1, [true]);
154
+ }
155
+
156
+ pub(crate) fn validate(
157
+ bytes: usize,
158
+ cols: &RawColumns<Uncompressed>,
159
+ ) -> Result<RawColumns<Uncompressed>, BadColumnLayout> {
160
+ Columns::validate(bytes, cols)
161
+ }
162
+
163
+ pub(crate) fn validate_op_order(&self) -> bool {
164
+ let mut stepper = Default::default();
165
+ for op in self.iter() {
166
+ if !op.step(&mut stepper) {
167
+ return false;
168
+ }
169
+ }
170
+ true
171
+ }
172
+
173
+ pub(crate) fn validate_top_index(&self) -> bool {
174
+ let _top = &self.cols.index.top;
175
+ let _visible = &self.cols.index.visible;
176
+
177
+ assert_eq!(_top.len(), _visible.len());
178
+ assert_eq!(_top.len(), self.len());
179
+
180
+ let top_iter = _top.iter();
181
+ let vis_iter = _visible.iter();
182
+ let op_iter = self.iter();
183
+
184
+ let mut last_op = None;
185
+ let mut first_top = None;
186
+ let mut last_vis = None;
187
+
188
+ for ((top, vis), op) in top_iter.zip(vis_iter).zip(op_iter) {
189
+ let vis = *vis.unwrap();
190
+ let top = *top.unwrap();
191
+
192
+ let this_op = Some((op.obj, op.elemid_or_key()));
193
+
194
+ if this_op != last_op {
195
+ assert_eq!(first_top, last_vis);
196
+ last_op = this_op;
197
+ first_top = None;
198
+ last_vis = None;
199
+ }
200
+
201
+ if top {
202
+ assert!(vis);
203
+ if first_top.is_none() {
204
+ first_top = Some(op.pos);
205
+ }
206
+ }
207
+ if vis {
208
+ last_vis = Some(op.pos);
209
+ }
210
+ }
211
+ assert_eq!(first_top, last_vis);
212
+ true
213
+ }
214
+
215
+ pub(crate) fn set_indexes(&mut self, builder: IndexBuilder) {
216
+ let indexes = builder.finish();
217
+
218
+ assert_eq!(indexes.text.len(), self.len());
219
+ assert_eq!(indexes.mark.len(), self.len());
220
+ assert_eq!(indexes.visible.len(), self.len());
221
+ assert_eq!(indexes.inc.len(), self.cols.sub_len());
222
+
223
+ self.cols.index.text = indexes.text;
224
+ self.cols.index.top = indexes.top;
225
+ self.cols.index.visible = indexes.visible;
226
+ self.cols.index.inc = indexes.inc;
227
+ self.cols.index.mark = indexes.mark;
228
+ self.obj_info = indexes.obj_info;
229
+ }
230
+
231
+ pub(crate) fn splice_objects<O: OpLike>(&mut self, ops: &[O]) {
232
+ for op in ops {
233
+ if let Some(obj_info) = op.obj_info() {
234
+ self.obj_info.insert(op.id(), obj_info);
235
+ }
236
+ }
237
+ }
238
+
239
+ pub(crate) fn splice<O: OpLike>(&mut self, pos: usize, ops: &[O]) -> usize {
240
+ let added = self.cols.splice(pos, ops, self.text_encoding);
241
+ self.splice_objects(ops);
242
+ added
243
+ }
244
+
245
+ pub(crate) fn add_succ(&mut self, op_pos: &[SuccInsert]) {
246
+ const NONE: Option<u64> = None;
247
+ let mut succ_inc = 0;
248
+ let mut last_pos = None;
249
+ for i in op_pos.iter().rev() {
250
+ if last_pos == Some(i.pos) {
251
+ succ_inc += 1;
252
+ } else {
253
+ last_pos = Some(i.pos);
254
+ succ_inc = 1;
255
+ }
256
+ self.cols.succ_count.splice(i.pos, 1, [i.len + succ_inc]);
257
+ self.cols.succ_actor.splice(i.sub_pos, 0, [i.id.actoridx()]);
258
+ self.cols.succ_ctr.splice(i.sub_pos, 0, [i.id.icounter()]);
259
+ self.cols.index.inc.splice(i.sub_pos, 0, [i.inc]);
260
+ if i.inc.is_none() {
261
+ self.cols.index.visible.splice(i.pos, 1, [false]);
262
+ self.cols.index.text.splice(i.pos, 1, [NONE]);
263
+ self.cols.index.top.splice(i.pos, 1, [false]);
264
+ }
265
+ }
266
+ }
267
+
268
+ pub(crate) fn parent_object(&self, child: &ObjId, clock: Option<&Clock>) -> Option<Parent> {
269
+ let (op, visible) = self.find_op_by_id_and_vis(child.id()?, clock)?;
270
+ let obj = op.obj;
271
+ let typ = self.object_type(&obj)?;
272
+ let prop = match op.key {
273
+ KeyRef::Map(k) => Prop::Map(k.to_string()),
274
+ KeyRef::Seq(_) => {
275
+ let seq_type = match typ {
276
+ ObjType::List => SequenceType::List,
277
+ ObjType::Text => SequenceType::Text,
278
+ _ => panic!("unexpected object type {:?} for seq key {:?}", typ, op.key),
279
+ };
280
+ let index = self.seek_list_opid(&op.obj, op.id, seq_type, clock)?.index;
281
+ Prop::Seq(index)
282
+ }
283
+ };
284
+ Some(Parent {
285
+ typ,
286
+ obj: op.obj,
287
+ prop,
288
+ visible,
289
+ })
290
+ }
291
+
292
+ pub(crate) fn keys<'a>(&'a self, obj: &ObjId, clock: Option<Clock>) -> Keys<'a> {
293
+ let iter = self.iter_obj(obj).visible_slow(clock).top_ops();
294
+ Keys::new(self, iter)
295
+ }
296
+
297
+ pub(crate) fn spans(&self, obj: &ObjId, clock: Option<Clock>) -> SpansInternal<'_> {
298
+ let range = self.scope_to_obj(obj);
299
+ SpansInternal::new(self, range, clock, self.text_encoding)
300
+ }
301
+
302
+ pub(crate) fn list_range<R: RangeBounds<usize>>(
303
+ &self,
304
+ obj: &ObjId,
305
+ range: R,
306
+ clock: Option<Clock>,
307
+ ) -> ListRange<'_> {
308
+ let obj_range = self.scope_to_obj(obj);
309
+ ListRange::new(self, obj_range, clock, range)
310
+ }
311
+
312
+ pub(crate) fn map_range<R: RangeBounds<String>>(
313
+ &self,
314
+ obj: &ObjId,
315
+ range: R,
316
+ clock: Option<Clock>,
317
+ ) -> MapRange<'_> {
318
+ let obj_range = self.scope_to_obj(obj);
319
+
320
+ let start = match range.start_bound() {
321
+ std::ops::Bound::Unbounded => obj_range.start,
322
+ std::ops::Bound::Included(s) => {
323
+ self.cols
324
+ .key_str
325
+ .scope_to_value(Some(s.as_str()), obj_range.clone())
326
+ .start
327
+ }
328
+ std::ops::Bound::Excluded(s) => {
329
+ self.cols
330
+ .key_str
331
+ .scope_to_value(Some(s.as_str()), obj_range.clone())
332
+ .end
333
+ }
334
+ };
335
+
336
+ let end = match range.end_bound() {
337
+ std::ops::Bound::Unbounded => obj_range.end,
338
+ std::ops::Bound::Included(s) => {
339
+ self.cols
340
+ .key_str
341
+ .scope_to_value(Some(s.as_str()), obj_range)
342
+ .end
343
+ }
344
+ std::ops::Bound::Excluded(s) => {
345
+ self.cols
346
+ .key_str
347
+ .scope_to_value(Some(s.as_str()), obj_range)
348
+ .start
349
+ }
350
+ };
351
+
352
+ MapRange::new(self, start..end, clock)
353
+ }
354
+
355
+ pub(crate) fn len(&self) -> usize {
356
+ self.cols.len()
357
+ }
358
+
359
+ pub(crate) fn sub_len(&self) -> usize {
360
+ self.cols.sub_len()
361
+ }
362
+
363
+ pub(crate) fn seq_length(
364
+ &self,
365
+ obj: &ObjId,
366
+ text_encoding: TextEncoding,
367
+ clock: Option<Clock>,
368
+ ) -> usize {
369
+ let range = self.scope_to_obj(obj);
370
+ let vis = VisIter::new(self, clock.as_ref(), range.clone());
371
+ let typ = self.object_type(obj).unwrap_or(ObjType::Map);
372
+ if typ == ObjType::Text {
373
+ if clock.is_none() {
374
+ // TODO - this could be done faster with the index
375
+ let text = self.cols.index.text.iter_range(range.clone());
376
+ let iter = SkipIter::new(text.clone(), vis.clone());
377
+ iter.filter_map(|n| n.as_deref().copied()).sum::<u64>() as usize
378
+ } else {
379
+ self.action_value_iter(range.clone(), clock.as_ref())
380
+ .map(|(action, value, _)| match (action, &value) {
381
+ (Action::Set, ScalarValue::Str(s)) => text_encoding.width(s),
382
+ (Action::Mark, _) => 0,
383
+ _ => text_encoding.width("\u{fffc}"),
384
+ })
385
+ .sum()
386
+ }
387
+ } else if typ == ObjType::List {
388
+ let insert = self.cols.insert.iter_range(range.clone()).as_acc();
389
+ SkipIter::new(insert, vis)
390
+ .fold((hexane::Acc::default(), 0), |(prev, count), curr| {
391
+ let inc = if prev != curr { 1 } else { 0 };
392
+ (curr, count + inc)
393
+ })
394
+ .1
395
+ } else {
396
+ let key = self.cols.key_str.iter_range(range.clone());
397
+ SkipIter::new(key, vis)
398
+ .fold((None, 0), |(prev, count), curr| {
399
+ let inc = if prev.as_ref() != Some(&curr) { 1 } else { 0 };
400
+ (Some(curr), count + inc)
401
+ })
402
+ .1
403
+ }
404
+ }
405
+
406
+ pub(crate) fn query_insert_at_text(
407
+ &self,
408
+ obj: &ObjId,
409
+ index: NonZeroUsize,
410
+ ) -> Option<QueryNth> {
411
+ let range = self.scope_to_obj(obj);
412
+ let mut iter = self.cols.index.text.iter_range(range.clone()).with_acc();
413
+ let start_acc = iter.acc().as_usize();
414
+ let tx = iter.shift_acc(index.get() - 1)?;
415
+ let current_acc = tx.acc.as_usize();
416
+ let iter = self.iter_range(&(tx.pos..range.end));
417
+ let marks = self.cols.index.mark.rich_text_at(tx.pos, None);
418
+ let mut query = InsertQuery::new(
419
+ iter,
420
+ index.get(),
421
+ SequenceType::Text,
422
+ self.text_encoding,
423
+ None,
424
+ marks,
425
+ );
426
+ query.resolve(current_acc - start_acc).ok()
427
+ }
428
+
429
+ pub(crate) fn query_insert_at_list(
430
+ &self,
431
+ obj: &ObjId,
432
+ index: NonZeroUsize,
433
+ ) -> Option<QueryNth> {
434
+ let range = self.scope_to_obj(obj);
435
+
436
+ let mut iter = self.cols.index.top.iter_range(range.clone());
437
+ iter.advance_acc_by(index.get() - 1);
438
+ let start_pos = iter.pos();
439
+ let iter = self.iter_range(&(start_pos..range.end));
440
+ let marks = self.cols.index.mark.rich_text_at(start_pos, None);
441
+ let mut query = InsertQuery::new(
442
+ iter,
443
+ index.get(),
444
+ SequenceType::List,
445
+ self.text_encoding,
446
+ None,
447
+ marks,
448
+ );
449
+ query.resolve(index.get() - 1).ok()
450
+ }
451
+
452
+ pub(crate) fn query_insert_at(
453
+ &self,
454
+ obj: &ObjId,
455
+ index: usize,
456
+ seq_type: SequenceType,
457
+ clock: Option<Clock>,
458
+ ) -> Result<QueryNth, AutomergeError> {
459
+ if clock.is_none() && index > 0 {
460
+ let index = NonZeroUsize::new(index).unwrap();
461
+ let query = if seq_type == SequenceType::List {
462
+ self.query_insert_at_list(obj, index)
463
+ } else {
464
+ self.query_insert_at_text(obj, index)
465
+ };
466
+ if let Some(q) = query {
467
+ debug_assert_eq!(
468
+ Ok(&q),
469
+ InsertQuery::new(
470
+ self.iter_obj(obj),
471
+ index.get(),
472
+ seq_type,
473
+ self.text_encoding,
474
+ clock,
475
+ Default::default()
476
+ )
477
+ .resolve(0)
478
+ .as_ref()
479
+ );
480
+ return Ok(q);
481
+ }
482
+ }
483
+ InsertQuery::new(
484
+ self.iter_obj(obj),
485
+ index,
486
+ seq_type,
487
+ self.text_encoding,
488
+ clock,
489
+ Default::default(),
490
+ )
491
+ .resolve(0)
492
+ }
493
+
494
+ pub(crate) fn seek_ops_by_map_key<'a>(
495
+ &'a self,
496
+ obj: &ObjId,
497
+ key: &str,
498
+ clock: Option<&Clock>,
499
+ ) -> OpsFound<'a> {
500
+ let range = self.prop_range(obj, key);
501
+ let iter = self.iter_range(&range);
502
+ let end_pos = iter.end_pos();
503
+ let ops = iter.visible(self, clock).collect::<Vec<_>>();
504
+ assert_eq!(end_pos, range.end);
505
+ OpsFound {
506
+ index: 0,
507
+ ops,
508
+ range,
509
+ end_pos,
510
+ }
511
+ }
512
+
513
+ pub(crate) fn seek_ops_by_index<'a>(
514
+ &'a self,
515
+ obj: &ObjId,
516
+ index: usize,
517
+ seq_type: SequenceType,
518
+ clock: Option<&Clock>,
519
+ ) -> OpsFound<'a> {
520
+ if clock.is_none() {
521
+ let found = if seq_type == SequenceType::List {
522
+ self.seek_list_ops_by_index_fast(obj, index)
523
+ } else {
524
+ self.seek_text_ops_by_index_fast(obj, index)
525
+ };
526
+ #[cfg(feature = "slow_path_assertions")]
527
+ {
528
+ let slow = self.seek_ops_by_index_slow(obj, index, seq_type, clock);
529
+ assert_eq!(found, slow, "fast != slow");
530
+ }
531
+ found
532
+ } else {
533
+ self.seek_ops_by_index_slow(obj, index, seq_type, clock)
534
+ }
535
+ }
536
+
537
+ pub(crate) fn seek_ops_by_index_slow<'a>(
538
+ &'a self,
539
+ obj: &ObjId,
540
+ index: usize,
541
+ seq_type: SequenceType,
542
+ clock: Option<&Clock>,
543
+ ) -> OpsFound<'a> {
544
+ let sub_iter = self.iter_obj(obj);
545
+ let end = sub_iter.range.end;
546
+ let mut end_pos = sub_iter.pos();
547
+ let iter = OpsFoundIter::new(sub_iter.no_marks(), clock.cloned());
548
+ let mut len = 0;
549
+ let mut range = end_pos..end_pos;
550
+ for mut ops in iter {
551
+ let width = ops.width(seq_type, self.text_encoding);
552
+ if len + width > index {
553
+ ops.index = len;
554
+ return ops;
555
+ }
556
+ len += width;
557
+ end_pos = ops.end_pos;
558
+ range = ops.range;
559
+ }
560
+ assert_eq!(range.end, end_pos);
561
+ OpsFound {
562
+ index,
563
+ ops: vec![],
564
+ end_pos: end,
565
+ range: end..end,
566
+ }
567
+ }
568
+
569
+ fn list_register_at_pos(&self, pos: usize, range: Range<usize>) -> Range<usize> {
570
+ let mut iter = self.cols.insert.iter_range(pos..range.end);
571
+ let acc = iter.calculate_acc().as_usize();
572
+ let insert_op = iter.next().flatten().as_deref().copied().unwrap_or(false);
573
+
574
+ if insert_op {
575
+ iter.advance_acc_by(0);
576
+ pos..iter.pos()
577
+ } else {
578
+ // ACC here represents the number of insert ops to come before pos
579
+ // as insert_op is false and this is a list we know there's at least one
580
+ // insert op before us and acc > 0
581
+ let mut iter = self.cols.insert.iter_range(0..range.end);
582
+ iter.advance_acc_by(acc - 1);
583
+ let start = iter.pos();
584
+ iter.advance_acc_by(1);
585
+ let end = iter.pos();
586
+ start..end
587
+ }
588
+ }
589
+
590
+ pub(crate) fn seek_list_ops_by_index_fast<'a>(
591
+ &'a self,
592
+ obj: &ObjId,
593
+ index: usize,
594
+ ) -> OpsFound<'a> {
595
+ let range = self.scope_to_obj(obj);
596
+
597
+ let mut iter = self.cols.index.top.iter_range(range.clone());
598
+ iter.advance_acc_by(index);
599
+ let tx_pos = iter.pos();
600
+
601
+ if iter.next().is_some() {
602
+ let range = self.list_register_at_pos(tx_pos, range);
603
+ let end_pos = range.end;
604
+ let ops = self.iter_range(&range).visible(self, None).collect();
605
+ OpsFound {
606
+ index,
607
+ ops,
608
+ range,
609
+ end_pos,
610
+ }
611
+ } else {
612
+ let end_pos = range.end;
613
+ OpsFound {
614
+ index,
615
+ ops: vec![],
616
+ range: end_pos..end_pos,
617
+ end_pos,
618
+ }
619
+ }
620
+ }
621
+
622
+ pub(crate) fn seek_text_ops_by_index_fast<'a>(
623
+ &'a self,
624
+ obj: &ObjId,
625
+ mut index: usize,
626
+ ) -> OpsFound<'a> {
627
+ let mut range = self.scope_to_obj(obj);
628
+
629
+ let mut iter = self.cols.index.text.iter_range(range.clone()).with_acc();
630
+
631
+ let mut ops = vec![];
632
+ let mut end_pos = range.end;
633
+ let obj_start = iter.acc();
634
+ if let Some(tx) = iter.shift_acc(index) {
635
+ assert!(tx.acc >= obj_start);
636
+ range.start = tx.pos;
637
+ index = (tx.acc - obj_start).as_usize();
638
+ // TODO
639
+ // could use a SkipIter here
640
+ // could grab only needed fields and not all ops
641
+ for op in self.iter_range(&range) {
642
+ if op.insert {
643
+ if !ops.is_empty() {
644
+ break;
645
+ }
646
+ range.start = op.pos;
647
+ }
648
+ end_pos = op.pos + 1;
649
+ range.end = op.pos + 1;
650
+ if op.succ().len() == 0 && op.action != Action::Mark {
651
+ ops.push(op);
652
+ }
653
+ }
654
+ } else {
655
+ // This is required for the returned FoundOps to have the same
656
+ // range as in the OpSet::seek_ops_by_index_slow function in
657
+ // the case where there are no ops in the object
658
+ range.start = range.end;
659
+ }
660
+
661
+ assert_eq!(range.end, end_pos);
662
+ if ops.is_empty() {
663
+ // As above, this line is needed to normalise the `range` produced to
664
+ // match that for the OpSet::seek_ops_by_index_slow function in the
665
+ // case where there are no ops
666
+ range = end_pos..end_pos;
667
+ }
668
+ OpsFound {
669
+ index,
670
+ ops,
671
+ range,
672
+ end_pos,
673
+ }
674
+ }
675
+
676
+ fn get(&self, pos: usize) -> Option<Op<'_>> {
677
+ self.iter_range(&(pos..(pos + 1))).next()
678
+ }
679
+
680
+ fn get_op_id_pos(&self, id: OpId) -> Option<usize> {
681
+ let counters = &self.cols.id_ctr;
682
+ let actors = &self.cols.id_actor;
683
+ counters
684
+ .find_by_value(id.counter())
685
+ .find(|&pos| actors.get(pos) == Some(Some(Cow::Owned(id.actoridx()))))
686
+ }
687
+
688
+ pub(crate) fn seek_list_opid(
689
+ &self,
690
+ obj: &ObjId,
691
+ opid: OpId,
692
+ seq_type: SequenceType,
693
+ clock: Option<&Clock>,
694
+ ) -> Option<FoundOpId<'_>> {
695
+ if clock.is_none() {
696
+ let found = self.seek_list_opid_fast(obj, opid, seq_type);
697
+ debug_assert_eq!(found, self.seek_list_opid_slow(obj, opid, seq_type, clock));
698
+ found
699
+ } else {
700
+ self.seek_list_opid_slow(obj, opid, seq_type, clock)
701
+ }
702
+ }
703
+
704
+ pub(crate) fn seek_list_opid_fast(
705
+ &self,
706
+ obj: &ObjId,
707
+ id: OpId,
708
+ encoding: SequenceType,
709
+ ) -> Option<FoundOpId<'_>> {
710
+ let ostart = self.scope_to_obj(obj).start;
711
+ let pos = self.get_op_id_pos(id)?;
712
+ let op = self.get(pos)?;
713
+ let visible;
714
+ let index;
715
+ if encoding == SequenceType::List {
716
+ let (delta, item) = self.cols.index.top.get_acc_delta(ostart, pos);
717
+ visible = item.as_deref().copied().unwrap_or(false);
718
+ index = delta.as_usize();
719
+ } else {
720
+ let (delta, item) = self.cols.index.text.get_acc_delta(ostart, pos);
721
+ visible = item.is_some();
722
+ index = delta.as_usize();
723
+ }
724
+ Some(FoundOpId { op, index, visible })
725
+ }
726
+
727
+ pub(crate) fn seek_list_opid_slow(
728
+ &self,
729
+ obj: &ObjId,
730
+ opid: OpId,
731
+ seq_type: SequenceType,
732
+ clock: Option<&Clock>,
733
+ ) -> Option<FoundOpId<'_>> {
734
+ let op = self.iter_obj(obj).find(|op| op.id == opid)?;
735
+ let iter = OpsFoundIter::new(self.iter_obj(obj).no_marks(), clock.cloned());
736
+ let mut index = 0;
737
+ for ops in iter {
738
+ if ops.end_pos > op.pos {
739
+ let visible = ops.ops.contains(&op);
740
+ return Some(FoundOpId { op, index, visible });
741
+ }
742
+ index += ops.width(seq_type, self.text_encoding);
743
+ }
744
+ None
745
+ }
746
+
747
+ pub(crate) fn action_iter_range(&self, range: &Range<usize>) -> ActionIter<'_> {
748
+ ActionIter::new(self.cols.action.iter_range(range.clone()))
749
+ }
750
+
751
+ pub(crate) fn insert_acc_range(&self, range: &Range<usize>) -> InsertAcc<'_> {
752
+ self.cols.insert.iter_range(range.clone()).as_acc()
753
+ }
754
+
755
+ pub(crate) fn key_str_iter_range(&self, range: &Range<usize>) -> ColumnDataIter<'_, StrCursor> {
756
+ self.cols.key_str.iter_range(range.clone())
757
+ }
758
+
759
+ pub(crate) fn action_value_iter(
760
+ &self,
761
+ range: Range<usize>,
762
+ clock: Option<&Clock>,
763
+ ) -> SkipIter<ActionValueIter<'_>, VisIter<'_>> {
764
+ let value = self.value_iter_range(&range);
765
+ let action = self.action_iter_range(&range);
766
+ let vis = VisIter::new(self, clock, range);
767
+ let iter = ActionValueIter::new(action, value);
768
+ SkipIter::new(iter, vis)
769
+ }
770
+
771
+ pub(crate) fn text(&self, obj: &ObjId, clock: Option<Clock>) -> String {
772
+ let range = self.scope_to_obj(obj);
773
+ let skip = self.action_value_iter(range, clock.as_ref());
774
+ skip.map(|item| match item {
775
+ (Action::Set, ScalarValue::Str(s), _) => s,
776
+ (Action::Mark, _, _) => Cow::Borrowed(""),
777
+ (_, _, _) => Cow::Borrowed("\u{fffc}"),
778
+ })
779
+ .collect()
780
+ }
781
+
782
+ pub(crate) fn id_to_exid(&self, id: OpId) -> ExId {
783
+ if id == types::ROOT {
784
+ ExId::Root
785
+ } else {
786
+ ExId::Id(id.counter(), self.actors[id.actor()].clone(), id.actor())
787
+ }
788
+ }
789
+
790
+ pub(crate) fn iter_obj_ids(&self) -> IterObjIds<'_> {
791
+ let mut ctr = self.cols.obj_ctr.iter();
792
+ let mut actor = self.cols.obj_actor.iter();
793
+ let next_ctr = ctr.next_run();
794
+ let next_actor = actor.next_run();
795
+ let pos = 0;
796
+
797
+ IterObjIds {
798
+ ctr,
799
+ actor,
800
+ next_ctr,
801
+ next_actor,
802
+ pos,
803
+ }
804
+ }
805
+
806
+ pub(crate) fn iter_objs(&self) -> impl Iterator<Item = (ObjMeta, OpIter<'_>)> {
807
+ self.iter_obj_ids().filter_map(|(id, range)| {
808
+ let typ = self.object_type(&id)?;
809
+ let obj_meta = ObjMeta { id, typ };
810
+ Some((obj_meta, self.iter_range(&range)))
811
+ })
812
+ }
813
+
814
+ pub(crate) fn top_ops<'a>(
815
+ &'a self,
816
+ obj: &ObjId,
817
+ clock: Option<Clock>,
818
+ ) -> TopOpIter<'a, VisibleOpIter<'a, OpIter<'a>>> {
819
+ self.iter_obj(obj).visible_slow(clock).top_ops()
820
+ }
821
+
822
+ pub(crate) fn to_string<E: Exportable>(&self, id: E) -> String {
823
+ match id.export() {
824
+ Export::Id(id) => format!("{}@{}", id.counter(), self.actors[id.actor()]),
825
+ Export::Special(s) => s,
826
+ }
827
+ }
828
+
829
+ pub(crate) fn find_op_by_id_and_vis(
830
+ &self,
831
+ id: &OpId,
832
+ clock: Option<&Clock>,
833
+ ) -> Option<(Op<'_>, bool)> {
834
+ if clock.is_none() {
835
+ let result = self.find_op_by_id_and_vis_fast(id);
836
+ debug_assert_eq!(result, self.find_op_by_id_and_vis_slow(id, clock));
837
+ result
838
+ } else {
839
+ self.find_op_by_id_and_vis_slow(id, clock)
840
+ }
841
+ }
842
+
843
+ pub(crate) fn find_op_by_id_and_vis_fast(&self, id: &OpId) -> Option<(Op<'_>, bool)> {
844
+ let pos = self.get_op_id_pos(*id)?;
845
+ let visible = self
846
+ .cols
847
+ .index
848
+ .top
849
+ .get(pos)
850
+ .flatten()
851
+ .as_deref()
852
+ .copied()
853
+ .unwrap_or(false);
854
+ let op = self.get(pos)?;
855
+ Some((op, visible))
856
+ }
857
+
858
+ pub(crate) fn find_op_by_id_and_vis_slow(
859
+ &self,
860
+ id: &OpId,
861
+ clock: Option<&Clock>,
862
+ ) -> Option<(Op<'_>, bool)> {
863
+ let start = self.get_op_id_pos(*id)?;
864
+ let mut iter = self.iter_range(&(start..self.len()));
865
+ let mut o1 = iter.next()?;
866
+ let mut vis = o1.scope_to_clock(clock);
867
+ for mut o2 in iter {
868
+ if o2.obj != o1.obj || o1.elemid_or_key() != o2.elemid_or_key() {
869
+ break;
870
+ }
871
+ if o2.scope_to_clock(clock) {
872
+ vis = false;
873
+ break;
874
+ }
875
+ }
876
+ Some((o1, vis))
877
+ }
878
+
879
+ pub(crate) fn get_increment_diff_at_pos(&self, pos: usize, clock: &ClockRange) -> (i64, i64) {
880
+ if let Some(val) = self.cols.succ_count.get_with_acc(pos) {
881
+ let start = val.acc.as_usize();
882
+ let len = *val.item.unwrap_or_default() as usize;
883
+ let end = start + len;
884
+ let succ = SuccCursors {
885
+ len,
886
+ succ_actor: self.cols.succ_actor.iter_range(start..end),
887
+ succ_counter: self.cols.succ_ctr.iter_range(start..end),
888
+ inc_values: self.cols.index.inc.iter_range(start..end),
889
+ };
890
+ let mut inc1 = 0;
891
+ let mut inc2 = 0;
892
+ for (id, value) in succ.with_inc() {
893
+ if let Some(i) = value {
894
+ if clock.visible_before(&id) {
895
+ inc1 += i;
896
+ }
897
+ if clock.visible_after(&id) {
898
+ inc2 += i;
899
+ }
900
+ }
901
+ }
902
+ (inc1, inc2)
903
+ } else {
904
+ (0, 0)
905
+ }
906
+ }
907
+
908
+ pub(crate) fn object_type(&self, obj: &ObjId) -> Option<ObjType> {
909
+ self.obj_info.object_type(obj)
910
+ }
911
+
912
+ pub(crate) fn object_parent(&self, obj: &ObjId) -> Option<ObjId> {
913
+ self.obj_info.object_parent(obj)
914
+ }
915
+
916
+ pub(crate) fn get_actor(&self, idx: usize) -> &ActorId {
917
+ &self.actors[idx]
918
+ }
919
+
920
+ pub(crate) fn get_actor_safe(&self, idx: usize) -> Option<&ActorId> {
921
+ self.actors.get(idx)
922
+ }
923
+
924
+ pub(crate) fn lookup_actor(&self, actor: &ActorId) -> Option<usize> {
925
+ self.actors.binary_search(actor).ok()
926
+ }
927
+
928
+ pub(crate) fn new(text_encoding: TextEncoding) -> Self {
929
+ OpSet {
930
+ actors: vec![],
931
+ cols: Columns::default(),
932
+ obj_info: ObjIndex::default(),
933
+ text_encoding,
934
+ }
935
+ }
936
+
937
+ pub(crate) fn load(doc: &Document<'_>, text_encoding: TextEncoding) -> Result<Self, PackError> {
938
+ // FIXME - shouldn't need to clone bytes here (eventually)
939
+ let data = doc.op_raw_bytes();
940
+ let actors = doc.actors().to_vec();
941
+ Self::from_parts(doc.op_metadata.clone(), data, actors, text_encoding)
942
+ }
943
+
944
+ #[cfg(test)]
945
+ pub(crate) fn from_doc_ops<
946
+ 'a,
947
+ I: Iterator<Item = super::op::Op<'a>> + ExactSizeIterator + Clone,
948
+ >(
949
+ actors: Vec<ActorId>,
950
+ ops: I,
951
+ ) -> Self {
952
+ let cols = Columns::new(ops);
953
+ OpSet {
954
+ actors,
955
+ cols,
956
+ obj_info: ObjIndex::default(),
957
+ text_encoding: TextEncoding::platform_default(),
958
+ }
959
+ }
960
+
961
+ fn from_parts(
962
+ cols: RawColumns<Uncompressed>,
963
+ data: &[u8],
964
+ actors: Vec<ActorId>,
965
+ text_encoding: TextEncoding,
966
+ ) -> Result<Self, PackError> {
967
+ let cols = Columns::load(cols.as_map(), data, &actors)?;
968
+
969
+ let op_set = OpSet {
970
+ actors,
971
+ cols,
972
+ obj_info: ObjIndex::default(),
973
+ text_encoding,
974
+ };
975
+
976
+ Ok(op_set)
977
+ }
978
+
979
+ pub(crate) fn export(&self) -> (RawColumns<Uncompressed>, Vec<u8>) {
980
+ self.cols.export()
981
+ }
982
+
983
+ pub(crate) fn scope_to_obj(&self, obj: &ObjId) -> Range<usize> {
984
+ let range = self.cols.obj_ctr.scope_to_value(obj.counter(), ..);
985
+ self.cols.obj_actor.scope_to_value(obj.actor(), range)
986
+ }
987
+
988
+ pub(crate) fn iter_ctr_range(
989
+ &self,
990
+ range: Range<usize>,
991
+ ) -> SkipIter<OpIter<'_>, SkipWrap<MergeIter<CtrWalker<'_>, SuccWalker<'_>>>> {
992
+ SkipIter::new(
993
+ self.iter(),
994
+ MergeIter::new(
995
+ CtrWalker::new(&self.cols.id_ctr, range.clone()),
996
+ SuccWalker::new(self, range),
997
+ )
998
+ .skip(),
999
+ )
1000
+ }
1001
+
1002
+ pub(crate) fn prop_range(&self, obj: &ObjId, prop: &str) -> Range<usize> {
1003
+ let range = self.scope_to_obj(obj);
1004
+ self.cols.key_str.scope_to_value(Some(prop), range)
1005
+ }
1006
+
1007
+ pub(crate) fn iter_obj<'a>(&'a self, obj: &ObjId) -> OpIter<'a> {
1008
+ let range = self.scope_to_obj(obj);
1009
+ self.iter_range(&range)
1010
+ }
1011
+
1012
+ pub(crate) fn value_iter_range(&self, range: &Range<usize>) -> ValueIter<'_> {
1013
+ let value_meta = self.cols.value_meta.iter_range(range.clone());
1014
+ let value_advance = value_meta.calculate_acc().as_usize();
1015
+ let value_raw = self.cols.value.raw_reader(value_advance);
1016
+ ValueIter::new(value_meta, value_raw)
1017
+ }
1018
+
1019
+ pub(crate) fn id_iter_range(&self, range: &Range<usize>) -> OpIdIter<'_> {
1020
+ OpIdIter::new(
1021
+ self.cols.id_actor.iter_range(range.clone()),
1022
+ self.cols.id_ctr.iter_range(range.clone()),
1023
+ )
1024
+ }
1025
+
1026
+ pub(crate) fn mark_info_iter_range(&self, range: &Range<usize>) -> MarkInfoIter<'_> {
1027
+ MarkInfoIter::new(
1028
+ self.cols.mark_name.iter_range(range.clone()),
1029
+ self.cols.expand.iter_range(range.clone()),
1030
+ )
1031
+ }
1032
+
1033
+ pub(crate) fn succ_iter_range(&self, range: &Range<usize>) -> SuccIterIter<'_> {
1034
+ let succ_count = self.cols.succ_count.iter_range(range.clone());
1035
+ let succ_range = succ_count.calculate_acc().as_usize()..usize::MAX;
1036
+ let succ_actor = self.cols.succ_actor.iter_range(succ_range.clone());
1037
+ let succ_counter = self.cols.succ_ctr.iter_range(succ_range.clone());
1038
+ let inc_values = self.cols.index.inc.iter_range(succ_range);
1039
+ SuccIterIter::new(succ_count, succ_actor, succ_counter, inc_values)
1040
+ }
1041
+
1042
+ pub(crate) fn iter_range(&self, range: &Range<usize>) -> OpIter<'_> {
1043
+ let value = self.value_iter_range(range);
1044
+ let succ = self.succ_iter_range(range);
1045
+
1046
+ OpIter {
1047
+ pos: range.start,
1048
+ id: self.id_iter_range(range),
1049
+ obj: ObjIdIter::new(
1050
+ self.cols.obj_actor.iter_range(range.clone()),
1051
+ self.cols.obj_ctr.iter_range(range.clone()),
1052
+ ),
1053
+ key: KeyIter::new(
1054
+ self.cols.key_str.iter_range(range.clone()),
1055
+ self.cols.key_actor.iter_range(range.clone()),
1056
+ self.cols.key_ctr.iter_range(range.clone()),
1057
+ ),
1058
+ succ,
1059
+ insert: InsertIter::new(self.cols.insert.iter_range(range.clone())),
1060
+ action: ActionIter::new(self.cols.action.iter_range(range.clone())),
1061
+ value,
1062
+ marks: self.mark_info_iter_range(range),
1063
+ range: range.clone(),
1064
+ op_set: self,
1065
+ }
1066
+ }
1067
+
1068
+ pub(crate) fn obj_id_iter(&self) -> ObjIdIter<'_> {
1069
+ ObjIdIter::new(self.cols.obj_actor.iter(), self.cols.obj_ctr.iter())
1070
+ }
1071
+
1072
+ pub(crate) fn iter(&self) -> OpIter<'_> {
1073
+ OpIter {
1074
+ pos: 0,
1075
+ id: OpIdIter::new(self.cols.id_actor.iter(), self.cols.id_ctr.iter()),
1076
+ obj: ObjIdIter::new(self.cols.obj_actor.iter(), self.cols.obj_ctr.iter()),
1077
+ key: KeyIter::new(
1078
+ self.cols.key_str.iter(),
1079
+ self.cols.key_actor.iter(),
1080
+ self.cols.key_ctr.iter(),
1081
+ ),
1082
+ succ: SuccIterIter::new(
1083
+ self.cols.succ_count.iter(),
1084
+ self.cols.succ_actor.iter(),
1085
+ self.cols.succ_ctr.iter(),
1086
+ self.cols.index.inc.iter(),
1087
+ ),
1088
+ insert: InsertIter::new(self.cols.insert.iter()),
1089
+ action: ActionIter::new(self.cols.action.iter()),
1090
+ value: ValueIter::new(self.cols.value_meta.iter(), self.cols.value.raw_reader(0)),
1091
+ marks: MarkInfoIter::new(self.cols.mark_name.iter(), self.cols.expand.iter()),
1092
+ range: 0..self.len(),
1093
+ op_set: self,
1094
+ }
1095
+ }
1096
+
1097
+ // iter ops
1098
+
1099
+ // better error handling
1100
+ // export bytes
1101
+ // insert op
1102
+ // seek nth (read)
1103
+ // seek nth (insert)
1104
+ // seek prop
1105
+ // seek opid
1106
+ // seek mark
1107
+
1108
+ // split slabs at some point
1109
+
1110
+ // slab in-place edits
1111
+ // slab index vec<cursor>
1112
+
1113
+ // ugly api stuff
1114
+ //
1115
+ // * boolean packable has unused pack/unpack - maybe we want two traits
1116
+ // one for Rle<> and one for Cursor<> that overlap?
1117
+ // * columns that don't handle nulls still take Option<Item> and the
1118
+ // iterator still returns Option<item> - could be nice to more cleanly
1119
+ // handle columns that can't take nulls - currently hide this with
1120
+ // MaybePackable allowing you to pass in Item or Option<Item> to splice
1121
+ // * maybe do something with types to make scan required to get
1122
+ // validated bytes
1123
+
1124
+ pub(crate) fn decode(_spec: ColumnSpec, _data: &[u8]) {
1125
+ /*
1126
+ match spec.col_type() {
1127
+ ColumnType::Actor => ActorCursor::decode(data),
1128
+ ColumnType::String => StrCursor::decode(data),
1129
+ ColumnType::Integer => UIntCursor::decode(data),
1130
+ ColumnType::DeltaInteger => DeltaCursor::decode(data),
1131
+ ColumnType::Boolean => BooleanCursor::decode(data),
1132
+ ColumnType::Group => UIntCursor::decode(data),
1133
+ ColumnType::ValueMetadata => MetaCursor::decode(data),
1134
+ ColumnType::Value => log!("raw :: {:?}", data),
1135
+ }
1136
+ */
1137
+ }
1138
+
1139
+ pub(crate) fn insert_actor(&mut self, idx: usize, actor: ActorId) {
1140
+ if self.actors.len() != idx {
1141
+ self.rewrite_with_new_actor(idx)
1142
+ }
1143
+ self.actors.insert(idx, actor)
1144
+ }
1145
+
1146
+ pub(crate) fn rewrite_with_new_actor(&mut self, idx: usize) {
1147
+ self.cols.rewrite_with_new_actor(idx);
1148
+ self.cols.index.mark.rewrite_with_new_actor(idx);
1149
+ self.obj_info = ObjIndex(
1150
+ self.obj_info
1151
+ .0
1152
+ .iter()
1153
+ .map(|(id, make)| (id.with_new_actor(idx), make.with_new_actor(idx)))
1154
+ .collect(),
1155
+ );
1156
+ }
1157
+
1158
+ pub(crate) fn remove_actor(&mut self, idx: usize) {
1159
+ self.actors.remove(idx);
1160
+ self.cols.rewrite_without_actor(idx);
1161
+ self.obj_info = ObjIndex(
1162
+ self.obj_info
1163
+ .0
1164
+ .iter()
1165
+ .filter_map(|(id, make)| Some((id.without_actor(idx)?, make.without_actor(idx)?)))
1166
+ .collect(),
1167
+ );
1168
+ }
1169
+ }
1170
+
1171
+ #[derive(Debug, Clone, PartialEq)]
1172
+ pub(crate) struct Parent {
1173
+ pub(crate) obj: ObjId,
1174
+ pub(crate) typ: ObjType,
1175
+ pub(crate) prop: Prop,
1176
+ pub(crate) visible: bool,
1177
+ }
1178
+
1179
+ #[derive(Debug, Clone, PartialEq)]
1180
+ pub(crate) struct QueryNth {
1181
+ pub(crate) marks: Option<Arc<MarkSet>>,
1182
+ pub(crate) pos: usize,
1183
+ pub(crate) index: usize,
1184
+ pub(crate) elemid: ElemId,
1185
+ }
1186
+
1187
+ #[derive(Debug, Clone, PartialEq)]
1188
+ pub(crate) struct FoundOpId<'a> {
1189
+ pub(crate) op: Op<'a>,
1190
+ pub(crate) index: usize,
1191
+ pub(crate) visible: bool,
1192
+ }
1193
+
1194
+ #[derive(Debug, Default, PartialEq, Clone)]
1195
+ pub(crate) struct OpsFound<'a> {
1196
+ pub(crate) index: usize,
1197
+ pub(crate) ops: Vec<Op<'a>>,
1198
+ pub(crate) end_pos: usize,
1199
+ pub(crate) range: Range<usize>,
1200
+ }
1201
+
1202
+ impl OpsFound<'_> {
1203
+ fn width(&self, seq_type: SequenceType, text_encoding: TextEncoding) -> usize {
1204
+ self.ops
1205
+ .last()
1206
+ .map(|o| o.width(seq_type, text_encoding))
1207
+ .unwrap_or(0)
1208
+ }
1209
+
1210
+ /// Determine what action to take based on the found operations
1211
+ ///
1212
+ /// The action provided by the user may actually not be needed, or it may
1213
+ /// not result in visible changes to the document. This method determines
1214
+ /// what the `ResolvedAction` representing these cases should be and also
1215
+ /// updates the `OpsFound::ops` where necessary.
1216
+ ///
1217
+ /// # Returns
1218
+ ///
1219
+ /// `Some(ResolvedAction)` if there is an op which needs to be inserted into
1220
+ /// the opset, or `None` otherwise
1221
+ pub(crate) fn resolve_action(
1222
+ &mut self,
1223
+ original_action: types::OpType,
1224
+ ) -> Option<ResolvedAction> {
1225
+ if let Some(op) = self.ops.last() {
1226
+ if let types::OpType::Put(v) = &original_action {
1227
+ if op.action == Action::Set && &op.value == v {
1228
+ if self.ops.len() == 1 {
1229
+ // There's one operation with the same value as the incoming action,
1230
+ // we don't need to do anything at all
1231
+ return None;
1232
+ } else {
1233
+ // We want to emit a delete op for all the ops which did not "win", i.e.
1234
+ // every op apart from the first one in the found ops - which is first
1235
+ // because it is ordered by lamport timestamp and thus is the winner.
1236
+ // Therefore, pop the winning op off the stack and resolve the action
1237
+ // to a delete for the remaining ops
1238
+ self.ops.pop();
1239
+ return Some(ResolvedAction::ConflictResolution(types::OpType::Delete));
1240
+ }
1241
+ }
1242
+ }
1243
+ } else if original_action == types::OpType::Delete {
1244
+ // If the original action is a delete and there are no existing ops we don't need to do anything
1245
+ return None;
1246
+ }
1247
+ Some(ResolvedAction::VisibleUpdate(original_action))
1248
+ }
1249
+
1250
+ pub(crate) fn elemid(&self) -> Option<ElemId> {
1251
+ self.ops.last().and_then(|o| o.cursor().ok())
1252
+ }
1253
+ }
1254
+
1255
+ /// The "resolved" action of an operation returned by the `OpsFound::resolve_action` method.
1256
+ ///
1257
+ /// This enum is necessary to distinguish between two kinds of action we need to take:
1258
+ ///
1259
+ /// * Actions which have a visible effect on the document, such as inserting new values
1260
+ /// * Actions which just resolve conflicts, without changing the document state
1261
+ ///
1262
+ /// It's useful to distinguish these so that we can tell whether we need to generate
1263
+ /// patches for the operation or not.
1264
+ pub(crate) enum ResolvedAction {
1265
+ // An operation which resolves a conflict but does not change the observed state
1266
+ // I.e. it is invisible to the materialized view
1267
+ ConflictResolution(types::OpType),
1268
+ // A normal operation which is visible in the document
1269
+ VisibleUpdate(types::OpType),
1270
+ }
1271
+
1272
+ impl ResolvedAction {
1273
+ pub(crate) fn is_increment(&self) -> bool {
1274
+ let action = match self {
1275
+ ResolvedAction::ConflictResolution(action) => action,
1276
+ ResolvedAction::VisibleUpdate(action) => action,
1277
+ };
1278
+ matches!(action, types::OpType::Increment { .. })
1279
+ }
1280
+ }
1281
+
1282
+ pub(crate) struct IterObjIds<'a> {
1283
+ ctr: ColumnDataIter<'a, UIntCursor>,
1284
+ actor: ColumnDataIter<'a, ActorCursor>,
1285
+ next_ctr: Option<Run<'a, u64>>,
1286
+ next_actor: Option<Run<'a, ActorIdx>>,
1287
+ pos: usize,
1288
+ }
1289
+
1290
+ impl Iterator for IterObjIds<'_> {
1291
+ type Item = (ObjId, Range<usize>);
1292
+
1293
+ fn next(&mut self) -> Option<Self::Item> {
1294
+ let start = self.pos;
1295
+ match (self.next_ctr.clone(), self.next_actor.clone()) {
1296
+ (Some(mut run1), Some(mut run2)) => {
1297
+ match run1.count.cmp(&run2.count) {
1298
+ Ordering::Less => {
1299
+ run2.count -= run1.count;
1300
+ self.next_actor = Some(run2.clone());
1301
+ self.pos += run1.count;
1302
+ self.next_ctr = self.ctr.next_run();
1303
+ }
1304
+ Ordering::Greater => {
1305
+ run1.count -= run2.count;
1306
+ self.next_ctr = Some(run1.clone());
1307
+ self.pos += run2.count;
1308
+ self.next_actor = self.actor.next_run();
1309
+ }
1310
+ Ordering::Equal => {
1311
+ self.pos += run1.count;
1312
+ self.next_ctr = self.ctr.next_run();
1313
+ self.next_actor = self.actor.next_run();
1314
+ }
1315
+ }
1316
+ let end = self.pos;
1317
+ let obj = ObjId::load(
1318
+ run1.value.as_deref().copied(),
1319
+ run2.value.as_deref().copied(),
1320
+ )?;
1321
+ Some((obj, start..end))
1322
+ }
1323
+ (None, None) => None,
1324
+ _ => panic!(),
1325
+ }
1326
+ }
1327
+ }
1328
+
1329
+ #[cfg(test)]
1330
+ mod tests {
1331
+ use super::*;
1332
+
1333
+ use hexane::{ColumnData, DeltaCursor, IntCursor};
1334
+
1335
+ use crate::{
1336
+ op_set2::{
1337
+ op::SuccCursors,
1338
+ types::{Action, ActorCursor, ScalarValue},
1339
+ KeyRef,
1340
+ },
1341
+ storage::Document,
1342
+ transaction::Transactable,
1343
+ types::{ObjId, OpId},
1344
+ ActorId, AutoCommit, ObjType,
1345
+ };
1346
+
1347
+ use super::OpSet;
1348
+
1349
+ use rand::distr::Alphanumeric;
1350
+ use rand::RngExt;
1351
+
1352
+ #[test]
1353
+ fn suspend_resume_op_set_iter() {
1354
+ // most likely place for errors would be
1355
+ // in the values column (raw reader) and succ column
1356
+ // make sure to have a mix of small and large values
1357
+ // and a mix of succ column values with delets and counters
1358
+
1359
+ let mut doc = AutoCommit::new();
1360
+ let rand_text: String = rand::rng()
1361
+ .sample_iter(&Alphanumeric)
1362
+ .take(1000)
1363
+ .map(char::from)
1364
+ .collect();
1365
+
1366
+ doc.put(crate::ROOT, "aaa_int", 123).unwrap();
1367
+ doc.put(crate::ROOT, "mid_int", 123).unwrap();
1368
+ doc.put(crate::ROOT, "zzz_int", 123).unwrap();
1369
+ doc.put(crate::ROOT, "aaa_str", "abc").unwrap();
1370
+ doc.put(crate::ROOT, "mid_str", "abc").unwrap();
1371
+ doc.put(crate::ROOT, "zzz_str", "abc").unwrap();
1372
+
1373
+ let text = doc.put_object(crate::ROOT, "text", ObjType::Text).unwrap();
1374
+ doc.splice_text(&text, 0, 0, &rand_text).unwrap();
1375
+ let _ = doc.get_heads(); // force a new change
1376
+ doc.splice_text(&text, 100, 100, "").unwrap();
1377
+ let _ = doc.get_heads(); // force a new change
1378
+
1379
+ doc.put(crate::ROOT, "a_large", &rand_text).unwrap();
1380
+ doc.put(crate::ROOT, "z_large", &rand_text).unwrap();
1381
+
1382
+ doc.put(crate::ROOT, "a_large", ScalarValue::Counter(100))
1383
+ .unwrap();
1384
+ doc.put(crate::ROOT, "z_large", ScalarValue::Counter(200))
1385
+ .unwrap();
1386
+ for _ in 0..1000 {
1387
+ doc.increment(crate::ROOT, "a_large", 1).unwrap();
1388
+ doc.increment(crate::ROOT, "z_large", 1).unwrap();
1389
+ }
1390
+
1391
+ let _ = doc.get_heads(); // force a new change
1392
+
1393
+ let iter1 = doc.doc.ops().iter();
1394
+ let mut iter2 = doc.doc.ops().iter();
1395
+
1396
+ for op1 in iter1 {
1397
+ let op2 = iter2.next().unwrap();
1398
+ assert_eq!(op1, op2);
1399
+ let suspend = iter2.suspend();
1400
+ iter2 = suspend.try_resume(doc.doc.ops()).unwrap();
1401
+ }
1402
+ }
1403
+
1404
+ #[test]
1405
+ fn column_data_basic_iteration() {
1406
+ let mut doc = AutoCommit::new();
1407
+ let text = doc.put_object(crate::ROOT, "text", ObjType::Text).unwrap();
1408
+ doc.splice_text(&text, 0, 0, "hello").unwrap();
1409
+ doc.put(crate::ROOT, "key", "value").unwrap();
1410
+ doc.put(crate::ROOT, "key2", "value2").unwrap();
1411
+ doc.delete(crate::ROOT, "key2").unwrap();
1412
+ let saved = doc.save();
1413
+ let doc_chunk = load_document_chunk(&saved);
1414
+ let opset = super::OpSet::load(&doc_chunk, TextEncoding::platform_default()).unwrap();
1415
+ let ops = opset.iter().collect::<Vec<_>>();
1416
+ let actual_ops = doc.doc.ops().iter().collect::<Vec<_>>();
1417
+ if ops != actual_ops {
1418
+ for (i, (a, b)) in actual_ops.iter().zip(ops.iter()).enumerate() {
1419
+ if b != a {
1420
+ println!("op {} mismatch", i);
1421
+ println!("expected: {:?}", a);
1422
+ println!("actual: {:?}", b);
1423
+ }
1424
+ }
1425
+ }
1426
+ assert_eq!(ops, actual_ops);
1427
+ }
1428
+
1429
+ fn load_document_chunk(data: &[u8]) -> Document<'_> {
1430
+ let input = crate::storage::parse::Input::new(data);
1431
+ let (_i, chunk) = crate::storage::Chunk::parse(input).unwrap();
1432
+ let crate::storage::Chunk::Document(doc) = chunk else {
1433
+ panic!("expected document chunk");
1434
+ };
1435
+ doc
1436
+ }
1437
+
1438
+ #[derive(Debug, Clone)]
1439
+ struct TestOp {
1440
+ id: OpId,
1441
+ obj: ObjId,
1442
+ action: Action,
1443
+ value: ScalarValue<'static>,
1444
+ key: KeyRef<'static>,
1445
+ insert: bool,
1446
+ succs: Vec<OpId>,
1447
+ expand: bool,
1448
+ mark_name: Option<Cow<'static, str>>,
1449
+ }
1450
+
1451
+ impl<'a> PartialEq<super::super::op::Op<'a>> for TestOp {
1452
+ fn eq(&self, other: &super::super::op::Op<'a>) -> bool {
1453
+ let other_succ = other.succ().collect::<Vec<_>>();
1454
+ self.id == other.id
1455
+ && self.obj == other.obj
1456
+ && self.action == other.action
1457
+ && self.value == other.value
1458
+ && self.key == other.key
1459
+ && self.insert == other.insert
1460
+ && self.succs == other_succ
1461
+ && self.expand == other.expand
1462
+ && self.mark_name == other.mark_name
1463
+ }
1464
+ }
1465
+
1466
+ fn with_test_ops<F>(actors: Vec<ActorId>, test_ops: &[TestOp], f: F)
1467
+ where
1468
+ F: FnOnce(super::OpSet),
1469
+ {
1470
+ let mut ops = Vec::new();
1471
+
1472
+ let mut group_data = ColumnData::<UIntCursor>::new();
1473
+ let mut succ_actor_data = ColumnData::<ActorCursor>::new();
1474
+ let mut succ_counter_data = ColumnData::<DeltaCursor>::new();
1475
+ group_data.splice(
1476
+ 0,
1477
+ 0,
1478
+ test_ops
1479
+ .iter()
1480
+ .map(|o| o.succs.len() as u64)
1481
+ .collect::<Vec<_>>(),
1482
+ );
1483
+ succ_actor_data.splice(
1484
+ 0,
1485
+ 0,
1486
+ test_ops
1487
+ .iter()
1488
+ .flat_map(|o| o.succs.iter().map(|s| s.actoridx()))
1489
+ .collect::<Vec<_>>(),
1490
+ );
1491
+ let inc_index = ColumnData::<IntCursor>::init_empty(succ_actor_data.len());
1492
+ succ_counter_data.splice(
1493
+ 0,
1494
+ 0,
1495
+ test_ops
1496
+ .iter()
1497
+ .flat_map(|o| o.succs.iter().map(|s| s.counter() as i64))
1498
+ .collect::<Vec<_>>(),
1499
+ );
1500
+
1501
+ let mut group_iter = group_data.iter();
1502
+ let mut actor_iter = succ_actor_data.iter();
1503
+ let mut counter_iter = succ_counter_data.iter();
1504
+ let mut inc_values = inc_index.iter();
1505
+
1506
+ // first encode the succs
1507
+ for test_op in test_ops {
1508
+ let group_count = group_iter.next().unwrap().unwrap();
1509
+ let op = super::super::op::Op {
1510
+ pos: 0, // not relevent for this equality test
1511
+ id: test_op.id,
1512
+ obj: test_op.obj,
1513
+ action: test_op.action,
1514
+ value: test_op.value.clone(),
1515
+ key: test_op.key.clone(),
1516
+ insert: test_op.insert,
1517
+ expand: test_op.expand,
1518
+ mark_name: test_op.mark_name.clone(),
1519
+ conflict: false,
1520
+ succ_cursors: SuccCursors {
1521
+ len: *group_count as usize,
1522
+ succ_counter: counter_iter.clone(),
1523
+ succ_actor: actor_iter.clone(),
1524
+ inc_values: inc_values.clone(),
1525
+ },
1526
+ };
1527
+ for _ in 0..*group_count {
1528
+ counter_iter.next();
1529
+ actor_iter.next();
1530
+ inc_values.next();
1531
+ }
1532
+ ops.push(op);
1533
+ }
1534
+ let op_set = OpSet::from_doc_ops(actors, ops.iter().cloned());
1535
+ f(op_set);
1536
+ }
1537
+
1538
+ #[test]
1539
+ fn column_data_iter_range() {
1540
+ let actors = vec![crate::ActorId::random(), crate::ActorId::random()];
1541
+
1542
+ let ops = vec![
1543
+ TestOp {
1544
+ id: OpId::new(1, 1),
1545
+ obj: ObjId::root(),
1546
+ action: Action::MakeMap,
1547
+ value: ScalarValue::Null,
1548
+ key: KeyRef::Map("key".into()),
1549
+ insert: false,
1550
+ succs: vec![OpId::new(5, 1), OpId::new(6, 1), OpId::new(10, 1)],
1551
+ expand: false,
1552
+ mark_name: None,
1553
+ },
1554
+ TestOp {
1555
+ id: OpId::new(2, 1),
1556
+ obj: ObjId::root(),
1557
+ action: Action::Set,
1558
+ value: ScalarValue::str("value1"),
1559
+ key: KeyRef::Map("key1".into()),
1560
+ insert: false,
1561
+ succs: vec![],
1562
+ expand: false,
1563
+ mark_name: None,
1564
+ },
1565
+ TestOp {
1566
+ id: OpId::new(3, 1),
1567
+ obj: ObjId::root(),
1568
+ action: Action::Set,
1569
+ value: ScalarValue::str("value2"),
1570
+ key: KeyRef::Map("key2".into()),
1571
+ insert: false,
1572
+ succs: vec![OpId::new(6, 1)],
1573
+ expand: false,
1574
+ mark_name: None,
1575
+ },
1576
+ TestOp {
1577
+ id: OpId::new(4, 1),
1578
+ obj: ObjId(OpId::new(1, 1)),
1579
+ action: Action::Set,
1580
+ value: ScalarValue::str("inner_value1"),
1581
+ key: KeyRef::Map("inner_key1".into()),
1582
+ insert: false,
1583
+ succs: vec![OpId::new(7, 1), OpId::new(8, 2), OpId::new(9, 1)],
1584
+ expand: false,
1585
+ mark_name: None,
1586
+ },
1587
+ TestOp {
1588
+ id: OpId::new(5, 1),
1589
+ obj: ObjId(OpId::new(1, 1)),
1590
+ action: Action::Set,
1591
+ value: ScalarValue::str("inner_value2"),
1592
+ key: KeyRef::Map("inner_key2".into()),
1593
+ insert: false,
1594
+ succs: vec![],
1595
+ expand: false,
1596
+ mark_name: None,
1597
+ },
1598
+ ];
1599
+
1600
+ with_test_ops(actors, &ops, |opset| {
1601
+ let range = opset.scope_to_obj(&ObjId(OpId::new(1, 1)));
1602
+ let mut iter = opset.iter_range(&range);
1603
+ println!(
1604
+ "ITER :: range={:?} pos={} max={}",
1605
+ range,
1606
+ iter.pos(),
1607
+ iter.end_pos()
1608
+ );
1609
+ for o in &ops {
1610
+ println!("OP={:?}", o);
1611
+ }
1612
+ let op = iter.next().unwrap();
1613
+ assert_eq!(ops[3], op);
1614
+ let op = iter.next().unwrap();
1615
+ assert_eq!(ops[4], op);
1616
+ let op = iter.next();
1617
+ assert!(op.is_none());
1618
+ });
1619
+ }
1620
+
1621
+ #[test]
1622
+ fn column_data_op_iterators() {
1623
+ let actors = vec![crate::ActorId::random(), crate::ActorId::random()];
1624
+
1625
+ let test_ops = vec![
1626
+ TestOp {
1627
+ id: OpId::new(1, 1),
1628
+ obj: ObjId::root(),
1629
+ action: Action::MakeMap,
1630
+ value: ScalarValue::Null,
1631
+ key: KeyRef::Map("map".into()),
1632
+ insert: false,
1633
+ succs: vec![],
1634
+ expand: false,
1635
+ mark_name: None,
1636
+ },
1637
+ TestOp {
1638
+ id: OpId::new(2, 1),
1639
+ obj: ObjId::root(),
1640
+ action: Action::MakeMap,
1641
+ value: ScalarValue::Null,
1642
+ key: KeyRef::Map("list".into()),
1643
+ insert: false,
1644
+ succs: vec![],
1645
+ expand: false,
1646
+ mark_name: None,
1647
+ },
1648
+ TestOp {
1649
+ id: OpId::new(3, 1),
1650
+ obj: ObjId(OpId::new(1, 1)),
1651
+ action: Action::Set,
1652
+ value: ScalarValue::str("value1"),
1653
+ key: KeyRef::Map("key1".into()),
1654
+ insert: false,
1655
+ succs: vec![],
1656
+ expand: false,
1657
+ mark_name: None,
1658
+ },
1659
+ TestOp {
1660
+ id: OpId::new(4, 1),
1661
+ obj: ObjId(OpId::new(1, 1)),
1662
+ action: Action::Set,
1663
+ value: ScalarValue::str("value2a"),
1664
+ key: KeyRef::Map("key2".into()),
1665
+ insert: false,
1666
+ succs: vec![],
1667
+ expand: false,
1668
+ mark_name: None,
1669
+ },
1670
+ TestOp {
1671
+ id: OpId::new(4, 2),
1672
+ obj: ObjId(OpId::new(1, 1)),
1673
+ action: Action::Set,
1674
+ value: ScalarValue::str("value2b"),
1675
+ key: KeyRef::Map("key2".into()),
1676
+ insert: false,
1677
+ succs: vec![OpId::new(5, 2)],
1678
+ expand: false,
1679
+ mark_name: None,
1680
+ },
1681
+ TestOp {
1682
+ id: OpId::new(5, 2),
1683
+ obj: ObjId(OpId::new(1, 1)),
1684
+ action: Action::Set,
1685
+ value: ScalarValue::str("value2c"),
1686
+ key: KeyRef::Map("key2".into()),
1687
+ insert: false,
1688
+ succs: vec![],
1689
+ expand: false,
1690
+ mark_name: None,
1691
+ },
1692
+ TestOp {
1693
+ id: OpId::new(6, 1),
1694
+ obj: ObjId(OpId::new(1, 1)),
1695
+ action: Action::Set,
1696
+ value: ScalarValue::str("value3a"),
1697
+ key: KeyRef::Map("key3".into()),
1698
+ insert: false,
1699
+ succs: vec![OpId::new(7, 2)],
1700
+ expand: false,
1701
+ mark_name: None,
1702
+ },
1703
+ TestOp {
1704
+ id: OpId::new(7, 2),
1705
+ obj: ObjId(OpId::new(1, 1)),
1706
+ action: Action::Set,
1707
+ value: ScalarValue::str("value3b"),
1708
+ key: KeyRef::Map("key3".into()),
1709
+ insert: false,
1710
+ succs: vec![],
1711
+ expand: false,
1712
+ mark_name: None,
1713
+ },
1714
+ TestOp {
1715
+ id: OpId::new(8, 1),
1716
+ obj: ObjId(OpId::new(2, 1)),
1717
+ action: Action::Set,
1718
+ value: ScalarValue::str("a"),
1719
+ key: KeyRef::Seq(ElemId::head()),
1720
+ insert: true,
1721
+ succs: vec![],
1722
+ expand: false,
1723
+ mark_name: None,
1724
+ },
1725
+ TestOp {
1726
+ id: OpId::new(9, 1),
1727
+ obj: ObjId(OpId::new(2, 1)),
1728
+ action: Action::Set,
1729
+ value: ScalarValue::str("b"),
1730
+ key: KeyRef::Seq(ElemId(OpId::new(8, 1))),
1731
+ insert: true,
1732
+ succs: vec![],
1733
+ expand: false,
1734
+ mark_name: None,
1735
+ },
1736
+ ];
1737
+
1738
+ with_test_ops(actors, &test_ops, |opset| {
1739
+ let iter = opset.iter_obj(&ObjId(OpId::new(1, 1)));
1740
+ let ops = iter.collect::<Vec<_>>();
1741
+ assert_eq!(&test_ops[2..8], ops.as_slice());
1742
+
1743
+ let range = opset.prop_range(&ObjId(OpId::new(1, 1)), "key2");
1744
+ let iter = opset.iter_range(&range);
1745
+ let ops = iter.collect::<Vec<_>>();
1746
+ assert_eq!(&test_ops[3..6], ops.as_slice());
1747
+
1748
+ let iter = opset.iter_obj(&ObjId(OpId::new(1, 1)));
1749
+ let ops = iter.top_ops().collect::<Vec<_>>();
1750
+ assert_eq!(&test_ops[2], &ops[0]);
1751
+ assert_eq!(&test_ops[5], &ops[1]);
1752
+ assert_eq!(&test_ops[7], &ops[2]);
1753
+ assert_eq!(3, ops.len());
1754
+
1755
+ let iter = opset.iter_obj(&ObjId(OpId::new(1, 1)));
1756
+ let ops = iter
1757
+ .key_ops()
1758
+ .map(|n| n.collect::<Vec<_>>())
1759
+ .collect::<Vec<_>>();
1760
+ let key1 = ops.first().unwrap().as_slice();
1761
+ let key2 = ops.get(1).unwrap().as_slice();
1762
+ let key3 = ops.get(2).unwrap().as_slice();
1763
+ let key4 = ops.get(3);
1764
+ assert_eq!(&test_ops[2..3], key1);
1765
+ assert_eq!(&test_ops[3..6], key2);
1766
+ assert_eq!(&test_ops[6..8], key3);
1767
+ assert!(key4.is_none());
1768
+
1769
+ let iter = opset.iter_obj(&ObjId(OpId::new(1, 1)));
1770
+ let ops = iter
1771
+ .visible_slow(None)
1772
+ .key_ops()
1773
+ .map(|n| n.collect::<Vec<_>>())
1774
+ .collect::<Vec<_>>();
1775
+ let key1 = ops.first().unwrap().as_slice();
1776
+ let key2 = ops.get(1).unwrap().as_slice();
1777
+ let key3 = ops.get(2).unwrap().as_slice();
1778
+ let key4 = ops.get(3);
1779
+ let key2test = vec![test_ops[3].clone(), test_ops[5].clone()];
1780
+ assert_eq!(&test_ops[2..3], key1);
1781
+ assert_eq!(&key2test, key2);
1782
+ assert_eq!(&test_ops[7..8], key3);
1783
+ assert!(key4.is_none());
1784
+
1785
+ let iter = opset.iter_obj(&ObjId(OpId::new(1, 1)));
1786
+ let ops = iter.visible_slow(None).top_ops().collect::<Vec<_>>();
1787
+ assert_eq!(&test_ops[2], &ops[0]);
1788
+ assert_eq!(&test_ops[5], &ops[1]);
1789
+ assert_eq!(&test_ops[7], &ops[2]);
1790
+ assert_eq!(3, ops.len());
1791
+ });
1792
+ }
1793
+ }