about summary refs log tree commit diff
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2013-08-17 22:52:00 -0700
committerbors <bors@rust-lang.org>2013-08-17 22:52:00 -0700
commit758c5e823621d1a6ef57f7a3a3cd5ba19116a777 (patch)
tree2b5634a4a7607481b9456909332b3004e3ed988b
parent6a88415ed80cf98ff3c8864a2b1cbf57f32e6208 (diff)
parent1fcb7ed9a67f316344b0b39e7682dceb1a61cf3e (diff)
downloadrust-758c5e823621d1a6ef57f7a3a3cd5ba19116a777.tar.gz
rust-758c5e823621d1a6ef57f7a3a3cd5ba19116a777.zip
auto merge of #8547 : kballard/rust/trait-parse-err-msg, r=alexcrichton
When parsing a trait function, the function must end with either `;` or
`{` (signifying a default implementation). The error message incorrectly
stated that it must be `;` or `}`.

Fixes #6610.
-rw-r--r--src/libsyntax/parse/parser.rs2
-rw-r--r--src/test/compile-fail/issue-6610.rs13
2 files changed, 14 insertions, 1 deletions
diff --git a/src/libsyntax/parse/parser.rs b/src/libsyntax/parse/parser.rs
index a2664dcf890..de7abb8d1f4 100644
--- a/src/libsyntax/parse/parser.rs
+++ b/src/libsyntax/parse/parser.rs
@@ -953,7 +953,7 @@ impl Parser {
               _ => {
                     p.fatal(
                         fmt!(
-                            "expected `;` or `}` but found `%s`",
+                            "expected `;` or `{` but found `%s`",
                             self.this_token_to_str()
                         )
                     );
diff --git a/src/test/compile-fail/issue-6610.rs b/src/test/compile-fail/issue-6610.rs
new file mode 100644
index 00000000000..f90833a852b
--- /dev/null
+++ b/src/test/compile-fail/issue-6610.rs
@@ -0,0 +1,13 @@
+// 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 <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.
+
+trait Foo { fn a() } //~ ERROR expected `;` or `{` but found `}`
+
+fn main() {}