// This test is similar to `macros.rs`, but nested in modules. // run-pass // edition:2018 #![allow(non_camel_case_types)] mod foo { // Test that ambiguity errors are not emitted between `self::test` and // `::test`, assuming the latter (crate) is not in `extern_prelude`. macro_rules! m1 { () => { mod test { pub struct Foo(pub ()); } } } pub use test::Foo; m1!(); // Test that qualified paths can refer to both the external crate and local item. macro_rules! m2 { () => { mod std { pub struct io(pub ()); } } } pub use ::std::io as std_io; pub use self::std::io as local_io; m2!(); } // Test that we can refer to the external crate unqualified // (when there isn't a local item with the same name). use std::io; mod bar { // Also test the unqualified external crate import in a nested module, // to show that the above import doesn't resolve through a local `std` // item, e.g., the automatically injected `extern crate std;`, which in // the Rust 2018 should no longer be visible through `crate::std`. pub use std::io; } fn main() { foo::Foo(()); let _ = foo::std_io::stdout(); foo::local_io(()); let _ = io::stdout(); let _ = bar::io::stdout(); }