Option<T>
This crate provides convenient wrappers for dealing with &mut Option<T>
. There are two main types, OptionGuard
and OptionGuardMut
:
OptionGuard
Using EmptyOptionExt::steal
on an &mut Option<T>
produces the T
from the option as well as an OptionGuard
. If OptionGuard::restore
is not called before the OptionGuard
is dropped, then a panic will occur.
Calling guard.restore()
puts the stolen value back into the original option:
```rust use empty_option::EmptyOptionExt;
// A mutable option, from which we shall steal a value! let mut thing = Some(5);
// Scope so that when we do guard.restore()
, the mutable borrow on thing
will end.
{
// Steal the value - we now have the guard and also a concrete T
from our Option<T>
.
let (guard, five) = thing.steal();
assert_eq!(five, 5);
// Move the value back into `thing` - we're done.
guard.restore(6);
}
// The value is returned by guard.restore()
.
assert_eq!(thing, Some(6));
```
But, if the guard is dropped instead, a runtime panic results.
```rust,shouldpanic use emptyoption::EmptyOptionExt;
let mut thing = Some(5);
let (_, _) = thing.steal();
// Never return the value! ```
Calling .steal()
on a None
immediately panics:
```rust,should_panic let mut thing = None;
// Panics here! let (guard, _) = thing.steal();
guard.restore(5); ```
OptionGuardMut
Using EmptyOptionExt::steal_mut
on an &mut Option<T>
produces an OptionGuardMut
, which dereferences to a T
. To get the inner value out, OptionGuardMut::into_inner
can be called. On Drop
, if the OptionGuardMut
is not consumed with OptionGuardMut::into_inner
, the value in the OptionGuardMut
will be returned to the Option
that it was borrowed from.
Take a value from an option, which is automatically returned:
```rust use empty_option::EmptyOptionExt;
let mut thing = Some(5);
{ let mut stolen = thing.steal_mut();
assert_eq!(*stolen, 5);
*stolen = 6;
}
assert_eq!(thing, Some(6)); ```
If the guard is consumed, the value is never returned.
```rust use empty_option::EmptyOptionExt;
let mut thing = Some(5);
{ // Keep the thing! let stolen = thing.stealmut().intoinner();
assert_eq!(stolen, 5);
}
assert_eq!(thing, None); ```
Calling steal_mut
on a None
immediately panics:
```rust,should_panic
let mut thing: Option
// Panics here! thing.steal_mut(); ```
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.