diff options
| author | Nick Cameron <ncameron@mozilla.com> | 2015-03-12 10:44:56 +1300 |
|---|---|---|
| committer | Nick Cameron <ncameron@mozilla.com> | 2015-03-18 16:47:24 +1300 |
| commit | 46aa621452b591e5c504fd85dfe514b92c49c228 (patch) | |
| tree | 47d070831f78420310ab3418baa5ff91b98a0010 /src/test | |
| parent | ea8b82e90c450febb1f26a07862a1ec89c22addd (diff) | |
| download | rust-46aa621452b591e5c504fd85dfe514b92c49c228.tar.gz rust-46aa621452b591e5c504fd85dfe514b92c49c228.zip | |
Fix private module loophole in the 'private type in public item' check
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/compile-fail/priv_in_pub_sig_priv_mod.rs | 28 | ||||
| -rw-r--r-- | src/test/run-pass/export-unexported-dep.rs | 31 | ||||
| -rw-r--r-- | src/test/run-pass/issue-15774.rs | 2 |
3 files changed, 29 insertions, 32 deletions
diff --git a/src/test/compile-fail/priv_in_pub_sig_priv_mod.rs b/src/test/compile-fail/priv_in_pub_sig_priv_mod.rs new file mode 100644 index 00000000000..f589daf3f39 --- /dev/null +++ b/src/test/compile-fail/priv_in_pub_sig_priv_mod.rs @@ -0,0 +1,28 @@ +// 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. + +// Test that we properly check for private types in public signatures, even +// inside a private module (#22261). + +mod a { + struct Priv; + + pub fn expose_a() -> Priv { //~Error: private type in exported type signature + panic!(); + } + + mod b { + pub fn expose_b() -> super::Priv { //~Error: private type in exported type signature + panic!(); + } + } +} + +pub fn main() {} diff --git a/src/test/run-pass/export-unexported-dep.rs b/src/test/run-pass/export-unexported-dep.rs deleted file mode 100644 index 807d28feb6e..00000000000 --- a/src/test/run-pass/export-unexported-dep.rs +++ /dev/null @@ -1,31 +0,0 @@ -// Copyright 2012 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. - -// This tests that exports can have visible dependencies on things -// that are not exported, allowing for a sort of poor-man's ADT - -mod foo { - // not exported - #[derive(Copy)] - enum t { t1, t2, } - - impl PartialEq for t { - fn eq(&self, other: &t) -> bool { - ((*self) as uint) == ((*other) as uint) - } - fn ne(&self, other: &t) -> bool { !(*self).eq(other) } - } - - pub fn f() -> t { return t::t1; } - - pub fn g(v: t) { assert!((v == t::t1)); } -} - -pub fn main() { foo::g(foo::f()); } diff --git a/src/test/run-pass/issue-15774.rs b/src/test/run-pass/issue-15774.rs index 77fa862f7d4..e2f42278cbc 100644 --- a/src/test/run-pass/issue-15774.rs +++ b/src/test/run-pass/issue-15774.rs @@ -11,7 +11,7 @@ #![deny(warnings)] #![allow(unused_imports)] -enum Foo { A } +pub enum Foo { A } mod bar { pub fn normal(x: ::Foo) { use Foo::A; |
