pub struct List<T: ?Sized + ListItem<ID>, const ID: u64 = 0> { /* private fields */ }
Expand description
A linked list.
All elements in this linked list will be ListArc
references to the value. Since a value can
only have one ListArc
(for each pair of prev/next pointers), this ensures that the same
prev/next pointers are not used for several linked lists.
§Invariants
- If the list is empty, then
first
is null. Otherwise,first
points at theListLinks
field of the first element in the list. - All prev/next pointers in
ListLinks
fields of items in the list are valid and form a cycle. - For every item in the list, the list owns the associated
ListArc
reference and has exclusive access to theListLinks
field.
Implementations§
Source§impl<T: ?Sized + ListItem<ID>, const ID: u64> List<T, ID>
impl<T: ?Sized + ListItem<ID>, const ID: u64> List<T, ID>
Sourcepub fn push_back(&mut self, item: ListArc<T, ID>)
pub fn push_back(&mut self, item: ListArc<T, ID>)
Add the provided item to the back of the list.
Sourcepub fn push_front(&mut self, item: ListArc<T, ID>)
pub fn push_front(&mut self, item: ListArc<T, ID>)
Add the provided item to the front of the list.
Sourcepub unsafe fn remove(&mut self, item: &T) -> Option<ListArc<T, ID>>
pub unsafe fn remove(&mut self, item: &T) -> Option<ListArc<T, ID>>
Removes the provided item from this list and returns it.
This returns None
if the item is not in the list. (Note that by the safety requirements,
this means that the item is not in any list.)
§Safety
item
must not be in a different linked list (with the same id).
Sourcepub fn push_all_back(&mut self, other: &mut List<T, ID>)
pub fn push_all_back(&mut self, other: &mut List<T, ID>)
Moves all items from other
into self
.
The items of other
are added to the back of self
, so the last item of other
becomes
the last item of self
.
Sourcepub fn cursor_front(&mut self) -> Option<Cursor<'_, T, ID>>
pub fn cursor_front(&mut self) -> Option<Cursor<'_, T, ID>>
Returns a cursor to the first element of the list.
If the list is empty, this returns None
.