#case-insensitive #hash-map #string-key #case-folding #api-key #unicase

case_insensitive_hashmap

A HashMap that uses case-insensitive strings as keys

4 releases (2 stable)

1.0.1 Jul 5, 2024
1.0.0 Jun 5, 2020
0.9.1 Jun 5, 2020
0.9.0 Jun 5, 2020

#186 in Text processing

Download history 696/week @ 2024-07-23 575/week @ 2024-07-30 179/week @ 2024-08-06 246/week @ 2024-08-13 242/week @ 2024-08-20 279/week @ 2024-08-27 224/week @ 2024-09-03 240/week @ 2024-09-10 148/week @ 2024-09-17 181/week @ 2024-09-24 386/week @ 2024-10-01 403/week @ 2024-10-08 201/week @ 2024-10-15 319/week @ 2024-10-22 273/week @ 2024-10-29 189/week @ 2024-11-05

1,061 downloads per month
Used in 3 crates

MIT license

23KB
484 lines

CaseInsensitiveHashMap

A wrapper around the std::collections::HashMap that uses case-insensitive Strings for keys.

Since this is a simple wrapper around the standard HashMap, please see its documentation for more information.

The key type of the CaseInsensitiveHashMap is always UniCase<String>. Most methods that have a key parameter have a constraint <K: Into<Key>>. This means that you can call them with a String, a &str or a UniCase<String> if you already have one. This make the API more ergonomic than the alternative of using UniCase<String> directly as a key type in your own std::collections::HashMap.

Examples

use unicase::UniCase;
use case_insensitive_hashmap::CaseInsensitiveHashMap;

let mut map = CaseInsensitiveHashMap::new();
map.insert("a", 20);
map.insert("B".to_string(), 40);

// All these are valid key forms.
assert!(map.contains_key("A"));
assert!(map.contains_key("A".to_string()));
let uc = UniCase::new("A".to_string());
assert!(map.contains_key(uc));

// Lookup of values is case-insensitive.
assert_eq!(map.get("a"), Some(&20));
assert_eq!(map.get("A"), Some(&20));

assert_eq!(map["a"], 20);
assert_eq!(map["A"], 20);

Implementation

This uses the UniCase crate to handle the case-insensitivity. Strings that are used as keys are wrapped in UniCase objects so that they hash and compare for equality in a case-insensitive manner.

Release Notes

  • 1.0.1 - bumped version of UniCase to 2.7.0.

Dependencies

~91KB