diff options
| author | P1start <rewi-github@whanau.org> | 2014-10-27 17:43:38 +1300 |
|---|---|---|
| committer | P1start <rewi-github@whanau.org> | 2014-10-30 19:51:16 +1300 |
| commit | 14398f29290b0d96dbe60f329b69062442eefb33 (patch) | |
| tree | 835b271b073cc5e981441de2cf8d2195edcb2718 /src/libsyntax/parse/parser.rs | |
| parent | fb00015246824313e8882935c9ba175ea6daf9d4 (diff) | |
| download | rust-14398f29290b0d96dbe60f329b69062442eefb33.tar.gz rust-14398f29290b0d96dbe60f329b69062442eefb33.zip | |
Add a message for when a `.` follows a macro invocation
Diffstat (limited to 'src/libsyntax/parse/parser.rs')
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index d9dd37fcb4f..f04f9efd7a7 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -3592,6 +3592,16 @@ impl<'a> Parser<'a> { let hi = self.span.hi; if id.name == token::special_idents::invalid.name { + if self.token == token::Dot { + let span = self.span; + let token_string = self.this_token_to_string(); + self.span_err(span, + format!("expected statement, found `{}`", + token_string).as_slice()); + let mac_span = mk_sp(lo, hi); + self.span_help(mac_span, "try parenthesizing this macro invocation"); + self.abort_if_errors(); + } P(spanned(lo, hi, StmtMac( spanned(lo, hi, MacInvocTT(pth, tts, EMPTY_CTXT)), false))) } else { |
