summaryrefslogtreecommitdiffstats
path: root/tests/ui/issues/issue-31776.rs
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:18:58 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 12:18:58 +0000
commita4b7ed7a42c716ab9f05e351f003d589124fd55d (patch)
treeb620cd3f223850b28716e474e80c58059dca5dd4 /tests/ui/issues/issue-31776.rs
parentAdding upstream version 1.67.1+dfsg1. (diff)
downloadrustc-a4b7ed7a42c716ab9f05e351f003d589124fd55d.tar.xz
rustc-a4b7ed7a42c716ab9f05e351f003d589124fd55d.zip
Adding upstream version 1.68.2+dfsg1.upstream/1.68.2+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'tests/ui/issues/issue-31776.rs')
-rw-r--r--tests/ui/issues/issue-31776.rs55
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/ui/issues/issue-31776.rs b/tests/ui/issues/issue-31776.rs
new file mode 100644
index 000000000..c86623ce2
--- /dev/null
+++ b/tests/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
+}