use core::{
fmt,
iter::{FromIterator, FusedIterator},
ops::RangeBounds,
};
use alloc::vec::Vec;
use crate::{Segment, SegmentSet};
impl<T> SegmentSet<T> {
pub fn iter(&self) -> Iter<'_, T> {
Iter(self.map.ranges())
}
pub fn len(&self) -> usize {
self.map.len()
}
pub fn is_empty(&self) -> bool {
self.map.is_empty()
}
pub fn into_vec(self) -> Vec<Segment<T>> {
self.into_iter().collect()
}
}
impl<Item: RangeBounds<T>, T: Clone + Ord> FromIterator<Item> for SegmentSet<T> {
fn from_iter<I: IntoIterator<Item = Item>>(iter: I) -> Self {
let mut set = Self::new();
for item in iter {
set.insert(item);
}
set
}
}
impl<T: Clone + Ord> Extend<Segment<T>> for SegmentSet<T> {
#[inline]
fn extend<Iter: IntoIterator<Item = Segment<T>>>(&mut self, iter: Iter) {
iter.into_iter().for_each(move |range| {
self.insert(range);
});
}
}
impl<'a, T: 'a + Ord + Copy> Extend<&'a Segment<T>> for SegmentSet<T> {
fn extend<I: IntoIterator<Item = &'a Segment<T>>>(&mut self, iter: I) {
self.extend(iter.into_iter().cloned());
}
}
#[derive(Clone)]
pub struct Iter<'a, T: 'a>(crate::map::iterators::Ranges<'a, T, ()>);
impl<T: fmt::Debug> fmt::Debug for Iter<'_, T> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
f.debug_tuple("Iter").field(&self.0.clone()).finish()
}
}
impl<'a, T> Iterator for Iter<'a, T> {
type Item = &'a Segment<T>;
fn next(&mut self) -> Option<&'a Segment<T>> {
self.0.next()
}
fn size_hint(&self) -> (usize, Option<usize>) {
self.0.size_hint()
}
fn last(mut self) -> Option<&'a Segment<T>> {
self.next_back()
}
fn min(mut self) -> Option<&'a Segment<T>> {
self.next()
}
fn max(mut self) -> Option<&'a Segment<T>> {
self.next_back()
}
}
impl<T> FusedIterator for Iter<'_, T> {}
impl<'a, T> DoubleEndedIterator for Iter<'a, T> {
fn next_back(&mut self) -> Option<&'a Segment<T>> {
self.0.next_back()
}
}
impl<T> ExactSizeIterator for Iter<'_, T> {
fn len(&self) -> usize {
self.0.len()
}
}
impl<T> IntoIterator for SegmentSet<T> {
type Item = Segment<T>;
type IntoIter = IntoIter<T>;
fn into_iter(self) -> Self::IntoIter {
IntoIter(self.map.into_iter())
}
}
pub struct IntoIter<T>(crate::map::iterators::IntoIter<T, ()>);
impl<T: fmt::Debug> fmt::Debug for IntoIter<T> {
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
self.0.fmt(f)
}
}
impl<T> Iterator for IntoIter<T> {
type Item = Segment<T>;
fn next(&mut self) -> Option<Segment<T>> {
self.0.next().map(|(range, _)| range)
}
fn size_hint(&self) -> (usize, Option<usize>) {
self.0.size_hint()
}
}
impl<T> DoubleEndedIterator for IntoIter<T> {
fn next_back(&mut self) -> Option<Self::Item> {
self.0.next_back().map(|(range, _)| range)
}
}
impl<T> FusedIterator for IntoIter<T> {}