OptionalCow

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() -> OptionalCow<'a, T, Marker>

Constructor returning none.

Source

pub fn new(src: <T as ToOwned>::Owned) -> OptionalCow<'a, T, Marker>

Just a constructor.

Source

pub fn new_with_ref(src: &'a T) -> OptionalCow<'a, T, Marker>

Just a constructor.

Source

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

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) -> OptionalCow<'a, T, Marker>

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

Source§

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

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() -> OptionalCow<'a, T, Marker>

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 BTreeMap<K, V>
where Borrowed: ToOwned + 'static + ?Sized, V: Borrow<Borrowed>, Marker: Clone + Copy + 'static,

Source§

type Key<'k> = &'k K where BTreeMap<K, V>: '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 BTreeMap<K, V>: '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

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 HashMap<K, V>: '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 HashMap<K, V>: '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

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 BTreeSet<V>: '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 BTreeSet<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

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 HashSet<V>: '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 HashSet<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

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 LinkedList<V>: '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 LinkedList<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

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 Vec<V>: '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 Vec<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

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 VecDeque<V>: '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 VecDeque<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

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) -> OptionalCow<'a, T, Marker>

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>) -> OptionalCow<'a, T, Marker>

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>>) -> OptionalCow<'a, T, Marker>

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>) -> Option<Cow<'a, T>>

Converts to this type from the input type.
Source§

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

Source§

fn eq(&self, other: &OptionalCow<'a, T, Marker>) -> 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 + Eq + ?Sized, 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<C, E> EntryToVal<C> for E
where C: Collection<Entry = E>,

Source§

type Val = <C as Collection>::Val

The type of values stored in the collection. This might be distinct from Entry in complex collections. For example, in a HashMap, while Entry might be a ( key, value ) tuple, Val might only be the value part.
Source§

fn entry_to_val(self) -> <E as EntryToVal<C>>::Val

Converts an entry into a value representation specific to the type of collection. This conversion is crucial for handling operations on entries, especially when they need to be treated or accessed as individual values, such as retrieving the value part from a key-value pair in a hash map.
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<'a, T> ToStringWith<WithDebug> for T
where T: Debug + ?Sized,

Source§

fn to_string_with<'s>(&'s self) -> Cow<'s, str>

Converts the type to a string using Debug formatting.

Source§

impl<'a, T> ToStringWith<WithDebugMultiline> for T
where T: Debug + ?Sized,

Source§

fn to_string_with<'s>(&'s self) -> Cow<'s, str>

Converts the type to a string using Debug formatting.

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

impl<C, Val> ValToEntry<C> for Val
where C: CollectionValToEntry<Val>,

Source§

fn val_to_entry(self) -> <C as CollectionValToEntry<Val>>::Entry

Invokes the val_to_entry function of the CollectionValToEntry trait to convert the value to an entry.

Source§

type Entry = <C as CollectionValToEntry<Val>>::Entry

Represents the type of entry that corresponds to the value within the collection. Type Entry is defined by the Collection trait.
Source§

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