#array #ecs #data-structures #gamedev

generational_array

A small package to handle generational arrays and prevent the ABA problem while reusing unused space

2 releases

0.1.1 May 4, 2022
0.1.0 May 4, 2022

#849 in Game dev

Download history 7/week @ 2024-02-19 23/week @ 2024-02-26 15/week @ 2024-03-11 44/week @ 2024-04-01

59 downloads per month

MIT license

8KB
107 lines

Generational Array

Why to use it

Using a generational array presents two main advantages :

  • When you remove an element from the array and try to access it, the ABA problem is prevented thanks to generations
  • The array will try to allocate the smallest amount of memory by reusing the unused cells in the array.

This module provides a simple interface for working with generational arrays with almost no additionnal runtime complexity compared to a classic vector.

How to use it

The types

This module exposes 4 different types

Name Description
GenerationalIndex Type representing an index in a generational array. It's made of an index (usize) and a generation (usize)
See methods
GenerationalArray Generic type representing the generational array
GenerationalArrayResult Enum used when getting a reference to an item from the generational array
See variants
GenerationalArrayResultMut Enum used when getting a mutable reference to an item from the generational array
See variants

Methods of GenerationalArray

Method Use
new Creates new instance of GenerationalArray
insert Adds an element, takes the value as parameter and returns the index (GenerationalIndex)
remove Removes an element, takes index as parameters and returns a Result<_, &'static str>
get Get a reference to an element, takes index and returns GenerationalArrayResult
get_mut Get a reference to an element, takes index and returns GenerationalArrayResultMut
is_empty Whether the array is empty or not, returns bool
size Returns the size (usize) of the array
used_size Returns the actual number (usize) of not empty cells in the array

GenerationalArrayResult

Variant Meaning
None The current index contains None
OutDated The index's generation doesn't match with the current generation
OutOfBounds The index is out of bounds
Some The value has been found, mutable or not depending whether you called get or get_mut

By Maxooz

No runtime deps