y-rb 0.1.2 → 0.1.4.alpha.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/ext/yrb/Cargo.lock +623 -0
- data/{Cargo.toml → ext/yrb/Cargo.toml} +7 -10
- data/ext/yrb/extconf.rb +6 -0
- data/ext/yrb/src/lib.rs +476 -0
- data/ext/yrb/src/utils.rs +36 -0
- data/ext/yrb/src/yany.rs +44 -0
- data/ext/yrb/src/yarray.rs +175 -0
- data/ext/yrb/src/yattrs.rs +48 -0
- data/ext/yrb/src/ydoc.rs +39 -0
- data/ext/yrb/src/ymap.rs +165 -0
- data/ext/yrb/src/ytext.rs +228 -0
- data/ext/yrb/src/ytransaction.rs +58 -0
- data/ext/yrb/src/yvalue.rs +235 -0
- data/ext/yrb/src/yxml_element.rs +225 -0
- data/ext/yrb/src/yxml_text.rs +154 -0
- data/lib/y/doc.rb +2 -2
- data/lib/y/text.rb +9 -7
- data/lib/y/version.rb +1 -1
- data/lib/y.rb +16 -0
- metadata +70 -41
- data/.dockerignore +0 -5
- data/.editorconfig +0 -16
- data/.rspec +0 -3
- data/.rubocop.yml +0 -23
- data/.rustfmt.toml +0 -74
- data/.yardopts +0 -2
- data/Gemfile +0 -13
- data/Gemfile.lock +0 -75
- data/LICENSE.txt +0 -21
- data/README.md +0 -98
- data/Rakefile +0 -39
- data/bin/console +0 -15
- data/bin/setup +0 -8
- data/docs/decisions.md +0 -64
- data/docs/examples.md +0 -16
- data/docs/release.md +0 -9
- data/ext/Rakefile +0 -9
- data/lib/y/rb.rb +0 -17
- data/src/lib.rs +0 -248
- data/src/util.rs +0 -146
- data/src/yarray.rs +0 -184
- data/src/ydoc.rs +0 -71
- data/src/ymap.rs +0 -199
- data/src/ytext.rs +0 -204
- data/src/ytransaction.rs +0 -102
- data/src/yxml.rs +0 -550
- data/y-rb.gemspec +0 -44
data/src/yarray.rs
DELETED
@@ -1,184 +0,0 @@
|
|
1
|
-
use crate::util::{map_ruby_type_to_rust, map_yrs_value_to_ruby};
|
2
|
-
use crate::ytransaction::{YTransaction, TRANSACTION_WRAPPER};
|
3
|
-
use rutie::{
|
4
|
-
AnyObject, Array as RArray, Fixnum, Hash, Integer, NilClass, Object, Proc,
|
5
|
-
Symbol, VM
|
6
|
-
};
|
7
|
-
use yrs::types::{Change, Value};
|
8
|
-
use yrs::{Array, SubscriptionId};
|
9
|
-
|
10
|
-
wrappable_struct!(Array, ArrayWrapper, ARRAY_WRAPPER);
|
11
|
-
class!(YArray);
|
12
|
-
|
13
|
-
#[rustfmt::skip]
|
14
|
-
methods!(
|
15
|
-
YArray,
|
16
|
-
rtself,
|
17
|
-
fn yarray_each(block: Proc) -> NilClass {
|
18
|
-
let b = block.map_err(|e| VM::raise_ex(e)).unwrap();
|
19
|
-
|
20
|
-
let a: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
21
|
-
|
22
|
-
a
|
23
|
-
.iter()
|
24
|
-
.for_each(|val| {
|
25
|
-
let args = [map_yrs_value_to_ruby(val)];
|
26
|
-
b.call(&args);
|
27
|
-
});
|
28
|
-
|
29
|
-
NilClass::new()
|
30
|
-
},
|
31
|
-
fn yarray_get(index: Fixnum) -> AnyObject {
|
32
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
33
|
-
|
34
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
35
|
-
let val = arr.get(i.to_u32());
|
36
|
-
|
37
|
-
map_yrs_value_to_ruby(val.unwrap())
|
38
|
-
},
|
39
|
-
fn yarray_insert(
|
40
|
-
transaction: YTransaction,
|
41
|
-
index: Fixnum,
|
42
|
-
value: AnyObject) -> NilClass {
|
43
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
44
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
45
|
-
|
46
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
47
|
-
|
48
|
-
let val = value.map_err(|e| VM::raise_ex(e)).unwrap();
|
49
|
-
let v = map_ruby_type_to_rust(val).unwrap();
|
50
|
-
|
51
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
52
|
-
arr.insert(tx, i.to_u32(), v);
|
53
|
-
|
54
|
-
NilClass::new()
|
55
|
-
},
|
56
|
-
fn yarray_insert_range(
|
57
|
-
transaction: YTransaction,
|
58
|
-
index: Fixnum,
|
59
|
-
values: RArray) -> NilClass {
|
60
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
61
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
62
|
-
|
63
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
64
|
-
|
65
|
-
let values = values.map_err(|e| VM::raise_ex(e)).unwrap();
|
66
|
-
let mapped_values = values
|
67
|
-
.into_iter()
|
68
|
-
.map(|value| map_ruby_type_to_rust(value).unwrap() )
|
69
|
-
.collect::<Vec<_>>();
|
70
|
-
|
71
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
72
|
-
arr.insert_range(tx, i.to_u32(), mapped_values);
|
73
|
-
|
74
|
-
NilClass::new()
|
75
|
-
},
|
76
|
-
fn yarray_length() -> Fixnum {
|
77
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
78
|
-
Fixnum::new(i64::from(arr.len()))
|
79
|
-
},
|
80
|
-
fn yarray_observe(callback: Proc) -> Integer {
|
81
|
-
let c = callback.map_err(|e| VM::raise_ex(e)).unwrap();
|
82
|
-
|
83
|
-
let arr: &mut Array = rtself.get_data_mut(&*ARRAY_WRAPPER);
|
84
|
-
let subscription_id: SubscriptionId = arr
|
85
|
-
.observe(move |transaction, array_event| {
|
86
|
-
let delta = array_event.delta(transaction);
|
87
|
-
let mut changes: Vec<AnyObject> = Vec::new();
|
88
|
-
|
89
|
-
for change in delta {
|
90
|
-
match change {
|
91
|
-
Change::Added(v) => {
|
92
|
-
let mut payload = Hash::new();
|
93
|
-
let values = v.iter().map(|v| map_yrs_value_to_ruby(v.clone()) ).collect::<Vec<_>>();
|
94
|
-
payload.store(Symbol::new("added"), RArray::from_iter(values));
|
95
|
-
|
96
|
-
changes.push(payload.to_any_object());
|
97
|
-
},
|
98
|
-
Change::Retain(position) => {
|
99
|
-
let mut payload = Hash::new();
|
100
|
-
payload.store(Symbol::new("retain"), Integer::from(*position));
|
101
|
-
|
102
|
-
changes.push(payload.to_any_object());
|
103
|
-
},
|
104
|
-
Change::Removed(position) => {
|
105
|
-
let mut payload = Hash::new();
|
106
|
-
payload.store(Symbol::new("removed"), Integer::from(*position));
|
107
|
-
|
108
|
-
changes.push(payload.to_any_object());
|
109
|
-
}
|
110
|
-
}
|
111
|
-
}
|
112
|
-
|
113
|
-
let args = &[RArray::from_iter(changes).to_any_object()];
|
114
|
-
c.call(args);
|
115
|
-
})
|
116
|
-
.into();
|
117
|
-
|
118
|
-
Integer::from(subscription_id)
|
119
|
-
},
|
120
|
-
fn yarray_push_back(transaction: YTransaction, value: AnyObject) -> NilClass {
|
121
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
122
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
123
|
-
|
124
|
-
let val = value.map_err(|e| VM::raise_ex(e)).unwrap();
|
125
|
-
let v = map_ruby_type_to_rust(val).unwrap();
|
126
|
-
|
127
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
128
|
-
arr.push_back(tx, v);
|
129
|
-
|
130
|
-
NilClass::new()
|
131
|
-
},
|
132
|
-
fn yarray_push_front(transaction: YTransaction, value: AnyObject) -> NilClass {
|
133
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
134
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
135
|
-
|
136
|
-
let val = value.map_err(|e| VM::raise_ex(e)).unwrap();
|
137
|
-
let v = map_ruby_type_to_rust(val).unwrap();
|
138
|
-
|
139
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
140
|
-
arr.push_front(tx, v);
|
141
|
-
|
142
|
-
NilClass::new()
|
143
|
-
},
|
144
|
-
fn yarray_remove(transaction: YTransaction, index: Fixnum) -> NilClass {
|
145
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
146
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
147
|
-
|
148
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
149
|
-
|
150
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
151
|
-
arr.remove(tx, i.to_u32());
|
152
|
-
|
153
|
-
NilClass::new()
|
154
|
-
},
|
155
|
-
fn yarray_remove_range(
|
156
|
-
transaction: YTransaction,
|
157
|
-
index: Fixnum,
|
158
|
-
length: Fixnum) -> NilClass {
|
159
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
160
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
161
|
-
|
162
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
163
|
-
let l = length.map_err(|e| VM::raise_ex(e)).unwrap();
|
164
|
-
|
165
|
-
let arr: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
166
|
-
arr.remove_range(tx, i.to_u32(), l.to_u32());
|
167
|
-
|
168
|
-
NilClass::new()
|
169
|
-
},
|
170
|
-
fn yarray_to_a() -> RArray {
|
171
|
-
let v: &Array = rtself.get_data(&*ARRAY_WRAPPER);
|
172
|
-
map_yrs_value_to_ruby(Value::YArray(v.clone()))
|
173
|
-
.try_convert_to::<RArray>()
|
174
|
-
.unwrap()
|
175
|
-
}
|
176
|
-
fn yarray_unobserve(subscription_id: Integer) -> NilClass {
|
177
|
-
let s = subscription_id.map_err(|e| VM::raise_ex(e)).unwrap();
|
178
|
-
|
179
|
-
let arr: &mut Array = rtself.get_data_mut(&*ARRAY_WRAPPER);
|
180
|
-
arr.unobserve(s.into());
|
181
|
-
|
182
|
-
NilClass::new()
|
183
|
-
}
|
184
|
-
);
|
data/src/ydoc.rs
DELETED
@@ -1,71 +0,0 @@
|
|
1
|
-
use crate::util::{convert_array_to_vecu8, convert_vecu8_to_array};
|
2
|
-
use crate::ytransaction::TRANSACTION_WRAPPER;
|
3
|
-
use rutie::rubysys::class;
|
4
|
-
use rutie::types::{Argc, Value};
|
5
|
-
use rutie::util::str_to_cstring;
|
6
|
-
use rutie::{AnyObject, Array, Integer, Module, Object};
|
7
|
-
use std::mem;
|
8
|
-
use yrs::updates::decoder::Decode;
|
9
|
-
use yrs::{Doc, OffsetKind, Options, StateVector};
|
10
|
-
|
11
|
-
wrappable_struct!(Doc, DocWrapper, DOC_WRAPPER);
|
12
|
-
class!(YDoc);
|
13
|
-
|
14
|
-
methods!(
|
15
|
-
YDoc,
|
16
|
-
rtself,
|
17
|
-
fn ydoc_transact() -> AnyObject {
|
18
|
-
let doc = rtself.get_data(&*DOC_WRAPPER);
|
19
|
-
let transaction = doc.transact();
|
20
|
-
|
21
|
-
Module::from_existing("Y")
|
22
|
-
.get_nested_class("Transaction")
|
23
|
-
.wrap_data(transaction, &*TRANSACTION_WRAPPER)
|
24
|
-
},
|
25
|
-
fn ydoc_encode_diff_v1(state_vector: Array) -> Array {
|
26
|
-
let mut doc: &Doc = rtself.get_data_mut(&*DOC_WRAPPER);
|
27
|
-
let state_vector_encoded: Vec<u8> =
|
28
|
-
convert_array_to_vecu8(state_vector.unwrap());
|
29
|
-
|
30
|
-
let result = &StateVector::decode_v1(state_vector_encoded.as_slice());
|
31
|
-
let sv = match result {
|
32
|
-
Ok(sv) => sv,
|
33
|
-
Err(error) => {
|
34
|
-
panic!("decoding the state vector failed: {:?}", error)
|
35
|
-
}
|
36
|
-
};
|
37
|
-
|
38
|
-
let update = doc.encode_state_as_update_v1(sv);
|
39
|
-
convert_vecu8_to_array(update)
|
40
|
-
}
|
41
|
-
);
|
42
|
-
|
43
|
-
pub extern "C" fn ydoc_new(
|
44
|
-
argc: Argc,
|
45
|
-
argv: *const AnyObject,
|
46
|
-
_rtself: AnyObject,
|
47
|
-
) -> AnyObject {
|
48
|
-
let args = Value::from(0);
|
49
|
-
|
50
|
-
unsafe {
|
51
|
-
let p_argv: *const Value = mem::transmute(argv);
|
52
|
-
|
53
|
-
class::rb_scan_args(argc, p_argv, str_to_cstring("*").as_ptr(), &args)
|
54
|
-
};
|
55
|
-
|
56
|
-
let arguments = Array::from(args);
|
57
|
-
let client_id = arguments.at(0).try_convert_to::<Integer>();
|
58
|
-
|
59
|
-
let mut options = Options::default();
|
60
|
-
if let Ok(c_id) = client_id {
|
61
|
-
options.client_id = c_id.into();
|
62
|
-
};
|
63
|
-
// make sure we treat offsets for codepoints not bytes
|
64
|
-
options.offset_kind = OffsetKind::Utf32;
|
65
|
-
|
66
|
-
let doc = Doc::with_options(options);
|
67
|
-
|
68
|
-
Module::from_existing("Y")
|
69
|
-
.get_nested_class("Doc")
|
70
|
-
.wrap_data(doc, &*DOC_WRAPPER)
|
71
|
-
}
|
data/src/ymap.rs
DELETED
@@ -1,199 +0,0 @@
|
|
1
|
-
use crate::util::{map_ruby_type_to_rust, map_yrs_value_to_ruby};
|
2
|
-
use crate::ytransaction::{YTransaction, TRANSACTION_WRAPPER};
|
3
|
-
use lib0::any::Any;
|
4
|
-
use rutie::{
|
5
|
-
AnyObject, Array, Boolean, Class, Fixnum, Hash, Integer, NilClass, Object,
|
6
|
-
Proc, RString, Symbol, VM
|
7
|
-
};
|
8
|
-
use std::rc::Rc;
|
9
|
-
use yrs::types::EntryChange;
|
10
|
-
use yrs::{Map, SubscriptionId};
|
11
|
-
|
12
|
-
wrappable_struct!(Map, MapWrapper, MAP_WRAPPER);
|
13
|
-
class!(YMap);
|
14
|
-
|
15
|
-
#[rustfmt::skip]
|
16
|
-
methods!(
|
17
|
-
YMap,
|
18
|
-
rtself,
|
19
|
-
fn ymap_clear(transaction: YTransaction) -> NilClass {
|
20
|
-
let mut tx = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
21
|
-
let txn = tx.get_data_mut(&*TRANSACTION_WRAPPER);
|
22
|
-
|
23
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
24
|
-
m.clear(txn);
|
25
|
-
|
26
|
-
NilClass::new()
|
27
|
-
},
|
28
|
-
fn ymap_contains(key: AnyObject) -> Boolean {
|
29
|
-
let k = key.map_err(|e| VM::raise_ex(e)).unwrap();
|
30
|
-
|
31
|
-
let k2 = if let Ok(t) = k.try_convert_to::<Symbol>() {
|
32
|
-
t.to_string()
|
33
|
-
} else if let Ok(t) = k.try_convert_to::<RString>() {
|
34
|
-
t.to_string()
|
35
|
-
} else {
|
36
|
-
VM::raise(Class::from_existing("IllegalArgumentError"), "Only strings and symbols are supported as map keys.");
|
37
|
-
return Boolean::new(false);
|
38
|
-
};
|
39
|
-
|
40
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
41
|
-
let result = m.contains(&k2);
|
42
|
-
|
43
|
-
Boolean::new(result)
|
44
|
-
},
|
45
|
-
fn ymap_each(block: Proc) -> NilClass {
|
46
|
-
let b = block.map_err(|e| VM::raise_ex(e)).unwrap();
|
47
|
-
|
48
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
49
|
-
|
50
|
-
m
|
51
|
-
.iter()
|
52
|
-
.for_each(|(key, val)| {
|
53
|
-
let args = [
|
54
|
-
RString::new_utf8(key).to_any_object(),
|
55
|
-
map_yrs_value_to_ruby(val)
|
56
|
-
];
|
57
|
-
b.call(&args);
|
58
|
-
});
|
59
|
-
|
60
|
-
NilClass::new()
|
61
|
-
},
|
62
|
-
fn ymap_get(key: AnyObject) -> AnyObject {
|
63
|
-
let k = key.map_err(|e| VM::raise_ex(e)).unwrap();
|
64
|
-
|
65
|
-
let k2 = if let Ok(t) = k.try_convert_to::<Symbol>() {
|
66
|
-
t.to_string()
|
67
|
-
} else if let Ok(t) = k.try_convert_to::<RString>() {
|
68
|
-
t.to_string()
|
69
|
-
} else {
|
70
|
-
VM::raise(Class::from_existing("IllegalArgumentError"), "Only strings and symbols are supported as map keys.");
|
71
|
-
return NilClass::new().to_any_object();
|
72
|
-
};
|
73
|
-
|
74
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
75
|
-
let result = m.get(&k2);
|
76
|
-
|
77
|
-
map_yrs_value_to_ruby(result.unwrap_or(yrs::types::Value::Any(Any::Null)))
|
78
|
-
},
|
79
|
-
fn ymap_insert(transaction: YTransaction, key: AnyObject, value: AnyObject) -> AnyObject {
|
80
|
-
let mut tx = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
81
|
-
let k = key.map_err(|e| VM::raise_ex(e)).unwrap();
|
82
|
-
let v = value.map_err(|e| VM::raise_ex(e)).unwrap();
|
83
|
-
|
84
|
-
let k2 = if let Ok(t) = k.try_convert_to::<Symbol>() {
|
85
|
-
t.to_string()
|
86
|
-
} else if let Ok(t) = k.try_convert_to::<RString>() {
|
87
|
-
t.to_string()
|
88
|
-
} else {
|
89
|
-
VM::raise(Class::from_existing("IllegalArgumentError"), "Only strings and symbols are supported as map keys.");
|
90
|
-
return NilClass::new().to_any_object();
|
91
|
-
};
|
92
|
-
|
93
|
-
let txn = tx.get_data_mut(&*TRANSACTION_WRAPPER);
|
94
|
-
|
95
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
96
|
-
|
97
|
-
let result = m.insert(
|
98
|
-
txn,
|
99
|
-
Rc::from(k2),
|
100
|
-
map_ruby_type_to_rust(v).unwrap()
|
101
|
-
);
|
102
|
-
|
103
|
-
map_yrs_value_to_ruby(result.unwrap_or(yrs::types::Value::Any(Any::Null)))
|
104
|
-
},
|
105
|
-
fn ymap_observe(callback: Proc) -> Integer {
|
106
|
-
let c = callback.map_err(|e| VM::raise_ex(e)).unwrap();
|
107
|
-
|
108
|
-
let map: &mut Map = rtself.get_data_mut(&*MAP_WRAPPER);
|
109
|
-
let subscription_id: SubscriptionId = map
|
110
|
-
.observe(move |transaction, map_event| {
|
111
|
-
let delta = map_event.keys(transaction);
|
112
|
-
let mut changes: Vec<AnyObject> = Vec::new();
|
113
|
-
|
114
|
-
for (key, change) in delta {
|
115
|
-
match change {
|
116
|
-
EntryChange::Inserted(v) => {
|
117
|
-
let mut h = Hash::new();
|
118
|
-
h.store(Symbol::new(&key.to_string()), map_yrs_value_to_ruby(v.clone()));
|
119
|
-
|
120
|
-
let mut payload = Hash::new();
|
121
|
-
payload.store(Symbol::new("inserted"), h);
|
122
|
-
|
123
|
-
changes.push(payload.to_any_object());
|
124
|
-
},
|
125
|
-
EntryChange::Updated(old, new) => {
|
126
|
-
let mut values = Array::with_capacity(2);
|
127
|
-
values.push(map_yrs_value_to_ruby(old.clone()));
|
128
|
-
values.push(map_yrs_value_to_ruby(new.clone()));
|
129
|
-
|
130
|
-
let mut h = Hash::new();
|
131
|
-
h.store(Symbol::new(&key.to_string()), values);
|
132
|
-
|
133
|
-
let mut payload = Hash::new();
|
134
|
-
payload.store(Symbol::new("updated"), h);
|
135
|
-
|
136
|
-
changes.push(payload.to_any_object());
|
137
|
-
},
|
138
|
-
EntryChange::Removed(v) => {
|
139
|
-
let mut h = Hash::new();
|
140
|
-
h.store(Symbol::new(&key.to_string()), map_yrs_value_to_ruby(v.clone()));
|
141
|
-
|
142
|
-
let mut payload = Hash::new();
|
143
|
-
payload.store(Symbol::new("removed"), h);
|
144
|
-
|
145
|
-
changes.push(payload.to_any_object());
|
146
|
-
}
|
147
|
-
}
|
148
|
-
}
|
149
|
-
|
150
|
-
let args = &[Array::from_iter(changes).to_any_object()];
|
151
|
-
c.call(args);
|
152
|
-
})
|
153
|
-
.into();
|
154
|
-
|
155
|
-
Integer::from(subscription_id)
|
156
|
-
},
|
157
|
-
fn ymap_remove(transaction: YTransaction, key: AnyObject) -> AnyObject {
|
158
|
-
let mut tx = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
159
|
-
let k = key.map_err(|e| VM::raise_ex(e)).unwrap();
|
160
|
-
|
161
|
-
let k2 = if let Ok(t) = k.try_convert_to::<Symbol>() {
|
162
|
-
t.to_string()
|
163
|
-
} else if let Ok(t) = k.try_convert_to::<RString>() {
|
164
|
-
t.to_string()
|
165
|
-
} else {
|
166
|
-
VM::raise(Class::from_existing("IllegalArgumentError"), "Only strings and symbols are supported as map keys.");
|
167
|
-
return NilClass::new().to_any_object();
|
168
|
-
};
|
169
|
-
|
170
|
-
let txn = tx.get_data_mut(&*TRANSACTION_WRAPPER);
|
171
|
-
|
172
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
173
|
-
let result = m.remove(txn, &k2);
|
174
|
-
|
175
|
-
map_yrs_value_to_ruby(result.unwrap_or(yrs::types::Value::Any(Any::Null)))
|
176
|
-
},
|
177
|
-
fn ymap_size() -> Fixnum {
|
178
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
179
|
-
Fixnum::new(i64::from(m.len()))
|
180
|
-
},
|
181
|
-
fn ymap_to_hash() -> Hash {
|
182
|
-
let m: &Map = rtself.get_data(&*MAP_WRAPPER);
|
183
|
-
let mut h = Hash::new();
|
184
|
-
|
185
|
-
for (key, val) in m.iter() {
|
186
|
-
h.store(Symbol::new(key), map_yrs_value_to_ruby(val));
|
187
|
-
}
|
188
|
-
|
189
|
-
h
|
190
|
-
},
|
191
|
-
fn ymap_unobserve(subscription_id: Integer) -> NilClass {
|
192
|
-
let s = subscription_id.map_err(|e| VM::raise_ex(e)).unwrap();
|
193
|
-
|
194
|
-
let map: &mut Map = rtself.get_data_mut(&*MAP_WRAPPER);
|
195
|
-
map.unobserve(s.into());
|
196
|
-
|
197
|
-
NilClass::new()
|
198
|
-
}
|
199
|
-
);
|
data/src/ytext.rs
DELETED
@@ -1,204 +0,0 @@
|
|
1
|
-
use crate::util::{
|
2
|
-
map_attrs_to_hash, map_hash_to_attrs, map_ruby_type_to_rust,
|
3
|
-
map_yrs_value_to_ruby
|
4
|
-
};
|
5
|
-
use crate::ytransaction::{YTransaction, TRANSACTION_WRAPPER};
|
6
|
-
use rutie::{
|
7
|
-
AnyObject, Fixnum, Hash, Integer, NilClass, Object, Proc, RString, Symbol,
|
8
|
-
VM
|
9
|
-
};
|
10
|
-
use yrs::types::Delta;
|
11
|
-
use yrs::{SubscriptionId, Text};
|
12
|
-
|
13
|
-
wrappable_struct!(Text, TextWrapper, TEXT_WRAPPER);
|
14
|
-
class!(YText);
|
15
|
-
|
16
|
-
#[rustfmt::skip]
|
17
|
-
methods!(
|
18
|
-
YText,
|
19
|
-
rtself,
|
20
|
-
fn ytext_insert(transaction: YTransaction, index: Fixnum, chunk: RString) -> NilClass {
|
21
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
22
|
-
|
23
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
24
|
-
|
25
|
-
let c = chunk.map_err(|e| VM::raise_ex(e)).unwrap().to_string();
|
26
|
-
|
27
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
28
|
-
let text: &Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
29
|
-
|
30
|
-
text.insert(tx, i.to_u32(), &c);
|
31
|
-
|
32
|
-
NilClass::new()
|
33
|
-
},
|
34
|
-
fn ytext_insert_embed(
|
35
|
-
transaction: YTransaction,
|
36
|
-
index: Fixnum,
|
37
|
-
content: AnyObject) -> NilClass {
|
38
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
39
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
40
|
-
|
41
|
-
let c = content.map_err(|e| VM::raise_ex(e)).unwrap();
|
42
|
-
let v = map_ruby_type_to_rust(c).map_err(|e| VM::raise_ex(e)).unwrap();
|
43
|
-
|
44
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
45
|
-
let text: &Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
46
|
-
|
47
|
-
text.insert_embed(tx, i.to_u32(), v);
|
48
|
-
|
49
|
-
NilClass::new()
|
50
|
-
}
|
51
|
-
fn ytext_insert_embed_with_attributes(
|
52
|
-
transaction: YTransaction,
|
53
|
-
index: Fixnum,
|
54
|
-
embed: AnyObject,
|
55
|
-
attrs: Hash) -> NilClass {
|
56
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
57
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
58
|
-
|
59
|
-
let c = embed.map_err(|e| VM::raise_ex(e)).unwrap();
|
60
|
-
let v = map_ruby_type_to_rust(c).map_err(|e| VM::raise_ex(e)).unwrap();
|
61
|
-
|
62
|
-
let a = attrs.map_err(|e| VM::raise_ex(e)).unwrap();
|
63
|
-
let mapped_attrs = map_hash_to_attrs(a);
|
64
|
-
|
65
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
66
|
-
let text: &Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
67
|
-
|
68
|
-
text.insert_embed_with_attributes(tx, i.to_u32(), v, mapped_attrs);
|
69
|
-
|
70
|
-
NilClass::new()
|
71
|
-
}
|
72
|
-
fn ytext_insert_with_attributes(
|
73
|
-
transaction: YTransaction,
|
74
|
-
index: Fixnum,
|
75
|
-
chunk: RString,
|
76
|
-
attrs: Hash) -> NilClass {
|
77
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
78
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
79
|
-
|
80
|
-
let c = chunk.map_err(|e| VM::raise_ex(e)).unwrap().to_string();
|
81
|
-
|
82
|
-
let a = attrs.map_err(|e| VM::raise_ex(e)).unwrap();
|
83
|
-
let mapped_attrs = map_hash_to_attrs(a);
|
84
|
-
|
85
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
86
|
-
let text: &Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
87
|
-
|
88
|
-
text.insert_with_attributes(tx, i.to_u32(), &c, mapped_attrs);
|
89
|
-
|
90
|
-
NilClass::new()
|
91
|
-
},
|
92
|
-
fn ytext_length() -> Fixnum {
|
93
|
-
let text = rtself.get_data(&*TEXT_WRAPPER);
|
94
|
-
|
95
|
-
Fixnum::new(i64::from(text.len()))
|
96
|
-
}
|
97
|
-
fn ytext_push(transaction: YTransaction, value: RString) -> NilClass {
|
98
|
-
let value_str = value.map_err(|e| VM::raise_ex(e)).unwrap().to_string();
|
99
|
-
|
100
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
101
|
-
|
102
|
-
let t = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
103
|
-
let text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
104
|
-
|
105
|
-
text.push(t, &value_str);
|
106
|
-
|
107
|
-
NilClass::new()
|
108
|
-
},
|
109
|
-
fn ytext_remove_range(transaction: YTransaction, index: Fixnum, length: Fixnum) -> NilClass {
|
110
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
111
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
112
|
-
let l = length.map_err(|e| VM::raise_ex(e)).unwrap();
|
113
|
-
|
114
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
115
|
-
let text: &Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
116
|
-
|
117
|
-
text.remove_range(tx, i.to_u32(), l.to_u32());
|
118
|
-
|
119
|
-
NilClass::new()
|
120
|
-
},
|
121
|
-
fn ytext_format(transaction: YTransaction, index: Fixnum, length: Fixnum, attrs: Hash) -> NilClass {
|
122
|
-
let mut txn = transaction.map_err(|e| VM::raise_ex(e)).unwrap();
|
123
|
-
let i = index.map_err(|e| VM::raise_ex(e)).unwrap();
|
124
|
-
let l = length.map_err(|e| VM::raise_ex(e)).unwrap();
|
125
|
-
|
126
|
-
let a = attrs.map_err(|e| VM::raise_ex(e)).unwrap();
|
127
|
-
let mapped_attrs = map_hash_to_attrs(a);
|
128
|
-
|
129
|
-
let tx = txn.get_data_mut(&*TRANSACTION_WRAPPER);
|
130
|
-
let text: &Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
131
|
-
|
132
|
-
text.format(tx, i.to_u32(), l.to_u32(), mapped_attrs);
|
133
|
-
|
134
|
-
NilClass::new()
|
135
|
-
},
|
136
|
-
fn ytext_observe(callback: Proc) -> Integer {
|
137
|
-
let c = callback.map_err(|e| VM::raise_ex(e)).unwrap();
|
138
|
-
|
139
|
-
let text: &mut Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
140
|
-
let subscription_id: SubscriptionId = text
|
141
|
-
.observe(move |transaction, text_event| {
|
142
|
-
let delta = text_event.delta(transaction);
|
143
|
-
for event in delta {
|
144
|
-
match event {
|
145
|
-
Delta::Inserted(v, attrs) => {
|
146
|
-
let mut payload = Hash::new();
|
147
|
-
payload.store(Symbol::new("insert"), map_yrs_value_to_ruby(v.clone()));
|
148
|
-
|
149
|
-
match attrs {
|
150
|
-
Some(a) => {
|
151
|
-
let copy = a.clone();
|
152
|
-
let result = map_attrs_to_hash(*copy).to_any_object();
|
153
|
-
payload.store(Symbol::new("attributes"), result);
|
154
|
-
},
|
155
|
-
None => ()
|
156
|
-
}
|
157
|
-
|
158
|
-
let args = &[payload.to_any_object()];
|
159
|
-
c.call(args);
|
160
|
-
},
|
161
|
-
Delta::Retain(position, attrs) => {
|
162
|
-
let mut payload = Hash::new();
|
163
|
-
payload.store(Symbol::new("retain"), Integer::from(*position));
|
164
|
-
|
165
|
-
match attrs {
|
166
|
-
Some(a) => {
|
167
|
-
let copy = a.clone();
|
168
|
-
let result = map_attrs_to_hash(*copy).to_any_object();
|
169
|
-
payload.store(Symbol::new("attributes"), result);
|
170
|
-
},
|
171
|
-
None => ()
|
172
|
-
}
|
173
|
-
|
174
|
-
let args = &[payload.to_any_object()];
|
175
|
-
c.call(args);
|
176
|
-
},
|
177
|
-
Delta::Deleted(position) => {
|
178
|
-
let mut payload = Hash::new();
|
179
|
-
payload.store(Symbol::new("delete"), Integer::from(*position));
|
180
|
-
|
181
|
-
let args = &[payload.to_any_object()];
|
182
|
-
c.call(args);
|
183
|
-
}
|
184
|
-
}
|
185
|
-
}
|
186
|
-
})
|
187
|
-
.into();
|
188
|
-
|
189
|
-
Integer::from(subscription_id)
|
190
|
-
},
|
191
|
-
fn ytext_to_string() -> RString {
|
192
|
-
let text = rtself.get_data(&*TEXT_WRAPPER);
|
193
|
-
|
194
|
-
RString::new_utf8(&text.to_string())
|
195
|
-
},
|
196
|
-
fn ytext_unobserve(subscription_id: Integer) -> NilClass {
|
197
|
-
let s = subscription_id.map_err(|e| VM::raise_ex(e)).unwrap();
|
198
|
-
|
199
|
-
let text: &mut Text = rtself.get_data_mut(&*TEXT_WRAPPER);
|
200
|
-
text.unobserve(s.into());
|
201
|
-
|
202
|
-
NilClass::new()
|
203
|
-
}
|
204
|
-
);
|