rollup merge of #21782: alexcrichton/issue-21771

Previously if --extern was specified it would not override crates in the
standard distribution, leading to issues like #21771. This commit alters the
behavior such that if --extern is passed then it will always override any other
choice of crates and no previous match will be used (unless it is the same path
as --extern).

Closes #21771
This commit is contained in:
Alex Crichton 2015-02-02 10:56:59 -08:00
commit 7b185f9cda
4 changed files with 35 additions and 0 deletions

View File

@ -330,6 +330,7 @@ impl<'a> CrateReader<'a> {
if found {
ret = Some(cnum);
}
return
}
// Alright, so we've gotten this far which means that `data` has the

View File

@ -0,0 +1,5 @@
-include ../tools.mk
all:
$(RUSTC) libc.rs
$(RUSTC) main.rs --extern libc=$(TMPDIR)/liblibc.rlib

View File

@ -0,0 +1,13 @@
// 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 <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.
#![crate_type = "lib"]
pub fn foo() {}

View File

@ -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 <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.
extern crate libc;
fn main() {
libc::foo();
}