mirror of
https://github.com/RGBCube/uutils-coreutils
synced 2025-07-27 11:07:44 +00:00
build/fix ~ (build.rs) fix 'feature => sub-crate/util' translation logic + improved output formatting
This commit is contained in:
parent
0cb5fbd6b5
commit
1fe7cc5595
1 changed files with 47 additions and 38 deletions
75
build.rs
75
build.rs
|
@ -11,18 +11,22 @@ pub fn main() {
|
||||||
println!("cargo:rustc-cfg=build={:?}", profile);
|
println!("cargo:rustc-cfg=build={:?}", profile);
|
||||||
}
|
}
|
||||||
|
|
||||||
let feature_prefix = "CARGO_FEATURE_";
|
let env_feature_prefix: &str = "CARGO_FEATURE_";
|
||||||
|
let feature_prefix: &str = "feat_";
|
||||||
|
let override_prefix: &str = "uu_";
|
||||||
|
|
||||||
let out_dir = env::var("OUT_DIR").unwrap();
|
let out_dir = env::var("OUT_DIR").unwrap();
|
||||||
|
|
||||||
let mut crates = Vec::new();
|
let mut crates = Vec::new();
|
||||||
for (key, val) in env::vars() {
|
for (key, val) in env::vars() {
|
||||||
if val == "1" && key.starts_with(feature_prefix) {
|
if val == "1" && key.starts_with(env_feature_prefix) {
|
||||||
let krate = key[feature_prefix.len()..].to_lowercase();
|
let krate = key[env_feature_prefix.len()..].to_lowercase();
|
||||||
match krate.as_ref() {
|
match krate.as_ref() {
|
||||||
"default" | "macos" | "unix" | "windows" => continue,
|
"default" | "macos" | "unix" | "windows" => continue, // common/standard feature names
|
||||||
"nightly" | "test_unimplemented" => continue,
|
"nightly" | "test_unimplemented" => continue, // crate-local custom features
|
||||||
s if s.starts_with("feat_") => continue,
|
"test" => continue, // over-ridden with 'uu_test' to avoid collision with rust core crate 'test'
|
||||||
_ => {}
|
s if s.starts_with(feature_prefix) => continue, // crate feature sets
|
||||||
|
_ => {} // util feature name
|
||||||
}
|
}
|
||||||
crates.push(krate.to_string());
|
crates.push(krate.to_string());
|
||||||
}
|
}
|
||||||
|
@ -32,50 +36,55 @@ pub fn main() {
|
||||||
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();
|
||||||
|
|
||||||
mf.write_all(
|
mf.write_all(
|
||||||
|
"type UtilityMap = HashMap<&'static str, fn(Vec<String>) -> i32>;\n\
|
||||||
|
\n\
|
||||||
|
fn util_map() -> UtilityMap {\n\
|
||||||
|
\tlet mut map: UtilityMap = HashMap::new();\n\
|
||||||
"
|
"
|
||||||
type UtilityMap = HashMap<&'static str, fn(Vec<String>) -> i32>;
|
|
||||||
|
|
||||||
fn util_map() -> UtilityMap {
|
|
||||||
let mut map: UtilityMap = HashMap::new();\n"
|
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
for krate in crates {
|
for krate in crates {
|
||||||
match krate.as_ref() {
|
match krate.as_ref() {
|
||||||
// ToDO: add another bypass method for publishing name collisions requiring a non-`uu_` prefix for a util
|
k if k.starts_with(override_prefix) => mf
|
||||||
// * use "uu_" prefix as bypass method to avoid name collisions with imported crates, when necessary (eg, 'test')
|
|
||||||
k if k.starts_with("uu_")
|
|
||||||
=> mf
|
|
||||||
.write_all(
|
.write_all(
|
||||||
format!("map.insert(\"{k}\", {krate}::uumain);\n", k = krate.clone().remove("uu_".len()), krate = krate)
|
format!(
|
||||||
|
"\tmap.insert(\"{k}\", {krate}::uumain);\n",
|
||||||
|
k = krate[override_prefix.len()..].to_string(),
|
||||||
|
krate = krate
|
||||||
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap(),
|
.unwrap(),
|
||||||
"false" | "true" => mf
|
"false" | "true" => mf
|
||||||
.write_all(
|
.write_all(
|
||||||
format!("map.insert(\"{krate}\", r#{krate}::uumain);\n", krate = krate)
|
format!(
|
||||||
|
"\tmap.insert(\"{krate}\", r#{krate}::uumain);\n",
|
||||||
|
krate = krate
|
||||||
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
)
|
)
|
||||||
.unwrap(),
|
.unwrap(),
|
||||||
"hashsum" => mf
|
"hashsum" => mf
|
||||||
.write_all(
|
.write_all(
|
||||||
format!(
|
format!(
|
||||||
"
|
"\
|
||||||
map.insert(\"{krate}\", {krate}::uumain);
|
\tmap.insert(\"{krate}\", {krate}::uumain);\n\
|
||||||
map.insert(\"md5sum\", {krate}::uumain);
|
\t\tmap.insert(\"md5sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha1sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha1sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha224sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha224sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha256sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha256sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha384sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha384sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha512sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha512sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha3sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha3sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha3-224sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha3-224sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha3-256sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha3-256sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha3-384sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha3-384sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"sha3-512sum\", {krate}::uumain);
|
\t\tmap.insert(\"sha3-512sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"shake128sum\", {krate}::uumain);
|
\t\tmap.insert(\"shake128sum\", {krate}::uumain);\n\
|
||||||
map.insert(\"shake256sum\", {krate}::uumain);\n",
|
\t\tmap.insert(\"shake256sum\", {krate}::uumain);\n\
|
||||||
|
",
|
||||||
krate = krate
|
krate = krate
|
||||||
)
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
|
@ -84,7 +93,7 @@ pub fn main() {
|
||||||
_ => mf
|
_ => mf
|
||||||
.write_all(
|
.write_all(
|
||||||
format!(
|
format!(
|
||||||
"map.insert(\"{krate}\", {krate}::uumain);\n",
|
"\tmap.insert(\"{krate}\", {krate}::uumain);\n",
|
||||||
krate = krate
|
krate = krate
|
||||||
)
|
)
|
||||||
.as_bytes(),
|
.as_bytes(),
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue