From 6f749949aca3b0a830d45e9d7df85d720568103f Mon Sep 17 00:00:00 2001 From: messense Date: Sun, 8 Jan 2023 22:03:43 +0800 Subject: [PATCH] Support array of `rustflags` in cargo config file --- src/common.rs | 25 ++++++++++++++++++++++--- 1 file changed, 22 insertions(+), 3 deletions(-) diff --git a/src/common.rs b/src/common.rs index ecefb79..affe88c 100644 --- a/src/common.rs +++ b/src/common.rs @@ -543,9 +543,25 @@ fn default_build_target_from_config(workdir: &Path) -> Result> { Ok(Some(target.to_string())) } +#[derive(Debug, Clone, Deserialize)] +#[serde(untagged)] +enum Rustflags { + String(String), + Array(Vec), +} + +impl From for String { + fn from(rustflags: Rustflags) -> String { + match rustflags { + Rustflags::String(flags) => flags, + Rustflags::Array(flags) => flags.join(" "), + } + } +} + #[derive(Debug, Deserialize)] struct CargoConfigRustflags { - rustflags: Option, + rustflags: Option, } #[derive(Debug, Deserialize)] @@ -582,9 +598,12 @@ fn get_rustflags(workdir: &Path, target: &str) -> Result> { let cargo_config: CargoConfig = serde_json::from_slice(&output.stdout)?; match cargo_config.target.get(target) { Some(CargoConfigRustflags { rustflags }) if rustflags.is_some() => { - Ok(rustflags.clone()) + Ok(rustflags.clone().map(|flags| flags.into())) } - _ => Ok(cargo_config.build.and_then(|c| c.rustflags)), + _ => Ok(cargo_config + .build + .and_then(|c| c.rustflags) + .map(|flags| flags.into())), } } }