y-rb 0.3.2-x64-mingw-ucrt → 0.4.1-x64-mingw-ucrt

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 39fc8e3c31a8953aa8d3556c561d76416ba4cf9a2ec381a980fa9b5bbc26260b
4
- data.tar.gz: 7ef6139c676a38bf22c5dc01c944d7588f67609591d217f9813d85edd391b2da
3
+ metadata.gz: 470f58b417b5fa272fa8ae7c343c5bdd5f7caa7c33e16b05c219a502076506d2
4
+ data.tar.gz: 04777b42761fe611a821c10aefb8ee9e9f9c3c61790a6cc0ffd74b02317d45df
5
5
  SHA512:
6
- metadata.gz: 34f44ecb9ca0646eaa1814f177582d58de48e9be919c782c4181f7320b45dc5368e7c0ecff702c3ec8f646cc93556523e4bbdeecbf28d56fc7dd4a370f63d91e
7
- data.tar.gz: ec555f344466cf79221ed6aa2d5cd65f7c0efc56f2dd4b13c156e6115c39975c592e49c31b00998107eb27e2a1f05216b35f9e6c65c14ea648fabe4681cb25c5
6
+ metadata.gz: 3b7046f178d39061a4e72035fdd09a9117daaea2d80ba2d6939755e826e08a88b1f50d6687cea48cf8468be8a27e1cf3f4f3bbc29b73befd4d2a8cc03cf1509f
7
+ data.tar.gz: 4b4324243babc47d2c23e9de0ffb31210476041a736609f294c1b48f6499c87d267923d024dcdd362372a22a80220eb67bf5dc5f7cf6d8f3ade08727cbb3ce99
data/ext/yrb/Cargo.toml CHANGED
@@ -1,20 +1,19 @@
1
1
  [package]
2
2
  name = "yrb"
3
- version = "0.3.2"
3
+ version = "0.4.1"
4
4
  authors = ["Hannes Moser <box@hannesmoser.at>", "Hannes Moser <hmoser@gitlab.com>"]
5
5
  edition = "2021"
6
6
  homepage = "https://github.com/y-crdt/yrb"
7
7
  repository = "https://github.com/y-crdt/yrb"
8
8
 
9
9
  [dependencies]
10
- lib0 = "0.12.2" # must match yrs version
11
- magnus = { git = "https://github.com/matsadler/magnus", rev = "4c9857cecabec2df6cc230763560815520de20b7"} # waiting for release with full rb-sys backend
12
- rb-sys = { version = "~0.9.35", features = ["link-ruby"] }
13
- thiserror = "1.0.37"
14
- yrs = "0.12.2"
10
+ lib0 = "0.14.1" # must match yrs version
11
+ magnus = { git = "https://github.com/matsadler/magnus", rev = "a51ccaf01d82e9e1a981e4f3fbaca35100513b08" }
12
+ thiserror = "1.0.38"
13
+ yrs = "0.14.1"
15
14
 
16
15
  [dev-dependencies]
17
- magnus = { git = "https://github.com/matsadler/magnus", rev = "4c9857cecabec2df6cc230763560815520de20b7", features = ["embed"] } # waiting for release with full rb-sys backend
16
+ magnus = { git = "https://github.com/matsadler/magnus", rev = "a51ccaf01d82e9e1a981e4f3fbaca35100513b08", features = ["embed"] }
18
17
 
19
18
  [lib]
20
19
  name = "yrb"
@@ -64,7 +64,7 @@ impl Awareness {
64
64
 
65
65
  /// Returns a globally unique client ID of an underlying [Doc].
66
66
  pub fn client_id(&self) -> ClientID {
67
- self.doc.client_id
67
+ self.doc.client_id()
68
68
  }
69
69
 
70
70
  /// Returns a state map of all of the clients tracked by current [Awareness] instance. Those
@@ -76,7 +76,7 @@ impl Awareness {
76
76
 
77
77
  /// Returns a JSON string state representation of a current [Awareness] instance.
78
78
  pub fn local_state(&self) -> Option<&str> {
79
- Some(self.states.get(&self.doc.client_id)?.as_str())
79
+ Some(self.states.get(&self.doc.client_id())?.as_str())
80
80
  }
81
81
 
82
82
  /// Sets a current [Awareness] instance state to a corresponding JSON string. This state will
@@ -84,7 +84,7 @@ impl Awareness {
84
84
  /// to be emitted if current instance was created using [Awareness::with_observer] method.
85
85
  ///
86
86
  pub fn set_local_state<S: Into<String>>(&mut self, json: S) {
87
- let client_id = self.doc.client_id;
87
+ let client_id = self.doc.client_id();
88
88
  self.update_meta(client_id);
89
89
  let new: String = json.into();
90
90
  match self.states.entry(client_id) {
@@ -120,7 +120,7 @@ impl Awareness {
120
120
  /// Clears out a state of a current client (see: [Awareness::client_id]),
121
121
  /// effectively marking it as disconnected.
122
122
  pub fn clean_local_state(&mut self) {
123
- let client_id = self.doc.client_id;
123
+ let client_id = self.doc.client_id();
124
124
  self.remove_state(client_id);
125
125
  }
126
126
 
@@ -192,7 +192,7 @@ impl Awareness {
192
192
  if is_new || is_removed {
193
193
  if is_null {
194
194
  // never let a remote client remove this local state
195
- if client_id == self.doc.client_id
195
+ if client_id == self.doc.client_id()
196
196
  && self.states.get(&client_id).is_some()
197
197
  {
198
198
  // remote client removed the local state. Do not remote state. Broadcast a message indicating
data/ext/yrb/src/lib.rs CHANGED
@@ -22,6 +22,7 @@ mod ytext;
22
22
  mod ytransaction;
23
23
  mod yvalue;
24
24
  mod yxml_element;
25
+ mod yxml_fragment;
25
26
  mod yxml_text;
26
27
 
27
28
  #[magnus::init]
@@ -33,10 +34,10 @@ fn init() -> Result<(), Error> {
33
34
  .expect("cannot find class Y::Array");
34
35
 
35
36
  yarray
36
- .define_private_method("yarray_each", method!(YArray::yarray_each, 1))
37
+ .define_private_method("yarray_each", method!(YArray::yarray_each, 2))
37
38
  .expect("cannot define private method: yarray_each");
38
39
  yarray
39
- .define_private_method("yarray_get", method!(YArray::yarray_get, 1))
40
+ .define_private_method("yarray_get", method!(YArray::yarray_get, 2))
40
41
  .expect("cannot define private method: yarray_get");
41
42
  yarray
42
43
  .define_private_method("yarray_insert", method!(YArray::yarray_insert, 3))
@@ -48,7 +49,7 @@ fn init() -> Result<(), Error> {
48
49
  )
49
50
  .expect("cannot define private method: yarray_insert_range");
50
51
  yarray
51
- .define_private_method("yarray_length", method!(YArray::yarray_length, 0))
52
+ .define_private_method("yarray_length", method!(YArray::yarray_length, 1))
52
53
  .expect("cannot define private method: yarray_length");
53
54
  yarray
54
55
  .define_private_method("yarray_observe", method!(YArray::yarray_observe, 1))
@@ -69,7 +70,7 @@ fn init() -> Result<(), Error> {
69
70
  )
70
71
  .expect("cannot define private method: yarray_remove_range");
71
72
  yarray
72
- .define_private_method("yarray_to_a", method!(YArray::yarray_to_a, 0))
73
+ .define_private_method("yarray_to_a", method!(YArray::yarray_to_a, 1))
73
74
  .expect("cannot define private method: yarray_to_a");
74
75
  yarray
75
76
  .define_private_method("yarray_unobserve", method!(YArray::yarray_unobserve, 1))
@@ -80,10 +81,40 @@ fn init() -> Result<(), Error> {
80
81
  .expect("cannot define class Y::Doc");
81
82
  ydoc.define_singleton_method("new", function!(YDoc::ydoc_new, -1))
82
83
  .expect("cannot define singleton method: ydoc_new");
84
+ ydoc.define_private_method("ydoc_encode_diff_v1", method!(YDoc::ydoc_encode_diff_v1, 2))
85
+ .expect("cannot define private method: ydoc_encode_diff_v1");
86
+ ydoc.define_private_method(
87
+ "ydoc_get_or_insert_array",
88
+ method!(YDoc::ydoc_get_or_insert_array, 1),
89
+ )
90
+ .expect("cannot define private method: ydoc_get_or_insert_array");
91
+ ydoc.define_private_method(
92
+ "ydoc_get_or_insert_map",
93
+ method!(YDoc::ydoc_get_or_insert_map, 1),
94
+ )
95
+ .expect("cannot define private method: ydoc_get_or_insert_map");
96
+ ydoc.define_private_method(
97
+ "ydoc_get_or_insert_text",
98
+ method!(YDoc::ydoc_get_or_insert_text, 1),
99
+ )
100
+ .expect("cannot define private method: ydoc_get_or_insert_text");
101
+ ydoc.define_private_method(
102
+ "ydoc_get_or_insert_xml_element",
103
+ method!(YDoc::ydoc_get_or_insert_xml_element, 1),
104
+ )
105
+ .expect("cannot define private method: ydoc_get_or_insert_xml_element");
106
+ ydoc.define_private_method(
107
+ "ydoc_get_or_insert_xml_fragment",
108
+ method!(YDoc::ydoc_get_or_insert_xml_fragment, 1),
109
+ )
110
+ .expect("cannot define private method: ydoc_get_or_insert_xml_fragment");
111
+ ydoc.define_private_method(
112
+ "ydoc_get_or_insert_xml_text",
113
+ method!(YDoc::ydoc_get_or_insert_xml_text, 1),
114
+ )
115
+ .expect("cannot define private method: ydoc_get_or_insert_xml_text");
83
116
  ydoc.define_private_method("ydoc_transact", method!(YDoc::ydoc_transact, 0))
84
117
  .expect("cannot define private method: ydoc_transact");
85
- ydoc.define_private_method("ydoc_encode_diff_v1", method!(YDoc::ydoc_encode_diff_v1, 1))
86
- .expect("cannot define private method: ydoc_encode_diff_v1");
87
118
 
88
119
  let ymap = module
89
120
  .define_class("Map", Default::default())
@@ -91,11 +122,11 @@ fn init() -> Result<(), Error> {
91
122
 
92
123
  ymap.define_private_method("ymap_clear", method!(YMap::ymap_clear, 1))
93
124
  .expect("cannot define private method: ymap_clear");
94
- ymap.define_private_method("ymap_contains", method!(YMap::ymap_contains, 1))
125
+ ymap.define_private_method("ymap_contains", method!(YMap::ymap_contains, 2))
95
126
  .expect("cannot define private method: ymap_contains");
96
- ymap.define_private_method("ymap_each", method!(YMap::ymap_each, 1))
127
+ ymap.define_private_method("ymap_each", method!(YMap::ymap_each, 2))
97
128
  .expect("cannot define private method: ymap_each");
98
- ymap.define_private_method("ymap_get", method!(YMap::ymap_get, 1))
129
+ ymap.define_private_method("ymap_get", method!(YMap::ymap_get, 2))
99
130
  .expect("cannot define private method: ymap_get");
100
131
  ymap.define_private_method("ymap_insert", method!(YMap::ymap_insert, 3))
101
132
  .expect("cannot define private method: ymap_insert");
@@ -103,9 +134,9 @@ fn init() -> Result<(), Error> {
103
134
  .expect("cannot define private method: ymap_observe");
104
135
  ymap.define_private_method("ymap_remove", method!(YMap::ymap_remove, 2))
105
136
  .expect("cannot define private method: ymap_remove");
106
- ymap.define_private_method("ymap_size", method!(YMap::ymap_size, 0))
137
+ ymap.define_private_method("ymap_size", method!(YMap::ymap_size, 1))
107
138
  .expect("cannot define private method: ymap_size");
108
- ymap.define_private_method("ymap_to_h", method!(YMap::ymap_to_h, 0))
139
+ ymap.define_private_method("ymap_to_h", method!(YMap::ymap_to_h, 1))
109
140
  .expect("cannot define private method: ymap_to_h");
110
141
  ymap.define_private_method("ymap_unobserve", method!(YMap::ymap_unobserve, 1))
111
142
  .expect("cannot define private method: ymap_unobserve");
@@ -126,6 +157,9 @@ fn init() -> Result<(), Error> {
126
157
  method!(YTransaction::ytransaction_commit, 0),
127
158
  )
128
159
  .expect("cannot define private method: ytransaction_commit");
160
+ ytransaction
161
+ .define_method("free", method!(YTransaction::ytransaction_free, 0))
162
+ .expect("");
129
163
  ytransaction
130
164
  .define_private_method(
131
165
  "ytransaction_get_array",
@@ -137,7 +171,7 @@ fn init() -> Result<(), Error> {
137
171
  "ytransaction_get_map",
138
172
  method!(YTransaction::ytransaction_get_map, 1),
139
173
  )
140
- .expect("cannot define private method: ytransaction_get_mao");
174
+ .expect("cannot define private method: ytransaction_get_map");
141
175
  ytransaction
142
176
  .define_private_method(
143
177
  "ytransaction_get_text",
@@ -150,6 +184,12 @@ fn init() -> Result<(), Error> {
150
184
  method!(YTransaction::ytransaction_get_xml_element, 1),
151
185
  )
152
186
  .expect("cannot define private method: ytransaction_get_xml_element");
187
+ ytransaction
188
+ .define_private_method(
189
+ "ytransaction_get_xml_fragment",
190
+ method!(YTransaction::ytransaction_get_xml_fragment, 1),
191
+ )
192
+ .expect("cannot define private method: ytransaction_get_xml_fragment");
153
193
  ytransaction
154
194
  .define_private_method(
155
195
  "ytransaction_get_xml_text",
@@ -189,7 +229,7 @@ fn init() -> Result<(), Error> {
189
229
  )
190
230
  .expect("cannot define private method: ytext_insert_with_attributes");
191
231
  ytext
192
- .define_private_method("ytext_length", method!(YText::ytext_length, 0))
232
+ .define_private_method("ytext_length", method!(YText::ytext_length, 1))
193
233
  .expect("cannot define private method: ytext_length");
194
234
  ytext
195
235
  .define_private_method("ytext_observe", method!(YText::ytext_observe, 1))
@@ -201,7 +241,7 @@ fn init() -> Result<(), Error> {
201
241
  .define_private_method("ytext_remove_range", method!(YText::ytext_remove_range, 3))
202
242
  .expect("cannot define private method: ytext_remove_range");
203
243
  ytext
204
- .define_private_method("ytext_to_s", method!(YText::ytext_to_s, 0))
244
+ .define_private_method("ytext_to_s", method!(YText::ytext_to_s, 1))
205
245
  .expect("cannot define private method: ytext_to_s");
206
246
  ytext
207
247
  .define_private_method("ytext_unobserve", method!(YText::ytext_unobserve, 1))
@@ -214,25 +254,25 @@ fn init() -> Result<(), Error> {
214
254
  yxml_element
215
255
  .define_private_method(
216
256
  "yxml_element_attributes",
217
- method!(YXmlElement::yxml_element_attributes, 0),
257
+ method!(YXmlElement::yxml_element_attributes, 1),
218
258
  )
219
259
  .expect("cannot define private method: yxml_element_attributes");
220
260
  yxml_element
221
261
  .define_private_method(
222
262
  "yxml_element_first_child",
223
- method!(YXmlElement::yxml_element_first_child, 0),
263
+ method!(YXmlElement::yxml_element_first_child, 1),
224
264
  )
225
265
  .expect("cannot define private method: yxml_element_first_child");
226
266
  yxml_element
227
267
  .define_private_method(
228
268
  "yxml_element_get",
229
- method!(YXmlElement::yxml_element_get, 1),
269
+ method!(YXmlElement::yxml_element_get, 2),
230
270
  )
231
271
  .expect("cannot define private method: yxml_element_get");
232
272
  yxml_element
233
273
  .define_private_method(
234
274
  "yxml_element_get_attribute",
235
- method!(YXmlElement::yxml_element_get_attribute, 1),
275
+ method!(YXmlElement::yxml_element_get_attribute, 2),
236
276
  )
237
277
  .expect("cannot define private method: yxml_element_get_attribute");
238
278
  yxml_element
@@ -250,13 +290,13 @@ fn init() -> Result<(), Error> {
250
290
  yxml_element
251
291
  .define_private_method(
252
292
  "yxml_element_insert_text",
253
- method!(YXmlElement::yxml_element_insert_text, 2),
293
+ method!(YXmlElement::yxml_element_insert_text, 3),
254
294
  )
255
295
  .expect("cannot define private method: yxml_element_insert_text");
256
296
  yxml_element
257
297
  .define_private_method(
258
298
  "yxml_element_next_sibling",
259
- method!(YXmlElement::yxml_element_next_sibling, 0),
299
+ method!(YXmlElement::yxml_element_next_sibling, 1),
260
300
  )
261
301
  .expect("cannot define private method: yxml_element_next_sibling");
262
302
  yxml_element
@@ -274,31 +314,31 @@ fn init() -> Result<(), Error> {
274
314
  yxml_element
275
315
  .define_private_method(
276
316
  "yxml_element_prev_sibling",
277
- method!(YXmlElement::yxml_element_prev_sibling, 0),
317
+ method!(YXmlElement::yxml_element_prev_sibling, 1),
278
318
  )
279
319
  .expect("cannot define private method: yxml_element_prev_sibling");
280
320
  yxml_element
281
321
  .define_private_method(
282
- "yxml_element_push_elem_back",
322
+ "yxml_element_push_element_back",
283
323
  method!(YXmlElement::yxml_element_push_element_back, 2),
284
324
  )
285
- .expect("cannot define private method: yxml_element_push_elem_back");
325
+ .expect("cannot define private method: yxml_element_push_element_back");
286
326
  yxml_element
287
327
  .define_private_method(
288
- "yxml_element_push_elem_front",
328
+ "yxml_element_push_element_front",
289
329
  method!(YXmlElement::yxml_element_push_element_front, 2),
290
330
  )
291
- .expect("cannot define private method: yxml_element_push_elem_front");
331
+ .expect("cannot define private method: yxml_element_push_element_front");
292
332
  yxml_element
293
333
  .define_private_method(
294
334
  "yxml_element_push_text_back",
295
- method!(YXmlElement::yxml_element_push_text_back, 1),
335
+ method!(YXmlElement::yxml_element_push_text_back, 2),
296
336
  )
297
337
  .expect("cannot define private method: yxml_element_push_text_back");
298
338
  yxml_element
299
339
  .define_private_method(
300
340
  "yxml_element_push_text_front",
301
- method!(YXmlElement::yxml_element_push_text_front, 1),
341
+ method!(YXmlElement::yxml_element_push_text_front, 2),
302
342
  )
303
343
  .expect("cannot define private method: yxml_element_push_text_front");
304
344
  yxml_element
@@ -313,10 +353,16 @@ fn init() -> Result<(), Error> {
313
353
  method!(YXmlElement::yxml_element_remove_range, 3),
314
354
  )
315
355
  .expect("cannot define private method: yxml_element_remove_range");
356
+ yxml_element
357
+ .define_private_method(
358
+ "yxml_element_siblings",
359
+ method!(YXmlElement::yxml_element_siblings, 1),
360
+ )
361
+ .expect("cannot define private method: yxml_element_siblings");
316
362
  yxml_element
317
363
  .define_private_method(
318
364
  "yxml_element_size",
319
- method!(YXmlElement::yxml_element_size, 0),
365
+ method!(YXmlElement::yxml_element_size, 1),
320
366
  )
321
367
  .expect("cannot define private method: yxml_element_size");
322
368
  yxml_element
@@ -328,7 +374,7 @@ fn init() -> Result<(), Error> {
328
374
  yxml_element
329
375
  .define_private_method(
330
376
  "yxml_element_to_s",
331
- method!(YXmlElement::yxml_element_to_s, 0),
377
+ method!(YXmlElement::yxml_element_to_s, 1),
332
378
  )
333
379
  .expect("cannot define private method: yxml_element_to_s");
334
380
  yxml_element
@@ -345,7 +391,7 @@ fn init() -> Result<(), Error> {
345
391
  yxml_text
346
392
  .define_private_method(
347
393
  "yxml_text_attributes",
348
- method!(YXmlText::yxml_text_attributes, 0),
394
+ method!(YXmlText::yxml_text_attributes, 1),
349
395
  )
350
396
  .expect("cannot define private method: yxml_text_attributes");
351
397
  yxml_text
@@ -354,7 +400,7 @@ fn init() -> Result<(), Error> {
354
400
  yxml_text
355
401
  .define_private_method(
356
402
  "yxml_text_get_attribute",
357
- method!(YXmlText::yxml_text_get_attribute, 1),
403
+ method!(YXmlText::yxml_text_get_attribute, 2),
358
404
  )
359
405
  .expect("cannot define private method: yxml_text_get_attribute");
360
406
  yxml_text
@@ -385,12 +431,12 @@ fn init() -> Result<(), Error> {
385
431
  )
386
432
  .expect("cannot define private method: yxml_text_insert_embed");
387
433
  yxml_text
388
- .define_private_method("yxml_text_length", method!(YXmlText::yxml_text_length, 0))
434
+ .define_private_method("yxml_text_length", method!(YXmlText::yxml_text_length, 1))
389
435
  .expect("cannot define private method: yxml_text_length");
390
436
  yxml_text
391
437
  .define_private_method(
392
438
  "yxml_text_next_sibling",
393
- method!(YXmlText::yxml_text_next_sibling, 0),
439
+ method!(YXmlText::yxml_text_next_sibling, 1),
394
440
  )
395
441
  .expect("cannot define private method: yxml_text_next_sibling");
396
442
  yxml_text
@@ -399,7 +445,7 @@ fn init() -> Result<(), Error> {
399
445
  yxml_text
400
446
  .define_private_method(
401
447
  "yxml_text_prev_sibling",
402
- method!(YXmlText::yxml_text_prev_sibling, 0),
448
+ method!(YXmlText::yxml_text_prev_sibling, 1),
403
449
  )
404
450
  .expect("cannot define private method: yxml_text_prev_sibling");
405
451
  yxml_text
@@ -412,7 +458,7 @@ fn init() -> Result<(), Error> {
412
458
  )
413
459
  .expect("cannot define private method: yxml_text_remove_range");
414
460
  yxml_text
415
- .define_private_method("yxml_text_to_s", method!(YXmlText::yxml_text_to_s, 0))
461
+ .define_private_method("yxml_text_to_s", method!(YXmlText::yxml_text_to_s, 1))
416
462
  .expect("cannot define private method: yxml_text_to_s");
417
463
 
418
464
  let yawareness = module
data/ext/yrb/src/utils.rs CHANGED
@@ -1,7 +1,7 @@
1
1
  use crate::yvalue::YValue;
2
2
  use lib0::any::Any;
3
3
  use magnus::r_hash::ForEach::Continue;
4
- use magnus::{Error, RHash, RString, Symbol, Value};
4
+ use magnus::{exception, Error, RHash, RString, Symbol, Value};
5
5
  use std::rc::Rc;
6
6
  use yrs::types::Attrs;
7
7
 
@@ -27,7 +27,10 @@ pub(crate) fn map_rhash_to_attrs(hash: RHash) -> Result<Attrs, Error> {
27
27
  });
28
28
 
29
29
  if result.is_err() {
30
- return Err(Error::runtime_error("could not map hash to attrs"));
30
+ return Err(Error::new(
31
+ exception::runtime_error(),
32
+ "could not map hash to attrs",
33
+ ));
31
34
  }
32
35
 
33
36
  Ok(a)
@@ -1,37 +1,50 @@
1
+ use crate::ytransaction::YTransaction;
1
2
  use crate::yvalue::YValue;
2
- use crate::YTransaction;
3
3
  use lib0::any::Any;
4
4
  use magnus::block::Proc;
5
5
  use magnus::value::Qnil;
6
6
  use magnus::{Error, RArray, RHash, Symbol, Value};
7
7
  use std::cell::RefCell;
8
8
  use yrs::types::Change;
9
- use yrs::Array;
9
+ use yrs::{Array, ArrayRef, Observable};
10
10
 
11
11
  #[magnus::wrap(class = "Y::Array")]
12
- pub(crate) struct YArray(pub(crate) RefCell<Array>);
12
+ pub(crate) struct YArray(pub(crate) RefCell<ArrayRef>);
13
13
 
14
14
  /// SAFETY: This is safe because we only access this data when the GVL is held.
15
15
  unsafe impl Send for YArray {}
16
16
 
17
17
  impl YArray {
18
- pub(crate) fn yarray_each(&self, block: Proc) {
19
- self.0.borrow_mut().iter().for_each(|val| {
18
+ pub(crate) fn yarray_each(&self, transaction: &YTransaction, block: Proc) -> Result<(), Error> {
19
+ let tx = transaction.transaction();
20
+ let tx = tx.as_ref().unwrap();
21
+
22
+ let arr = self.0.borrow();
23
+ arr.iter(tx).for_each(|val| {
20
24
  let yvalue = YValue::from(val);
21
25
  let args = (yvalue.into(),);
22
26
  let _ = block.call::<(Value,), Qnil>(args);
23
27
  });
28
+
29
+ Ok(())
24
30
  }
25
- pub(crate) fn yarray_get(&self, index: u32) -> Value {
26
- let v = self.0.borrow().get(index).unwrap();
31
+ pub(crate) fn yarray_get(&self, transaction: &YTransaction, index: u32) -> Value {
32
+ let tx = transaction.transaction();
33
+ let tx = tx.as_ref().unwrap();
34
+
35
+ let arr = self.0.borrow();
36
+ let v = arr.get(tx, index).unwrap();
27
37
  YValue::from(v).into()
28
38
  }
29
39
  pub(crate) fn yarray_insert(&self, transaction: &YTransaction, index: u32, value: Value) {
30
40
  let yvalue = YValue::from(value);
31
41
  let avalue = Any::from(yvalue);
32
- self.0
33
- .borrow_mut()
34
- .insert(&mut *transaction.0.borrow_mut(), index, avalue);
42
+
43
+ let mut tx = transaction.transaction();
44
+ let tx = tx.as_mut().unwrap();
45
+
46
+ let arr = self.0.borrow_mut();
47
+ arr.insert(tx, index, avalue);
35
48
  }
36
49
  pub(crate) fn yarray_insert_range(
37
50
  &self,
@@ -39,18 +52,24 @@ impl YArray {
39
52
  index: u32,
40
53
  values: RArray,
41
54
  ) {
42
- let arr: Vec<Any> = values
55
+ let arr = self.0.borrow_mut();
56
+ let mut tx = transaction.transaction();
57
+ let tx = tx.as_mut().unwrap();
58
+
59
+ let add_values: Vec<Any> = values
43
60
  .each()
44
61
  .into_iter()
45
62
  .map(|value| YValue::from(value.unwrap()).into())
46
63
  .collect();
47
64
 
48
- self.0
49
- .borrow_mut()
50
- .insert_range(&mut *transaction.0.borrow_mut(), index, arr);
65
+ arr.insert_range(tx, index, add_values)
51
66
  }
52
- pub(crate) fn yarray_length(&self) -> u32 {
53
- return self.0.borrow().len();
67
+ pub(crate) fn yarray_length(&self, transaction: &YTransaction) -> u32 {
68
+ let arr = self.0.borrow();
69
+ let tx = transaction.transaction();
70
+ let tx = tx.as_ref().unwrap();
71
+
72
+ arr.len(tx)
54
73
  }
55
74
  pub(crate) fn yarray_observe(&self, block: Proc) -> Result<u32, Error> {
56
75
  let change_added = Symbol::new("added").to_static();
@@ -111,32 +130,42 @@ impl YArray {
111
130
  pub(crate) fn yarray_push_back(&self, transaction: &YTransaction, value: Value) {
112
131
  let yvalue = YValue::from(value);
113
132
  let avalue = Any::from(yvalue);
114
- self.0
115
- .borrow_mut()
116
- .push_back(&mut *transaction.0.borrow_mut(), avalue)
133
+ let mut tx = transaction.transaction();
134
+ let tx = tx.as_mut().unwrap();
135
+
136
+ self.0.borrow_mut().push_back(tx, avalue);
117
137
  }
118
138
  pub(crate) fn yarray_push_front(&self, transaction: &YTransaction, value: Value) {
119
139
  let yvalue = YValue::from(value);
120
140
  let avalue = Any::from(yvalue);
121
- self.0
122
- .borrow_mut()
123
- .push_front(&mut *transaction.0.borrow_mut(), avalue)
141
+
142
+ let mut tx = transaction.transaction();
143
+ let tx = tx.as_mut().unwrap();
144
+
145
+ let arr = self.0.borrow_mut();
146
+ arr.push_front(tx, avalue)
124
147
  }
125
148
  pub(crate) fn yarray_remove(&self, transaction: &YTransaction, index: u32) {
126
- self.0
127
- .borrow_mut()
128
- .remove(&mut transaction.0.borrow_mut(), index)
149
+ let mut tx = transaction.transaction();
150
+ let tx = tx.as_mut().unwrap();
151
+
152
+ let arr = self.0.borrow_mut();
153
+ arr.remove(tx, index)
129
154
  }
130
155
  pub(crate) fn yarray_remove_range(&self, transaction: &YTransaction, index: u32, len: u32) {
131
- self.0
132
- .borrow_mut()
133
- .remove_range(&mut transaction.0.borrow_mut(), index, len)
156
+ let mut tx = transaction.transaction();
157
+ let tx = tx.as_mut().unwrap();
158
+
159
+ let arr = self.0.borrow_mut();
160
+ arr.remove_range(tx, index, len)
134
161
  }
135
- pub(crate) fn yarray_to_a(&self) -> RArray {
136
- let arr = self
137
- .0
138
- .borrow_mut()
139
- .iter()
162
+ pub(crate) fn yarray_to_a(&self, transaction: &YTransaction) -> RArray {
163
+ let arr = self.0.borrow();
164
+ let tx = transaction.transaction();
165
+ let tx = tx.as_ref().unwrap();
166
+
167
+ let arr = arr
168
+ .iter(tx)
140
169
  .map(|v| YValue::from(v).into())
141
170
  .collect::<Vec<Value>>();
142
171
 
@@ -146,3 +175,9 @@ impl YArray {
146
175
  self.0.borrow_mut().unobserve(subscription_id);
147
176
  }
148
177
  }
178
+
179
+ impl From<ArrayRef> for YArray {
180
+ fn from(v: ArrayRef) -> Self {
181
+ YArray(RefCell::from(v))
182
+ }
183
+ }
@@ -1,6 +1,5 @@
1
1
  use crate::awareness::{Awareness, AwarenessUpdate, Event};
2
- use magnus::block::Proc;
3
- use magnus::{Error, Value};
2
+ use magnus::{block::Proc, exception, Error, Value};
4
3
  use std::borrow::Borrow;
5
4
  use std::cell::RefCell;
6
5
  use std::collections::HashMap;
@@ -25,12 +24,11 @@ impl YAwareness {
25
24
 
26
25
  pub(crate) fn yawareness_apply_update(&self, update: Vec<u8>) -> Result<(), Error> {
27
26
  AwarenessUpdate::decode_v1(update.as_slice())
28
- .map_err(|_error| Error::runtime_error("cannot decode update"))
27
+ .map_err(|_error| Error::new(exception::runtime_error(), "cannot decode update"))
29
28
  .and_then(|value| {
30
- self.0
31
- .borrow_mut()
32
- .apply_update(value)
33
- .map_err(|_error| Error::runtime_error("cannot apply awareness update"))
29
+ self.0.borrow_mut().apply_update(value).map_err(|_error| {
30
+ Error::new(exception::runtime_error(), "cannot apply awareness update")
31
+ })
34
32
  })
35
33
  }
36
34
 
@@ -83,7 +81,12 @@ impl YAwareness {
83
81
  .borrow_mut()
84
82
  .update()
85
83
  .map(|update| update.encode_v1())
86
- .map_err(|_error| Error::runtime_error("cannot create update for current state"))
84
+ .map_err(|_error| {
85
+ Error::new(
86
+ exception::runtime_error(),
87
+ "cannot create update for current state",
88
+ )
89
+ })
87
90
  }
88
91
 
89
92
  pub(crate) fn yawareness_update_with_clients(
@@ -95,7 +98,10 @@ impl YAwareness {
95
98
  .update_with_clients(clients)
96
99
  .map(|update| update.encode_v1())
97
100
  .map_err(|_error| {
98
- Error::runtime_error("cannot create update for current state and given clients")
101
+ Error::new(
102
+ exception::runtime_error(),
103
+ "cannot create update for current state and given clients",
104
+ )
99
105
  })
100
106
  }
101
107
  }