| Crates.io | empty-box |
| lib.rs | empty-box |
| version | 0.1.1 |
| created_at | 2017-06-01 19:40:12.652752+00 |
| updated_at | 2017-06-01 19:42:01.76112+00 |
| description | Allows for `Box`s to have their values moved out and replaced with new values, while reusing the same allocation. |
| homepage | https://github.com/sdleffler/empty-box-rs |
| repository | https://github.com/sdleffler/empty-box-rs |
| max_upload_size | |
| id | 17230 |
| size | 17,248 |
EmptyBox, a way to safely move values in and out of Boxs withoutreallocations
EmptyBox is similar to a statically checked Box<Option<T>>:
use empty_box::EmptyBox;
// A box with a string!
let boxed = Box::new("Hello!".to_string());
// Oh no, we don't like that string.
let (string, empty) = EmptyBox::take(boxed);
// Let's make an objectively superior string, and put it into the original
// box.
let superior = "Objectively superior string!".to_string();
// Now we have our superior string in the box!
let boxed = empty.put(superior);
assert_eq!("Hello!", string);
assert_eq!("Objectively superior string!", &*boxed);
Creating an EmptyBox from a Box and then putting a T back into the
EmptyBox will avoid allocating a new Box, instead reusing whatever old
Box the T was EmptyBox::taken from.
Licensed under either of
at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.