#multimap #bidirectional #hash-map #map #two-way

bisetmap

BisetMap is a fast and thread-safe two-way hash map of sets. It is best suited where you need to associate two collumns uniquely. Each key is associated to one or more other unique values. The structure is interior mutable and all operations are thread safe. Each clone provides access to the same underlying data. Serialize and Deserialize from serde are also implemented.

7 releases

Uses old Rust 2015

0.1.6 Nov 9, 2017
0.1.5 Nov 9, 2017

#1273 in Data structures

Download history 109/week @ 2024-07-22 424/week @ 2024-07-29 124/week @ 2024-08-05 190/week @ 2024-08-12 277/week @ 2024-08-19 172/week @ 2024-08-26 204/week @ 2024-09-02 156/week @ 2024-09-09 160/week @ 2024-09-16 297/week @ 2024-09-23 304/week @ 2024-09-30 276/week @ 2024-10-07 145/week @ 2024-10-14 255/week @ 2024-10-21 133/week @ 2024-10-28 121/week @ 2024-11-04

655 downloads per month
Used in mapped_futures

MIT license

21KB
229 lines

crates.io Documentation

BisetMap

BisetMap is a fast and thread-safe two-way hash map of sets for Rust. It is best suited where you need to associate two collumns uniquely. Each key is associated to one or more other unique values.

The structure is interior mutable and all operations are thread safe. Each clone provides access to the same underlying data. Serialize and Deserialize from serde are also implemented.

Usage

To use BisetMap in your Rust project, add bisetmap = 0.1 to the dependencies section of your Cargo.toml. See the docs for more details and example code.

Examples

use bisetmap::BisetMap;

let subscriptions = BisetMap::new();

// insert client-ids and subscription topics
subscriptions.insert("Bob", "Tech");
subscriptions.insert("Bob", "Math");
subscriptions.insert("Alice", "Tech");
subscriptions.insert("Alice", "Romance");

// retrieve topic by client-id (left to right)
assert_eq!(subscriptions.get(&"Bob"), ["Math", "Tech"]);
assert_eq!(subscriptions.get(&"Alice"), ["Romance", "Tech"]);

// retrieve clients by topic (right to left)
assert_eq!(subscriptions.rev_get(&"Tech"), ["Alice", "Bob"]);
assert_eq!(subscriptions.rev_get(&"Math"), ["Bob"]);

// check membership
assert!(subscriptions.contains(&"Bob", &"Math"));
assert!(!subscriptions.contains(&"Bob", &"Romance"));

// check key/value existence
assert!(subscriptions.key_exists(&"Alice"));
assert!(subscriptions.value_exists(&"Tech"));

License

BisetMap is licensed under the MIT license.

Dependencies

~100–325KB