1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#![doc = include_str!("../README.md")]
#![cfg_attr(docsrs, feature(doc_cfg, doc_auto_cfg))]
use std::collections::HashMap;
#[cfg(feature = "static")]
use lazy_static::{lazy_static, initialize};
#[cfg(feature = "static")]
lazy_static! {
static ref DICT: HashMap<String, Vec<String>> = parse_dict();
}
#[cfg(feature = "static")]
pub fn init() {
initialize(&DICT);
}
pub fn dict() -> HashMap<String, Vec<String>> {
let mut dict: HashMap<String, Vec<String>> = HashMap::new();
#[cfg(feature = "static")]
dict.extend(DICT.to_owned());
if dict.is_empty() {
dict.extend(parse_dict());
}
dict
}
pub fn synonyms(word: impl AsRef<str>) -> Vec<String> {
let mut s = dict()
.get(word.as_ref())
.map(|x| x.clone())
.unwrap_or_default();
s.dedup();
s.sort_by(|a, b| a.cmp(&b));
s
}
fn parse_dict() -> HashMap<String, Vec<String>> {
let mut dict: HashMap<String, Vec<String>> = HashMap::new();
#[cfg(feature = "wordnet")]
for line in thesaurus_wordnet::uncompress().lines() {
parse_dict_line(line, &mut dict);
}
#[cfg(feature = "moby")]
for line in thesaurus_moby::uncompress().lines() {
parse_dict_line(line, &mut dict);
}
dict
}
fn parse_dict_line(line: &str, dict: &mut HashMap<String, Vec<String>>) {
let mut line: Vec<String> = line.split('|').map(|x| x.to_string().to_lowercase()).collect();
let name = line.remove(0);
if let Some(x) = dict.get_mut(&name) {
x.extend_from_slice(&line);
x.dedup();
} else {
dict.insert(name, line);
}
}