pub struct List<T> { /* private fields */ }Expand description
A singly linked list. See the crate-level documentation for more.
Implementations§
Source§impl<T> List<T>
impl<T> List<T>
Sourcepub fn push(&mut self, element: T)
pub fn push(&mut self, element: T)
Prepends an element to the beginning of the List.
§Examples
use cons_rs::List;
let mut list = List::new();
list.push(1);
assert_eq!(list.peek(), Some(&1));
list.push(2);
assert_eq!(list.peek(), Some(&2));Sourcepub fn pop(&mut self) -> Option<T>
pub fn pop(&mut self) -> Option<T>
Removes the element at the front of the List,
and returns it.
§Examples
use cons_rs::List;
let mut list = List::new();
assert_eq!(list.pop(), None);
list.push(1);
assert_eq!(list.pop(), Some(1));
assert_eq!(list.pop(), None);Sourcepub fn is_empty(&self) -> bool
pub fn is_empty(&self) -> bool
Checks if the List is empty.
§Examples
use cons_rs::List;
let mut list = List::new();
assert!(list.is_empty());
list.push(1);
assert!(!list.is_empty());Sourcepub fn clear(&mut self)
pub fn clear(&mut self)
Removes all elements from the List.
§Examples
use cons_rs::List;
let mut list = List::new();
list.push(1);
list.push(2);
list.clear();
assert!(list.is_empty());Sourcepub fn len(&self) -> usize
pub fn len(&self) -> usize
Returns the length of the List.
§Examples
use cons_rs::List;
let mut list = List::new();
assert_eq!(list.len(), 0);
list.push(1);
assert_eq!(list.len(), 1);Sourcepub fn peek(&self) -> Option<&T>
pub fn peek(&self) -> Option<&T>
Returns an immutable reference to the value
at the head of the List, if it exists.
§Examples
use cons_rs::List;
let mut list = List::new();
assert_eq!(list.peek(), None);
list.push(1);
assert_eq!(list.peek(), Some(&1));Sourcepub fn peek_mut(&mut self) -> Option<&mut T>
pub fn peek_mut(&mut self) -> Option<&mut T>
Returns a mutable reference to the value
at the head of the List, if it exists.
§Examples
use cons_rs::List;
let mut list = List::new();
assert_eq!(list.peek_mut(), None);
list.push(1);
assert_eq!(list.peek_mut(), Some(&mut 1));
*list.peek_mut().unwrap() = 50;
assert_eq!(list.peek_mut(), Some(&mut 50));Sourcepub fn iter(&self) -> Iter<'_, T> ⓘ
pub fn iter(&self) -> Iter<'_, T> ⓘ
Creates an iterator that yields shared references
to all the elements in the List.
To get mutable references, see iter_mut.
§Examples
use cons_rs::List;
let mut list = List::new();
list.push(1);
list.push(2);
let mut iter = list.iter();
assert_eq!(iter.next(), Some(&2));
assert_eq!(iter.next(), Some(&1));
assert_eq!(iter.next(), None);Sourcepub fn iter_mut(&mut self) -> IterMut<'_, T> ⓘ
pub fn iter_mut(&mut self) -> IterMut<'_, T> ⓘ
Creates an iterator that yields mutable references
to all the elements in the List.
To get shared references, see iter.
§Examples
use cons_rs::List;
let mut list = List::new();
list.push(1);
list.push(2);
for elem in list.iter_mut() {
*elem += 10;
}
assert_eq!(list.pop(), Some(12));
assert_eq!(list.pop(), Some(11));
assert_eq!(list.pop(), None);Trait Implementations§
Source§impl<T> Extend<T> for List<T>
impl<T> Extend<T> for List<T>
Source§fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I)
fn extend<I: IntoIterator<Item = T>>(&mut self, iter: I)
Extends a collection with the contents of an iterator. Read more
Source§fn extend_one(&mut self, item: A)
fn extend_one(&mut self, item: A)
🔬This is a nightly-only experimental API. (
extend_one)Extends a collection with exactly one element.
Source§fn extend_reserve(&mut self, additional: usize)
fn extend_reserve(&mut self, additional: usize)
🔬This is a nightly-only experimental API. (
extend_one)Reserves capacity in a collection for the given number of additional elements. Read more
Source§impl<T> FromIterator<T> for List<T>
impl<T> FromIterator<T> for List<T>
Source§fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self
fn from_iter<I: IntoIterator<Item = T>>(iter: I) -> Self
Creates a value from an iterator. Read more
Source§impl<'a, T> IntoIterator for &'a List<T>
impl<'a, T> IntoIterator for &'a List<T>
Source§impl<'a, T> IntoIterator for &'a mut List<T>
impl<'a, T> IntoIterator for &'a mut List<T>
Source§impl<'a, T> IntoIterator for List<T>
impl<'a, T> IntoIterator for List<T>
impl<T: Eq> Eq for List<T>
Auto Trait Implementations§
impl<T> Freeze for List<T>
impl<T> RefUnwindSafe for List<T>where
T: RefUnwindSafe,
impl<T> Send for List<T>where
T: Send,
impl<T> Sync for List<T>where
T: Sync,
impl<T> Unpin for List<T>
impl<T> UnwindSafe for List<T>where
T: UnwindSafe,
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more