Struct OptionalCow

Source
#[repr(transparent)]
pub struct OptionalCow<'a, T, Marker>(pub Option<Cow<'a, T>>, _) where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static;
Expand description

Universal wrapper with transparent option of copy on write reference emphasizing a specific aspect of identity of its internal type.

Tuple Fields§

§0: Option<Cow<'a, T>>

Implementations§

Source§

impl<'a, T, Marker> OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source

pub fn into_owned(&self) -> <T as ToOwned>::Owned
where <T as ToOwned>::Owned: Default,

Creates owned data from borrowed data, usually by cloning.

Source

pub fn is_borrowed(&self) -> bool

Check is it borrowed.

Source

pub fn is_some(&self) -> bool

Check does it have some value.

Source

pub fn none() -> Self

Constructor returning none.

Source

pub fn new(src: <T as ToOwned>::Owned) -> Self

Just a constructor.

Source

pub fn new_with_ref(src: &'a T) -> Self

Just a constructor.

Source

pub fn new_with_inner(src: Option<Cow<'a, T>>) -> Self

Just a constructor.

Source

pub fn inner(self) -> Option<Cow<'a, T>>

Just a constructor.

Methods from Deref<Target = Option<Cow<'a, T>>>§

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<'a, T, Marker> AsRef<Option<Cow<'a, T>>> for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

fn as_ref(&self) -> &Option<Cow<'a, T>>

Converts this type into a shared reference of the (usually inferred) input type.
Source§

impl<'a, T, Marker> Clone for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

fn clone(&self) -> Self

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<'a, T, Marker> Debug for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized + Debug, <T as ToOwned>::Owned: Debug, Marker: Clone + Copy + 'static,

Source§

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

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

impl<'a, T, Marker> Default for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, <T as ToOwned>::Owned: Default, Marker: Clone + Copy + 'static,

Source§

fn default() -> Self

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

impl<'a, T, Marker> Deref for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

type Target = Option<Cow<'a, T>>

The resulting type after dereferencing.
Source§

fn deref(&self) -> &Option<Cow<'a, T>>

Dereferences the value.
Source§

impl<K, V, Borrowed, Marker> Fields<K, OptionalCow<'_, Borrowed, Marker>> for Bmap<K, V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = &'k K where Self: 'k, K: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v, V: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<K, V, Borrowed, Marker> Fields<K, OptionalCow<'_, Borrowed, Marker>> for HashMap<K, V>
where K: Hash + Eq, Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = &'k K where Self: 'k, K: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v, V: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<V, Borrowed, Marker> Fields<usize, OptionalCow<'_, Borrowed, Marker>> for BTreeSet<V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = usize where Self: 'k, usize: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<V, Borrowed, Marker> Fields<usize, OptionalCow<'_, Borrowed, Marker>> for HashSet<V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = usize where Self: 'k, usize: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<V, Borrowed, Marker> Fields<usize, OptionalCow<'_, Borrowed, Marker>> for LinkedList<V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = usize where Self: 'k, usize: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<V, Borrowed, Marker> Fields<usize, OptionalCow<'_, Borrowed, Marker>> for Vec<V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = usize where Self: 'k, usize: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<V, Borrowed, Marker> Fields<usize, OptionalCow<'_, Borrowed, Marker>> for VecDeque<V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = usize where Self: 'k, usize: 'k

The type of key yielded by the iterator, parameterized by a lifetime 'k. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

type Val<'v> = OptionalCow<'v, Borrowed, Marker> where Self: 'v

The type of value yielded by the iterator, parameterized by a lifetime 'v. This ensures the values’ lifetimes are tied to the entity being iterated over.
Source§

fn fields<'s>( &'s self, ) -> impl IteratorTrait<Item = (Self::Key<'s>, Self::Val<'s>)>

Returns an iterator over fields of the specified type within the entity.
Source§

impl<'a, T, Marker> From<&'a T> for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

fn from(src: &'a T) -> Self

Converts to this type from the input type.
Source§

impl<'a, T, Marker> From<Cow<'a, T>> for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

fn from(src: Cow<'a, T>) -> Self

Converts to this type from the input type.
Source§

impl<'a, T, Marker> From<Option<Cow<'a, T>>> for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

fn from(src: Option<Cow<'a, T>>) -> Self

Converts to this type from the input type.
Source§

impl<'a, T, Marker> From<OptionalCow<'a, T, Marker>> for Option<Cow<'a, T>>
where T: ToOwned + ?Sized, Marker: Clone + Copy + 'static,

Source§

fn from(src: OptionalCow<'a, T, Marker>) -> Self

Converts to this type from the input type.
Source§

impl<'a, T, Marker> PartialEq for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized + PartialEq, Marker: Clone + Copy + 'static,

Source§

fn eq(&self, other: &Self) -> 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<'a, T, Marker> Eq for OptionalCow<'a, T, Marker>
where T: ToOwned + ?Sized + Eq, Marker: Clone + Copy + 'static,

Auto Trait Implementations§

§

impl<'a, T, Marker> Freeze for OptionalCow<'a, T, Marker>
where <T as ToOwned>::Owned: Freeze, T: ?Sized,

§

impl<'a, T, Marker> RefUnwindSafe for OptionalCow<'a, T, Marker>

§

impl<'a, T, Marker> Send for OptionalCow<'a, T, Marker>
where <T as ToOwned>::Owned: Send, T: Sync + ?Sized,

§

impl<'a, T, Marker> Sync for OptionalCow<'a, T, Marker>
where <T as ToOwned>::Owned: Sync, T: Sync + ?Sized,

§

impl<'a, T, Marker> Unpin for OptionalCow<'a, T, Marker>
where <T as ToOwned>::Owned: Unpin, T: ?Sized,

§

impl<'a, T, Marker> UnwindSafe for OptionalCow<'a, T, Marker>
where <T as ToOwned>::Owned: UnwindSafe, T: RefUnwindSafe + ?Sized,

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.
Source§

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

Source§

fn type_name(&self) -> &'static str

Return name of type of variable.