diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs index cad19543608ba..e9f55c62b6c55 100644 --- a/src/libsyntax/parse/parser.rs +++ b/src/libsyntax/parse/parser.rs @@ -308,6 +308,7 @@ pub fn Parser(sess: @mut ParseSess, quote_depth: @mut 0, obsolete_set: @mut HashSet::new(), mod_path_stack: @mut ~[], + open_braces: @mut ~[] } } @@ -336,6 +337,8 @@ pub struct Parser { obsolete_set: @mut HashSet, /// Used to determine the path to externally loaded source files mod_path_stack: @mut ~[@str], + /// Stack of spans of open delimiters. Used for error message. + open_braces: @mut ~[@Span] } #[unsafe_destructor] @@ -2022,12 +2025,18 @@ impl Parser { match *self.token { token::EOF => { - self.fatal("file ended with unbalanced delimiters"); + for sp in self.open_braces.iter() { + self.span_note(**sp, "Did you mean to close this delimiter?"); + } + // There shouldn't really be a span, but it's easier for the test runner + // if we give it one + self.fatal("This file contains an un-closed delimiter "); } token::LPAREN | token::LBRACE | token::LBRACKET => { let close_delim = token::flip_delimiter(&*self.token); // Parse the open delimiter. + (*self.open_braces).push(@*self.span); let mut result = ~[parse_any_tt_tok(self)]; let trees = @@ -2038,6 +2047,7 @@ impl Parser { // Parse the close delimiter. result.push(parse_any_tt_tok(self)); + self.open_braces.pop(); tt_delim(@mut result) } diff --git a/src/test/compile-fail/issue-2354-1.rs b/src/test/compile-fail/issue-2354-1.rs new file mode 100644 index 0000000000000..67b5c6becc741 --- /dev/null +++ b/src/test/compile-fail/issue-2354-1.rs @@ -0,0 +1,12 @@ +// Copyright 2013 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 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +static foo: int = 2; } //~ ERROR incorrect close delimiter: + diff --git a/src/test/compile-fail/issue-2354.rs b/src/test/compile-fail/issue-2354.rs index 409e1c1f04020..9761bd3317c70 100644 --- a/src/test/compile-fail/issue-2354.rs +++ b/src/test/compile-fail/issue-2354.rs @@ -8,13 +8,7 @@ // option. This file may not be copied, modified, or distributed // except according to those terms. -// xfail-test -/* - Ideally, the error about the missing close brace in foo would be reported - near the corresponding open brace. But currently it's reported at the end. - xfailed for now (see Issue #2354) - */ -fn foo() { //~ ERROR this open brace is not closed +fn foo() { //~ NOTE Did you mean to close this delimiter? match Some(x) { Some(y) { fail!(); } None { fail!(); } @@ -25,4 +19,4 @@ fn bar() { while (i < 1000) {} } -fn main() {} +fn main() {} //~ ERROR This file contains an un-closed delimiter