Permit pub items in blocks
This commit is contained in:
parent
f59fd46425
commit
df4821698e
3 changed files with 20 additions and 121 deletions
|
|
@ -1129,35 +1129,12 @@ impl<'a, 'tcx, 'v> Visitor<'v> for PrivacyVisitor<'a, 'tcx> {
|
|||
|
||||
struct SanePrivacyVisitor<'a, 'tcx: 'a> {
|
||||
tcx: &'a ty::ctxt<'tcx>,
|
||||
in_block: bool,
|
||||
}
|
||||
|
||||
impl<'a, 'tcx, 'v> Visitor<'v> for SanePrivacyVisitor<'a, 'tcx> {
|
||||
/// We want to visit items in the context of their containing
|
||||
/// module and so forth, so supply a crate for doing a deep walk.
|
||||
fn visit_nested_item(&mut self, item: hir::ItemId) {
|
||||
self.visit_item(self.tcx.map.expect_item(item.id))
|
||||
}
|
||||
|
||||
fn visit_item(&mut self, item: &hir::Item) {
|
||||
self.check_sane_privacy(item);
|
||||
if self.in_block {
|
||||
self.check_all_inherited(item);
|
||||
}
|
||||
|
||||
let orig_in_block = self.in_block;
|
||||
|
||||
// Modules turn privacy back on, otherwise we inherit
|
||||
self.in_block = if let hir::ItemMod(..) = item.node { false } else { orig_in_block };
|
||||
|
||||
intravisit::walk_item(self, item);
|
||||
self.in_block = orig_in_block;
|
||||
}
|
||||
|
||||
fn visit_block(&mut self, b: &'v hir::Block) {
|
||||
let orig_in_block = replace(&mut self.in_block, true);
|
||||
intravisit::walk_block(self, b);
|
||||
self.in_block = orig_in_block;
|
||||
}
|
||||
}
|
||||
|
||||
|
|
@ -1206,40 +1183,6 @@ impl<'a, 'tcx> SanePrivacyVisitor<'a, 'tcx> {
|
|||
hir::ItemUse(..) | hir::ItemTy(..) => {}
|
||||
}
|
||||
}
|
||||
|
||||
/// When inside of something like a function or a method, visibility has no
|
||||
/// control over anything so this forbids any mention of any visibility
|
||||
fn check_all_inherited(&self, item: &hir::Item) {
|
||||
let check_inherited = |sp, vis| {
|
||||
if vis != hir::Inherited {
|
||||
span_err!(self.tcx.sess, sp, E0447,
|
||||
"visibility has no effect inside functions or block expressions");
|
||||
}
|
||||
};
|
||||
|
||||
check_inherited(item.span, item.vis);
|
||||
match item.node {
|
||||
hir::ItemImpl(_, _, _, _, _, ref impl_items) => {
|
||||
for impl_item in impl_items {
|
||||
check_inherited(impl_item.span, impl_item.vis);
|
||||
}
|
||||
}
|
||||
hir::ItemForeignMod(ref fm) => {
|
||||
for fi in &fm.items {
|
||||
check_inherited(fi.span, fi.vis);
|
||||
}
|
||||
}
|
||||
hir::ItemStruct(ref vdata, _) => {
|
||||
for f in vdata.fields() {
|
||||
check_inherited(f.span, f.node.kind.visibility());
|
||||
}
|
||||
}
|
||||
hir::ItemDefaultImpl(..) | hir::ItemEnum(..) | hir::ItemTrait(..) |
|
||||
hir::ItemConst(..) | hir::ItemStatic(..) | hir::ItemFn(..) |
|
||||
hir::ItemMod(..) | hir::ItemExternCrate(..) |
|
||||
hir::ItemUse(..) | hir::ItemTy(..) => {}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
|
@ -1823,11 +1766,8 @@ pub fn check_crate(tcx: &ty::ctxt,
|
|||
|
||||
// Sanity check to make sure that all privacy usage and controls are
|
||||
// reasonable.
|
||||
let mut visitor = SanePrivacyVisitor {
|
||||
tcx: tcx,
|
||||
in_block: false,
|
||||
};
|
||||
intravisit::walk_crate(&mut visitor, krate);
|
||||
let mut visitor = SanePrivacyVisitor { tcx: tcx };
|
||||
krate.visit_all_items(&mut visitor);
|
||||
|
||||
// Figure out who everyone's parent is
|
||||
let mut visitor = ParentVisitor {
|
||||
|
|
|
|||
|
|
@ -40,37 +40,30 @@ pub extern "C" { //~ ERROR unnecessary visibility qualifier
|
|||
|
||||
const MAIN: u8 = {
|
||||
trait MarkerTr {}
|
||||
pub trait Tr { //~ ERROR visibility has no effect inside functions or block
|
||||
pub trait Tr {
|
||||
fn f();
|
||||
const C: u8;
|
||||
type T;
|
||||
}
|
||||
pub struct S { //~ ERROR visibility has no effect inside functions or block
|
||||
pub a: u8 //~ ERROR visibility has no effect inside functions or block
|
||||
pub struct S {
|
||||
pub a: u8
|
||||
}
|
||||
struct Ts(pub u8); //~ ERROR visibility has no effect inside functions or block
|
||||
struct Ts(pub u8);
|
||||
|
||||
pub impl MarkerTr for .. {} //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub impl Tr for S { //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub fn f() {} //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub const C: u8 = 0; //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub type T = u8; //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
}
|
||||
pub impl S { //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub fn f() {} //~ ERROR visibility has no effect inside functions or block
|
||||
pub const C: u8 = 0; //~ ERROR visibility has no effect inside functions or block
|
||||
// pub type T = u8; // ERROR visibility has no effect inside functions or block
|
||||
pub fn f() {}
|
||||
pub const C: u8 = 0;
|
||||
// pub type T = u8;
|
||||
}
|
||||
pub extern "C" { //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub fn f(); //~ ERROR visibility has no effect inside functions or block
|
||||
pub static St: u8; //~ ERROR visibility has no effect inside functions or block
|
||||
pub fn f();
|
||||
pub static St: u8;
|
||||
}
|
||||
|
||||
0
|
||||
|
|
@ -78,36 +71,29 @@ const MAIN: u8 = {
|
|||
|
||||
fn main() {
|
||||
trait MarkerTr {}
|
||||
pub trait Tr { //~ ERROR visibility has no effect inside functions or block
|
||||
pub trait Tr {
|
||||
fn f();
|
||||
const C: u8;
|
||||
type T;
|
||||
}
|
||||
pub struct S { //~ ERROR visibility has no effect inside functions or block
|
||||
pub a: u8 //~ ERROR visibility has no effect inside functions or block
|
||||
pub struct S {
|
||||
pub a: u8
|
||||
}
|
||||
struct Ts(pub u8); //~ ERROR visibility has no effect inside functions or block
|
||||
struct Ts(pub u8);
|
||||
|
||||
pub impl MarkerTr for .. {} //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub impl Tr for S { //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub fn f() {} //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub const C: u8 = 0; //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub type T = u8; //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
}
|
||||
pub impl S { //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub fn f() {} //~ ERROR visibility has no effect inside functions or block
|
||||
pub const C: u8 = 0; //~ ERROR visibility has no effect inside functions or block
|
||||
// pub type T = u8; // ERROR visibility has no effect inside functions or block
|
||||
pub fn f() {}
|
||||
pub const C: u8 = 0;
|
||||
// pub type T = u8;
|
||||
}
|
||||
pub extern "C" { //~ ERROR unnecessary visibility qualifier
|
||||
//~^ ERROR visibility has no effect inside functions or block
|
||||
pub fn f(); //~ ERROR visibility has no effect inside functions or block
|
||||
pub static St: u8; //~ ERROR visibility has no effect inside functions or block
|
||||
pub fn f();
|
||||
pub static St: u8;
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,27 +0,0 @@
|
|||
// Copyright 2013-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.
|
||||
|
||||
fn main() {
|
||||
pub use std::usize; //~ ERROR: visibility has no effect
|
||||
pub struct A; //~ ERROR: visibility has no effect
|
||||
pub enum B {} //~ ERROR: visibility has no effect
|
||||
pub trait C { //~ ERROR: visibility has no effect
|
||||
fn foo(&self) {}
|
||||
}
|
||||
impl A {
|
||||
pub fn foo(&self) {} //~ ERROR: visibility has no effect
|
||||
}
|
||||
|
||||
struct D {
|
||||
pub foo: isize, //~ ERROR: visibility has no effect
|
||||
}
|
||||
pub fn foo() {} //~ ERROR: visibility has no effect
|
||||
pub mod bar {} //~ ERROR: visibility has no effect
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue