7dffd24da5
Suggest publicly accessible paths for items in private mod: When encountering a path in non-import situations that are not reachable due to privacy constraints, search for any public re-exports that the user could use instead. Track whether an import suggestion is offering a re-export. When encountering a path with private segments, mention if the item at the final path segment is not publicly accessible at all. Add item visibility metadata to privacy errors from imports: On unreachable imports, record the item that was being imported in order to suggest publicly available re-exports or to be explicit that the item is not available publicly from any path. In order to allow this, we add a mode to `resolve_path` that will not add new privacy errors, nor return early if it encounters one. This way we can get the `Res` corresponding to the final item in the import, which is used in the privacy error machinery.
32 lines
892 B
Plaintext
32 lines
892 B
Plaintext
error[E0603]: enum `Foo` is private
|
|
--> $DIR/issue-11680.rs:6:21
|
|
|
|
|
LL | let _b = other::Foo::Bar(1);
|
|
| ^^^ --- tuple variant `Bar` is not publicly re-exported
|
|
| |
|
|
| private enum
|
|
|
|
|
note: the enum `Foo` is defined here
|
|
--> $DIR/auxiliary/issue-11680.rs:1:1
|
|
|
|
|
LL | enum Foo {
|
|
| ^^^^^^^^
|
|
|
|
error[E0603]: enum `Foo` is private
|
|
--> $DIR/issue-11680.rs:9:27
|
|
|
|
|
LL | let _b = other::test::Foo::Bar(1);
|
|
| ^^^ --- tuple variant `Bar` is not publicly re-exported
|
|
| |
|
|
| private enum
|
|
|
|
|
note: the enum `Foo` is defined here
|
|
--> $DIR/auxiliary/issue-11680.rs:6:5
|
|
|
|
|
LL | enum Foo {
|
|
| ^^^^^^^^
|
|
|
|
error: aborting due to 2 previous errors
|
|
|
|
For more information about this error, try `rustc --explain E0603`.
|