diff --git a/Cargo.lock b/Cargo.lock index dd4d48c126f..a912eee97db 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -176,7 +176,6 @@ dependencies = [ "getopts", "ignore", "libc", - "merge", "num_cpus", "once_cell", "opener", @@ -2220,12 +2219,6 @@ dependencies = [ "autocfg", ] -[[package]] -name = "merge" -version = "0.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "10bbef93abb1da61525bbc45eeaff6473a41907d19f8f9aa5168d214e10693e9" - [[package]] name = "minifier" version = "0.0.41" diff --git a/src/bootstrap/Cargo.toml b/src/bootstrap/Cargo.toml index 1f218dd8d67..b68b2163f87 100644 --- a/src/bootstrap/Cargo.toml +++ b/src/bootstrap/Cargo.toml @@ -47,7 +47,6 @@ toml = "0.5" time = "0.1" ignore = "0.4.10" opener = "0.5" -merge = { version = "0.1.0", default-features = false, features = ["std"] } once_cell = "1.7.2" [target.'cfg(windows)'.dependencies.winapi] diff --git a/src/bootstrap/config.rs b/src/bootstrap/config.rs index fcca783fbfe..c930657c5bd 100644 --- a/src/bootstrap/config.rs +++ b/src/bootstrap/config.rs @@ -18,7 +18,6 @@ pub use crate::flags::Subcommand; use crate::flags::{Color, Flags}; use crate::util::exe; use build_helper::t; -use merge::Merge; use serde::Deserialize; macro_rules! check_ci_llvm { @@ -334,6 +333,10 @@ struct TomlConfig { profile: Option, } +trait Merge { + fn merge(&mut self, other: Self); +} + impl Merge for TomlConfig { fn merge( &mut self, @@ -357,6 +360,8 @@ impl Merge for TomlConfig { } } +// We are using a decl macro instead of a derive proc macro here to reduce the compile time of +// rustbuild. macro_rules! derive_merge { ($(#[$attr:meta])* struct $name:ident { $($field:ident: $field_ty:ty,)* @@ -369,7 +374,9 @@ macro_rules! derive_merge { impl Merge for $name { fn merge(&mut self, other: Self) { $( - Merge::merge(&mut self.$field, other.$field); + if !self.$field.is_some() { + self.$field = other.$field; + } )* } }