That aims to be simple and straightforward to use when sharing data between threads.
An attempt at creating an Arc-RwLock combination that is straightforward to use and no hassle , instead of worrying about being fast and lean.
```rust use cura::Cura; trait Foo:Send+Sync { fn get(&self)->i32; fn set(&mut self,i:i32); }
struct FF{i:i32,}; struct BB{i:i32};
impl Foo for FF{ fn get(&self)->i32{return self.i;} fn set(&mut self,i:i32){self.i=i;} }
impl Foo for BB{ fn get(&self)->i32{return self.i;} fn set(&mut self,i:i32){self.i=i;} }
let t=FF{i:1};
// you can do straight "frombox" but currently its impossible to
// "alter" unsized types
let foo2:Cura
{ asserteq!(a.read().get(),1); { a.alter(|s|{ s.set(2); Some(()) }); } { a.alter(|s|{ //this only works for Sized types *s=Box::new(BB{i:2}); Some(()) }); } let lock=a.read(); let v=lock; asserteq!(v.get(),2) }//lock dropped here { (*b.write()).set(3); //lock dropped here i think }
assert_eq!((*a.read()).get(),3);
```