diff options
| author | Niko Matsakis <niko@alum.mit.edu> | 2016-04-20 14:44:07 -0400 |
|---|---|---|
| committer | Manish Goregaokar <manishsmail@gmail.com> | 2016-04-24 18:10:57 +0530 |
| commit | ecd10f04cea34352ff240b0462d40cd1d95a4e0f (patch) | |
| tree | fb7f1f7adc4a1044d3a9316631fef61e46ce984b /src/libsyntax/parse | |
| parent | 23ccaddaa7d1cb71e49ef1b1f423b3245fa3a879 (diff) | |
| download | rust-ecd10f04cea34352ff240b0462d40cd1d95a4e0f.tar.gz rust-ecd10f04cea34352ff240b0462d40cd1d95a4e0f.zip | |
thread tighter span for closures around
Track the span corresponding to the `|...|` part of the closure.
Diffstat (limited to 'src/libsyntax/parse')
| -rw-r--r-- | src/libsyntax/parse/parser.rs | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index f3d3bbd9f99..a4284d0b674 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -3225,13 +3225,15 @@ impl<'a> Parser<'a> { Ok(self.mk_expr(lo, hi, ExprKind::IfLet(pat, expr, thn, els), attrs)) } - // `|args| expr` - pub fn parse_lambda_expr(&mut self, lo: BytePos, + // `move |args| expr` + pub fn parse_lambda_expr(&mut self, + lo: BytePos, capture_clause: CaptureBy, attrs: ThinAttributes) -> PResult<'a, P<Expr>> { let decl = self.parse_fn_block_decl()?; + let decl_hi = self.last_span.hi; let body = match decl.output { FunctionRetTy::Default(_) => { // If no explicit return type is given, parse any @@ -3255,7 +3257,8 @@ impl<'a> Parser<'a> { Ok(self.mk_expr( lo, body.span.hi, - ExprKind::Closure(capture_clause, decl, body), attrs)) + ExprKind::Closure(capture_clause, decl, body, mk_sp(lo, decl_hi)), + attrs)) } // `else` token already eaten |
