about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorMarcus Klaas <mail@marcusklaas.nl>2016-04-03 22:30:21 +0200
committerMarcus Klaas <mail@marcusklaas.nl>2016-04-11 21:22:37 +0200
commit05e4116af2e015ebafcfb18b3db21c25ef9c7c99 (patch)
tree5e816a4c1c5dd954ec1d2eab7b49be3070720379 /src
parentc0b8c438203ada8768f2f8ea7c750131744f97ef (diff)
downloadrust-05e4116af2e015ebafcfb18b3db21c25ef9c7c99.tar.gz
rust-05e4116af2e015ebafcfb18b3db21c25ef9c7c99.zip
Fix the span for try shorthand expressions
Diffstat (limited to 'src')
-rw-r--r--src/libsyntax/parse/parser.rs2
-rw-r--r--src/test/compile-fail/symbol-names/issue-32709.rs20
2 files changed, 21 insertions, 1 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs
index 9027a5b1074..f4a42684965 100644
--- a/src/libsyntax/parse/parser.rs
+++ b/src/libsyntax/parse/parser.rs
@@ -2576,7 +2576,7 @@ impl<'a> Parser<'a> {
         loop {
             // expr?
             while self.eat(&token::Question) {
-                let hi = self.span.hi;
+                let hi = self.last_span.hi;
                 e = self.mk_expr(lo, hi, ExprKind::Try(e), None);
             }
 
diff --git a/src/test/compile-fail/symbol-names/issue-32709.rs b/src/test/compile-fail/symbol-names/issue-32709.rs
new file mode 100644
index 00000000000..f9d11f3a171
--- /dev/null
+++ b/src/test/compile-fail/symbol-names/issue-32709.rs
@@ -0,0 +1,20 @@
+// Copyright 2016 The Rust Project Developers. See the COPYRIGHT
+// file at the top-level directory of this distribution and at
+// http://rust-lang.org/COPYRIGHT.
+//
+// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
+// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
+// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
+// option. This file may not be copied, modified, or distributed
+// except according to those terms.
+
+#![feature(question_mark)]
+
+// Make sure that the span of try shorthand does not include the trailing
+// semicolon;
+fn a() -> Result<i32, ()> {
+    Err(5)?; //~ ERROR 16:5: 16:12
+    Ok(1)
+}
+
+fn main() {}