6个稳定版本
7.3.5 | 2023年4月3日 |
---|---|
7.3.4 | 2023年3月29日 |
341 在 过程宏 中排名
每月72次下载
14KB
264 行
crdts_derive
使用方法
添加依赖
将 crdts
、crdts_derive
和 serde
依赖添加到 Cargo.toml
[dependencies]
crdts = "7.3"
crdts_derive = "7.3"
serde = { version = "1.0", features = [ "derive" ] }
自定义CRDT结构体
use crdts::{GCounter, Map, Orswot};
use crdts_derive::crdt;
use serde::{Deserialize, Serialize};
#[crdt(u64)]
#[derive(Default, Debug, Clone, Serialize, Deserialize)]
pub struct Data {
a: Orswot<String, String>,
b: Map<u64, Orswot<Vec<u8>, u64>, u64>,
c: Orswot<Vec<u8>, u64>,
d: GCounter<u64>,
}
使用此结构体
#[test]
fn test() {
use crdts::{CmRDT, CvRDT, Dot};
let mut data1 = Data::default();
let mut data2 = data1.clone();
let actor = 1;
let counter = 1;
let dot = Dot::new(actor, counter);
let op1 = data1.a.add(
format!("{actor}-{counter}"),
data1.a.read().derive_add_ctx(actor.to_string()),
);
let add_ctx = data1.b.read_ctx().derive_add_ctx(actor);
let op2 = data1
.b
.update(actor, add_ctx, |v, a| v.add(vec![actor as u8; 20], a));
let op3 = data1
.c
.add(vec![actor as u8; 20], data1.c.read().derive_add_ctx(actor));
let op4 = data1.d.inc(actor);
data1.apply(DataCrdtOp {
dot,
a_op: Some(op1),
b_op: Some(op2),
c_op: Some(op3),
d_op: Some(op4),
});
println!("data1: {:#?}", data1);
let actor = 2;
let counter = 1;
let dot = Dot::new(actor, counter);
let op1 = data2.a.add(
format!("{actor}-{counter}"),
data2.a.read().derive_add_ctx(actor.to_string()),
);
let add_ctx = data2.b.read_ctx().derive_add_ctx(actor);
let op2 = data2
.b
.update(actor, add_ctx, |v, a| v.add(vec![actor as u8; 20], a));
let op3 = data2
.c
.add(vec![actor as u8; 20], data2.c.read().derive_add_ctx(actor));
let op4 = data2.d.inc(actor);
data2.apply(DataCrdtOp {
dot,
a_op: Some(op1),
b_op: Some(op2),
c_op: Some(op3),
d_op: Some(op4),
});
println!("data2: {:#?}", data2);
data1.merge(data2);
println!("data3: {:#?}", data1);
}
兼容的crdts版本
crdts_derive
版本的兼容性
crdts_derive |
crdts |
---|---|
7.3 |
7.3 |
依赖
~0.8–1.4MB
~26K SLoC