tst 0.12.1

Ternary search trie collection in rust with similar API to std::collections as it possible
Documentation
//! Ternary search trie (TST) container.

/// - Create a `TSTMap` containing a given list of elements:
///
/// # Examples
///
/// ```
/// #[macro_use]
/// extern crate tst;
/// # fn main() {
/// let m = tstmap!{
///     "b" => 2, "a" => -1, "c" => 3,
/// };
///
/// assert_eq!(3, m.len());
/// assert_eq!(m["a"], -1);
/// assert_eq!(m["b"], 2);
/// assert_eq!(m["c"], 3);
/// # }
/// ```
#[macro_export]
macro_rules! tstmap {
    () => {{
        $crate::TSTMap::new()
    }};
    // trailing comma case
    ($($key:expr_2021 => $value:expr_2021,)+) => (tstmap!($($key => $value),+));
    ($( $key: expr_2021 => $val: expr_2021 ),*) => {{
        let mut m = $crate::TSTMap::new();
        $(
            m.insert($key, $val);
        )*
        m
    }};
}

/// - Create a `TSTSet` containing a given list of elements:
///
/// # Examples
///
/// ```
/// #[macro_use]
/// extern crate tst;
/// # fn main() {
/// let s = tstset!{
///     "bcb", "bca", "bcd"
/// };
///
/// assert_eq!(3, s.len());
/// assert!(!s.contains("b"));
/// assert!(!s.contains("bc"));
/// assert!(s.contains("bca"));
/// assert!(s.contains("bcb"));
/// assert!(s.contains("bcd"));
/// # }
/// ```
#[macro_export]
macro_rules! tstset {
    () => {{
        $crate::TSTSet::new()
    }};
    // trailing comma case
    ($($key:expr_2021,)+) => (tstset!($($key),+));
    ($($key: expr_2021),*) => {{
        let mut s = $crate::TSTSet::new();
        $(
            s.insert($key);
        )*
        s
    }};
}

extern crate core;

pub use tst_map::TSTMap;
pub use tst_set::TSTSet;

/// TST container map and set implementation.
mod node;
mod traverse;
mod map;
mod set;

pub mod tst_map {
    pub use crate::map::*;
}

pub mod tst_set {
    pub use crate::set::*;
}