2024-04-06 17:33:37 -05:00
|
|
|
#![allow(unexpected_cfgs)] // since we want to recognize them as unexpected
|
|
|
|
|
2023-03-10 15:39:14 -06:00
|
|
|
pub mod inner {
|
2024-07-12 13:52:52 -05:00
|
|
|
#[cfg(FALSE)] //~ NOTE the item is gated here
|
2023-03-10 15:39:14 -06:00
|
|
|
pub fn uwu() {}
|
|
|
|
//~^ NOTE found an item that was configured out
|
|
|
|
|
2024-07-12 13:52:52 -05:00
|
|
|
#[cfg(FALSE)] //~ NOTE the item is gated here
|
|
|
|
//~^ NOTE the item is gated here
|
|
|
|
//~| NOTE the item is gated here
|
2024-03-20 04:06:58 -05:00
|
|
|
pub mod doesnt_exist {
|
|
|
|
//~^ NOTE found an item that was configured out
|
|
|
|
//~| NOTE found an item that was configured out
|
|
|
|
//~| NOTE found an item that was configured out
|
2023-03-10 15:39:14 -06:00
|
|
|
pub fn hello() {}
|
2024-03-20 04:06:58 -05:00
|
|
|
pub mod hi {}
|
2023-03-10 15:39:14 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
pub mod wrong {
|
|
|
|
#[cfg(feature = "suggesting me fails the test!!")]
|
|
|
|
pub fn meow() {}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub mod right {
|
2024-07-12 13:52:52 -05:00
|
|
|
#[cfg(feature = "what-a-cool-feature")] //~ NOTE the item is gated behind the `what-a-cool-feature` feature
|
2023-03-10 15:39:14 -06:00
|
|
|
pub fn meow() {}
|
|
|
|
//~^ NOTE found an item that was configured out
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-20 04:06:58 -05:00
|
|
|
mod placeholder {
|
|
|
|
use super::inner::doesnt_exist;
|
|
|
|
//~^ ERROR unresolved import `super::inner::doesnt_exist`
|
|
|
|
//~| NOTE no `doesnt_exist` in `inner`
|
|
|
|
use super::inner::doesnt_exist::hi;
|
|
|
|
//~^ ERROR unresolved import `super::inner::doesnt_exist`
|
|
|
|
//~| NOTE could not find `doesnt_exist` in `inner`
|
|
|
|
}
|
|
|
|
|
2023-03-10 15:39:14 -06:00
|
|
|
#[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.
|
|
|
|
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
|
|
|
|
|
|
|
|
// 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
|
|
|
|
}
|