Enum OptionBool

Source
pub enum OptionBool {
    SomeTrue,
    SomeFalse,
    None,
}
Expand description

The OptionBool type, a space-efficient Option replacement

Variants§

§

SomeTrue

Some(true)

§

SomeFalse

Some(false)

§

None

None

Implementations§

Source§

impl OptionBool

Source

pub fn some(b: bool) -> Self

Create a SomeTrue for true, SomeFalse for false

Source

pub fn none() -> Self

Create a None value.

§Examples
assert_eq!(OptionBool::none(), optional::OptionBool::None);
Source

pub fn is_some(&self) -> bool

Returns true if the option is a Some value.

§Examples
assert!(OptionBool::SomeTrue.is_some());
assert!(OptionBool::SomeFalse.is_some());
assert!(!OptionBool::None.is_some());
Source

pub fn is_none(&self) -> bool

Returns true if the option is a Some value.

§Examples
assert!(!OptionBool::SomeTrue.is_none());
assert!(!OptionBool::SomeFalse.is_none());
assert!(OptionBool::None.is_none());
Source

pub fn expect(&self, msg: &str) -> bool

Unwraps the contained bool, panics on None with given message.

§Panics

if self is None

§Examples

For SomeTrue/SomeFalse, the corresponding bool is returned.

assert!(OptionBool::SomeTrue.expect("FAIL"));
assert!(!OptionBool::SomeFalse.expect("FAIL"));

On None, it panics with the given message.

OptionBool::None.expect("FAIL"); // panics with FAIL
Source

pub fn unwrap(&self) -> bool

Unwraps the contained bool, panics on None.

§Panics

if self is None

§Examples

For SomeTrue/SomeFalse, the corresponding bool is returned.

assert!(OptionBool::SomeTrue.unwrap());
assert!(!OptionBool::SomeFalse.unwrap());

On None, it panics with “unwrap called on None”

OptionBool::None.unwrap(); // panics
Source

pub fn unwrap_or(&self, def: bool) -> bool

Returns the contained bool or a default.

§Examples
assert!(OptionBool::SomeTrue.unwrap_or(false));
assert!(!OptionBool::SomeFalse.unwrap_or(true));
assert!(OptionBool::None.unwrap_or(true));
assert!(!OptionBool::None.unwrap_or(false));
Source

pub fn unwrap_or_else<F>(self, f: F) -> bool
where F: FnOnce() -> bool,

Returns the contained bool or a computed default.

§Examples
assert!(OptionBool::SomeTrue.unwrap_or_else(|| false));
assert!(!OptionBool::SomeFalse.unwrap_or_else(|| panic!()));
assert!(OptionBool::None.unwrap_or_else(|| true));
Source

pub fn map<U, F>(self, f: F) -> Option<U>
where F: FnOnce(bool) -> U,

Maps an OptionBool to an Option<U> by applying the function over the contained bool.

Note that there is also map_bool(..) which works similarly, but returns another OptionBool.

§Examples

Convert the contained bool to a Yes/No message

assert_eq!(Some("Yes"), OptionBool::SomeTrue.map(
    |b| if b { "Yes" } else { "No" }));
Source

pub fn map_bool<F>(self, f: F) -> OptionBool
where F: FnOnce(bool) -> bool,

Maps an OptionBool to another OptionBool by applying the function over the contained bool.

Note that there is also map(..) which works similarly, but returns an Option<bool>.

§Examples

Invert the contained bool

assert_eq!(OptionBool::SomeTrue,
    OptionBool::SomeFalse.map_bool(|b| !b));
Source

pub fn map_or<U, F>(self, default: U, f: F) -> U
where F: FnOnce(bool) -> U,

Maps a value to a U by applying the function or return a default U.

§Examples

Map to a string (as per the daily wtf’s boolean definition):

assert_eq!("True", OptionBool::SomeTrue.map_or("FileNotFound",
    |b| if b { "True" } else { "False" }));
Source

pub fn map_or_else<U, D, F>(self, default: D, f: F) -> U
where D: FnOnce() -> U, F: FnOnce(bool) -> U,

Maps a value to a U by applying the function or return a computed default.

§Examples
assert_eq!("True", OptionBool::SomeTrue.map_or_else(|| "FileNotFound",
    |b| if b { "True" } else { "False" }));
Source

pub fn ok_or<E>(self, err: E) -> Result<bool, E>

Transforms the OptionBool into a Result<bool, E>, mapping SomeX to Ok(X) and None to Err(err).

§Examples
assert_eq!(OptionBool::SomeTrue.ok_or("Ouch"), Ok(true));
assert_eq!(OptionBool::None.ok_or("Ouch"), Err("Ouch"));
Source

pub fn ok_or_else<E, F>(self, err: F) -> Result<bool, E>
where F: FnOnce() -> E,

Transforms the OptionBool into a Result<bool, E>, mapping SomeX to Ok(X) and None to a calculated Err(err).

§Examples
assert_eq!(OptionBool::SomeTrue.ok_or_else(|| something_expensive()), Ok(true));
assert_eq!(OptionBool::None.ok_or_else(|| "Ouch"), Err("Ouch"));
Source

pub fn and<U>(self, optb: Option<U>) -> Option<U>

Returns None if the option is None, otherwise returns optb.

§Examples
assert_eq!(Some(1), OptionBool::SomeTrue.and(Some(1)));
assert_eq!(None, OptionBool::None.and(Some(1)));
let actual : Option<u8> = None;
assert_eq!(None, OptionBool::SomeTrue.and(actual));
Source

pub fn and_bool(self, optb: OptionBool) -> OptionBool

Returns None if the option is None, otherwise returns optb.

§Examples
assert_eq!(OptionBool::SomeTrue,
    OptionBool::SomeFalse.and_bool(OptionBool::SomeTrue));
assert_eq!(OptionBool::None,
    OptionBool::None.and_bool(OptionBool::SomeFalse));
assert_eq!(OptionBool::None,
    OptionBool::SomeTrue.and_bool(OptionBool::None));
Source

pub fn and_then<U, F>(self, f: F) -> Option<U>
where F: FnOnce(bool) -> Option<U>,

returns None if the OptionBool is None, otherwise calls f with the boolean value and returns the result as an Option<U>

Note that there is also and_then_bool(..) which works similarly, but returns another OptionBool.

§Examples
assert_eq!(None, OptionBool::SomeFalse.and_then(
    |x| if x { Some(true) } else { None }));
Source

pub fn and_then_bool<F>(self, f: F) -> OptionBool
where F: FnOnce(bool) -> OptionBool,

returns None if the OptionBool is None, otherwise calls f with the boolean value and returns the result as an OptionBool

Note that there is also and_then(..) which works similarly, but returns an Option<bool>.

§Examples
assert_eq!(OptionBool::None, OptionBool::SomeFalse.and_then_bool(
    |x| if x { OptionBool::SomeTrue } else { OptionBool::None }));
Source

pub fn or(self, optb: Option<bool>) -> Option<bool>

Returns this as Option unless this is None, in which case returns optb.

§Examples
assert_eq!(Some(false), OptionBool::SomeFalse.or(Some(true)));
assert_eq!(Some(true), OptionBool::None.or(Some(true)));
assert_eq!(None, OptionBool::None.or(None));
Source

pub fn or_bool(self, optb: OptionBool) -> OptionBool

Returns this as Option unless this is None, in which case returns optb.

§Examples
assert_eq!(OptionBool::SomeFalse,
    OptionBool::SomeFalse.or_bool(OptionBool::SomeTrue));
assert_eq!(OptionBool::SomeTrue,
    OptionBool::None.or_bool(OptionBool::SomeTrue));
assert_eq!(OptionBool::None,
    OptionBool::None.or_bool(OptionBool::None));
Source

pub fn or_else<F>(self, f: F) -> Option<bool>
where F: FnOnce() -> Option<bool>,

Returns this as Option unless this is None, in which case use the supplied function to calculate the result.

Note that there is also or_else_bool(..) which works similarly, but returns another OptionBool.

§Examples
assert_eq!(Some(false), OptionBool::SomeFalse.or_else(|| Some(true)));
assert_eq!(Some(true), OptionBool::None.or_else(|| Some(true)));
assert_eq!(None, OptionBool::None.or_else(|| None));
Source

pub fn or_else_bool<F>(self, f: F) -> OptionBool
where F: FnOnce() -> OptionBool,

Returns this as Option unless this is None, in which case use the supplied function to calculate the result.

Note that there is also or_else(..) which works similarly, but returns an Option<bool>.

§Examples
assert_eq!(OptionBool::SomeFalse,
    OptionBool::SomeFalse.or_else_bool(|| OptionBool::SomeTrue));
assert_eq!(OptionBool::SomeTrue,
    OptionBool::None.or_else_bool(|| OptionBool::SomeTrue));
assert_eq!(OptionBool::None,
    OptionBool::None.or_else_bool(|| OptionBool::None));
Source

pub fn iter(&self) -> Iter<'_, bool>

return an iterator over all contained (that is zero or one) values.

§Examples
assert_eq!(None, OptionBool::None.iter().next());
assert_eq!(Some(&true), OptionBool::SomeTrue.iter().next());
Source

pub fn as_slice(self) -> &'static [bool]

return a possibly empty slice with the contained value, if any.

§Examples
assert_eq!(&[true], OptionBool::SomeTrue.as_slice());
assert!(OptionBool::None.as_slice().is_empty());
Source

pub fn take(&mut self) -> Option<bool>

Takes the value out of the OptionBool and returns ist as Option<bool>, changing self to None.

Note that there is also take_bool(..) which works similarly, but returns an OptionBool.

§Examples
let mut x = OptionBool::some(true);
assert_eq!(Some(true), x.take());
assert_eq!(OptionBool::None, x);
Source

pub fn take_bool(&mut self) -> OptionBool

Takes the value out of the OptionBool, changing self to None.

Note that there is also take(..) which works similarly, but returns an Option<bool>.

§Examples
let mut x = OptionBool::some(true);
assert_eq!(OptionBool::some(true), x.take_bool());
assert_eq!(OptionBool::None, x);

Methods from Deref<Target = Option<bool>>§

1.0.0 · Source

pub fn is_some(&self) -> bool

Returns true if the option is a Some value.

§Examples
let x: Option<u32> = Some(2);
assert_eq!(x.is_some(), true);

let x: Option<u32> = None;
assert_eq!(x.is_some(), false);
1.0.0 · Source

pub fn is_none(&self) -> bool

Returns true if the option is a None value.

§Examples
let x: Option<u32> = Some(2);
assert_eq!(x.is_none(), false);

let x: Option<u32> = None;
assert_eq!(x.is_none(), true);
1.0.0 · Source

pub fn as_ref(&self) -> Option<&T>

Converts from &Option<T> to Option<&T>.

§Examples

Calculates the length of an Option<String> as an Option<usize> without moving the String. The map method takes the self argument by value, consuming the original, so this technique uses as_ref to first take an Option to a reference to the value inside the original.

let text: Option<String> = Some("Hello, world!".to_string());
// First, cast `Option<String>` to `Option<&String>` with `as_ref`,
// then consume *that* with `map`, leaving `text` on the stack.
let text_length: Option<usize> = text.as_ref().map(|s| s.len());
println!("still can print text: {text:?}");
1.33.0 · Source

pub fn as_pin_ref(self: Pin<&Option<T>>) -> Option<Pin<&T>>

Converts from Pin<&Option<T>> to Option<Pin<&T>>.

1.33.0 · Source

pub fn as_pin_mut(self: Pin<&mut Option<T>>) -> Option<Pin<&mut T>>

Converts from Pin<&mut Option<T>> to Option<Pin<&mut T>>.

1.75.0 · Source

pub fn as_slice(&self) -> &[T]

Returns a slice of the contained value, if any. If this is None, an empty slice is returned. This can be useful to have a single type of iterator over an Option or slice.

Note: Should you have an Option<&T> and wish to get a slice of T, you can unpack it via opt.map_or(&[], std::slice::from_ref).

§Examples
assert_eq!(
    [Some(1234).as_slice(), None.as_slice()],
    [&[1234][..], &[][..]],
);

The inverse of this function is (discounting borrowing) [_]::first:

for i in [Some(1234_u16), None] {
    assert_eq!(i.as_ref(), i.as_slice().first());
}
1.40.0 · Source

pub fn as_deref(&self) -> Option<&<T as Deref>::Target>
where T: Deref,

Converts from Option<T> (or &Option<T>) to Option<&T::Target>.

Leaves the original Option in-place, creating a new one with a reference to the original one, additionally coercing the contents via Deref.

§Examples
let x: Option<String> = Some("hey".to_owned());
assert_eq!(x.as_deref(), Some("hey"));

let x: Option<String> = None;
assert_eq!(x.as_deref(), None);
1.0.0 · Source

pub fn iter(&self) -> Iter<'_, T>

Returns an iterator over the possibly contained value.

§Examples
let x = Some(4);
assert_eq!(x.iter().next(), Some(&4));

let x: Option<u32> = None;
assert_eq!(x.iter().next(), None);

Trait Implementations§

Source§

impl Clone for OptionBool

Source§

fn clone(&self) -> OptionBool

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for OptionBool

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for OptionBool

OptionBool defaults to None.

Source§

fn default() -> OptionBool

Returns the “default value” for a type. Read more
Source§

impl Deref for OptionBool

We can deref-coerce to Option<bool>

Source§

type Target = Option<bool>

The resulting type after dereferencing.
Source§

fn deref(&self) -> &'static Option<bool>

Dereferences the value.
Source§

impl<'a> From<&'a Option<bool>> for OptionBool

Source§

fn from(o: &'a Option<bool>) -> Self

Converts to this type from the input type.
Source§

impl<'a> From<&'a OptionBool> for Option<bool>

Source§

fn from(o: &'a OptionBool) -> Option<bool>

Converts to this type from the input type.
Source§

impl From<Option<bool>> for OptionBool

Source§

fn from(o: Option<bool>) -> Self

Converts to this type from the input type.
Source§

impl From<OptionBool> for Option<bool>

Source§

fn from(o: OptionBool) -> Option<bool>

Converts to this type from the input type.
Source§

impl Hash for OptionBool

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl Index<RangeFull> for OptionBool

Index for RangeFull (to slice)

Source§

type Output = [bool]

The returned type after indexing.
Source§

fn index<'a>(&'a self, _: RangeFull) -> &'static [bool]

Performs the indexing (container[index]) operation. Read more
Source§

impl IntoIterator for OptionBool

IntoIterator works as expected

§Examples

let mut pass : bool = false;
for b in OptionBool::SomeTrue { pass = b; }
assert!(pass);

for b in OptionBool::None { assert!(false); }
Source§

type Item = bool

The type of the elements being iterated over.
Source§

type IntoIter = IterBool

Which kind of iterator are we turning this into?
Source§

fn into_iter(self) -> IterBool

Creates an iterator from a value. Read more
Source§

impl Ord for OptionBool

Source§

fn cmp(&self, other: &OptionBool) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · Source§

fn max(self, other: Self) -> Self
where Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · Source§

fn min(self, other: Self) -> Self
where Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · Source§

fn clamp(self, min: Self, max: Self) -> Self
where Self: Sized,

Restrict a value to a certain interval. Read more
Source§

impl<'a> PartialEq<OptionBool> for &'a OptionBool

Source§

fn eq(&self, other: &OptionBool) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialEq for OptionBool

Source§

fn eq(&self, other: &OptionBool) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialOrd for OptionBool

Some(true) > Some(false) > None

Source§

fn partial_cmp(&self, other: &OptionBool) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · Source§

fn lt(&self, other: &Rhs) -> bool

Tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · Source§

fn le(&self, other: &Rhs) -> bool

Tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · Source§

fn gt(&self, other: &Rhs) -> bool

Tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · Source§

fn ge(&self, other: &Rhs) -> bool

Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
Source§

impl Copy for OptionBool

Source§

impl Eq for OptionBool

Source§

impl StructuralPartialEq for OptionBool

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<P, T> Receiver for P
where P: Deref<Target = T> + ?Sized, T: ?Sized,

Source§

type Target = T

🔬This is a nightly-only experimental API. (arbitrary_self_types)
The target type on which the method may be called.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.