QuickMap and CI

This commit adds a new datatype: the quickmap. It provides an extremely
fast but relatively high collision string hash to whatever key hashmap.

This is optimized purely for variable names, and is intended to use for
variable name lookup during (eval ...) or (string->symbol ...) if I must
implement that.

The hashmap is bucketed, with a set number of buckets (199 in this case).
Each bucket is preallocated at initialization containing an empty vector.
There will only ever be one of these initialized as it is only to contain
globally accessible names.

The interface provides new, get, remove, contains_key, insert, and an
iterator implementation.

Unit tests are included and CI is updated.

Signed-off-by: Ava Affine <ava@sunnypup.io>
This commit is contained in:
Ava Apples Affine 2025-06-10 14:16:38 -07:00
parent a12d15b2cd
commit 3a0a141738
3 changed files with 217 additions and 0 deletions

View file

@ -26,5 +26,6 @@ pub mod lexer;
pub mod parser;
pub mod number;
pub mod stackstack;
pub mod hmap;
extern crate alloc;