summaryrefslogtreecommitdiffstats
path: root/src/test/ui/issues/issue-31776.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:02:58 +0000
commit698f8c2f01ea549d77d7dc3338a12e04c11057b9 (patch)
tree173a775858bd501c378080a10dca74132f05bc50 /src/test/ui/issues/issue-31776.rs
parentInitial commit. (diff)
downloadrustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.tar.xz
rustc-698f8c2f01ea549d77d7dc3338a12e04c11057b9.zip
Adding upstream version 1.64.0+dfsg1.upstream/1.64.0+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--src/test/ui/issues/issue-31776.rs55
1 files changed, 55 insertions, 0 deletions
diff --git a/src/test/ui/issues/issue-31776.rs b/src/test/ui/issues/issue-31776.rs
new file mode 100644
index 000000000..c86623ce2
--- /dev/null
+++ b/src/test/ui/issues/issue-31776.rs
@@ -0,0 +1,55 @@
+// run-pass
+#![allow(dead_code)]
+#![allow(unused_variables)]
+// Various scenarios in which `pub` is required in blocks
+
+struct S;
+
+mod m {
+ fn f() {
+ impl ::S {
+ pub fn s(&self) {}
+ }
+ }
+}
+
+// Scenario 1
+
+pub trait Tr {
+ type A;
+}
+pub struct S1;
+
+fn f() {
+ pub struct Z;
+
+ impl ::Tr for ::S1 {
+ type A = Z; // Private-in-public error unless `struct Z` is pub
+ }
+}
+
+// Scenario 2
+
+trait Tr1 {
+ type A;
+ fn pull(&self) -> Self::A;
+}
+struct S2;
+
+mod m1 {
+ fn f() {
+ pub struct Z {
+ pub field: u8
+ }
+
+ impl ::Tr1 for ::S2 {
+ type A = Z;
+ fn pull(&self) -> Self::A { Z{field: 10} }
+ }
+ }
+}
+
+fn main() {
+ S.s(); // Privacy error, unless `fn s` is pub
+ let a = S2.pull().field; // Privacy error unless `field: u8` is pub
+}