From d3cd15bf3081ddbd4720984001e3f2a09f53d621 Mon Sep 17 00:00:00 2001 From: David Tolnay Date: Tue, 19 Dec 2023 19:15:11 -0800 Subject: [PATCH] Propagate cargo features from source manifest --- src/dependencies.rs | 2 ++ src/run.rs | 10 ++-------- 2 files changed, 4 insertions(+), 8 deletions(-) diff --git a/src/dependencies.rs b/src/dependencies.rs index 6b25485..934ae61 100644 --- a/src/dependencies.rs +++ b/src/dependencies.rs @@ -96,6 +96,8 @@ pub struct WorkspacePackage { #[derive(Deserialize, Default, Debug)] pub struct Manifest { + #[serde(rename = "cargo-features", default)] + pub cargo_features: Vec, #[serde(default)] pub package: Package, #[serde(default)] diff --git a/src/run.rs b/src/run.rs index 3e95649..e0e5503 100644 --- a/src/run.rs +++ b/src/run.rs @@ -5,7 +5,7 @@ use crate::env::Update; use crate::error::{Error, Result}; use crate::expand::{expand_globs, ExpandedTest}; use crate::flock::Lock; -use crate::manifest::{Bin, Build, Config, Edition, Manifest, Name, Package, Workspace}; +use crate::manifest::{Bin, Build, Config, Manifest, Name, Package, Workspace}; use crate::message::{self, Fail, Warn}; use crate::normalize::{self, Context, Variations}; use crate::{features, rustflags, Expected, Runner, Test}; @@ -222,12 +222,6 @@ impl Runner { .ok_or(Error::NoWorkspaceManifest)?, }; - let cargo_features = if let Edition::E2024 = edition { - vec!["edition2024".to_owned()] - } else { - vec![] - }; - let mut dependencies = Map::new(); dependencies.extend(source_manifest.dependencies); dependencies.extend(source_manifest.dev_dependencies); @@ -292,7 +286,7 @@ impl Runner { } let mut manifest = Manifest { - cargo_features, + cargo_features: source_manifest.cargo_features, package: Package { name: project_name.to_owned(), version: "0.0.0".to_owned(),