Struct intrusive_collections::rbtree::Cursor

source ·
pub struct Cursor<'a, A: Adapter>
where A::LinkOps: RBTreeOps,
{ /* private fields */ }
Expand description

A cursor which provides read-only access to a RBTree.

Implementations§

source§

impl<'a, A: Adapter> Cursor<'a, A>
where A::LinkOps: RBTreeOps,

source

pub fn is_null(&self) -> bool

Checks if the cursor is currently pointing to the null object.

source

pub fn get(&self) -> Option<&'a <A::PointerOps as PointerOps>::Value>

Returns a reference to the object that the cursor is currently pointing to.

This returns None if the cursor is currently pointing to the null object.

source

pub fn clone_pointer(&self) -> Option<<A::PointerOps as PointerOps>::Pointer>

Clones and returns the pointer that points to the element that the cursor is referencing.

This returns None if the cursor is currently pointing to the null object.

source

pub fn move_next(&mut self)

Moves the cursor to the next element of the RBTree.

If the cursor is pointer to the null object then this will move it to the first element of the RBTree. If it is pointing to the last element of the RBTree then this will move it to the null object.

source

pub fn move_prev(&mut self)

Moves the cursor to the previous element of the RBTree.

If the cursor is pointer to the null object then this will move it to the last element of the RBTree. If it is pointing to the first element of the RBTree then this will move it to the null object.

source

pub fn peek_next(&self) -> Cursor<'_, A>

Returns a cursor pointing to the next element of the RBTree.

If the cursor is pointer to the null object then this will return the first element of the RBTree. If it is pointing to the last element of the RBTree then this will return a null cursor.

source

pub fn peek_prev(&self) -> Cursor<'_, A>

Returns a cursor pointing to the previous element of the RBTree.

If the cursor is pointer to the null object then this will return the last element of the RBTree. If it is pointing to the first element of the RBTree then this will return a null cursor.

Trait Implementations§

source§

impl<'a, A: Adapter> Clone for Cursor<'a, A>
where A::LinkOps: RBTreeOps,

source§

fn clone(&self) -> Cursor<'a, A>

Returns a copy of the value. Read more
1.0.0 · source§

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

Performs copy-assignment from source. Read more

Auto Trait Implementations§

§

impl<'a, A> Freeze for Cursor<'a, A>
where <<A as Adapter>::LinkOps as LinkOps>::LinkPtr: Freeze,

§

impl<'a, A> RefUnwindSafe for Cursor<'a, A>

§

impl<'a, A> Send for Cursor<'a, A>
where <<A as Adapter>::LinkOps as LinkOps>::LinkPtr: Send, A: Sync, <<A as Adapter>::PointerOps as PointerOps>::Value: Sync,

§

impl<'a, A> Sync for Cursor<'a, A>
where <<A as Adapter>::LinkOps as LinkOps>::LinkPtr: Sync, A: Sync, <<A as Adapter>::PointerOps as PointerOps>::Value: Sync,

§

impl<'a, A> Unpin for Cursor<'a, A>
where <<A as Adapter>::LinkOps as LinkOps>::LinkPtr: Unpin,

§

impl<'a, A> UnwindSafe for Cursor<'a, A>

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, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. 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> 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.