18 releases
0.2.1 | Oct 22, 2020 |
---|---|
0.2.0 | Jun 27, 2020 |
0.1.6 | Nov 17, 2019 |
0.1.4 | Oct 7, 2018 |
0.0.1 | Mar 20, 2015 |
#43 in Data structures
1,201,323 downloads per month
Used in 509 crates
(61 directly)
255KB
2K
SLoC
Rust Radix Trie
This is a Radix Trie implementation in Rust, building on the lessons learnt from TrieMap
and Sequence Trie. You can read about my experience implementing this data structure here.
Help Wanted, Enquire Within
Since writing this code I haven't used it in anger (or production) so it is no doubt in need of some maintenance, testing and optimisation love. If you would like to help out, try solving an open issue, optimise something, or just have a poke around! Thanks :)
Features
- Compressed nodes. Common key prefixes are stored only once.
- Trie-specific methods to look-up closest ancestors and descendants.
- Key Generic. Any type that can be serialised as a vector of bytes can be used as a key.
- Safe - no unsafe code.
Documentation
Usage
Available on Crates.io as radix_trie
.
Just add radix_trie
to the dependencies section of your Cargo.toml
, like so:
radix_trie = "0.2"
Contributors
Made by:
- Allan Simon (@allan-simon)
- Andrew Smith (@andrewcsmith)
- Arthur Carcano (@NougatRillettes)
- Devin Ragotzy (@DevinR528)
- @hanabi1224
- Jakob Dalsgaard (@jakobdalsgaard)
- Michael Sproul (@michaelsproul)
- Robin Lambertz (@roblabla)
- Sergey (@Albibek)
- Stuart Hinson (@stuarth)
- Vinzent Steinberg (@vks)
License
MIT License. Copyright © Michael Sproul and contributors 2015-present.