2022-08-01 14:45:58 -05:00
|
|
|
pub const DICT: &str = include_str!("../assets/dictionary.txt");
|
2019-10-28 10:01:22 -06:00
|
|
|
|
2022-08-01 14:45:58 -05:00
|
|
|
#[test]
|
|
|
|
fn codegen() {
|
|
|
|
let mut content = vec![];
|
|
|
|
generate(&mut content);
|
|
|
|
|
|
|
|
let content = String::from_utf8(content).unwrap();
|
|
|
|
let content = codegenrs::rustfmt(&content, None).unwrap();
|
2024-05-27 22:09:20 -05:00
|
|
|
snapbox::assert_data_eq!(content, snapbox::file!["../src/dict_codegen.rs"].raw());
|
2022-08-01 14:45:58 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
fn generate<W: std::io::Write>(file: &mut W) {
|
2022-09-01 07:15:42 -05:00
|
|
|
writeln!(
|
|
|
|
file,
|
|
|
|
"// This file is @generated by {}",
|
|
|
|
file!().replace('\\', "/")
|
|
|
|
)
|
|
|
|
.unwrap();
|
2022-08-01 14:45:58 -05:00
|
|
|
writeln!(file).unwrap();
|
|
|
|
|
|
|
|
let dict = parse_dict(DICT);
|
|
|
|
|
2024-12-28 20:58:19 -06:00
|
|
|
dictgen::DictGen::new()
|
|
|
|
.name("WORD_DICTIONARY")
|
|
|
|
.value_type("&[&str]")
|
2024-12-30 14:57:39 -06:00
|
|
|
.ordered_map()
|
2024-12-28 20:58:19 -06:00
|
|
|
.write(file, dict.map(|kv| (kv.0, format!("&{:?}", kv.1))))
|
|
|
|
.unwrap();
|
2022-08-01 14:45:58 -05:00
|
|
|
}
|
2019-10-28 10:01:22 -06:00
|
|
|
|
|
|
|
fn parse_dict(raw: &str) -> impl Iterator<Item = (&str, Vec<&str>)> {
|
|
|
|
raw.lines().map(|s| {
|
|
|
|
let mut parts = s.splitn(2, "->");
|
|
|
|
let typo = parts.next().unwrap().trim();
|
|
|
|
let corrections = parts
|
|
|
|
.next()
|
|
|
|
.unwrap()
|
2019-10-28 16:25:41 -06:00
|
|
|
.split(',')
|
2019-10-28 10:01:22 -06:00
|
|
|
.filter_map(|c| {
|
|
|
|
let c = c.trim();
|
|
|
|
if c.is_empty() {
|
|
|
|
None
|
|
|
|
} else {
|
|
|
|
Some(c)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.collect();
|
|
|
|
(typo, corrections)
|
|
|
|
})
|
|
|
|
}
|