From e5593a1a1040c1ea04c88660844dd16481998167 Mon Sep 17 00:00:00 2001 From: Etienne Tremel <995474+etiennetremel@users.noreply.github.com> Date: Thu, 13 Jun 2024 21:34:34 +0200 Subject: [PATCH] feat: add --no-default-features flag --- cargo-espflash/src/main.rs | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/cargo-espflash/src/main.rs b/cargo-espflash/src/main.rs index 48cdd421..f01d1710 100644 --- a/cargo-espflash/src/main.rs +++ b/cargo-espflash/src/main.rs @@ -128,6 +128,9 @@ struct BuildArgs { /// Comma delimited list of build features #[arg(long, use_value_delimiter = true)] pub features: Option>, + /// Do not activate the `default` feature + #[arg(long)] + pub no_default_features: bool, /// Require Cargo.lock and cache are up to date #[arg(long)] pub frozen: bool, @@ -373,6 +376,9 @@ fn build( .ok_or_else(|| NoTargetError::new(Some(chip)))?; let mut metadata_cmd = MetadataCommand::new(); + if build_options.no_default_features { + metadata_cmd.features(cargo_metadata::CargoOpt::NoDefaultFeatures); + } if let Some(features) = &build_options.features { metadata_cmd.features(cargo_metadata::CargoOpt::SomeFeatures(features.clone())); } @@ -435,6 +441,10 @@ fn build( args.push(package.to_string()); } + if build_options.no_default_features { + args.push("--no-default-features".to_string()); + } + if let Some(features) = &build_options.features { args.push("--features".to_string()); args.push(features.join(","));