diff options
| author | York Xiang <bombless@126.com> | 2015-04-18 09:18:46 +0800 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2015-04-30 15:11:41 -0700 |
| commit | da78718d20214abbb050cfce4b607236ae9df1c4 (patch) | |
| tree | 52438eafd7d301345881d26ce056e6a99c2a28a6 /src/libsyntax/parse/parser.rs | |
| parent | 4d4a5c896ca56eda10d0d35a32bb17e636eabfd3 (diff) | |
| download | rust-da78718d20214abbb050cfce4b607236ae9df1c4.tar.gz rust-da78718d20214abbb050cfce4b607236ae9df1c4.zip | |
Fix #20616
Conflicts: src/libsyntax/parse/parser.rs
Diffstat (limited to 'src/libsyntax/parse/parser.rs')
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 35 |
1 files changed, 33 insertions, 2 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index 0515d1ae945..a78347a13dc 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -896,8 +896,10 @@ impl<'a> Parser<'a> { pub fn bump(&mut self) -> PResult<()> { self.last_span = self.span; // Stash token for error recovery (sometimes; clone is not necessarily cheap). - self.last_token = if self.token.is_ident() || self.token.is_path() { - Some(box self.token.clone()) + self.last_token = if self.token.is_ident() || + self.token.is_path() || + self.token == token::Comma { + Some(Box::new(self.token.clone())) } else { None }; @@ -3796,8 +3798,37 @@ impl<'a> Parser<'a> { fn parse_generic_values_after_lt(&mut self) -> PResult<(Vec<ast::Lifetime>, Vec<P<Ty>>, Vec<P<TypeBinding>>)> { + let span_lo = self.span.lo; let lifetimes = try!(self.parse_lifetimes(token::Comma)); + let missing_comma = !lifetimes.is_empty() && + !self.token.is_like_gt() && + self.last_token + .as_ref().map_or(true, + |x| &**x != &token::Comma); + + if missing_comma { + + let msg = format!("expected `,` or `>` after lifetime \ + name, found `{}`", + self.this_token_to_string()); + self.span_err(self.span, &msg); + + let span_hi = self.span.hi; + let span_hi = if self.parse_ty_nopanic().is_ok() { + self.span.hi + } else { + span_hi + }; + + let msg = format!("did you mean a single argument type &'a Type, \ + or did you mean the comma-separated arguments \ + 'a, Type?"); + self.span_note(mk_sp(span_lo, span_hi), &msg); + + self.abort_if_errors() + } + // First parse types. let (types, returned) = try!(self.parse_seq_to_gt_or_return( Some(token::Comma), |
