diff options
| author | bors <bors@rust-lang.org> | 2014-03-16 17:01:54 -0700 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2014-03-16 17:01:54 -0700 |
| commit | 4e1172ebbd44b826b795c05dcecdd8c5557ecff6 (patch) | |
| tree | e42e67facbe288da0388562c5370be0b92978b69 | |
| parent | 9e89ffc60e4a72dd0e6e9b1930111235b18e595e (diff) | |
| parent | 8b6592ef1a29360716e49545cff42d7103366b02 (diff) | |
| download | rust-4e1172ebbd44b826b795c05dcecdd8c5557ecff6.tar.gz rust-4e1172ebbd44b826b795c05dcecdd8c5557ecff6.zip | |
auto merge of #12937 : sinistersnare/rust/method-error-message, r=huonw
its a common (yet easily fixable) error to just forget parens at the end of getter-like methods without any arguments. The current error message for that case asks for an anonymous function, this patch adds a note asking for either an anonymous function, or for trailing parens. This is my first contribution! do i need to do anything else?
| -rw-r--r-- | src/librustc/middle/typeck/check/mod.rs | 6 | ||||
| -rw-r--r-- | src/test/compile-fail/method-missing-call.rs | 34 |
2 files changed, 38 insertions, 2 deletions
diff --git a/src/librustc/middle/typeck/check/mod.rs b/src/librustc/middle/typeck/check/mod.rs index b3f7adc89e8..f4a04d824ad 100644 --- a/src/librustc/middle/typeck/check/mod.rs +++ b/src/librustc/middle/typeck/check/mod.rs @@ -2317,11 +2317,13 @@ fn check_expr_with_unifier(fcx: @FnCtxt, fcx.type_error_message( expr.span, |actual| { - format!("attempted to take value of method `{}` on type `{}` \ - (try writing an anonymous function)", + format!("attempted to take value of method `{}` on type `{}`", token::get_name(field), actual) }, expr_t, None); + + tcx.sess.span_note(expr.span, + "maybe a missing `()` to call it? If not, try an anonymous function."); } None => { diff --git a/src/test/compile-fail/method-missing-call.rs b/src/test/compile-fail/method-missing-call.rs new file mode 100644 index 00000000000..55a178af961 --- /dev/null +++ b/src/test/compile-fail/method-missing-call.rs @@ -0,0 +1,34 @@ +// Copyright 2014 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. + +// Tests to make sure that parens are needed for method calls without arguments. +// outputs text to make sure either an anonymous function is provided or +// open-close '()' parens are given + + +struct Point { + x: int, + y: int +} +impl Point { + fn new() -> Point { + Point{x:0, y:0} + } + fn get_x(&self) -> int { + self.x + } +} + +fn main() { + let point: Point = Point::new(); + let px: int = point.get_x;//~ ERROR attempted to take value of method `get_x` on type `Point` + //~^ NOTE maybe a missing `()` to call it? If not, try an anonymous function. +} + |
