bitstring_trees::tree

Enum InsertPositionWith

source
pub enum InsertPositionWith<N> {
    BelowLeaf(N),
    AlreadyExists(N),
    ReplaceNode(N),
}
Expand description

Result of finding position to insert a target key

Variants§

§

BelowLeaf(N)

Found node that is a leaf; its key is a prefix of the target key (but not equal to it)

Inserting the target key must convert the found node into an inner node and insert the target key as leaf.

§

AlreadyExists(N)

Found node with target key

§

ReplaceNode(N)

Found node to replace with target key

Parent node is a prefix of target key, but this node is not.

To insert a new node needs to replace the current one, using the shared prefix of this node and the target key as node key. (This node key could still be the target key.)

Trait Implementations§

source§

impl<N: Debug> Debug for InsertPositionWith<N>

source§

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

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

impl<N> From<InsertPositionWith<N>> for InsertPosition

source§

fn from(value: InsertPositionWith<N>) -> Self

Converts to this type from the input type.

Auto Trait Implementations§

§

impl<N> Freeze for InsertPositionWith<N>
where N: Freeze,

§

impl<N> RefUnwindSafe for InsertPositionWith<N>
where N: RefUnwindSafe,

§

impl<N> Send for InsertPositionWith<N>
where N: Send,

§

impl<N> Sync for InsertPositionWith<N>
where N: Sync,

§

impl<N> Unpin for InsertPositionWith<N>
where N: Unpin,

§

impl<N> UnwindSafe for InsertPositionWith<N>
where N: UnwindSafe,

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> 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, 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.