take_ref

Crates.iotake_ref
lib.rstake_ref
version0.2.0
sourcesrc
created_at2020-09-14 09:30:43.751385
updated_at2020-09-15 03:45:23.202535
descriptionTakeRef, TakeSlice, and TakeString traits enable treating references/slices and values interchangeably. They can be treated as references/slices. And you can take ownership of the value within with a clone performed only as needed.
homepage
repositoryhttps://github.com/bazald/take_ref/
max_upload_size
id288530
size27,791
Mitchell Keith Bloch (bazald)

documentation

README

take_ref

take_ref provides TakeRef, TakeSlice, and TakeString traits which enable treating references/slices and values interchangeably. They can be treated as references/slices. And you can take ownership of the value within with a clone performed only as needed.

An Example

The example take_slice can take in both &[i64] and Vec<i64> instances and refer to them multiple times before finally deciding that it needs to take ownership of a Vec<i64>. At that point if it is a &[i64] a Vec<i64> is constructed from the &[i64]. On the other hand, if it is a Vec<i64> ownership is transferred directly without overhead.

use take_ref::TakeSlice;

fn take_slice(value: impl TakeSlice<i64>) {
    value.as_slice();
    value.as_slice();
    value.take();
}
Commit count: 3

cargo fmt