18 releases

0.6.3 Mar 19, 2023
0.6.2 Jan 23, 2022
0.6.1 Apr 8, 2021
0.6.0 Jan 4, 2021
0.1.3 Sep 13, 2017

#17 in Data structures

Download history 114331/week @ 2024-06-30 128855/week @ 2024-07-07 128451/week @ 2024-07-14 145563/week @ 2024-07-21 120710/week @ 2024-07-28 118182/week @ 2024-08-04 121429/week @ 2024-08-11 117719/week @ 2024-08-18 122632/week @ 2024-08-25 128353/week @ 2024-09-01 132945/week @ 2024-09-08 119634/week @ 2024-09-15 134791/week @ 2024-09-22 134752/week @ 2024-09-29 140779/week @ 2024-10-06 156035/week @ 2024-10-13

572,248 downloads per month
Used in 297 crates (115 directly)

Apache-2.0/MIT

99KB
1.5K SLoC

bimap-rs

version documentation license

bimap-rs is a pure Rust library for dealing with bijective maps, aiming to feel like an extension of the standard library's data structures whenever possible. There are no external dependencies by default but Serde and no_std compatibility are available through feature flags.

  1. Quick start
  2. Feature flags
  3. Documentation
  4. Contributing
  5. Semantic versioning
  6. Minimum supported Rust version
  7. License

Quick start

To use the latest version of bimap-rs with the default features, add this to your project's Cargo.toml file:

[dependencies]
bimap = "0.6.3"

You can now run the bimap-rs Hello World!

fn main() {
    // A bijective map between letters of the English alphabet and their positions.
    let mut alphabet = bimap::BiMap::<char, u8>::new();

    alphabet.insert('A', 1);
    // ...
    alphabet.insert('Z', 26);

    println!("A is at position {}", alphabet.get_by_left(&'A').unwrap());
    println!("{} is at position 26", alphabet.get_by_right(&26).unwrap());
}

Feature flags

Flag name Description Enabled by default?
std Standard library usage (HashMap) yes
serde (De)serialization using Serde no

This Cargo.toml shows how these features can be enabled and disabled.

[dependencies]
# I just want to use `bimap-rs`.
bimap = "0.6.3"

# I want to use `bimap-rs` without the Rust standard library.
bimap = { version = "0.6.3", default-features = false }

# I want to use `bimap-rs` with Serde support.
bimap = { version = "0.6.3", features = ["serde"] }

Documentation

Documentation for the latest version of bimap-rs is available on docs.rs.

Contributing

Thank you for your interest in improving bimap-rs! Please read the code of conduct and the contributing guidelines before submitting an issue or opening a pull request.

Semantic versioning

bimap-rs adheres to the de-facto Rust variety of Semantic Versioning.

Minimum supported Rust version

bimap MSRV
v0.6.3 1.56.1
v0.6.2 1.56.1
v0.6.1 1.42.0
v0.6.0 1.38.0
v0.5.3 1.38.0
v0.5.2 1.38.0
v0.5.1 1.38.0
v0.5.0 1.38.0
v0.4.0 1.38.0

License

bimap-rs is dual-licensed under the Apache License and the MIT License. As a library user, this means that you are free to choose either license when using bimap-rs. As a library contributor, this means that any work you contribute to bimap-rs will be similarly dual-licensed.

Dependencies

~175KB