mirror of
https://github.com/rust-lang/rust.git
synced 2024-10-30 14:01:51 +00:00
Rollup merge of #89221 - aDotInTheVoid:macro-error-1, r=estebank
Give better error for `macro_rules! name!` r? ``@estebank`` ``@rustbot`` modify labels: +A-diagnostics +A-parser
This commit is contained in:
commit
6f31fa58fd
@ -1547,6 +1547,20 @@ impl<'a> Parser<'a> {
|
||||
self.expect(&token::Not)?; // `!`
|
||||
|
||||
let ident = self.parse_ident()?;
|
||||
|
||||
if self.eat(&token::Not) {
|
||||
// Handle macro_rules! foo!
|
||||
let span = self.prev_token.span;
|
||||
self.struct_span_err(span, "macro names aren't followed by a `!`")
|
||||
.span_suggestion(
|
||||
span,
|
||||
"remove the `!`",
|
||||
"".to_owned(),
|
||||
Applicability::MachineApplicable,
|
||||
)
|
||||
.emit();
|
||||
}
|
||||
|
||||
let body = self.parse_mac_args()?;
|
||||
self.eat_semi_for_macro_if_needed(&body);
|
||||
self.complain_if_pub_macro(vis, true);
|
||||
|
8
src/test/ui/macros/bang-after-name.fixed
Normal file
8
src/test/ui/macros/bang-after-name.fixed
Normal file
@ -0,0 +1,8 @@
|
||||
// run-rustfix
|
||||
#[allow(unused_macros)]
|
||||
|
||||
macro_rules! foo { //~ ERROR macro names aren't followed by a `!`
|
||||
() => {};
|
||||
}
|
||||
|
||||
fn main() {}
|
8
src/test/ui/macros/bang-after-name.rs
Normal file
8
src/test/ui/macros/bang-after-name.rs
Normal file
@ -0,0 +1,8 @@
|
||||
// run-rustfix
|
||||
#[allow(unused_macros)]
|
||||
|
||||
macro_rules! foo! { //~ ERROR macro names aren't followed by a `!`
|
||||
() => {};
|
||||
}
|
||||
|
||||
fn main() {}
|
8
src/test/ui/macros/bang-after-name.stderr
Normal file
8
src/test/ui/macros/bang-after-name.stderr
Normal file
@ -0,0 +1,8 @@
|
||||
error: macro names aren't followed by a `!`
|
||||
--> $DIR/bang-after-name.rs:4:17
|
||||
|
|
||||
LL | macro_rules! foo! {
|
||||
| ^ help: remove the `!`
|
||||
|
||||
error: aborting due to previous error
|
||||
|
Loading…
Reference in New Issue
Block a user