Rust-PHF is a library to generate efficient lookup tables at compile time using perfect hash functions.
It currently uses the CHD algorithm and can generate a 100,000 entry map in roughly .4 seconds.
Documentation is available at https://sfackler.github.io/doc/phf
#![feature(plugin)]
#[plugin] #[no_link]
extern crate phf_mac;
extern crate phf;
static KEYWORDS: phf::Map<&'static str, Keyword> = phf_map! {
"loop" => LOOP,
"continue" => CONTINUE,
"break" => BREAK,
"fn" => FN,
"extern" => EXTERN,
};
pub fn parse_keyword(keyword: &str) -> Option<Keyword> {
KEYWORDS.get(keyword).map(|t| t.clone())
}