diff options
| author | Mark Rousskov <mark.simulacrum@gmail.com> | 2018-06-08 17:20:55 -0600 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-06-08 17:20:55 -0600 |
| commit | 91b6842dc9b795cdee9bfe552f42cdd463e1a8dd (patch) | |
| tree | dccf7c5551e42de61416819a366233e2bc6a1866 /src/test | |
| parent | c40275b34f8a2b6a289181d1d5f376ff7c64f0c5 (diff) | |
| parent | 11c283cdfc536c2d0c984bea47c7ab246d4ed5d3 (diff) | |
| download | rust-91b6842dc9b795cdee9bfe552f42cdd463e1a8dd.tar.gz rust-91b6842dc9b795cdee9bfe552f42cdd463e1a8dd.zip | |
Rollup merge of #50143 - petrochenkov:mexuniq, r=nikomatsakis
Add deprecation lint for duplicated `macro_export`s cc https://github.com/rust-lang/rust/issues/35896#issuecomment-381370556
Diffstat (limited to 'src/test')
| -rw-r--r-- | src/test/run-pass/auxiliary/issue_38715.rs | 2 | ||||
| -rw-r--r-- | src/test/run-pass/auxiliary/two_macros_2.rs | 13 | ||||
| -rw-r--r-- | src/test/run-pass/mod_dir_path.rs | 4 | ||||
| -rw-r--r-- | src/test/ui/issue-38715.rs | 16 | ||||
| -rw-r--r-- | src/test/ui/issue-38715.stderr | 22 |
5 files changed, 55 insertions, 2 deletions
diff --git a/src/test/run-pass/auxiliary/issue_38715.rs b/src/test/run-pass/auxiliary/issue_38715.rs index cad3996eadb..cf4fee0e515 100644 --- a/src/test/run-pass/auxiliary/issue_38715.rs +++ b/src/test/run-pass/auxiliary/issue_38715.rs @@ -8,6 +8,8 @@ // option. This file may not be copied, modified, or distributed // except according to those terms. +#![allow(duplicate_macro_exports)] + #[macro_export] macro_rules! foo { ($i:ident) => {} } diff --git a/src/test/run-pass/auxiliary/two_macros_2.rs b/src/test/run-pass/auxiliary/two_macros_2.rs new file mode 100644 index 00000000000..b16cd3a4210 --- /dev/null +++ b/src/test/run-pass/auxiliary/two_macros_2.rs @@ -0,0 +1,13 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +macro_rules! macro_one { ($($t:tt)*) => ($($t)*) } + +macro_rules! macro_two { ($($t:tt)*) => ($($t)*) } diff --git a/src/test/run-pass/mod_dir_path.rs b/src/test/run-pass/mod_dir_path.rs index e2f33963c4b..fc91ea870d5 100644 --- a/src/test/run-pass/mod_dir_path.rs +++ b/src/test/run-pass/mod_dir_path.rs @@ -20,12 +20,12 @@ pub fn main() { #[path = "auxiliary"] mod foo { - mod two_macros; + mod two_macros_2; } #[path = "auxiliary"] mod bar { - macro_rules! m { () => { mod two_macros; } } + macro_rules! m { () => { mod two_macros_2; } } m!(); } } diff --git a/src/test/ui/issue-38715.rs b/src/test/ui/issue-38715.rs new file mode 100644 index 00000000000..552653c21ba --- /dev/null +++ b/src/test/ui/issue-38715.rs @@ -0,0 +1,16 @@ +// Copyright 2016 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +#[macro_export] +macro_rules! foo { ($i:ident) => {} } + +#[macro_export] +macro_rules! foo { () => {} } //~ ERROR a macro named `foo` has already been exported + //~| WARN this was previously accepted diff --git a/src/test/ui/issue-38715.stderr b/src/test/ui/issue-38715.stderr new file mode 100644 index 00000000000..a0dbcbd18c6 --- /dev/null +++ b/src/test/ui/issue-38715.stderr @@ -0,0 +1,22 @@ +error: a macro named `foo` has already been exported + --> $DIR/issue-38715.rs:15:1 + | +LL | macro_rules! foo { () => {} } //~ ERROR a macro named `foo` has already been exported + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ `foo` already exported + | + = note: #[deny(duplicate_macro_exports)] on by default + = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in the 2018 edition! + = note: for more information, see issue #35896 <https://github.com/rust-lang/rust/issues/35896> +note: previous macro export is now shadowed + --> $DIR/issue-38715.rs:12:1 + | +LL | macro_rules! foo { ($i:ident) => {} } + | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ + +error[E0601]: `main` function not found in crate `issue_38715` + | + = note: consider adding a `main` function to `$DIR/issue-38715.rs` + +error: aborting due to 2 previous errors + +For more information about this error, try `rustc --explain E0601`. |
