privacy: walk associated types in trait impls

This commit is contained in:
Jorge Aparicio 2015-03-02 23:26:14 -05:00
parent b4c965ee80
commit ac84af24db
2 changed files with 53 additions and 1 deletions

View File

@ -1376,10 +1376,11 @@ impl<'a, 'tcx, 'v> Visitor<'v> for VisiblePrivateTypesVisitor<'a, 'tcx> {
} }
} }
Some(ref tr) => { Some(ref tr) => {
// Any private types in a trait impl fall into two // Any private types in a trait impl fall into three
// categories. // categories.
// 1. mentioned in the trait definition // 1. mentioned in the trait definition
// 2. mentioned in the type params/generics // 2. mentioned in the type params/generics
// 3. mentioned in the associated types of the impl
// //
// Those in 1. can only occur if the trait is in // Those in 1. can only occur if the trait is in
// this crate and will've been warned about on the // this crate and will've been warned about on the
@ -1389,6 +1390,16 @@ impl<'a, 'tcx, 'v> Visitor<'v> for VisiblePrivateTypesVisitor<'a, 'tcx> {
// Those in 2. are warned via walk_generics and this // Those in 2. are warned via walk_generics and this
// call here. // call here.
visit::walk_path(self, &tr.path); visit::walk_path(self, &tr.path);
// Those in 3. are warned with this call.
for impl_item in impl_items {
match *impl_item {
ast::MethodImplItem(..) => {},
ast::TypeImplItem(ref typedef) => {
self.visit_ty(&typedef.typ);
}
}
}
} }
} }
} else if trait_ref.is_none() && self_is_public_path { } else if trait_ref.is_none() && self_is_public_path {

View File

@ -0,0 +1,41 @@
// 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.
pub struct PublicType;
struct PrivateType;
pub trait PublicTrait {
type Item;
}
trait PrivateTrait {
type Item;
}
impl PublicTrait for PublicType {
type Item = PrivateType; //~ ERROR private type in exported type signature
}
// OK
impl PublicTrait for PrivateType {
type Item = PrivateType;
}
// OK
impl PrivateTrait for PublicType {
type Item = PrivateType;
}
// OK
impl PrivateTrait for PrivateType {
type Item = PrivateType;
}
fn main() {}