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.
13 lines
444 B
Plaintext
13 lines
444 B
Plaintext
error[E0603]: module `index` is private
|
|
--> $DIR/private-trait-non-local.rs:2:18
|
|
|
|
|
LL | use core::slice::index::private_slice_index::Sealed;
|
|
| ^^^^^ private module ------ trait `Sealed` is not publicly re-exported
|
|
|
|
|
note: the module `index` is defined here
|
|
--> $SRC_DIR/core/src/slice/mod.rs:LL:COL
|
|
|
|
error: aborting due to previous error
|
|
|
|
For more information about this error, try `rustc --explain E0603`.
|