1use std::borrow::{Borrow, BorrowMut};
2use std::hash::Hash;
3use std::marker::PhantomData;
4use std::ops::{Deref, DerefMut, RangeBounds};
5use std::{fmt, slice, vec};
6
7#[cfg(feature = "nightly")]
8use rustc_serialize::{Decodable, Decoder, Encodable, Encoder};
9
10use crate::{Idx, IndexSlice};
11
12#[derive(Clone, PartialEq, Eq, Hash)]
39#[repr(transparent)]
40pub struct IndexVec<I: Idx, T> {
41 pub raw: Vec<T>,
42 _marker: PhantomData<fn(&I)>,
43}
44
45impl<I: Idx, T> IndexVec<I, T> {
46 #[inline]
48 pub const fn new() -> Self {
49 IndexVec::from_raw(Vec::new())
50 }
51
52 #[inline]
54 pub const fn from_raw(raw: Vec<T>) -> Self {
55 IndexVec { raw, _marker: PhantomData }
56 }
57
58 #[inline]
59 pub fn with_capacity(capacity: usize) -> Self {
60 IndexVec::from_raw(Vec::with_capacity(capacity))
61 }
62
63 #[inline]
75 pub fn from_elem<S>(elem: T, universe: &IndexSlice<I, S>) -> Self
76 where
77 T: Clone,
78 {
79 IndexVec::from_raw(vec![elem; universe.len()])
80 }
81
82 #[inline]
84 pub fn from_elem_n(elem: T, n: usize) -> Self
85 where
86 T: Clone,
87 {
88 IndexVec::from_raw(vec![elem; n])
89 }
90
91 #[inline]
95 pub fn from_fn_n(func: impl FnMut(I) -> T, n: usize) -> Self {
96 let _ = I::new(n);
98 IndexVec::from_raw((0..n).map(I::new).map(func).collect())
99 }
100
101 #[inline]
102 pub fn as_slice(&self) -> &IndexSlice<I, T> {
103 IndexSlice::from_raw(&self.raw)
104 }
105
106 #[inline]
107 pub fn as_mut_slice(&mut self) -> &mut IndexSlice<I, T> {
108 IndexSlice::from_raw_mut(&mut self.raw)
109 }
110
111 #[inline]
113 pub fn push(&mut self, d: T) -> I {
114 let idx = self.next_index();
115 self.raw.push(d);
116 idx
117 }
118
119 #[inline]
120 pub fn pop(&mut self) -> Option<T> {
121 self.raw.pop()
122 }
123
124 #[inline]
125 pub fn into_iter(self) -> vec::IntoIter<T> {
126 self.raw.into_iter()
127 }
128
129 #[inline]
130 pub fn into_iter_enumerated(
131 self,
132 ) -> impl DoubleEndedIterator<Item = (I, T)> + ExactSizeIterator {
133 let _ = I::new(self.len());
135 self.raw.into_iter().enumerate().map(|(n, t)| (I::new(n), t))
136 }
137
138 #[inline]
139 pub fn drain<R: RangeBounds<usize>>(&mut self, range: R) -> impl Iterator<Item = T> {
140 self.raw.drain(range)
141 }
142
143 #[inline]
144 pub fn drain_enumerated<R: RangeBounds<usize>>(
145 &mut self,
146 range: R,
147 ) -> impl Iterator<Item = (I, T)> {
148 let begin = match range.start_bound() {
149 std::ops::Bound::Included(i) => *i,
150 std::ops::Bound::Excluded(i) => i.checked_add(1).unwrap(),
151 std::ops::Bound::Unbounded => 0,
152 };
153 self.raw.drain(range).enumerate().map(move |(n, t)| (I::new(begin + n), t))
154 }
155
156 #[inline]
157 pub fn shrink_to_fit(&mut self) {
158 self.raw.shrink_to_fit()
159 }
160
161 #[inline]
162 pub fn truncate(&mut self, a: usize) {
163 self.raw.truncate(a)
164 }
165
166 #[inline]
173 pub fn ensure_contains_elem(&mut self, elem: I, fill_value: impl FnMut() -> T) -> &mut T {
174 let min_new_len = elem.index() + 1;
175 if self.len() < min_new_len {
176 self.raw.resize_with(min_new_len, fill_value);
177 }
178
179 &mut self[elem]
180 }
181
182 #[inline]
183 pub fn resize(&mut self, new_len: usize, value: T)
184 where
185 T: Clone,
186 {
187 self.raw.resize(new_len, value)
188 }
189
190 #[inline]
191 pub fn resize_to_elem(&mut self, elem: I, fill_value: impl FnMut() -> T) {
192 let min_new_len = elem.index() + 1;
193 self.raw.resize_with(min_new_len, fill_value);
194 }
195
196 #[inline]
197 pub fn append(&mut self, other: &mut Self) {
198 self.raw.append(&mut other.raw);
199 }
200}
201
202impl<I: Idx, T> IndexVec<I, Option<T>> {
204 #[inline]
205 pub fn insert(&mut self, index: I, value: T) -> Option<T> {
206 self.ensure_contains_elem(index, || None).replace(value)
207 }
208
209 #[inline]
210 pub fn get_or_insert_with(&mut self, index: I, value: impl FnOnce() -> T) -> &mut T {
211 self.ensure_contains_elem(index, || None).get_or_insert_with(value)
212 }
213
214 #[inline]
215 pub fn remove(&mut self, index: I) -> Option<T> {
216 self.get_mut(index)?.take()
217 }
218
219 #[inline]
220 pub fn contains(&self, index: I) -> bool {
221 self.get(index).and_then(Option::as_ref).is_some()
222 }
223}
224
225impl<I: Idx, T: fmt::Debug> fmt::Debug for IndexVec<I, T> {
226 fn fmt(&self, fmt: &mut fmt::Formatter<'_>) -> fmt::Result {
227 fmt::Debug::fmt(&self.raw, fmt)
228 }
229}
230
231impl<I: Idx, T> Deref for IndexVec<I, T> {
232 type Target = IndexSlice<I, T>;
233
234 #[inline]
235 fn deref(&self) -> &Self::Target {
236 self.as_slice()
237 }
238}
239
240impl<I: Idx, T> DerefMut for IndexVec<I, T> {
241 #[inline]
242 fn deref_mut(&mut self) -> &mut Self::Target {
243 self.as_mut_slice()
244 }
245}
246
247impl<I: Idx, T> Borrow<IndexSlice<I, T>> for IndexVec<I, T> {
248 fn borrow(&self) -> &IndexSlice<I, T> {
249 self
250 }
251}
252
253impl<I: Idx, T> BorrowMut<IndexSlice<I, T>> for IndexVec<I, T> {
254 fn borrow_mut(&mut self) -> &mut IndexSlice<I, T> {
255 self
256 }
257}
258
259impl<I: Idx, T> Extend<T> for IndexVec<I, T> {
260 #[inline]
261 fn extend<J: IntoIterator<Item = T>>(&mut self, iter: J) {
262 self.raw.extend(iter);
263 }
264
265 #[inline]
266 #[cfg(feature = "nightly")]
267 fn extend_one(&mut self, item: T) {
268 self.raw.push(item);
269 }
270
271 #[inline]
272 #[cfg(feature = "nightly")]
273 fn extend_reserve(&mut self, additional: usize) {
274 self.raw.reserve(additional);
275 }
276}
277
278impl<I: Idx, T> FromIterator<T> for IndexVec<I, T> {
279 #[inline]
280 fn from_iter<J>(iter: J) -> Self
281 where
282 J: IntoIterator<Item = T>,
283 {
284 IndexVec::from_raw(Vec::from_iter(iter))
285 }
286}
287
288impl<I: Idx, T> IntoIterator for IndexVec<I, T> {
289 type Item = T;
290 type IntoIter = vec::IntoIter<T>;
291
292 #[inline]
293 fn into_iter(self) -> vec::IntoIter<T> {
294 self.raw.into_iter()
295 }
296}
297
298impl<'a, I: Idx, T> IntoIterator for &'a IndexVec<I, T> {
299 type Item = &'a T;
300 type IntoIter = slice::Iter<'a, T>;
301
302 #[inline]
303 fn into_iter(self) -> slice::Iter<'a, T> {
304 self.iter()
305 }
306}
307
308impl<'a, I: Idx, T> IntoIterator for &'a mut IndexVec<I, T> {
309 type Item = &'a mut T;
310 type IntoIter = slice::IterMut<'a, T>;
311
312 #[inline]
313 fn into_iter(self) -> slice::IterMut<'a, T> {
314 self.iter_mut()
315 }
316}
317
318impl<I: Idx, T> Default for IndexVec<I, T> {
319 #[inline]
320 fn default() -> Self {
321 IndexVec::new()
322 }
323}
324
325impl<I: Idx, T, const N: usize> From<[T; N]> for IndexVec<I, T> {
326 #[inline]
327 fn from(array: [T; N]) -> Self {
328 IndexVec::from_raw(array.into())
329 }
330}
331
332#[cfg(feature = "nightly")]
333impl<S: Encoder, I: Idx, T: Encodable<S>> Encodable<S> for IndexVec<I, T> {
334 fn encode(&self, s: &mut S) {
335 Encodable::encode(&self.raw, s);
336 }
337}
338
339#[cfg(feature = "nightly")]
340impl<D: Decoder, I: Idx, T: Decodable<D>> Decodable<D> for IndexVec<I, T> {
341 fn decode(d: &mut D) -> Self {
342 IndexVec::from_raw(Vec::<T>::decode(d))
343 }
344}
345
346unsafe impl<I: Idx, T> Send for IndexVec<I, T> where T: Send {}
349
350#[cfg(test)]
351mod tests;