Tiny Rust library that exports Handle<T>
and RCHandle<T>
. Can be useful for wrapping native ffi structs/pointers.
Both Handle
and RCHandle
implement Clone
, where Handle
will clone the underlying struct instance (if it implements Clone
), and RCHandle
will keep the underlying pointer.
Handle
and RCHandle
implement Send
/Sync
by default with the send_sync
feature.
They both implement Deref
and DerefMut
, so you can access a field through a handle the same as you normally would on a normal instance.
Handle<T>
```rust
struct Animal { is_dog: bool, }
let animal = Animal { isdog: false }; let cat = Handle::frominstance(animal);
// clone cat
and mutate is_dog
, note that animal
is not mutable
let dog = handle.clone(); // this clones Animal
, Animal
must implement Clone
dog.is_dog = true;
```
RCHandle<T>
(reference-counted handle)```rust // don't have to #[derive(Clone)] here! struct Animal { is_dog: bool, }
let mut animal = Animal { isdog: false }; let mut handle = RCHandle::fromptr(&mut animal);
// note that Animal
does not implement Clone
, because
// cloning an RCHandle
does not clone the underlying type
let mut handle2 = handle.clone();
handle2.isdog = true; assert!(handle.isdog == handle2.is_dog); ```
To run tests, run cargo test
.
Public domain (unlicense).