diff options
| author | Georg Brandl <georg@python.org> | 2016-05-01 20:18:04 +0200 |
|---|---|---|
| committer | Georg Brandl <georg@python.org> | 2016-05-10 14:57:44 +0200 |
| commit | fef827672ddb0df866c77239f3fc034ed98de556 (patch) | |
| tree | 47aef317545495e31a7065b795a21a8138c31385 /src | |
| parent | a4d2424cc304e97f553c6d8eef17a24dc2f12c01 (diff) | |
| download | rust-fef827672ddb0df866c77239f3fc034ed98de556.tar.gz rust-fef827672ddb0df866c77239f3fc034ed98de556.zip | |
borrowck: do not suggest to change "&mut self" to "&mut mut self"
Matching the snippet string might not be the cleanest, but matching the AST node instead seems to end in a lot of nested `if let`s... Fixes #31424.
Diffstat (limited to 'src')
| -rw-r--r-- | src/librustc_borrowck/borrowck/mod.rs | 12 | ||||
| -rw-r--r-- | src/test/compile-fail/issue-31424.rs | 30 |
2 files changed, 37 insertions, 5 deletions
diff --git a/src/librustc_borrowck/borrowck/mod.rs b/src/librustc_borrowck/borrowck/mod.rs index f65e694939b..8518a27bd2c 100644 --- a/src/librustc_borrowck/borrowck/mod.rs +++ b/src/librustc_borrowck/borrowck/mod.rs @@ -970,11 +970,13 @@ impl<'a, 'tcx> BorrowckCtxt<'a, 'tcx> { if let Categorization::Local(local_id) = err.cmt.cat { let span = self.tcx.map.span(local_id); if let Ok(snippet) = self.tcx.sess.codemap().span_to_snippet(span) { - db.span_suggestion( - span, - &format!("to make the {} mutable, use `mut` as shown:", - self.cmt_to_string(&err.cmt)), - format!("mut {}", snippet)); + if snippet != "self" { + db.span_suggestion( + span, + &format!("to make the {} mutable, use `mut` as shown:", + self.cmt_to_string(&err.cmt)), + format!("mut {}", snippet)); + } } } } diff --git a/src/test/compile-fail/issue-31424.rs b/src/test/compile-fail/issue-31424.rs new file mode 100644 index 00000000000..262efab22a2 --- /dev/null +++ b/src/test/compile-fail/issue-31424.rs @@ -0,0 +1,30 @@ +// 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. + +// forbid-output: &mut mut self + +struct Struct; + +impl Struct { + fn foo(&mut self) { + (&mut self).bar(); + //~^ ERROR cannot borrow immutable argument `self` as mutable + // ... and no SUGGESTION that suggests `&mut mut self` + } + + // In this case we could keep the suggestion, but to distinguish the + // two cases is pretty hard. It's an obscure case anyway. + fn bar(self: &mut Self) { + (&mut self).bar(); + //~^ ERROR cannot borrow immutable argument `self` as mutable + } +} + +fn main () {} |
