From 73cfc8b15f0086d8134ab74d953a4c07a34a7d0d Mon Sep 17 00:00:00 2001 From: Nick Alexander Date: Tue, 9 Jun 2020 14:03:02 -0700 Subject: [PATCH] For non-MSVC, separate flags/options from the input file. (#513) This avoids a `clang-cl` issue common when cross-compiling from macOS to Windows: the `-Wslash-u-filename` where a `/Users/...` path is interpreted as the `cl.exe` flag `/U`. In general it's somewhere between harmless and good form to separate flags/options from input files, so `--` is used for all compilers save MSVC. There are no existing tests mocking out `clang-cl` and surface efforts didn't succeed, so that will have to wait for follow-up. --- src/lib.rs | 3 +++ tests/support/mod.rs | 9 +++++++++ tests/test.rs | 16 ++++++++++++++++ 3 files changed, 28 insertions(+) diff --git a/src/lib.rs b/src/lib.rs index 9abcc4915..c56888d31 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -1171,6 +1171,9 @@ impl Build { if !msvc || !is_asm || !is_arm { cmd.arg("-c"); } + if !msvc || compiler.family == (ToolFamily::Msvc { clang_cl: true }) { + cmd.arg("--"); // #513: For non-MSVC, separate flags/options from the input file. + } cmd.arg(&obj.src); run(&mut cmd, &name)?; diff --git a/tests/support/mod.rs b/tests/support/mod.rs index cde930e90..b56f7d7c3 100644 --- a/tests/support/mod.rs +++ b/tests/support/mod.rs @@ -151,6 +151,15 @@ impl Execution { }; self } + + pub fn must_end_with>(&self, p: &[P]) -> &Execution { + let expected = p.iter().map(|x| x.as_ref()).collect::>(); + if !self.args.iter().map(|x| OsStr::new(x)).collect::>().as_slice().ends_with(expected.as_slice()) { + panic!("did not end with {:?}", expected); + } else { + self + } + } } /// Hard link an executable or copy it if that fails. diff --git a/tests/test.rs b/tests/test.rs index 3c9b4dc49..e86e2130b 100644 --- a/tests/test.rs +++ b/tests/test.rs @@ -343,6 +343,14 @@ fn gnu_static() { test.cmd(0).must_have("-static").must_not_have("-shared"); } +#[test] +fn gnu_dash_dash() { + let test = Test::gnu(); + test.gcc().file("foo.c").compile("foo"); + + test.cmd(0).must_end_with(&["--", "foo.c"]); +} + #[test] fn msvc_smoke() { reset_env(); @@ -411,3 +419,11 @@ fn msvc_no_static_crt() { test.cmd(0).must_have("-MD"); } + +#[test] +fn msvc_no_dash_dash() { + let test = Test::msvc(); + test.gcc().file("foo.c").compile("foo"); + + test.cmd(0).must_not_have("--"); +}