forked from drahnr/cargo-spellcheck
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.rs
77 lines (65 loc) · 3.04 KB
/
build.rs
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
76
77
#[cfg(all(not(feature = "hunspell"), not(feature = "nlprules")))]
compile_error!("Well, cargo-spellcheck needs either `nlprules` or `hunspell` feature enabled.");
use std::env;
#[cfg(feature = "nlprules")]
use std::io::BufReader;
use std::path::PathBuf;
#[cfg(feature = "nlprules")]
use xz2::bufread::{XzDecoder, XzEncoder};
fn main() -> std::result::Result<(), Box<(dyn std::error::Error + 'static)>> {
println!("cargo:rerun-if-changed=build.rs");
println!("cargo:rerun-if-changed=Cargo.toml");
let out = env::var("OUT_DIR").expect("OUT_DIR exists in env vars. qed");
let out = PathBuf::from(out);
#[cfg(feature = "nlprules")]
{
const COMPRESSION_EXTENSION: &str = "xz";
const ARTIFACTS_DIR: &str = "nlprule-data";
println!("cargo:rerun-if-changed=nlprule-data/en_rules.bin.xz");
println!("cargo:rerun-if-changed=nlprule-data/en_tokenizer.bin.xz");
println!("cargo:rerun-if-changed={}/en_rules.bin", out.display());
println!("cargo:rerun-if-changed={}/en_tokenizer.bin", out.display());
let cwd = env::current_dir().expect("Current dir must exist. qed");
let cache_dir = Some(cwd.join(ARTIFACTS_DIR));
nlprule_build::BinaryBuilder::new(&["en"], &out)
.fallback_to_build_dir(false)
.cache_dir(cache_dir)
.transform(
|source, mut sink| {
let mut encoder = XzEncoder::new(BufReader::new(source), 9);
std::io::copy(&mut encoder, &mut sink)?;
Ok(())
},
|mut path: PathBuf| -> Result<PathBuf, Box<(dyn std::error::Error + Send + Sync + 'static)>> {
let mut ext = path.extension().map(|s| {
s.to_os_string()
.into_string()
.expect("Extension conversion from OSString to regular string works. qed") })
.unwrap_or_else(|| String::with_capacity(4));
ext.push('.');
ext.push_str(COMPRESSION_EXTENSION);
path.set_extension(ext);
Ok(path)
})
.build()?
.postprocess(
|source, mut sink| {
let mut decoder = XzDecoder::new(BufReader::new(source));
std::io::copy(&mut decoder, &mut sink)?;
Ok(())
},
|mut path: PathBuf| -> PathBuf {
let ext = path.extension()
.map(|s| { s.to_os_string().into_string().expect("Extension conversion from OSString to regular string works. qed") })
.unwrap_or_else(|| String::with_capacity(4));
assert!(&ext.ends_with(COMPRESSION_EXTENSION));
let k = ext.len().saturating_sub(COMPRESSION_EXTENSION.len() + 1);
path.set_extension(&ext[..k]);
path
}
)?
.validate()?;
}
let _ = out;
Ok(())
}