rustc: Don't error on the rlib symlinks
This commit implements a layman's version of realpath() for metadata::loader to use in order to not error on symlinks pointing to the same file. Closes #12459
This commit is contained in:
parent
043c972179
commit
8922fa0122
@ -67,6 +67,18 @@ pub struct ArchiveMetadata {
|
||||
priv data: &'static [u8],
|
||||
}
|
||||
|
||||
// FIXME(#11857) this should be a "real" realpath
|
||||
fn realpath(p: &Path) -> Path {
|
||||
use std::os;
|
||||
use std::io::fs;
|
||||
|
||||
let path = os::make_absolute(p);
|
||||
match fs::readlink(&path) {
|
||||
Ok(p) => p,
|
||||
Err(..) => path
|
||||
}
|
||||
}
|
||||
|
||||
impl Context {
|
||||
pub fn load_library_crate(&self, root_ident: Option<~str>) -> Library {
|
||||
match self.find_library_crate() {
|
||||
@ -121,7 +133,7 @@ impl Context {
|
||||
(HashSet::new(), HashSet::new())
|
||||
});
|
||||
let (ref mut rlibs, _) = *slot;
|
||||
rlibs.insert(path.clone());
|
||||
rlibs.insert(realpath(path));
|
||||
FileMatches
|
||||
}
|
||||
None => {
|
||||
@ -138,7 +150,7 @@ impl Context {
|
||||
(HashSet::new(), HashSet::new())
|
||||
});
|
||||
let (_, ref mut dylibs) = *slot;
|
||||
dylibs.insert(path.clone());
|
||||
dylibs.insert(realpath(path));
|
||||
FileMatches
|
||||
}
|
||||
None => {
|
||||
|
7
src/test/run-make/symlinked-libraries/Makefile
Normal file
7
src/test/run-make/symlinked-libraries/Makefile
Normal file
@ -0,0 +1,7 @@
|
||||
-include ../tools.mk
|
||||
|
||||
all:
|
||||
$(RUSTC) foo.rs
|
||||
mkdir -p $(TMPDIR)/other
|
||||
ln -nsf $(TMPDIR)/$(call DYLIB_GLOB,foo) $(TMPDIR)/other
|
||||
$(RUSTC) bar.rs -L $(TMPDIR)/other
|
15
src/test/run-make/symlinked-libraries/bar.rs
Normal file
15
src/test/run-make/symlinked-libraries/bar.rs
Normal file
@ -0,0 +1,15 @@
|
||||
// Copyright 2012-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.
|
||||
|
||||
extern crate foo;
|
||||
|
||||
fn main() {
|
||||
foo::bar();
|
||||
}
|
13
src/test/run-make/symlinked-libraries/foo.rs
Normal file
13
src/test/run-make/symlinked-libraries/foo.rs
Normal file
@ -0,0 +1,13 @@
|
||||
// Copyright 2012-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.
|
||||
|
||||
#[crate_type = "dylib"];
|
||||
|
||||
pub fn bar() {}
|
Loading…
x
Reference in New Issue
Block a user