5 releases
0.2.0 | Nov 23, 2024 |
---|---|
0.1.3 | May 28, 2024 |
0.1.2 | Nov 16, 2023 |
0.1.1 | Oct 3, 2023 |
0.1.0 | Sep 23, 2023 |
#182 in Internationalization (i18n)
126,472 downloads per month
Used in 98 crates
(7 directly)
415KB
7K
SLoC
zerotrie
A data structure offering zero-copy storage and retrieval of byte strings, with a focus
on the efficient storage of ASCII strings. Strings are mapped to usize
values.
ZeroTrie
does not support mutation because doing so would require recomputing the entire
data structure. Instead, it supports conversion to and from LiteMap
and BTreeMap
.
There are multiple variants of ZeroTrie
optimized for different use cases.
Examples
use zerotrie::ZeroTrie;
let data: &[(&str, usize)] = &[("abc", 11), ("xyz", 22), ("axyb", 33)];
let trie: ZeroTrie<Vec<u8>> = data.iter().copied().collect();
assert_eq!(trie.get("axyb"), Some(33));
assert_eq!(trie.byte_len(), 18);
Internal Structure
To read about the internal structure of ZeroTrie
, build the docs with private modules:
cargo doc --document-private-items --all-features --no-deps --open
More Information
For more information on development, authorship, contributing etc. please visit ICU4X home page
.
Dependencies
~225–750KB
~17K SLoC