From 2d664b0b8f6b6b2238ca48c782dbc4b5c69f8266 Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Thu, 14 May 2015 11:53:37 -0700 Subject: [PATCH] rustc_back: Don't pass 'u' to ar invocations This flag indicates that when files are being replaced or added to archives (the `r` flag) that the new file should not be inserted if it is not newer than the file that already exists in the archive. The compiler never actually has a use case of *not* wanting to insert a file because it already exists, and this causes rlibs to not be updated in some cases when the compiler was re-run too quickly. Closes #18913 --- src/librustc_back/archive.rs | 2 +- src/test/auxiliary/issue-18913-1.rs | 16 ++++++++++++++++ src/test/auxiliary/issue-18913-2.rs | 16 ++++++++++++++++ src/test/run-pass/issue-18913.rs | 18 ++++++++++++++++++ 4 files changed, 51 insertions(+), 1 deletion(-) create mode 100644 src/test/auxiliary/issue-18913-1.rs create mode 100644 src/test/auxiliary/issue-18913-2.rs create mode 100644 src/test/run-pass/issue-18913.rs diff --git a/src/librustc_back/archive.rs b/src/librustc_back/archive.rs index 39d1f5ba205e4..deac411800f1f 100644 --- a/src/librustc_back/archive.rs +++ b/src/librustc_back/archive.rs @@ -152,7 +152,7 @@ impl<'a> Archive<'a> { cmd.arg("d").arg(dst).arg(file); } Action::AddObjects(objs, update_symbols) => { - cmd.arg(if update_symbols {"crus"} else {"cruS"}) + cmd.arg(if update_symbols {"crs"} else {"crS"}) .arg(dst) .args(objs); } diff --git a/src/test/auxiliary/issue-18913-1.rs b/src/test/auxiliary/issue-18913-1.rs new file mode 100644 index 0000000000000..4315e27797f1e --- /dev/null +++ b/src/test/auxiliary/issue-18913-1.rs @@ -0,0 +1,16 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// no-prefer-dynamic + +#![crate_type = "rlib"] +#![crate_name = "foo"] + +pub fn foo() -> i32 { 0 } diff --git a/src/test/auxiliary/issue-18913-2.rs b/src/test/auxiliary/issue-18913-2.rs new file mode 100644 index 0000000000000..dcdeaec48f552 --- /dev/null +++ b/src/test/auxiliary/issue-18913-2.rs @@ -0,0 +1,16 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// no-prefer-dynamic + +#![crate_type = "rlib"] +#![crate_name = "foo"] + +pub fn foo() -> i32 { 1 } diff --git a/src/test/run-pass/issue-18913.rs b/src/test/run-pass/issue-18913.rs new file mode 100644 index 0000000000000..9bb1371045e9a --- /dev/null +++ b/src/test/run-pass/issue-18913.rs @@ -0,0 +1,18 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// aux-build:issue-18913-1.rs +// aux-build:issue-18913-2.rs + +extern crate foo; + +fn main() { + assert_eq!(foo::foo(), 1); +}