diff options
| author | kennytm <kennytm@gmail.com> | 2018-10-26 18:25:03 +0800 |
|---|---|---|
| committer | kennytm <kennytm@gmail.com> | 2018-10-26 23:06:28 +0800 |
| commit | c6cd57dd860efbe0cb7506dfad93462bcb520d74 (patch) | |
| tree | 3f744ab35258bbdd04afe712247a31e20cd6b521 /src/libsyntax/ext/tt | |
| parent | 9111fab74df4e0f6f2b8bfb5936f3772ba59a960 (diff) | |
| parent | f8818cbf8fc30ac626b2a0a306736c1293257209 (diff) | |
| download | rust-c6cd57dd860efbe0cb7506dfad93462bcb520d74.tar.gz rust-c6cd57dd860efbe0cb7506dfad93462bcb520d74.zip | |
Rollup merge of #55292 - estebank:macro-eof, r=pnkfelix
Macro diagnostics tweaks Fix #30128, fix #10951 by adding an appropriate span to the diagnostic. Fix #26288 by suggesting adding semicolon to macro call.
Diffstat (limited to 'src/libsyntax/ext/tt')
| -rw-r--r-- | src/libsyntax/ext/tt/macro_rules.rs | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/src/libsyntax/ext/tt/macro_rules.rs b/src/libsyntax/ext/tt/macro_rules.rs index 805aa9bef22..5e53b8b99c7 100644 --- a/src/libsyntax/ext/tt/macro_rules.rs +++ b/src/libsyntax/ext/tt/macro_rules.rs @@ -50,7 +50,12 @@ pub struct ParserAnyMacro<'a> { impl<'a> ParserAnyMacro<'a> { pub fn make(mut self: Box<ParserAnyMacro<'a>>, kind: AstFragmentKind) -> AstFragment { let ParserAnyMacro { site_span, macro_ident, ref mut parser } = *self; - let fragment = panictry!(parser.parse_ast_fragment(kind, true)); + let fragment = panictry!(parser.parse_ast_fragment(kind, true).map_err(|mut e| { + if e.span.is_dummy() { // Get around lack of span in error (#30128) + e.set_span(site_span); + } + e + })); // We allow semicolons at the end of expressions -- e.g. the semicolon in // `macro_rules! m { () => { panic!(); } }` isn't parsed by `.parse_expr()`, |
