Skip to main content

LabelSet

Struct LabelSet 

Source
pub struct LabelSet(/* private fields */);
Expand description

Shared, copy-on-write set of labels carried by one record.

Wraps an Arc<BTreeSet<LabelId>>. Cloning a record — and therefore the overlay delta maps that hold records, which a fresh writer seeds by cloning its parent’s — shares the same allocation instead of deep-copying the set. The first Self::insert into a SHARED set copies it once (Arc::make_mut); a uniquely owned set mutates in place. The serde representation is the plain label set, unchanged from the owned form.

§Performance

clone is O(1) (an Arc increment). Self::insert is O(log labels) plus a one-time O(labels) copy when the set is still shared (copy-on-write). Self::contains is O(log labels); Self::len and Self::is_empty are O(1).

Implementations§

Source§

impl LabelSet

Source

pub fn iter(&self) -> impl Iterator<Item = LabelId> + '_

Iterates the labels in ascending order.

§Performance

Creating the iterator is O(1); a full walk is O(labels).

Source

pub fn contains(&self, label: &LabelId) -> bool

Returns whether label is present.

§Performance

This method is O(log labels).

Source

pub fn len(&self) -> usize

Returns the number of labels.

§Performance

This method is O(1).

Source

pub fn is_empty(&self) -> bool

Returns whether the set is empty.

§Performance

This method is O(1).

Source

pub fn insert(&mut self, label: LabelId) -> bool

Inserts label, returning whether it was newly added.

A no-op insert (the label is already present) never copies, so re-asserting a label on a record whose set is still shared with a parent overlay stays O(log labels).

§Performance

This method is O(log labels), plus a one-time O(labels) copy-on-write when the set is shared and the label is new.

Trait Implementations§

Source§

impl Clone for LabelSet

Source§

fn clone(&self) -> LabelSet

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for LabelSet

Source§

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

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

impl Default for LabelSet

Source§

fn default() -> LabelSet

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

impl<'de> Deserialize<'de> for LabelSet

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Eq for LabelSet

Source§

impl FromIterator<LabelId> for LabelSet

Source§

fn from_iter<I: IntoIterator<Item = LabelId>>(iter: I) -> Self

Collects labels into a freshly owned (unshared) set.

§Performance

This function is O(labels × log labels).

Source§

impl PartialEq for LabelSet

Source§

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

Tests for self and other values to be equal, and is used by ==.
1.0.0 (const: unstable) · 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 Serialize for LabelSet

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for LabelSet

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<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

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> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> ErasedDestructor for T
where T: 'static,

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<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

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.