diff options
| author | bors <bors@rust-lang.org> | 2014-03-04 18:26:40 -0800 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2014-03-04 18:26:40 -0800 |
| commit | f1955e028cd3ea5097845f183f8cd099014ac6d8 (patch) | |
| tree | 41db094896455a00a7a44e65bfc61eb646b5396e | |
| parent | dcb24f5450c88ef17d47304685d2a1a0d82b2dbd (diff) | |
| parent | 4cdc6ce3374f934b6c8cab986d3b0c83119fed6f (diff) | |
| download | rust-f1955e028cd3ea5097845f183f8cd099014ac6d8.tar.gz rust-f1955e028cd3ea5097845f183f8cd099014ac6d8.zip | |
auto merge of #12688 : alexcrichton/rust/fix-some-link-args, r=brson
Linker argument order with respect to libraries is important enough that we shouldn't be attempting to filter out libraries getting passed through to the linker. When linking with a native library that has multiple dependant native libraries, it's useful to have control over the link argument order.
| -rw-r--r-- | src/librustc/metadata/cstore.rs | 7 | ||||
| -rw-r--r-- | src/test/run-make/no-duplicate-libs/Makefile | 6 | ||||
| -rw-r--r-- | src/test/run-make/no-duplicate-libs/bar.c | 3 | ||||
| -rw-r--r-- | src/test/run-make/no-duplicate-libs/foo.c | 1 | ||||
| -rw-r--r-- | src/test/run-make/no-duplicate-libs/main.rs | 20 |
5 files changed, 31 insertions, 6 deletions
diff --git a/src/librustc/metadata/cstore.rs b/src/librustc/metadata/cstore.rs index baca85d50ae..d6cee8fadb5 100644 --- a/src/librustc/metadata/cstore.rs +++ b/src/librustc/metadata/cstore.rs @@ -154,15 +154,10 @@ impl CStore { .collect() } - pub fn add_used_library(&self, lib: ~str, kind: NativeLibaryKind) - -> bool { + pub fn add_used_library(&self, lib: ~str, kind: NativeLibaryKind) { assert!(!lib.is_empty()); let mut used_libraries = self.used_libraries.borrow_mut(); - if used_libraries.get().iter().any(|&(ref x, _)| x == &lib) { - return false; - } used_libraries.get().push((lib, kind)); - true } pub fn get_used_libraries<'a>(&'a self) diff --git a/src/test/run-make/no-duplicate-libs/Makefile b/src/test/run-make/no-duplicate-libs/Makefile new file mode 100644 index 00000000000..1417da3de36 --- /dev/null +++ b/src/test/run-make/no-duplicate-libs/Makefile @@ -0,0 +1,6 @@ +-include ../tools.mk + +all: $(call STATICLIB,foo) $(call STATICLIB,bar) + $(RUSTC) main.rs + $(call RUN,main) + diff --git a/src/test/run-make/no-duplicate-libs/bar.c b/src/test/run-make/no-duplicate-libs/bar.c new file mode 100644 index 00000000000..330d914a011 --- /dev/null +++ b/src/test/run-make/no-duplicate-libs/bar.c @@ -0,0 +1,3 @@ +extern void foo(); + +void bar() { foo(); } diff --git a/src/test/run-make/no-duplicate-libs/foo.c b/src/test/run-make/no-duplicate-libs/foo.c new file mode 100644 index 00000000000..85e6cd8c390 --- /dev/null +++ b/src/test/run-make/no-duplicate-libs/foo.c @@ -0,0 +1 @@ +void foo() {} diff --git a/src/test/run-make/no-duplicate-libs/main.rs b/src/test/run-make/no-duplicate-libs/main.rs new file mode 100644 index 00000000000..12ddce34582 --- /dev/null +++ b/src/test/run-make/no-duplicate-libs/main.rs @@ -0,0 +1,20 @@ +// Copyright 2014 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 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +#[link(name = "foo")] +#[link(name = "bar")] +#[link(name = "foo")] +extern { + fn bar(); +} + +fn main() { + unsafe { bar() } +} |
