pub struct NEOrderedSet<T: Ord>(/* private fields */);Expand description
An ordered non-empty set type guaranteeing at least one element.
Implementations§
Source§impl<T: Ord> NEOrderedSet<T>
impl<T: Ord> NEOrderedSet<T>
Sourcepub fn new(head: T, tail: Vec<T>) -> Self
pub fn new(head: T, tail: Vec<T>) -> Self
Creates a new non-empty ordered set from one element and optional additional elements.
Sourcepub fn from(set: BTreeSet<T>) -> Result<Self, NonEmptyError>
pub fn from(set: BTreeSet<T>) -> Result<Self, NonEmptyError>
Attempts to create a non-empty ordered set from a BTreeSet. Returns an error if the provided set is empty.
Sourcepub fn insert(&mut self, value: T) -> bool
pub fn insert(&mut self, value: T) -> bool
Adds an element. Returns true if the set did not already contain the value.
Trait Implementations§
Source§impl<T: Clone + Ord> Clone for NEOrderedSet<T>
impl<T: Clone + Ord> Clone for NEOrderedSet<T>
Source§fn clone(&self) -> NEOrderedSet<T>
fn clone(&self) -> NEOrderedSet<T>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl<T: Ord> From<NEOrderedSet<T>> for BTreeSet<T>
impl<T: Ord> From<NEOrderedSet<T>> for BTreeSet<T>
Source§fn from(set: NEOrderedSet<T>) -> Self
fn from(set: NEOrderedSet<T>) -> Self
Converts to this type from the input type.
Source§impl<'a, T: Ord> IntoIterator for &'a NEOrderedSet<T>
impl<'a, T: Ord> IntoIterator for &'a NEOrderedSet<T>
Source§impl<T: Ord> IntoIterator for NEOrderedSet<T>
impl<T: Ord> IntoIterator for NEOrderedSet<T>
Source§impl<T: Ord + Ord> Ord for NEOrderedSet<T>
impl<T: Ord + Ord> Ord for NEOrderedSet<T>
Source§fn cmp(&self, other: &NEOrderedSet<T>) -> Ordering
fn cmp(&self, other: &NEOrderedSet<T>) -> Ordering
1.21.0 · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Compares and returns the maximum of two values. Read more
Source§impl<T: PartialOrd + Ord> PartialOrd for NEOrderedSet<T>
impl<T: PartialOrd + Ord> PartialOrd for NEOrderedSet<T>
impl<T: Eq + Ord> Eq for NEOrderedSet<T>
impl<T: Ord> StructuralPartialEq for NEOrderedSet<T>
Auto Trait Implementations§
impl<T> Freeze for NEOrderedSet<T>
impl<T> RefUnwindSafe for NEOrderedSet<T>where
T: RefUnwindSafe,
impl<T> Send for NEOrderedSet<T>where
T: Send,
impl<T> Sync for NEOrderedSet<T>where
T: Sync,
impl<T> Unpin for NEOrderedSet<T>
impl<T> UnwindSafe for NEOrderedSet<T>where
T: RefUnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more