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
47
48
49
50
51
//! # gen-vec
//!
//! Vector of reusable, generational indices that owns its values
//!
//! [Inspired by Catherine West's closing keynote at RustConf 2018](https://kyren.github.io/2018/09/14/rustconf-talk.html)
//!
//! ## Closed vs. Exposed index allocation implementations
//!
//! `ClosedGenVec` uses a non user-accessible index allocator to manage indices
//!
//! `ExposedGenVec` relies on an external `IndexAllocator`
//!
//! As such, an `IndexAllocator` must be created and used to allocate/deallocate indices manually.
//! This is useful for using the same `Index` across multiple `ExposedGenerationalVec` instances
//!
//! **Note:** `IndexAllocator` cannot be used with `ClosedGenerationalVec` since it has its own
//! internal `IndexAllocator`
//!
//! ## Explanation of Generational Indices
//!
//! `Index` structs are used to access the vector's contents. An `Index` contains an index for the vector
//! and a generation (which is 0 initially).
//!
//! Deallocated/removed `Index`s go into a list of free `Index`s that can be reused
//!
//! Every time an `Index` is reused, the internal generation is incremented. This ensures that a deallocated
//! `Index` handle can't access data that it no longer validly points to

#[cfg(feature = "serde")]
use serde::{Serialize, Deserialize};

/// An index of a generational vec
#[derive(Eq, PartialEq, Ord, PartialOrd, Hash, Clone, Copy, Debug)]
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
pub struct Index
{
    index: usize,
    generation: usize
}

/// An item within a generational vec
#[derive(Debug)]
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
struct Item<T>
{
    value: T,
    generation: usize
}

pub mod closed;
pub mod exposed;