From 9680ff6ccfceb6a19d38fd19eeb722ff79dc76b8 Mon Sep 17 00:00:00 2001 From: Andy Polyakov Date: Wed, 20 Sep 2023 10:35:41 +0200 Subject: [PATCH] Mirror clang's link stage on Windows. Fixes problem discussed in #811. [Also deduplicate clang --target argument on Windows, because it's passed later on in the "// Target flags" section.] --- src/lib.rs | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/src/lib.rs b/src/lib.rs index ecc5d48f5..f54d7f702 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1171,6 +1171,11 @@ impl Build { atlmfc_lib.display() )); } + + if compiler.family == ToolFamily::Clang { + // Mirror what clang does at link stage + self.print(&format_args!("cargo:rustc-link-arg=-defaultlib:oldnames")); + } } if self.link_lib_modifiers.is_empty() { @@ -1712,13 +1717,6 @@ impl Build { cmd.push_opt_unless_duplicate(format!("-O{}", opt_level).into()); } - if cmd.family == ToolFamily::Clang && target.contains("windows") { - // Disambiguate mingw and msvc on Windows. Problem is that - // depending on the origin clang can default to a mismatchig - // run-time. - cmd.push_cc_arg(format!("--target={}", target).into()); - } - if cmd.family == ToolFamily::Clang && target.contains("android") { // For compatibility with code that doesn't use pre-defined `__ANDROID__` macro. // If compiler used via ndk-build or cmake (officially supported build methods)