#map #key-set #set #vec #key-hash #vector #no-std

no-std vecmap-rs

A vector-based map and set implementation

18 releases

0.2.1 Jan 3, 2024
0.2.0 Dec 25, 2023
0.1.15 Dec 23, 2023
0.1.12 Sep 19, 2023
0.1.8 Oct 30, 2022

#177 in Data structures

Download history 999/week @ 2023-12-21 1383/week @ 2023-12-28 1380/week @ 2024-01-04 1532/week @ 2024-01-11 1776/week @ 2024-01-18 1381/week @ 2024-01-25 1793/week @ 2024-02-01 1337/week @ 2024-02-08 1506/week @ 2024-02-15 1328/week @ 2024-02-22 1489/week @ 2024-02-29 1344/week @ 2024-03-07 1391/week @ 2024-03-14 1577/week @ 2024-03-21 1393/week @ 2024-03-28 1427/week @ 2024-04-04

6,011 downloads per month
Used in 35 crates (3 directly)

MIT/Apache

135KB
2K SLoC

vecmap-rs

Build Status crates.io docs.rs License: Apache 2.0 License: MIT

A vector-based ordered map and set implementation with zero dependencies and support for #![no_std].

Map keys are not required to be hashable and do not need to form a total order. Therefore, VecMap<K, V> and VecSet<T> can be used with key types which neither implement Hash nor Ord.

Since vecmap-rs is a Vec<(K, V)> under the hood, worst case lookup and insertion performance is O(n) and scales with the number of map entries. Thus, its main use case are small collections with unhashable keys.

For key types that implement Hash and Ord consider using a map or set implementation with better performance such as HashMap/HashSet and BTreeMap/BTreeSet from the standard library or popular alternatives like IndexMap/IndexSet.

Cargo features

The following features are available:

  • serde: Provides Serialize and Deserialize implementations for VecMap and VecSet. This feature is disabled by default. Enabling it will pull in serde as a dependency.

License

The source code of vecmap-rs is licensed under either of Apache License, Version 2.0 or MIT license at your option.

Dependencies

~170KB