Crates.io | owning_ref_lockable |
lib.rs | owning_ref_lockable |
version | 0.4.2 |
source | src |
created_at | 2022-04-11 05:12:34.999647 |
updated_at | 2022-04-11 05:12:34.999647 |
description | A library for creating references that carry their owner with them. |
homepage | |
repository | https://github.com/Kimundi/owning-ref-rs |
max_upload_size | |
id | 565397 |
size | 144,741 |
This is a fork of https://github.com/Kimundi/owning-ref-rs with a couple of fixes needed for https://github.com/smessmer/lockable
A library for creating references that carry their owner with them.
This can sometimes be useful because Rust borrowing rules normally prevent moving a type that has been borrowed from. For example, this kind of code gets rejected:
fn return_owned_and_referenced<'a>() -> (Vec<u8>, &'a [u8]) {
let v = vec![1, 2, 3, 4];
let s = &v[1..3];
(v, s)
}
This library enables this safe usage by keeping the owner and the reference bundled together in a wrapper type that ensure that lifetime constraint:
fn return_owned_and_referenced() -> OwningRef<Vec<u8>, [u8]> {
let v = vec![1, 2, 3, 4];
let or = OwningRef::new(v);
let or = or.map(|v| &v[1..3]);
or
}
To get started, add the following to Cargo.toml
.
owning_ref = "0.4.1"
...and see the docs for how to use it.
extern crate owning_ref;
use owning_ref::BoxRef;
fn main() {
// Create an array owned by a Box.
let arr = Box::new([1, 2, 3, 4]) as Box<[i32]>;
// Transfer into a BoxRef.
let arr: BoxRef<[i32]> = BoxRef::new(arr);
assert_eq!(&*arr, &[1, 2, 3, 4]);
// We can slice the array without losing ownership or changing type.
let arr: BoxRef<[i32]> = arr.map(|arr| &arr[1..3]);
assert_eq!(&*arr, &[2, 3]);
// Also works for Arc, Rc, String and Vec!
}