mirror of
https://github.com/RGBCube/uutils-coreutils
synced 2025-07-27 11:07:44 +00:00
maint/build ~ (build.rs) support new tests directory organization
This commit is contained in:
parent
1b3bb56e66
commit
413b63bf5f
1 changed files with 61 additions and 12 deletions
73
build.rs
73
build.rs
|
@ -6,6 +6,8 @@ use std::io::Write;
|
||||||
use std::path::Path;
|
use std::path::Path;
|
||||||
|
|
||||||
pub fn main() {
|
pub fn main() {
|
||||||
|
// println!("cargo:warning=Running build.rs");
|
||||||
|
|
||||||
if let Ok(profile) = env::var("PROFILE") {
|
if let Ok(profile) = env::var("PROFILE") {
|
||||||
println!("cargo:rustc-cfg=build={:?}", profile);
|
println!("cargo:rustc-cfg=build={:?}", profile);
|
||||||
}
|
}
|
||||||
|
@ -15,6 +17,11 @@ pub fn main() {
|
||||||
let override_prefix: &str = "uu_";
|
let override_prefix: &str = "uu_";
|
||||||
|
|
||||||
let out_dir = env::var("OUT_DIR").unwrap();
|
let out_dir = env::var("OUT_DIR").unwrap();
|
||||||
|
// println!("cargo:warning=out_dir={}", out_dir);
|
||||||
|
let manifest_dir = env::var("CARGO_MANIFEST_DIR").unwrap().replace("\\", "/");
|
||||||
|
// println!("cargo:warning=manifest_dir={}", manifest_dir);
|
||||||
|
let util_tests_dir = format!("{}/tests/by-util", manifest_dir);
|
||||||
|
// println!("cargo:warning=util_tests_dir={}", util_tests_dir);
|
||||||
|
|
||||||
let mut crates = Vec::new();
|
let mut crates = Vec::new();
|
||||||
for (key, val) in env::vars() {
|
for (key, val) in env::vars() {
|
||||||
|
@ -33,6 +40,7 @@ pub fn main() {
|
||||||
crates.sort();
|
crates.sort();
|
||||||
|
|
||||||
let mut mf = File::create(Path::new(&out_dir).join("uutils_map.rs")).unwrap();
|
let mut mf = File::create(Path::new(&out_dir).join("uutils_map.rs")).unwrap();
|
||||||
|
let mut tf = File::create(Path::new(&out_dir).join("test_modules.rs")).unwrap();
|
||||||
|
|
||||||
mf.write_all(
|
mf.write_all(
|
||||||
"type UtilityMap = HashMap<&'static str, fn(Vec<String>) -> i32>;\n\
|
"type UtilityMap = HashMap<&'static str, fn(Vec<String>) -> i32>;\n\
|
||||||
|
@ -46,8 +54,8 @@ pub fn main() {
|
||||||
|
|
||||||
for krate in crates {
|
for krate in crates {
|
||||||
match krate.as_ref() {
|
match krate.as_ref() {
|
||||||
k if k.starts_with(override_prefix) => mf
|
k if k.starts_with(override_prefix) => {
|
||||||
.write_all(
|
mf.write_all(
|
||||||
format!(
|
format!(
|
||||||
"\tmap.insert(\"{k}\", {krate}::uumain);\n",
|
"\tmap.insert(\"{k}\", {krate}::uumain);\n",
|
||||||
k = krate[override_prefix.len()..].to_string(),
|
k = krate[override_prefix.len()..].to_string(),
|
||||||
|
@ -55,18 +63,38 @@ pub fn main() {
|
||||||
)
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap(),
|
.unwrap();
|
||||||
"false" | "true" => mf
|
tf.write_all(
|
||||||
.write_all(
|
format!(
|
||||||
|
"#[path=\"{dir}/test_{k}.rs\"]\nmod test_{k};\n",
|
||||||
|
k = krate[override_prefix.len()..].to_string(),
|
||||||
|
dir = util_tests_dir,
|
||||||
|
)
|
||||||
|
.as_bytes(),
|
||||||
|
)
|
||||||
|
.unwrap()
|
||||||
|
}
|
||||||
|
"false" | "true" => {
|
||||||
|
mf.write_all(
|
||||||
format!(
|
format!(
|
||||||
"\tmap.insert(\"{krate}\", r#{krate}::uumain);\n",
|
"\tmap.insert(\"{krate}\", r#{krate}::uumain);\n",
|
||||||
krate = krate
|
krate = krate
|
||||||
)
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap(),
|
.unwrap();
|
||||||
"hashsum" => mf
|
tf.write_all(
|
||||||
.write_all(
|
format!(
|
||||||
|
"#[path=\"{dir}/test_{krate}.rs\"]\nmod test_{krate};\n",
|
||||||
|
krate = krate,
|
||||||
|
dir = util_tests_dir,
|
||||||
|
)
|
||||||
|
.as_bytes(),
|
||||||
|
)
|
||||||
|
.unwrap()
|
||||||
|
}
|
||||||
|
"hashsum" => {
|
||||||
|
mf.write_all(
|
||||||
format!(
|
format!(
|
||||||
"\
|
"\
|
||||||
\tmap.insert(\"{krate}\", {krate}::uumain);\n\
|
\tmap.insert(\"{krate}\", {krate}::uumain);\n\
|
||||||
|
@ -88,20 +116,41 @@ pub fn main() {
|
||||||
)
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap(),
|
.unwrap();
|
||||||
_ => mf
|
tf.write_all(
|
||||||
.write_all(
|
format!(
|
||||||
|
"#[path=\"{dir}/test_{krate}.rs\"]\nmod test_{krate};\n",
|
||||||
|
krate = krate,
|
||||||
|
dir = util_tests_dir,
|
||||||
|
)
|
||||||
|
.as_bytes(),
|
||||||
|
)
|
||||||
|
.unwrap()
|
||||||
|
}
|
||||||
|
_ => {
|
||||||
|
mf.write_all(
|
||||||
format!(
|
format!(
|
||||||
"\tmap.insert(\"{krate}\", {krate}::uumain);\n",
|
"\tmap.insert(\"{krate}\", {krate}::uumain);\n",
|
||||||
krate = krate
|
krate = krate
|
||||||
)
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap(),
|
.unwrap();
|
||||||
|
tf.write_all(
|
||||||
|
format!(
|
||||||
|
"#[path=\"{dir}/test_{krate}.rs\"]\nmod test_{krate};\n",
|
||||||
|
krate = krate,
|
||||||
|
dir = util_tests_dir,
|
||||||
|
)
|
||||||
|
.as_bytes(),
|
||||||
|
)
|
||||||
|
.unwrap()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mf.write_all(b"map\n}\n").unwrap();
|
mf.write_all(b"map\n}\n").unwrap();
|
||||||
|
|
||||||
mf.flush().unwrap();
|
mf.flush().unwrap();
|
||||||
|
tf.flush().unwrap();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue