diff options
| author | Esteban Küber <esteban@kuber.com.ar> | 2018-12-30 11:52:15 -0800 |
|---|---|---|
| committer | Esteban Küber <esteban@kuber.com.ar> | 2018-12-31 08:24:00 -0800 |
| commit | 2cd0d14eb1e441cabc6e0226a3c1d03ba5a6cb05 (patch) | |
| tree | 65da9cee78b85c7d979c2e58c18dd9893226ddc0 /src/libsyntax/parse | |
| parent | 833f12ebd71259c21b03d8327107acab2309d064 (diff) | |
| download | rust-2cd0d14eb1e441cabc6e0226a3c1d03ba5a6cb05.tar.gz rust-2cd0d14eb1e441cabc6e0226a3c1d03ba5a6cb05.zip | |
Address review comments
- Suggest raw ident escaping in all editions - Keep primary label in all cases
Diffstat (limited to 'src/libsyntax/parse')
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 25 |
1 files changed, 13 insertions, 12 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index 1a0366932db..7c471fdebb3 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -798,18 +798,19 @@ impl<'a> Parser<'a> { let mut err = self.struct_span_err(self.span, &format!("expected identifier, found {}", self.this_token_descr())); - if let (true, token::Ident(ref s, false), true) = ( - self.span.rust_2018(), - &self.token, - self.token.is_used_keyword() || self.token.is_unused_keyword(), - ) { - err.span_suggestion_with_applicability( - self.span, - "you can escape reserved keywords to use them as identifiers", - format!("r#{}", s.to_string()), - Applicability::MaybeIncorrect, - ); - } else if let Some(token_descr) = self.token_descr() { + if let token::Ident(ident, false) = &self.token { + if ident.is_reserved() && !ident.is_path_segment_keyword() && + ident.name != keywords::Underscore.name() + { + err.span_suggestion_with_applicability( + self.span, + "you can escape reserved keywords to use them as identifiers", + format!("r#{}", ident), + Applicability::MaybeIncorrect, + ); + } + } + if let Some(token_descr) = self.token_descr() { err.span_label(self.span, format!("expected identifier, found {}", token_descr)); } else { err.span_label(self.span, "expected identifier"); |
