53 lines
1.3 KiB
Rust
53 lines
1.3 KiB
Rust
// 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();
|
|
}
|