2022-01-02 10:05:37 -06:00
|
|
|
//! See [`NonEmptyVec`].
|
2022-01-01 20:25:47 -06:00
|
|
|
|
2022-01-02 10:05:37 -06:00
|
|
|
/// A [`Vec`] that is guaranteed to at least contain one element.
|
|
|
|
pub struct NonEmptyVec<T> {
|
|
|
|
first: T,
|
|
|
|
rest: Vec<T>,
|
|
|
|
}
|
2022-01-01 20:25:47 -06:00
|
|
|
|
|
|
|
impl<T> NonEmptyVec<T> {
|
|
|
|
#[inline]
|
2022-01-02 10:05:37 -06:00
|
|
|
pub fn new(first: T) -> Self {
|
|
|
|
NonEmptyVec { first, rest: Vec::new() }
|
2022-01-01 20:25:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn last_mut(&mut self) -> &mut T {
|
2022-01-02 10:05:37 -06:00
|
|
|
self.rest.last_mut().unwrap_or(&mut self.first)
|
2022-01-01 20:25:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn pop(&mut self) -> Option<T> {
|
2022-01-02 10:05:37 -06:00
|
|
|
self.rest.pop()
|
2022-01-01 20:25:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn push(&mut self, value: T) {
|
2022-01-02 10:05:37 -06:00
|
|
|
self.rest.push(value)
|
2022-01-01 20:25:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
|
|
|
pub fn len(&self) -> usize {
|
2022-01-02 10:05:37 -06:00
|
|
|
1 + self.rest.len()
|
2022-01-01 20:25:47 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
#[inline]
|
2022-01-02 10:05:37 -06:00
|
|
|
pub fn into_last(mut self) -> T {
|
|
|
|
self.rest.pop().unwrap_or(self.first)
|
2022-01-01 20:25:47 -06:00
|
|
|
}
|
|
|
|
}
|