about summary refs log tree commit diff
path: root/src
diff options
context:
space:
mode:
authorGeorg Brandl <georg@python.org>2016-05-01 20:18:04 +0200
committerGeorg Brandl <georg@python.org>2016-05-10 14:57:44 +0200
commitfef827672ddb0df866c77239f3fc034ed98de556 (patch)
tree47aef317545495e31a7065b795a21a8138c31385 /src
parenta4d2424cc304e97f553c6d8eef17a24dc2f12c01 (diff)
downloadrust-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.rs12
-rw-r--r--src/test/compile-fail/issue-31424.rs30
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 () {}