On this page
Struct std::collections::linked_list::Cursor
pub struct Cursor<'a, T, A = Global>
where
T: 'a,
A: Allocator,{ /* private fields */ }
linked_list_cursors #58533)
A cursor over a LinkedList.
A Cursor is like an iterator, except that it can freely seek back-and-forth.
Cursors always rest between two elements in the list, and index in a logically circular way. To accommodate this, there is a “ghost” non-element that yields None between the head and tail of the list.
When created, cursors start at the front of the list, or the “ghost” non-element if the list is empty.
Implementations
impl<'a, T, A> Cursor<'a, T, A>
where
A: Allocator,
pub fn index(&self) -> Option<usize>
linked_list_cursors #58533)
Returns the cursor position index within the LinkedList.
This returns None if the cursor is currently pointing to the “ghost” non-element.
pub fn move_next(&mut self)
linked_list_cursors #58533)
Moves the cursor to the next element of the LinkedList.
If the cursor is pointing to the “ghost” non-element then this will move it to the first element of the LinkedList. If it is pointing to the last element of the LinkedList then this will move it to the “ghost” non-element.
pub fn move_prev(&mut self)
linked_list_cursors #58533)
Moves the cursor to the previous element of the LinkedList.
If the cursor is pointing to the “ghost” non-element then this will move it to the last element of the LinkedList. If it is pointing to the first element of the LinkedList then this will move it to the “ghost” non-element.
pub fn current(&self) -> Option<&'a T>
linked_list_cursors #58533)
Returns a reference to the element that the cursor is currently pointing to.
This returns None if the cursor is currently pointing to the “ghost” non-element.
pub fn peek_next(&self) -> Option<&'a T>
linked_list_cursors #58533)
Returns a reference to the next element.
If the cursor is pointing to the “ghost” non-element then this returns the first element of the LinkedList. If it is pointing to the last element of the LinkedList then this returns None.
pub fn peek_prev(&self) -> Option<&'a T>
linked_list_cursors #58533)
Returns a reference to the previous element.
If the cursor is pointing to the “ghost” non-element then this returns the last element of the LinkedList. If it is pointing to the first element of the LinkedList then this returns None.
pub fn front(&self) -> Option<&'a T>
linked_list_cursors #58533)
Provides a reference to the front element of the cursor’s parent list, or None if the list is empty.
pub fn back(&self) -> Option<&'a T>
linked_list_cursors #58533)
Provides a reference to the back element of the cursor’s parent list, or None if the list is empty.
Trait Implementations
impl<T, A> Clone for Cursor<'_, T, A>
where
A: Allocator,
fn clone(&self) -> Cursor<'_, T, A>
fn clone_from(&mut self, source: &Self)
source. Read more
impl<T, A> Debug for Cursor<'_, T, A>
where
T: Debug,
A: Allocator,
fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>
impl<T, A> Send for Cursor<'_, T, A>
where
T: Sync,
A: Allocator + Sync,
impl<T, A> Sync for Cursor<'_, T, A>
where
T: Sync,
A: Allocator + Sync,
Auto Trait Implementations
impl<'a, T, A> RefUnwindSafe for Cursor<'a, T, A>
where
A: RefUnwindSafe,
T: RefUnwindSafe,
impl<'a, T, A> Unpin for Cursor<'a, T, A>
impl<'a, T, A> UnwindSafe for Cursor<'a, T, A>
where
A: RefUnwindSafe,
T: RefUnwindSafe,
Blanket Implementations
impl<T> Any for T
where
T: 'static + ?Sized,
impl<T> Borrow<T> for T
where
T: ?Sized,
impl<T> BorrowMut<T> for T
where
T: ?Sized,
impl<T> From<T> for T
fn from(t: T) -> T
Returns the argument unchanged.
impl<T, U> Into<U> for T
where
U: From<T>,
fn into(self) -> U
Calls U::from(self).
That is, this conversion is whatever the implementation of From<T> for U chooses to do.
impl<T> ToOwned for T
where
T: Clone,
type Owned = T
fn to_owned(&self) -> T
fn clone_into(&self, target: &mut T)
impl<T, U> TryFrom<U> for T
where
U: Into<T>,
type Error = Infallible
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
impl<T, U> TryInto<U> for T
where
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
© 2010 The Rust Project Developers
Licensed under the Apache License, Version 2.0 or the MIT license, at your option.
https://doc.rust-lang.org/std/collections/linked_list/struct.Cursor.html