1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
use core::marker::PhantomData;

use crate::{Slice, SliceMut};

/// A reversed slice, from [`Slice::reverse`].
#[derive(Clone, Copy, PartialEq, Eq, Hash)]
pub struct Reverse<T, A>(pub A, PhantomData<fn() -> T>);

impl<T, A> Reverse<T, A>
where
    A: Slice<T>,
{
    pub fn new(data: A) -> Self {
        Self(data, PhantomData)
    }
}

impl<T, A> Slice<T> for Reverse<T, A>
where
    A: Slice<T>,
{
    fn get(&self, index: usize) -> Option<&T> {
        if index >= self.len() {
            return None;
        }

        self.0.get(self.0.len() - index - 1)
    }

    fn len(&self) -> usize {
        self.0.len()
    }
}

impl<T, A> SliceMut<T> for Reverse<T, A>
where
    A: SliceMut<T>,
{
    fn get_mut(&mut self, index: usize) -> Option<&mut T> {
        if index >= self.len() {
            return None;
        }

        self.0.get_mut(self.0.len() - index - 1)
    }
}