a647ba250a
`#[cfg]`s are frequently used to gate crate content behind cargo features. This can lead to very confusing errors when features are missing. For example, `serde` doesn't have the `derive` feature by default. Therefore, `serde::Serialize` fails to resolve with a generic error, even though the macro is present in the docs. This commit adds a list of all stripped item names to metadata. This is filled during macro expansion and then, through a fed query, persisted in metadata. The downstream resolver can then access the metadata to look at possible candidates for mentioning in the errors. This slightly increases metadata (800k->809k for the feature-heavy windows crate), but not enough to really matter.
52 lines
1.6 KiB
Rust
52 lines
1.6 KiB
Rust
pub mod inner {
|
|
#[cfg(FALSE)]
|
|
pub fn uwu() {}
|
|
//~^ NOTE found an item that was configured out
|
|
|
|
#[cfg(FALSE)]
|
|
pub mod doesnt_exist {
|
|
pub fn hello() {}
|
|
}
|
|
|
|
pub mod wrong {
|
|
#[cfg(feature = "suggesting me fails the test!!")]
|
|
pub fn meow() {}
|
|
}
|
|
|
|
pub mod right {
|
|
#[cfg(feature = "what-a-cool-feature")]
|
|
pub fn meow() {}
|
|
//~^ NOTE found an item that was configured out
|
|
}
|
|
}
|
|
|
|
#[cfg(i_dont_exist_and_you_can_do_nothing_about_it)]
|
|
pub fn vanished() {}
|
|
|
|
fn main() {
|
|
// There is no uwu at this path - no diagnostic.
|
|
uwu(); //~ ERROR cannot find function
|
|
//~^ NOTE not found in this scope
|
|
|
|
// It does exist here - diagnostic.
|
|
inner::uwu(); //~ ERROR cannot find function
|
|
//~| NOTE not found in `inner`
|
|
|
|
// The module isn't found - we would like to get a diagnostic, but currently don't due to
|
|
// the awkward way the resolver diagnostics are currently implemented.
|
|
// FIXME(Nilstrieb): Also add a note to the cfg diagnostic here
|
|
inner::doesnt_exist::hello(); //~ ERROR failed to resolve
|
|
//~| NOTE could not find `doesnt_exist` in `inner`
|
|
|
|
// It should find the one in the right module, not the wrong one.
|
|
inner::right::meow(); //~ ERROR cannot find function
|
|
//~| NOTE not found in `inner::right
|
|
//~| NOTE the item is gated behind the `what-a-cool-feature` feature
|
|
|
|
// Exists in the crate root - we would generally want a diagnostic,
|
|
// but currently don't have one.
|
|
// Not that it matters much though, this is highly unlikely to confuse anyone.
|
|
vanished(); //~ ERROR cannot find function
|
|
//~^ NOTE not found in this scope
|
|
}
|