Skip to content

Commit

Permalink
rustc: Encode the visibility of foreign items
Browse files Browse the repository at this point in the history
The privacy pass of the compiler was previously not taking into account the
privacy of foreign items, or bindings to external functions. This commit fixes
this oversight by encoding the visibility of foreign items into the metadata for
each crate.

Any code relying on this will start to fail to  compile and the bindings must be
marked with `pub` to indicate that they can be used externally.

Closes #16725
[breaking-change]
  • Loading branch information
alexcrichton committed Aug 25, 2014
1 parent 17f79af commit 1c76d55
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 1 deletion.
1 change: 1 addition & 0 deletions src/librustc/metadata/encoder.rs
Expand Up @@ -1371,6 +1371,7 @@ fn encode_info_for_foreign_item(ecx: &EncodeContext,

rbml_w.start_tag(tag_items_data_item);
encode_def_id(rbml_w, local_def(nitem.id));
encode_visibility(rbml_w, nitem.vis);
match nitem.node {
ForeignItemFn(..) => {
encode_family(rbml_w, style_fn_family(NormalFn));
Expand Down
2 changes: 1 addition & 1 deletion src/test/auxiliary/foreign_lib.rs
Expand Up @@ -15,6 +15,6 @@ pub mod rustrt {

#[link(name = "rust_test_helpers")]
extern {
fn rust_get_test_int() -> libc::intptr_t;
pub fn rust_get_test_int() -> libc::intptr_t;
}
}
14 changes: 14 additions & 0 deletions src/test/auxiliary/issue-16725.rs
@@ -0,0 +1,14 @@
// 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.

extern {
fn bar();
}

19 changes: 19 additions & 0 deletions src/test/compile-fail/issue-16725.rs
@@ -0,0 +1,19 @@
// 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.

// aux-build:issue-16725.rs

extern crate foo = "issue-16725";

fn main() {
unsafe { foo::bar(); }
//~^ ERROR: function `bar` is private
}

5 comments on commit 1c76d55

@bors
Copy link
Contributor

@bors bors commented on 1c76d55 Aug 25, 2014

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

saw approval from pcwalton
at alexcrichton@1c76d55

@bors
Copy link
Contributor

@bors bors commented on 1c76d55 Aug 25, 2014

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

merging alexcrichton/rust/issue-16725 = 1c76d55 into auto

@bors
Copy link
Contributor

@bors bors commented on 1c76d55 Aug 25, 2014

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

alexcrichton/rust/issue-16725 = 1c76d55 merged ok, testing candidate = 5fb2dfa

@bors
Copy link
Contributor

@bors bors commented on 1c76d55 Aug 25, 2014

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

fast-forwarding master to auto = 5fb2dfa

Please sign in to comment.