1use std::{
4 ops::{Index, IndexMut},
5 slice::GetDisjointMutError,
6};
7
8use index_vec::Idx;
9
10use crate::{
11 IndexedDomain, IndexedValue, ToIndex,
12 pointer::{ArcFamily, PointerFamily, RcFamily, RefFamily},
13};
14
15pub struct IndexVec<'a, K: IndexedValue + 'a, V, P: PointerFamily<'a>> {
17 vec: Vec<V>,
18 pub(crate) domain: P::Pointer<IndexedDomain<K>>,
19}
20
21impl<'a, K, V, P> IndexVec<'a, K, V, P>
22where
23 K: IndexedValue + 'a,
24 P: PointerFamily<'a>,
25 V: Clone,
26{
27 pub fn from_elem(elem: V, domain: &P::Pointer<IndexedDomain<K>>) -> Self {
29 let vec = vec![elem; domain.len()];
30 IndexVec {
31 vec,
32 domain: domain.clone(),
33 }
34 }
35}
36
37impl<'a, K, V, P> IndexVec<'a, K, V, P>
38where
39 K: IndexedValue + 'a,
40 P: PointerFamily<'a>,
41{
42 pub fn from_fn(f: impl FnMut(K::Index) -> V, domain: &P::Pointer<IndexedDomain<K>>) -> Self {
44 let vec = domain.indices().map(f).collect();
45 IndexVec {
46 vec,
47 domain: domain.clone(),
48 }
49 }
50
51 pub fn get<M>(&self, idx: impl ToIndex<K, M>) -> &V {
53 let idx = idx.to_index(&self.domain);
54 debug_assert!(self.domain.contains_index(idx));
55 unsafe { self.vec.get_unchecked(idx.index()) }
56 }
57
58 pub fn get_mut<M>(&mut self, idx: impl ToIndex<K, M>) -> &mut V {
60 let idx = idx.to_index(&self.domain);
61 debug_assert!(self.domain.contains_index(idx));
62 unsafe { self.vec.get_unchecked_mut(idx.index()) }
63 }
64
65 pub fn iter(&self) -> impl DoubleEndedIterator<Item = &V> + ExactSizeIterator<Item = &V> {
67 self.vec.iter()
68 }
69
70 pub fn iter_mut(
72 &mut self,
73 ) -> impl DoubleEndedIterator<Item = &mut V> + ExactSizeIterator<Item = &mut V> {
74 self.vec.iter_mut()
75 }
76
77 pub fn as_slice(&self) -> &[V] {
79 &self.vec
80 }
81
82 pub fn as_slice_mut(&mut self) -> &mut [V] {
84 &mut self.vec
85 }
86
87 pub fn get_disjoint_mut<const N: usize>(
90 &mut self,
91 indices: [K::Index; N],
92 ) -> Result<[&mut V; N], GetDisjointMutError> {
93 self.vec.get_disjoint_mut(indices.map(Idx::index))
94 }
95}
96
97impl<'a, K, V, P> Clone for IndexVec<'a, K, V, P>
98where
99 K: IndexedValue + 'a,
100 P: PointerFamily<'a>,
101 V: Clone,
102{
103 fn clone(&self) -> Self {
104 IndexVec {
105 vec: self.vec.clone(),
106 domain: self.domain.clone(),
107 }
108 }
109
110 fn clone_from(&mut self, source: &Self) {
111 self.vec.clone_from(&source.vec);
112 }
113}
114
115impl<'a, K, V, P> PartialEq for IndexVec<'a, K, V, P>
116where
117 K: IndexedValue + 'a,
118 P: PointerFamily<'a>,
119 V: PartialEq,
120{
121 fn eq(&self, other: &Self) -> bool {
122 self.vec == other.vec
123 }
124}
125
126impl<'a, K, V, P> Eq for IndexVec<'a, K, V, P>
127where
128 K: IndexedValue + 'a,
129 P: PointerFamily<'a>,
130 V: Eq,
131{
132}
133
134impl<'a, K, V, P> Index<K::Index> for IndexVec<'a, K, V, P>
135where
136 K: IndexedValue + 'a,
137 P: PointerFamily<'a>,
138{
139 type Output = V;
140
141 fn index(&self, index: K::Index) -> &Self::Output {
142 self.get(index)
143 }
144}
145
146impl<'a, K, V, P> IndexMut<K::Index> for IndexVec<'a, K, V, P>
147where
148 K: IndexedValue + 'a,
149 P: PointerFamily<'a>,
150{
151 fn index_mut(&mut self, index: K::Index) -> &mut Self::Output {
152 self.get_mut(index)
153 }
154}
155
156pub type RcIndexVec<K, V> = IndexVec<'static, K, V, RcFamily>;
158
159pub type ArcIndexVec<K, V> = IndexVec<'static, K, V, ArcFamily>;
161
162pub type RefIndexVec<'a, K, V> = IndexVec<'a, K, V, RefFamily<'a>>;