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,1363 @@
1
+ use super::op_set::{MarkIndexBuilder, ObjInfo, OpSet, ResolvedAction};
2
+ use super::types::{Action, ActorCursor, ActorIdx, KeyRef, MarkData, OpType, PropRef, ScalarValue};
3
+ use super::{ValueMeta, ValueRef};
4
+ use hexane::{ColumnDataIter, DeltaCursor, IntCursor};
5
+
6
+ use crate::clock::Clock;
7
+ use crate::error::AutomergeError;
8
+ use crate::exid::ExId;
9
+ use crate::types;
10
+ use crate::types::{ElemId, ObjId, ObjMeta, ObjType, OpId, SequenceType};
11
+ use crate::{hydrate, TextEncoding};
12
+
13
+ use std::borrow::Cow;
14
+ use std::cmp::Ordering;
15
+ use std::fmt::Debug;
16
+
17
+ pub(crate) trait AsBuilder: Debug {
18
+ fn as_builder(&self) -> &OpBuilder<'_>;
19
+ }
20
+
21
+ impl AsBuilder for ChangeOp {
22
+ fn as_builder(&self) -> &OpBuilder<'static> {
23
+ &self.bld
24
+ }
25
+ }
26
+
27
+ impl<'a> AsBuilder for OpBuilder<'a> {
28
+ fn as_builder(&self) -> &OpBuilder<'a> {
29
+ self
30
+ }
31
+ }
32
+
33
+ impl<'a> AsBuilder for &OpBuilder<'a> {
34
+ fn as_builder(&self) -> &OpBuilder<'a> {
35
+ self
36
+ }
37
+ }
38
+
39
+ impl AsBuilder for TxOp {
40
+ fn as_builder(&self) -> &OpBuilder<'static> {
41
+ &self.bld
42
+ }
43
+ }
44
+
45
+ impl AsBuilder for &TxOp {
46
+ fn as_builder(&self) -> &OpBuilder<'static> {
47
+ &self.bld
48
+ }
49
+ }
50
+
51
+ #[derive(Debug, Clone)]
52
+ pub(crate) struct ChangeOp {
53
+ pub(crate) succ: Vec<(OpId, Option<i64>)>,
54
+ pub(crate) pos: Option<usize>,
55
+ pub(crate) subsort: usize,
56
+ pub(crate) conflicted: bool,
57
+ pub(crate) bld: OpBuilder<'static>,
58
+ }
59
+
60
+ impl ChangeOp {
61
+ pub(crate) fn prop_static(&self) -> Option<PropRef<'static>> {
62
+ match &self.bld.key {
63
+ KeyRef::Map(s) => Some(PropRef::Map(Cow::Owned(String::from(s.as_ref())))),
64
+ _ => None,
65
+ }
66
+ }
67
+
68
+ pub(crate) fn prop(&self) -> Option<PropRef<'_>> {
69
+ match &self.bld.key {
70
+ KeyRef::Map(Cow::Owned(s)) => Some(PropRef::Map(Cow::Borrowed(s))),
71
+ KeyRef::Map(Cow::Borrowed(s)) => Some(PropRef::Map(Cow::Borrowed(s))),
72
+ _ => None,
73
+ }
74
+ }
75
+
76
+ pub(crate) fn mark_data(&self) -> Option<MarkData<'static>> {
77
+ let name = self.bld.mark_name.as_ref()?.clone();
78
+ let value = self.bld.value.clone();
79
+ Some(MarkData { name, value })
80
+ }
81
+
82
+ pub(crate) fn hydrate_value(&self, text_encoding: TextEncoding) -> hydrate::Value {
83
+ self.bld.hydrate_value(text_encoding)
84
+ }
85
+
86
+ pub(crate) fn hydrate_value_and_fix_counters(
87
+ &self,
88
+ text_encoding: TextEncoding,
89
+ ) -> hydrate::Value {
90
+ if self.bld.action == Action::Set {
91
+ if let ScalarValue::Counter(c) = &self.bld.value {
92
+ let inc: i64 = self.succ.iter().filter_map(|(_, inc)| *inc).sum();
93
+ hydrate::Value::Scalar(types::ScalarValue::counter(c + inc))
94
+ } else {
95
+ hydrate::Value::Scalar(self.bld.value.to_owned())
96
+ }
97
+ } else {
98
+ self.bld.hydrate_value(text_encoding)
99
+ }
100
+ }
101
+
102
+ pub(crate) fn width(&self, seq_type: SequenceType, text_encoding: TextEncoding) -> usize {
103
+ self.bld.width(seq_type, text_encoding)
104
+ }
105
+
106
+ pub(crate) fn visible(&self) -> bool {
107
+ !(self.bld.is_inc() || self.bld.is_delete() || self.has_succ())
108
+ }
109
+
110
+ pub(crate) fn has_succ(&self) -> bool {
111
+ self.succ.iter().any(|(_, inc)| inc.is_none())
112
+ }
113
+
114
+ pub(crate) fn insert(&self) -> bool {
115
+ self.bld.insert
116
+ }
117
+
118
+ pub(crate) fn is_set_or_make(&self) -> bool {
119
+ matches!(
120
+ self.bld.action,
121
+ Action::Set | Action::MakeMap | Action::MakeList | Action::MakeText | Action::MakeTable
122
+ )
123
+ }
124
+
125
+ pub(crate) fn action(&self) -> Action {
126
+ self.bld.action
127
+ }
128
+ pub(crate) fn value(&self) -> &ScalarValue<'static> {
129
+ &self.bld.value
130
+ }
131
+
132
+ pub(crate) fn key(&self) -> &KeyRef<'static> {
133
+ &self.bld.key
134
+ }
135
+
136
+ pub(crate) fn pred(&self) -> &[OpId] {
137
+ &self.bld.pred
138
+ }
139
+
140
+ pub(crate) fn id(&self) -> OpId {
141
+ self.bld.id
142
+ }
143
+
144
+ pub(crate) fn elemid_or_key(&self) -> KeyRef<'_> {
145
+ if self.bld.insert {
146
+ KeyRef::Seq(ElemId(self.bld.id))
147
+ } else {
148
+ match &self.bld.key {
149
+ KeyRef::Map(Cow::Owned(s)) => KeyRef::Map(Cow::Borrowed(s)),
150
+ _ => self.bld.key.clone(),
151
+ }
152
+ }
153
+ }
154
+
155
+ pub(crate) fn get_increment_value(&self) -> Option<i64> {
156
+ match (self.bld.action, &self.bld.value) {
157
+ (Action::Increment, ScalarValue::Int(i)) => Some(*i),
158
+ (Action::Increment, ScalarValue::Uint(i)) => Some(*i as i64),
159
+ _ => None,
160
+ }
161
+ }
162
+ }
163
+
164
+ #[derive(Debug, Clone)]
165
+ pub(crate) struct TxOp {
166
+ pub(crate) obj_type: ObjType,
167
+ pub(crate) index: usize,
168
+ pub(crate) pos: usize,
169
+ pub(crate) noop: bool,
170
+ pub(crate) bld: OpBuilder<'static>,
171
+ }
172
+
173
+ #[derive(Debug, Clone)]
174
+ pub(crate) struct OpBuilder<'a> {
175
+ pub(crate) id: OpId,
176
+ pub(crate) obj: ObjId,
177
+ pub(crate) action: Action,
178
+ pub(crate) key: KeyRef<'a>,
179
+ pub(crate) value: ScalarValue<'a>,
180
+ pub(crate) insert: bool,
181
+ pub(crate) expand: bool,
182
+ pub(crate) mark_name: Option<Cow<'a, str>>,
183
+ pub(crate) pred: Vec<OpId>,
184
+ }
185
+
186
+ impl OpBuilder<'_> {
187
+ pub(crate) fn mark_index(&self) -> Option<MarkIndexBuilder> {
188
+ match (self.action, &self.mark_name) {
189
+ (Action::Mark, Some(name)) => {
190
+ let name = Cow::Owned(name.to_string());
191
+ let value = self.value.clone().into_owned();
192
+ let data = MarkData { name, value };
193
+ Some(MarkIndexBuilder::Start(self.id, data))
194
+ }
195
+ (Action::Mark, None) => Some(MarkIndexBuilder::End(self.id.prev())),
196
+ _ => None,
197
+ }
198
+ }
199
+
200
+ pub(crate) fn width(&self, seq_type: SequenceType, text_encoding: TextEncoding) -> usize {
201
+ match seq_type {
202
+ SequenceType::List => 1,
203
+ SequenceType::Text if self.is_mark() => 0,
204
+ SequenceType::Text => text_encoding.width(self.as_str()),
205
+ }
206
+ }
207
+
208
+ pub(crate) fn is_inc(&self) -> bool {
209
+ self.action == Action::Increment
210
+ }
211
+
212
+ pub(crate) fn is_mark(&self) -> bool {
213
+ self.action == Action::Mark
214
+ }
215
+
216
+ pub(crate) fn as_str(&self) -> &str {
217
+ match (self.action, &self.value) {
218
+ (Action::Set, ScalarValue::Str(s)) => s,
219
+ (Action::Mark, _) => "",
220
+ _ => "\u{fffc}",
221
+ }
222
+ }
223
+
224
+ pub(crate) fn is_delete(&self) -> bool {
225
+ self.action == Action::Delete
226
+ }
227
+
228
+ pub(crate) fn get_increment_value(&self) -> Option<i64> {
229
+ match (self.action, &self.value) {
230
+ (Action::Increment, ScalarValue::Int(i)) => Some(*i),
231
+ (Action::Increment, ScalarValue::Uint(i)) => Some(*i as i64),
232
+ _ => None,
233
+ }
234
+ }
235
+
236
+ pub(crate) fn hydrate_value(&self, text_encoding: TextEncoding) -> hydrate::Value {
237
+ // FIXME
238
+ match self.action {
239
+ Action::Set => hydrate::Value::Scalar(self.value.to_owned()),
240
+ Action::MakeMap => hydrate::Value::map(),
241
+ Action::MakeList => hydrate::Value::list(),
242
+ Action::MakeText => hydrate::Value::new(ObjType::Text, text_encoding),
243
+ Action::MakeTable => hydrate::Value::new(ObjType::Table, text_encoding),
244
+ //Action::Mark if self.mark_name.is_some() => hydrate::Value::new(&self.value, text_rep),
245
+ //Action::Mark => hydrate::Value::Scalar("markEnd".into()),
246
+ _ => panic!("cant convert op into a value"),
247
+ }
248
+ }
249
+ }
250
+
251
+ impl TxOp {
252
+ pub(crate) fn id(&self) -> OpId {
253
+ self.bld.id
254
+ }
255
+
256
+ #[allow(clippy::too_many_arguments)]
257
+ pub(crate) fn list(
258
+ id: OpId,
259
+ obj: ObjMeta,
260
+ pos: usize,
261
+ index: usize,
262
+ action: ResolvedAction,
263
+ elemid: ElemId,
264
+ pred: Vec<OpId>,
265
+ ) -> Self {
266
+ let (op_type, noop) = match action {
267
+ ResolvedAction::ConflictResolution(action) => (action, true),
268
+ ResolvedAction::VisibleUpdate(action) => (action, false),
269
+ };
270
+ let (action, value, expand, mark_name) = op_type.decompose();
271
+ TxOp {
272
+ obj_type: obj.typ,
273
+ pos,
274
+ index,
275
+ noop,
276
+ bld: OpBuilder {
277
+ id,
278
+ obj: obj.id,
279
+ action,
280
+ value,
281
+ expand,
282
+ mark_name,
283
+ key: KeyRef::Seq(elemid),
284
+ insert: false,
285
+ pred,
286
+ },
287
+ }
288
+ }
289
+
290
+ pub(crate) fn map(
291
+ id: OpId,
292
+ obj: ObjMeta,
293
+ pos: usize,
294
+ action: ResolvedAction,
295
+ prop: String,
296
+ pred: Vec<OpId>,
297
+ ) -> Self {
298
+ let (action, noop) = match action {
299
+ ResolvedAction::ConflictResolution(action) => (action, true),
300
+ ResolvedAction::VisibleUpdate(action) => (action, false),
301
+ };
302
+ let (action, value, expand, mark_name) = action.clone().decompose();
303
+ TxOp {
304
+ obj_type: obj.typ,
305
+ index: 0,
306
+ pos,
307
+ noop,
308
+ bld: OpBuilder {
309
+ id,
310
+ obj: obj.id,
311
+ value,
312
+ action,
313
+ expand,
314
+ mark_name,
315
+ key: KeyRef::Map(Cow::Owned(prop)),
316
+ insert: false,
317
+ pred,
318
+ },
319
+ }
320
+ }
321
+
322
+ pub(crate) fn insert(
323
+ id: OpId,
324
+ obj: ObjMeta,
325
+ pos: usize,
326
+ index: usize,
327
+ _action: types::OpType,
328
+ elemid: ElemId,
329
+ ) -> Self {
330
+ let (action, value, expand, mark_name) = _action.clone().decompose();
331
+ TxOp {
332
+ obj_type: obj.typ,
333
+ pos,
334
+ index,
335
+ noop: false,
336
+ bld: OpBuilder {
337
+ id,
338
+ obj: obj.id,
339
+ action,
340
+ value,
341
+ expand,
342
+ mark_name,
343
+ key: KeyRef::Seq(elemid),
344
+ insert: true,
345
+ pred: vec![],
346
+ },
347
+ }
348
+ }
349
+
350
+ pub(crate) fn insert_val(
351
+ id: OpId,
352
+ obj: ObjMeta,
353
+ pos: usize,
354
+ value: types::ScalarValue,
355
+ elemid: ElemId,
356
+ ) -> Self {
357
+ let _action = types::OpType::Put(value);
358
+ let (action, value, expand, mark_name) = _action.clone().decompose();
359
+ TxOp {
360
+ pos,
361
+ index: 0,
362
+ obj_type: obj.typ,
363
+ noop: false,
364
+ bld: OpBuilder {
365
+ id,
366
+ obj: obj.id,
367
+ action,
368
+ value,
369
+ expand,
370
+ mark_name,
371
+ key: KeyRef::Seq(elemid),
372
+ insert: true,
373
+ pred: vec![],
374
+ },
375
+ }
376
+ }
377
+
378
+ pub(crate) fn insert_obj(
379
+ id: OpId,
380
+ obj: ObjMeta,
381
+ pos: usize,
382
+ index: usize,
383
+ obj_type: types::ObjType,
384
+ elemid: ElemId,
385
+ ) -> Self {
386
+ let _action = types::OpType::Make(obj_type);
387
+ let (action, value, expand, mark_name) = _action.clone().decompose();
388
+ TxOp {
389
+ obj_type: obj.typ,
390
+ pos,
391
+ index,
392
+ noop: false,
393
+ bld: OpBuilder {
394
+ id,
395
+ obj: obj.id,
396
+ action,
397
+ value,
398
+ expand,
399
+ mark_name,
400
+ key: elemid.into(),
401
+ insert: true,
402
+ pred: vec![],
403
+ },
404
+ }
405
+ }
406
+
407
+ pub(crate) fn list_del<I: IntoIterator<Item = OpId>>(
408
+ id: OpId,
409
+ obj: ObjMeta,
410
+ index: usize,
411
+ elemid: ElemId,
412
+ pred: I,
413
+ ) -> Self {
414
+ let _action = types::OpType::Delete;
415
+ let (action, value, expand, mark_name) = _action.clone().decompose();
416
+ TxOp {
417
+ obj_type: obj.typ,
418
+ pos: 0,
419
+ index,
420
+ noop: false,
421
+ bld: OpBuilder {
422
+ id,
423
+ obj: obj.id,
424
+ action,
425
+ value,
426
+ expand,
427
+ mark_name,
428
+ key: elemid.into(),
429
+ insert: false,
430
+ pred: pred.into_iter().collect(),
431
+ },
432
+ }
433
+ }
434
+
435
+ pub(crate) fn prop(&self) -> PropRef<'_> {
436
+ if let KeyRef::Map(s) = &self.bld.key {
437
+ PropRef::Map(s.clone())
438
+ } else {
439
+ PropRef::Seq(self.index)
440
+ }
441
+ }
442
+
443
+ pub(crate) fn hydrate_value(&self, text_encoding: TextEncoding) -> hydrate::Value {
444
+ self.bld.hydrate_value(text_encoding)
445
+ }
446
+
447
+ pub(crate) fn get_increment_value(&self) -> Option<i64> {
448
+ self.bld.get_increment_value()
449
+ }
450
+
451
+ pub(crate) fn is_delete(&self) -> bool {
452
+ self.bld.is_delete()
453
+ }
454
+
455
+ pub(crate) fn as_str(&self) -> &str {
456
+ self.bld.as_str()
457
+ }
458
+
459
+ pub(crate) fn is_mark(&self) -> bool {
460
+ self.bld.is_mark()
461
+ }
462
+ }
463
+
464
+ impl OpLike for &TxOp {
465
+ type SuccIter<'b>
466
+ = std::array::IntoIter<OpId, 0>
467
+ where
468
+ Self: 'b;
469
+
470
+ fn mark_index(op: &Self) -> Option<MarkIndexBuilder> {
471
+ op.bld.mark_index()
472
+ }
473
+
474
+ fn width(op: &Self, seq_type: SequenceType, text_encoding: TextEncoding) -> u64 {
475
+ op.bld.width(seq_type, text_encoding) as u64
476
+ }
477
+
478
+ fn visible(op: &Self) -> bool {
479
+ !op.bld.is_inc()
480
+ }
481
+
482
+ fn obj_info(&self) -> Option<ObjInfo> {
483
+ let obj_type = ObjType::try_from(self.bld.action).ok()?;
484
+ let parent = self.bld.obj;
485
+ Some(ObjInfo { parent, obj_type })
486
+ }
487
+
488
+ fn id_actor(op: &Self) -> ActorIdx {
489
+ op.as_builder().id.actoridx()
490
+ }
491
+ fn id_ctr(op: &Self) -> i64 {
492
+ op.as_builder().id.icounter()
493
+ }
494
+
495
+ fn succ_inc(_op: &Self) -> Box<dyn Iterator<Item = Option<i64>> + '_> {
496
+ let v: Vec<Option<i64>> = vec![];
497
+ Box::new(v.into_iter())
498
+ }
499
+
500
+ fn succ(&self) -> Self::SuccIter<'_> {
501
+ [].into_iter()
502
+ }
503
+
504
+ fn id(&self) -> OpId {
505
+ self.as_builder().id
506
+ }
507
+ fn obj(&self) -> ObjId {
508
+ self.as_builder().obj
509
+ }
510
+ fn action(o: &Self) -> Action {
511
+ o.as_builder().action
512
+ }
513
+
514
+ fn key_str(o: &Self) -> Option<&str> {
515
+ match &o.as_builder().key {
516
+ KeyRef::Map(Cow::Owned(s)) => Some(s),
517
+ KeyRef::Map(Cow::Borrowed(s)) => Some(*s),
518
+ _ => None,
519
+ }
520
+ }
521
+
522
+ fn key(&self) -> KeyRef<'_> {
523
+ match &self.as_builder().key {
524
+ KeyRef::Map(Cow::Owned(s)) => KeyRef::Map(Cow::Borrowed(s)),
525
+ _ => self.as_builder().key.clone(),
526
+ }
527
+ }
528
+
529
+ fn raw_value(&self) -> Option<Cow<'_, [u8]>> {
530
+ self.as_builder().value.as_raw()
531
+ }
532
+ fn meta_value(&self) -> ValueMeta {
533
+ ValueMeta::from(&self.as_builder().value)
534
+ }
535
+ fn insert(o: &Self) -> bool {
536
+ o.as_builder().insert
537
+ }
538
+ fn mark_name(o: &Self) -> Option<Cow<'_, str>> {
539
+ o.as_builder().mark_name.as_deref().map(Cow::Borrowed)
540
+ }
541
+ fn expand(o: &Self) -> bool {
542
+ o.as_builder().expand
543
+ }
544
+ }
545
+
546
+ impl OpLike for TxOp {
547
+ type SuccIter<'b> = std::array::IntoIter<OpId, 0>;
548
+
549
+ fn mark_index(op: &Self) -> Option<MarkIndexBuilder> {
550
+ op.bld.mark_index()
551
+ }
552
+
553
+ fn width(op: &Self, seq_type: SequenceType, text_encoding: TextEncoding) -> u64 {
554
+ op.bld.width(seq_type, text_encoding) as u64
555
+ }
556
+
557
+ fn visible(op: &Self) -> bool {
558
+ !op.bld.is_inc()
559
+ }
560
+
561
+ fn obj_info(&self) -> Option<ObjInfo> {
562
+ let obj_type = ObjType::try_from(self.bld.action).ok()?;
563
+ let parent = self.bld.obj;
564
+ Some(ObjInfo { parent, obj_type })
565
+ }
566
+
567
+ fn id_actor(op: &Self) -> ActorIdx {
568
+ op.as_builder().id.actoridx()
569
+ }
570
+ fn id_ctr(op: &Self) -> i64 {
571
+ op.as_builder().id.icounter()
572
+ }
573
+
574
+ fn succ_inc(_op: &Self) -> Box<dyn Iterator<Item = Option<i64>>> {
575
+ let v: Vec<Option<i64>> = vec![];
576
+ Box::new(v.into_iter())
577
+ }
578
+
579
+ fn succ(&self) -> Self::SuccIter<'_> {
580
+ [].into_iter()
581
+ }
582
+
583
+ fn id(&self) -> OpId {
584
+ self.as_builder().id
585
+ }
586
+ fn obj(&self) -> ObjId {
587
+ self.as_builder().obj
588
+ }
589
+ fn action(o: &Self) -> Action {
590
+ o.as_builder().action
591
+ }
592
+
593
+ fn key_str(o: &Self) -> Option<&str> {
594
+ match &o.as_builder().key {
595
+ KeyRef::Map(Cow::Owned(s)) => Some(s),
596
+ KeyRef::Map(Cow::Borrowed(s)) => Some(*s),
597
+ _ => None,
598
+ }
599
+ }
600
+
601
+ fn key(&self) -> KeyRef<'_> {
602
+ match &self.as_builder().key {
603
+ KeyRef::Map(Cow::Owned(s)) => KeyRef::Map(Cow::Borrowed(s)),
604
+ _ => self.as_builder().key.clone(),
605
+ }
606
+ }
607
+
608
+ fn raw_value(&self) -> Option<Cow<'_, [u8]>> {
609
+ self.as_builder().value.as_raw()
610
+ }
611
+ fn meta_value(&self) -> ValueMeta {
612
+ ValueMeta::from(&self.as_builder().value)
613
+ }
614
+ fn insert(o: &Self) -> bool {
615
+ o.as_builder().insert
616
+ }
617
+ fn mark_name(o: &Self) -> Option<Cow<'_, str>> {
618
+ o.as_builder().mark_name.as_deref().map(Cow::Borrowed)
619
+ }
620
+ fn expand(o: &Self) -> bool {
621
+ o.as_builder().expand
622
+ }
623
+ }
624
+
625
+ impl OpLike for ChangeOp {
626
+ type SuccIter<'b> = Box<dyn ExactSizeIterator<Item = OpId> + 'b>;
627
+
628
+ fn mark_index(op: &Self) -> Option<MarkIndexBuilder> {
629
+ op.bld.mark_index()
630
+ }
631
+
632
+ fn width(op: &Self, seq_type: SequenceType, text_encoding: TextEncoding) -> u64 {
633
+ if Self::visible(op) {
634
+ op.bld.width(seq_type, text_encoding) as u64
635
+ } else {
636
+ 0
637
+ }
638
+ }
639
+
640
+ fn visible(op: &Self) -> bool {
641
+ !(op.bld.is_inc() || op.bld.is_delete() || op.succ.iter().any(|(_, inc)| inc.is_none()))
642
+ }
643
+
644
+ fn top(op: &Self) -> bool {
645
+ !op.conflicted && Self::visible(op)
646
+ }
647
+
648
+ fn obj_info(&self) -> Option<ObjInfo> {
649
+ let obj_type = ObjType::try_from(self.bld.action).ok()?;
650
+ let parent = self.bld.obj;
651
+ Some(ObjInfo { parent, obj_type })
652
+ }
653
+
654
+ fn id_actor(op: &Self) -> ActorIdx {
655
+ op.as_builder().id.actoridx()
656
+ }
657
+ fn id_ctr(op: &Self) -> i64 {
658
+ op.as_builder().id.icounter()
659
+ }
660
+
661
+ fn succ_inc(op: &Self) -> Box<dyn Iterator<Item = Option<i64>> + '_> {
662
+ Box::new(op.succ.iter().map(|o| o.1))
663
+ }
664
+
665
+ fn succ(&self) -> Self::SuccIter<'_> {
666
+ Box::new(self.succ.iter().map(|o| o.0))
667
+ }
668
+
669
+ fn id(&self) -> OpId {
670
+ self.as_builder().id
671
+ }
672
+ fn obj(&self) -> ObjId {
673
+ self.as_builder().obj
674
+ }
675
+ fn action(o: &Self) -> Action {
676
+ o.as_builder().action
677
+ }
678
+
679
+ fn key_str(o: &Self) -> Option<&str> {
680
+ match &o.as_builder().key {
681
+ KeyRef::Map(Cow::Owned(s)) => Some(s),
682
+ KeyRef::Map(Cow::Borrowed(s)) => Some(*s),
683
+ _ => None,
684
+ }
685
+ }
686
+
687
+ fn key(&self) -> KeyRef<'_> {
688
+ match &self.as_builder().key {
689
+ KeyRef::Map(Cow::Owned(s)) => KeyRef::Map(Cow::Borrowed(s)),
690
+ _ => self.as_builder().key.clone(),
691
+ }
692
+ }
693
+
694
+ fn raw_value(&self) -> Option<Cow<'_, [u8]>> {
695
+ self.as_builder().value.as_raw()
696
+ }
697
+ fn meta_value(&self) -> ValueMeta {
698
+ ValueMeta::from(&self.as_builder().value)
699
+ }
700
+ fn insert(o: &Self) -> bool {
701
+ o.as_builder().insert
702
+ }
703
+ fn mark_name(o: &Self) -> Option<Cow<'_, str>> {
704
+ o.as_builder().mark_name.as_deref().map(Cow::Borrowed)
705
+ }
706
+ fn expand(o: &Self) -> bool {
707
+ o.as_builder().expand
708
+ }
709
+ }
710
+
711
+ impl PartialEq<TxOp> for TxOp {
712
+ fn eq(&self, other: &Self) -> bool {
713
+ self.bld.id == other.bld.id
714
+ }
715
+ }
716
+
717
+ impl Eq for TxOp {}
718
+
719
+ impl PartialOrd for TxOp {
720
+ fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
721
+ Some(self.cmp(other))
722
+ }
723
+ }
724
+
725
+ impl Ord for TxOp {
726
+ fn cmp(&self, other: &Self) -> Ordering {
727
+ self.bld.id.cmp(&other.bld.id)
728
+ }
729
+ }
730
+
731
+ impl<'a> OpLike for Op<'a> {
732
+ type SuccIter<'b>
733
+ = SuccCursors<'a>
734
+ where
735
+ Self: 'b;
736
+
737
+ fn mark_index(op: &Self) -> Option<MarkIndexBuilder> {
738
+ op.mark_index()
739
+ }
740
+
741
+ fn width(op: &Self, seq_type: SequenceType, text_encoding: TextEncoding) -> u64 {
742
+ op.width(seq_type, text_encoding) as u64
743
+ }
744
+
745
+ fn visible(_op: &Self) -> bool {
746
+ true // FIXME
747
+ }
748
+
749
+ fn obj_info(&self) -> Option<ObjInfo> {
750
+ let obj_type = ObjType::try_from(self.action).ok()?;
751
+ let parent = self.obj;
752
+ Some(ObjInfo { parent, obj_type })
753
+ }
754
+
755
+ fn id_actor(op: &Self) -> ActorIdx {
756
+ op.id.actoridx()
757
+ }
758
+ fn id_ctr(op: &Self) -> i64 {
759
+ op.id.icounter()
760
+ }
761
+
762
+ fn id(&self) -> OpId {
763
+ self.id
764
+ }
765
+
766
+ fn obj(&self) -> ObjId {
767
+ self.obj
768
+ }
769
+
770
+ fn action(o: &Self) -> Action {
771
+ o.action
772
+ }
773
+
774
+ fn key_str(o: &Self) -> Option<&str> {
775
+ match &o.key {
776
+ KeyRef::Map(Cow::Owned(s)) => Some(s),
777
+ KeyRef::Map(Cow::Borrowed(s)) => Some(*s),
778
+ _ => None,
779
+ }
780
+ }
781
+
782
+ fn key(&self) -> KeyRef<'_> {
783
+ self.key.clone()
784
+ }
785
+
786
+ fn raw_value(&self) -> Option<Cow<'_, [u8]>> {
787
+ self.value.as_raw()
788
+ }
789
+
790
+ fn meta_value(&self) -> ValueMeta {
791
+ ValueMeta::from(&self.value)
792
+ }
793
+
794
+ fn succ_inc(op: &Self) -> Box<dyn Iterator<Item = Option<i64>> + '_> {
795
+ Box::new(IncCursors(op.succ_cursors.clone()))
796
+ }
797
+
798
+ fn succ(&self) -> Self::SuccIter<'_> {
799
+ self.succ()
800
+ }
801
+
802
+ fn insert(o: &Self) -> bool {
803
+ o.insert
804
+ }
805
+
806
+ fn expand(o: &Self) -> bool {
807
+ o.expand
808
+ }
809
+
810
+ fn mark_name(o: &Self) -> Option<Cow<'_, str>> {
811
+ o.mark_name.clone()
812
+ }
813
+ }
814
+
815
+ #[derive(Debug, Clone)]
816
+ pub(crate) struct Op<'a> {
817
+ pub(crate) pos: usize,
818
+ pub(crate) conflict: bool,
819
+ pub(crate) id: OpId,
820
+ pub(crate) action: Action,
821
+ pub(crate) obj: ObjId,
822
+ pub(crate) key: KeyRef<'a>,
823
+ pub(crate) insert: bool,
824
+ pub(crate) value: ScalarValue<'a>,
825
+ pub(crate) expand: bool,
826
+ pub(crate) mark_name: Option<Cow<'a, str>>,
827
+ pub(super) succ_cursors: SuccCursors<'a>,
828
+ }
829
+
830
+ #[derive(Clone, Default)]
831
+ pub(crate) struct SuccCursors<'a> {
832
+ pub(super) len: usize,
833
+ pub(super) succ_actor: ColumnDataIter<'a, ActorCursor>,
834
+ pub(super) succ_counter: ColumnDataIter<'a, DeltaCursor>,
835
+ pub(super) inc_values: ColumnDataIter<'a, IntCursor>,
836
+ }
837
+
838
+ impl<'a> SuccCursors<'a> {
839
+ pub(crate) fn pos(&self) -> usize {
840
+ self.succ_actor.pos()
841
+ }
842
+ pub(crate) fn with_inc(self) -> SuccIncCursors<'a> {
843
+ SuccIncCursors(self)
844
+ }
845
+ }
846
+
847
+ impl std::fmt::Debug for SuccCursors<'_> {
848
+ fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
849
+ f.debug_struct("SuccCursors")
850
+ .field("len", &self.len)
851
+ .finish()
852
+ }
853
+ }
854
+
855
+ pub(crate) struct SuccIncCursors<'a>(SuccCursors<'a>);
856
+
857
+ struct IncCursors<'a>(SuccCursors<'a>);
858
+
859
+ impl Iterator for SuccCursors<'_> {
860
+ type Item = OpId;
861
+
862
+ fn next(&mut self) -> Option<Self::Item> {
863
+ if self.len == 0 {
864
+ None
865
+ } else {
866
+ let counter = self.succ_counter.next()??;
867
+ let actor = self.succ_actor.next()??;
868
+ self.len -= 1;
869
+ Some(OpId::new(*counter as u64, u64::from(*actor) as usize))
870
+ }
871
+ }
872
+ }
873
+
874
+ impl ExactSizeIterator for SuccCursors<'_> {
875
+ fn len(&self) -> usize {
876
+ self.len
877
+ }
878
+ }
879
+
880
+ impl Iterator for SuccIncCursors<'_> {
881
+ type Item = (OpId, Option<i64>);
882
+
883
+ fn next(&mut self) -> Option<Self::Item> {
884
+ if self.0.len == 0 {
885
+ None
886
+ } else {
887
+ let counter = self.0.succ_counter.next()??;
888
+ let actor = self.0.succ_actor.next()??;
889
+ self.0.len -= 1;
890
+ let inc = self.0.inc_values.next()?.as_deref().copied();
891
+ let id = OpId::new(*counter as u64, u64::from(*actor) as usize);
892
+ Some((id, inc))
893
+ }
894
+ }
895
+ }
896
+
897
+ impl Iterator for IncCursors<'_> {
898
+ type Item = Option<i64>;
899
+
900
+ fn next(&mut self) -> Option<Self::Item> {
901
+ if self.0.len == 0 {
902
+ None
903
+ } else {
904
+ self.0.len -= 1;
905
+ let inc = self.0.inc_values.next()?.as_deref().copied();
906
+ Some(inc)
907
+ }
908
+ }
909
+ }
910
+
911
+ impl ExactSizeIterator for SuccIncCursors<'_> {
912
+ fn len(&self) -> usize {
913
+ self.0.len()
914
+ }
915
+ }
916
+
917
+ #[derive(Debug, Clone, PartialEq)]
918
+ pub(crate) struct SuccInsert {
919
+ pub(crate) id: OpId,
920
+ pub(crate) pos: usize,
921
+ pub(crate) inc: Option<i64>,
922
+ pub(crate) len: u64,
923
+ pub(crate) sub_pos: usize,
924
+ }
925
+
926
+ impl<'a> Op<'a> {
927
+ pub(crate) fn mark_index(&self) -> Option<MarkIndexBuilder> {
928
+ match (&self.action, &self.mark_name) {
929
+ (Action::Mark, Some(name)) => {
930
+ let name = Cow::Owned(name.to_string());
931
+ let value = self.value.clone().into_owned();
932
+ let data = MarkData { name, value };
933
+ Some(MarkIndexBuilder::Start(self.id, data))
934
+ }
935
+ (Action::Mark, None) => Some(MarkIndexBuilder::End(self.id.prev())),
936
+ _ => None,
937
+ }
938
+ }
939
+
940
+ pub(crate) fn add_succ(&self, id: OpId, mut inc: Option<i64>) -> SuccInsert {
941
+ let pos = self.pos;
942
+ let mut succ = self.succ_cursors.clone();
943
+ if inc.is_some() && !self.is_counter() {
944
+ inc = None;
945
+ }
946
+ let len = succ.len() as u64;
947
+ let mut sub_pos = succ.pos();
948
+ while let Some(i) = succ.next() {
949
+ if i > id {
950
+ break;
951
+ }
952
+ sub_pos = succ.pos();
953
+ }
954
+ SuccInsert {
955
+ id,
956
+ pos,
957
+ inc,
958
+ len,
959
+ sub_pos,
960
+ }
961
+ }
962
+
963
+ pub(crate) fn fix_counter(&mut self, clock: Option<&Clock>) {
964
+ if let ScalarValue::Counter(n) = self.value {
965
+ let mut inc = 0;
966
+ for (i, val) in self.succ_inc() {
967
+ if let Some(v) = val {
968
+ if let Some(c) = clock {
969
+ if c.covers(&i) {
970
+ inc += v;
971
+ }
972
+ } else {
973
+ inc += v;
974
+ }
975
+ }
976
+ }
977
+ self.value = ScalarValue::Counter(n + inc);
978
+ }
979
+ }
980
+
981
+ pub(crate) fn as_str(&self) -> &str {
982
+ if self.action == Action::Mark {
983
+ ""
984
+ } else if let ScalarValue::Str(s) = &self.value {
985
+ s.as_ref()
986
+ } else {
987
+ "\u{fffc}"
988
+ }
989
+ }
990
+
991
+ pub(crate) fn width(&self, seq_type: SequenceType, text_encoding: TextEncoding) -> usize {
992
+ match seq_type {
993
+ SequenceType::List => 1,
994
+ SequenceType::Text if self.action == Action::Mark => 0,
995
+ SequenceType::Text => text_encoding.width(self.as_str()),
996
+ }
997
+ }
998
+
999
+ pub(crate) fn op_type(&self) -> OpType<'a> {
1000
+ OpType::from_action_and_value(self.action, &self.value, &self.mark_name, self.expand)
1001
+ }
1002
+
1003
+ pub(crate) fn succ(&self) -> SuccCursors<'a> {
1004
+ self.succ_cursors.clone()
1005
+ }
1006
+
1007
+ pub(crate) fn succ_inc(&self) -> impl ExactSizeIterator<Item = (OpId, Option<i64>)> + 'a {
1008
+ self.succ_cursors.clone().with_inc()
1009
+ }
1010
+
1011
+ pub(crate) fn exid(&self, op_set: &OpSet) -> ExId {
1012
+ let id = self.id;
1013
+ if id == types::ROOT {
1014
+ ExId::Root
1015
+ } else {
1016
+ ExId::Id(
1017
+ id.counter(),
1018
+ op_set.get_actor(id.actor()).clone(),
1019
+ id.actor(),
1020
+ )
1021
+ }
1022
+ }
1023
+
1024
+ pub(crate) fn elemid_or_key(&self) -> KeyRef<'a> {
1025
+ if self.insert {
1026
+ KeyRef::Seq(ElemId(self.id))
1027
+ } else {
1028
+ self.key.clone()
1029
+ }
1030
+ }
1031
+
1032
+ pub(crate) fn step(&self, stepper: &mut OpStepper<'a>) -> bool {
1033
+ if self.obj != stepper.obj {
1034
+ let ok = self.obj > stepper.obj;
1035
+ stepper.obj = self.obj;
1036
+ stepper.key = self.elemid_or_key();
1037
+ stepper.id = self.id;
1038
+ ok
1039
+ } else {
1040
+ let ok = if self.elemid_or_key() == stepper.key {
1041
+ self.id > stepper.id
1042
+ } else {
1043
+ match (&self.key, &stepper.key) {
1044
+ (KeyRef::Map(s1), KeyRef::Map(s2)) => s1 > s2,
1045
+ (KeyRef::Seq(e1), KeyRef::Seq(e2)) if self.insert => {
1046
+ e1 == e2 || ElemId(self.id) < *e2
1047
+ }
1048
+ _ => false,
1049
+ }
1050
+ };
1051
+ stepper.key = self.elemid_or_key();
1052
+ stepper.id = self.id;
1053
+ ok
1054
+ }
1055
+ }
1056
+
1057
+ pub(crate) fn cursor(&self) -> Result<ElemId, AutomergeError> {
1058
+ if self.insert {
1059
+ Ok(ElemId(self.id))
1060
+ } else {
1061
+ match self.key {
1062
+ KeyRef::Seq(e) => Ok(e),
1063
+ _ => Err(AutomergeError::InvalidCursorOp),
1064
+ }
1065
+ }
1066
+ }
1067
+
1068
+ pub(crate) fn tagged_value(&self, op_set: &'a OpSet) -> (types::Value<'static>, ExId) {
1069
+ (self.value().into_value(), self.exid(op_set))
1070
+ }
1071
+
1072
+ pub(crate) fn get_increment_value(&self) -> Option<i64> {
1073
+ match (self.action, &self.value) {
1074
+ (Action::Increment, ScalarValue::Int(i)) => Some(*i),
1075
+ (Action::Increment, ScalarValue::Uint(i)) => Some(*i as i64),
1076
+ _ => None,
1077
+ }
1078
+ }
1079
+
1080
+ pub(crate) fn value(&self) -> ValueRef<'a> {
1081
+ match &self.action() {
1082
+ OpType::Make(obj_type) => ValueRef::Object(*obj_type),
1083
+ OpType::Put(scalar) => ValueRef::Scalar(scalar.clone()),
1084
+ OpType::MarkBegin(_, _) => {
1085
+ ValueRef::Scalar(ScalarValue::Str(Cow::Borrowed("markBegin")))
1086
+ }
1087
+ OpType::MarkEnd(_) => ValueRef::Scalar(ScalarValue::Str(Cow::Borrowed("markEnd"))),
1088
+ _ => panic!("cant convert op into a value - {:?}", self),
1089
+ }
1090
+ }
1091
+
1092
+ pub(crate) fn hydrate_value(&self, text_encoding: TextEncoding) -> hydrate::Value {
1093
+ match &self.action() {
1094
+ OpType::Make(obj_type) => hydrate::Value::new(*obj_type, text_encoding),
1095
+ OpType::Put(scalar) => hydrate::Value::Scalar(scalar.to_owned()),
1096
+ OpType::MarkBegin(_, mark) => hydrate::Value::new(&mark.value, text_encoding),
1097
+ OpType::MarkEnd(_) => hydrate::Value::Scalar("markEnd".into()),
1098
+ _ => panic!("cant convert op into a value"),
1099
+ }
1100
+ }
1101
+
1102
+ pub(crate) fn action(&self) -> OpType<'a> {
1103
+ self.op_type()
1104
+ }
1105
+
1106
+ pub(crate) fn is_inc(&self) -> bool {
1107
+ self.action == Action::Increment
1108
+ }
1109
+
1110
+ pub(crate) fn is_counter(&self) -> bool {
1111
+ matches!(&self.value, ScalarValue::Counter(_))
1112
+ }
1113
+
1114
+ pub(crate) fn is_mark(&self) -> bool {
1115
+ self.action == Action::Mark
1116
+ }
1117
+
1118
+ pub(crate) fn build(self, pred: Vec<OpId>) -> OpBuilder<'a> {
1119
+ OpBuilder {
1120
+ id: self.id,
1121
+ obj: self.obj,
1122
+ action: self.action,
1123
+ value: self.value,
1124
+ key: self.key,
1125
+ insert: self.insert,
1126
+ expand: self.expand,
1127
+ mark_name: self.mark_name,
1128
+ pred,
1129
+ }
1130
+ }
1131
+
1132
+ pub(crate) fn visible(&self) -> bool {
1133
+ if self.is_inc() {
1134
+ false
1135
+ } else if self.is_counter() {
1136
+ !self.succ_inc().any(|(_, inc)| inc.is_none())
1137
+ } else {
1138
+ self.succ_cursors.len() == 0
1139
+ }
1140
+ }
1141
+
1142
+ pub(crate) fn del(id: OpId, obj: ObjId, key: KeyRef<'a>) -> Self {
1143
+ Op {
1144
+ pos: 0,
1145
+ conflict: false,
1146
+ id,
1147
+ action: Action::Delete,
1148
+ obj,
1149
+ key,
1150
+ insert: false,
1151
+ value: ScalarValue::Null,
1152
+ expand: false,
1153
+ mark_name: None,
1154
+ succ_cursors: SuccCursors::default(),
1155
+ }
1156
+ }
1157
+
1158
+ pub(crate) fn prop(&self) -> Option<PropRef<'a>> {
1159
+ let key_str = self.key.key_str()?;
1160
+ Some(PropRef::Map(key_str))
1161
+ }
1162
+ }
1163
+
1164
+ impl PartialEq<Op<'_>> for Op<'_> {
1165
+ fn eq(&self, other: &Op<'_>) -> bool {
1166
+ self.id == other.id
1167
+ }
1168
+ }
1169
+
1170
+ impl PartialOrd for Op<'_> {
1171
+ fn partial_cmp(&self, other: &Self) -> Option<Ordering> {
1172
+ Some(self.cmp(other))
1173
+ }
1174
+ }
1175
+
1176
+ impl Ord for Op<'_> {
1177
+ fn cmp(&self, other: &Self) -> Ordering {
1178
+ self.id.cmp(&other.id)
1179
+ }
1180
+ }
1181
+
1182
+ impl std::hash::Hash for Op<'_> {
1183
+ fn hash<H: std::hash::Hasher>(&self, state: &mut H) {
1184
+ self.id.hash(state)
1185
+ }
1186
+ }
1187
+
1188
+ impl Eq for Op<'_> {}
1189
+
1190
+ // TODO - AS ChangeOp and OpLike fill almost the exact same function
1191
+
1192
+ pub(crate) trait AsChangeOp {
1193
+ fn obj_actor(op: &Self) -> Option<Cow<'_, ActorIdx>>;
1194
+ fn obj_ctr(op: &Self) -> Option<Cow<'_, u64>>;
1195
+ fn key_actor(op: &Self) -> Option<Cow<'_, ActorIdx>>;
1196
+ fn key_ctr(op: &Self) -> Option<Cow<'_, i64>>;
1197
+ fn key_str(op: &Self) -> Option<Cow<'_, str>>;
1198
+ fn insert(op: &Self) -> Option<Cow<'_, bool>>;
1199
+ fn action(op: &Self) -> Option<Cow<'_, Action>>;
1200
+ fn value(op: &Self) -> Option<Cow<'_, [u8]>>;
1201
+ fn value_meta(op: &Self) -> Option<Cow<'_, ValueMeta>>;
1202
+ fn pred_count(op: &Self) -> Option<Cow<'_, u64>>;
1203
+ fn expand(op: &Self) -> Option<Cow<'_, bool>>;
1204
+ fn mark_name(op: &Self) -> Option<Cow<'_, str>>;
1205
+ fn op_id_ctr(op: &Self) -> u64;
1206
+ fn pred(op: &Self) -> &[OpId];
1207
+
1208
+ fn id_actor(id: &OpId) -> Option<Cow<'_, ActorIdx>> {
1209
+ Some(Cow::Owned(id.actoridx()))
1210
+ }
1211
+
1212
+ fn id_ctr(id: &OpId) -> Option<Cow<'_, i64>> {
1213
+ Some(Cow::Owned(id.icounter()))
1214
+ }
1215
+ }
1216
+
1217
+ impl<T: AsChangeOp> AsChangeOp for Option<T> {
1218
+ fn obj_actor(op: &Self) -> Option<Cow<'_, ActorIdx>> {
1219
+ T::obj_actor(op.as_ref()?)
1220
+ }
1221
+ fn obj_ctr(op: &Self) -> Option<Cow<'_, u64>> {
1222
+ T::obj_ctr(op.as_ref()?)
1223
+ }
1224
+ fn key_actor(op: &Self) -> Option<Cow<'_, ActorIdx>> {
1225
+ T::key_actor(op.as_ref()?)
1226
+ }
1227
+ fn key_ctr(op: &Self) -> Option<Cow<'_, i64>> {
1228
+ T::key_ctr(op.as_ref()?)
1229
+ }
1230
+ fn key_str(op: &Self) -> Option<Cow<'_, str>> {
1231
+ T::key_str(op.as_ref()?)
1232
+ }
1233
+ fn insert(op: &Self) -> Option<Cow<'_, bool>> {
1234
+ T::insert(op.as_ref()?)
1235
+ }
1236
+ fn action(op: &Self) -> Option<Cow<'_, Action>> {
1237
+ T::action(op.as_ref()?)
1238
+ }
1239
+ fn value(op: &Self) -> Option<Cow<'_, [u8]>> {
1240
+ T::value(op.as_ref()?)
1241
+ }
1242
+ fn value_meta(op: &Self) -> Option<Cow<'_, ValueMeta>> {
1243
+ T::value_meta(op.as_ref()?)
1244
+ }
1245
+ fn pred_count(op: &Self) -> Option<Cow<'_, u64>> {
1246
+ T::pred_count(op.as_ref()?)
1247
+ }
1248
+ fn expand(op: &Self) -> Option<Cow<'_, bool>> {
1249
+ T::expand(op.as_ref()?)
1250
+ }
1251
+ fn mark_name(op: &Self) -> Option<Cow<'_, str>> {
1252
+ T::mark_name(op.as_ref()?)
1253
+ }
1254
+ fn op_id_ctr(op: &Self) -> u64 {
1255
+ op.as_ref().map(|o| T::op_id_ctr(o)).unwrap_or(0)
1256
+ }
1257
+ fn pred(op: &Self) -> &[OpId] {
1258
+ op.as_ref().map(T::pred).unwrap_or(&[])
1259
+ }
1260
+ }
1261
+
1262
+ impl<B: AsBuilder> AsChangeOp for B {
1263
+ fn obj_actor(op: &Self) -> Option<Cow<'_, ActorIdx>> {
1264
+ op.as_builder().obj.actor().map(Cow::Owned)
1265
+ }
1266
+
1267
+ fn obj_ctr(op: &Self) -> Option<Cow<'_, u64>> {
1268
+ op.as_builder().obj.counter().map(Cow::Owned)
1269
+ }
1270
+
1271
+ fn key_actor(op: &Self) -> Option<Cow<'_, ActorIdx>> {
1272
+ op.as_builder().key.actor().map(Cow::Owned)
1273
+ }
1274
+ fn key_ctr(op: &Self) -> Option<Cow<'_, i64>> {
1275
+ op.as_builder().key.icounter().map(Cow::Owned)
1276
+ }
1277
+ fn key_str(op: &Self) -> Option<Cow<'_, str>> {
1278
+ op.as_builder().key.key_str()
1279
+ }
1280
+ fn insert(op: &Self) -> Option<Cow<'_, bool>> {
1281
+ Some(Cow::Owned(op.as_builder().insert))
1282
+ }
1283
+ fn action(op: &Self) -> Option<Cow<'_, Action>> {
1284
+ Some(Cow::Owned(op.as_builder().action))
1285
+ }
1286
+ fn value(op: &Self) -> Option<Cow<'_, [u8]>> {
1287
+ op.as_builder().value.as_raw()
1288
+ }
1289
+ fn value_meta(op: &Self) -> Option<Cow<'_, ValueMeta>> {
1290
+ Some(Cow::Owned(ValueMeta::from(&op.as_builder().value)))
1291
+ }
1292
+ fn pred_count(op: &Self) -> Option<Cow<'_, u64>> {
1293
+ Some(Cow::Owned(op.as_builder().pred.len() as u64))
1294
+ }
1295
+ fn expand(op: &Self) -> Option<Cow<'_, bool>> {
1296
+ Some(Cow::Owned(op.as_builder().expand))
1297
+ }
1298
+ fn mark_name(op: &Self) -> Option<Cow<'_, str>> {
1299
+ op.as_builder().mark_name.clone()
1300
+ }
1301
+ fn op_id_ctr(op: &Self) -> u64 {
1302
+ op.as_builder().id.counter()
1303
+ }
1304
+ fn pred(op: &Self) -> &[OpId] {
1305
+ op.as_builder().pred.as_slice()
1306
+ }
1307
+ }
1308
+
1309
+ pub(crate) trait OpLike: Debug {
1310
+ type SuccIter<'b>: ExactSizeIterator<Item = OpId> + 'b
1311
+ where
1312
+ Self: 'b;
1313
+ fn id_actor(op: &Self) -> ActorIdx;
1314
+ fn id_ctr(op: &Self) -> i64;
1315
+ fn id(&self) -> OpId;
1316
+ fn obj(&self) -> ObjId;
1317
+ fn obj_actor(op: &Self) -> Option<ActorIdx> {
1318
+ op.obj().actor()
1319
+ }
1320
+ fn obj_ctr(op: &Self) -> Option<u64> {
1321
+ op.obj().counter()
1322
+ }
1323
+ fn action(o: &Self) -> Action;
1324
+ fn key_str(o: &Self) -> Option<&str>;
1325
+ fn key_actor(op: &Self) -> Option<ActorIdx> {
1326
+ op.key().actor()
1327
+ }
1328
+ fn key_ctr(op: &Self) -> Option<i64> {
1329
+ op.key().icounter()
1330
+ }
1331
+ fn key(&self) -> KeyRef<'_>;
1332
+ fn raw_value(&self) -> Option<Cow<'_, [u8]>>; // allocation
1333
+ fn meta_value(&self) -> ValueMeta;
1334
+ fn insert(op: &Self) -> bool;
1335
+ fn expand(op: &Self) -> bool;
1336
+ fn succ(&self) -> Self::SuccIter<'_>;
1337
+ fn succ_inc(op: &Self) -> Box<dyn Iterator<Item = Option<i64>> + '_>;
1338
+ fn mark_name(op: &Self) -> Option<Cow<'_, str>>;
1339
+ fn mark_index(op: &Self) -> Option<MarkIndexBuilder>;
1340
+ fn width(op: &Self, seq_type: SequenceType, text_encoding: TextEncoding) -> u64;
1341
+ fn visible(op: &Self) -> bool;
1342
+ fn top(op: &Self) -> bool {
1343
+ Self::visible(op)
1344
+ }
1345
+ fn obj_info(&self) -> Option<ObjInfo>;
1346
+ }
1347
+
1348
+ #[derive(Clone, Debug)]
1349
+ pub(crate) struct OpStepper<'a> {
1350
+ obj: ObjId,
1351
+ key: KeyRef<'a>,
1352
+ id: OpId,
1353
+ }
1354
+
1355
+ impl Default for OpStepper<'_> {
1356
+ fn default() -> Self {
1357
+ OpStepper {
1358
+ obj: ObjId::root(),
1359
+ key: KeyRef::Map(Cow::Borrowed("")),
1360
+ id: OpId::default(),
1361
+ }
1362
+ }
1363
+ }