2023-10-30 03:13:52 +00:00
|
|
|
use std::time::Instant;
|
|
|
|
|
2024-09-09 08:16:02 +00:00
|
|
|
use loro_internal::{LoroDoc, TreeParentId};
|
2023-10-30 03:13:52 +00:00
|
|
|
use rand::{rngs::StdRng, Rng};
|
|
|
|
|
2024-05-07 06:01:13 +00:00
|
|
|
#[allow(unused)]
|
2023-11-05 07:53:33 +00:00
|
|
|
fn checkout() {
|
|
|
|
let depth = 300;
|
2024-07-12 08:15:54 +00:00
|
|
|
let loro = LoroDoc::new_auto_commit();
|
2023-11-05 07:53:33 +00:00
|
|
|
let tree = loro.get_tree("tree");
|
|
|
|
let mut ids = vec![];
|
|
|
|
let mut versions = vec![];
|
2024-09-09 08:16:02 +00:00
|
|
|
let id1 = tree.create_at(TreeParentId::Root, 0).unwrap();
|
2023-11-05 07:53:33 +00:00
|
|
|
ids.push(id1);
|
|
|
|
versions.push(loro.oplog_frontiers());
|
|
|
|
for _ in 1..depth {
|
2024-09-09 08:16:02 +00:00
|
|
|
let id = tree
|
|
|
|
.create_at(TreeParentId::Node(*ids.last().unwrap()), 0)
|
|
|
|
.unwrap();
|
2023-11-05 07:53:33 +00:00
|
|
|
ids.push(id);
|
|
|
|
versions.push(loro.oplog_frontiers());
|
|
|
|
}
|
|
|
|
let mut rng: StdRng = rand::SeedableRng::seed_from_u64(0);
|
|
|
|
|
|
|
|
for _ in 0..1000 {
|
|
|
|
let i = rng.gen::<usize>() % depth;
|
|
|
|
let f = &versions[i];
|
|
|
|
loro.checkout(f).unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[allow(unused)]
|
|
|
|
fn mov() {
|
2024-05-07 06:01:13 +00:00
|
|
|
let loro = LoroDoc::new_auto_commit();
|
2023-10-30 03:13:52 +00:00
|
|
|
let tree = loro.get_tree("tree");
|
|
|
|
let mut ids = vec![];
|
|
|
|
let size = 10000;
|
|
|
|
for _ in 0..size {
|
2024-09-09 08:16:02 +00:00
|
|
|
ids.push(tree.create_at(TreeParentId::Root, 0).unwrap())
|
2023-10-30 03:13:52 +00:00
|
|
|
}
|
|
|
|
let mut rng: StdRng = rand::SeedableRng::seed_from_u64(0);
|
2024-05-07 06:01:13 +00:00
|
|
|
let n = 100000;
|
2023-10-30 03:13:52 +00:00
|
|
|
|
|
|
|
for _ in 0..n {
|
|
|
|
let i = rng.gen::<usize>() % size;
|
|
|
|
let j = rng.gen::<usize>() % size;
|
2024-09-09 08:16:02 +00:00
|
|
|
let children_num = tree.children_num(&TreeParentId::Node(ids[j])).unwrap_or(0);
|
|
|
|
tree.move_to(ids[i], TreeParentId::Node(ids[j]), children_num)
|
2023-11-28 08:22:43 +00:00
|
|
|
.unwrap_or_default();
|
2023-10-30 03:13:52 +00:00
|
|
|
}
|
2024-05-07 06:01:13 +00:00
|
|
|
println!("encode snapshot size {:?}", loro.export_snapshot().len());
|
|
|
|
println!(
|
|
|
|
"encode updates size {:?}",
|
|
|
|
loro.export_from(&Default::default()).len()
|
|
|
|
);
|
2023-11-05 07:53:33 +00:00
|
|
|
}
|
2024-05-07 06:01:13 +00:00
|
|
|
|
|
|
|
#[allow(unused)]
|
|
|
|
fn create() {
|
|
|
|
let size = 100000;
|
|
|
|
let loro = LoroDoc::default();
|
|
|
|
let tree = loro.get_tree("tree");
|
|
|
|
for _ in 0..size {
|
2024-09-09 08:16:02 +00:00
|
|
|
tree.create_at(TreeParentId::Root, 0).unwrap();
|
2023-11-05 07:53:33 +00:00
|
|
|
}
|
2024-05-07 06:01:13 +00:00
|
|
|
println!("encode snapshot size {:?}\n", loro.export_snapshot().len());
|
|
|
|
println!(
|
|
|
|
"encode updates size {:?}",
|
|
|
|
loro.export_from(&Default::default()).len()
|
|
|
|
);
|
|
|
|
}
|
2023-11-05 07:53:33 +00:00
|
|
|
|
2024-05-07 06:01:13 +00:00
|
|
|
fn main() {
|
|
|
|
let s = Instant::now();
|
|
|
|
mov();
|
2023-10-30 03:13:52 +00:00
|
|
|
println!("{} ms", s.elapsed().as_millis());
|
|
|
|
}
|