diff options
| author | James Addison <jay@jp-hosting.net> | 2021-04-14 12:52:06 +0100 |
|---|---|---|
| committer | James Addison <jay@jp-hosting.net> | 2021-04-14 12:52:06 +0100 |
| commit | ff47e978383e86f7e97174840e37f64ea1d72bce (patch) | |
| tree | cb27b2fb1fe23dc683b119ca34355ac0bc7db017 /compiler/rustc_parse/src/parser/diagnostics.rs | |
| parent | 0174dd6f921cc63c7e2d9aa5c01aa591f9a26745 (diff) | |
| parent | d408fdd4a82bc3e7ea61dd81bc9a8781b2bf939d (diff) | |
| download | rust-ff47e978383e86f7e97174840e37f64ea1d72bce.tar.gz rust-ff47e978383e86f7e97174840e37f64ea1d72bce.zip | |
Merge branch 'master' into compiler/E0384-reduce-assertiveness
Diffstat (limited to 'compiler/rustc_parse/src/parser/diagnostics.rs')
| -rw-r--r-- | compiler/rustc_parse/src/parser/diagnostics.rs | 32 |
1 files changed, 17 insertions, 15 deletions
diff --git a/compiler/rustc_parse/src/parser/diagnostics.rs b/compiler/rustc_parse/src/parser/diagnostics.rs index 77e85c06ff5..70a5ac6f15e 100644 --- a/compiler/rustc_parse/src/parser/diagnostics.rs +++ b/compiler/rustc_parse/src/parser/diagnostics.rs @@ -666,21 +666,23 @@ impl<'a> Parser<'a> { ); match x { Ok((_, _, false)) => { - self.bump(); // `>` - match self.parse_expr() { - Ok(_) => { - e.span_suggestion_verbose( - binop.span.shrink_to_lo(), - TURBOFISH_SUGGESTION_STR, - "::".to_string(), - Applicability::MaybeIncorrect, - ); - e.emit(); - *expr = self.mk_expr_err(expr.span.to(self.prev_token.span)); - return Ok(()); - } - Err(mut err) => { - err.cancel(); + if self.eat(&token::Gt) { + match self.parse_expr() { + Ok(_) => { + e.span_suggestion_verbose( + binop.span.shrink_to_lo(), + TURBOFISH_SUGGESTION_STR, + "::".to_string(), + Applicability::MaybeIncorrect, + ); + e.emit(); + *expr = + self.mk_expr_err(expr.span.to(self.prev_token.span)); + return Ok(()); + } + Err(mut err) => { + err.cancel(); + } } } } |
