summaryrefslogtreecommitdiffstats
path: root/src/test/ui/borrowck/mut-borrow-in-loop-2.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/ui/borrowck/mut-borrow-in-loop-2.rs')
-rw-r--r--src/test/ui/borrowck/mut-borrow-in-loop-2.rs35
1 files changed, 0 insertions, 35 deletions
diff --git a/src/test/ui/borrowck/mut-borrow-in-loop-2.rs b/src/test/ui/borrowck/mut-borrow-in-loop-2.rs
deleted file mode 100644
index d13fb7e56..000000000
--- a/src/test/ui/borrowck/mut-borrow-in-loop-2.rs
+++ /dev/null
@@ -1,35 +0,0 @@
-// run-rustfix
-#![allow(dead_code)]
-
-struct Events<R>(R);
-
-struct Other;
-
-pub trait Trait<T> {
- fn handle(value: T) -> Self;
-}
-
-// Blanket impl. (If you comment this out, compiler figures out that it
-// is passing an `&mut` to a method that must be expecting an `&mut`,
-// and injects an auto-reborrow.)
-impl<T, U> Trait<U> for T where T: From<U> {
- fn handle(_: U) -> Self { unimplemented!() }
-}
-
-impl<'a, R> Trait<&'a mut Events<R>> for Other {
- fn handle(_: &'a mut Events<R>) -> Self { unimplemented!() }
-}
-
-fn this_compiles<'a, R>(value: &'a mut Events<R>) {
- for _ in 0..3 {
- Other::handle(&mut *value);
- }
-}
-
-fn this_does_not<'a, R>(value: &'a mut Events<R>) {
- for _ in 0..3 {
- Other::handle(value); //~ ERROR use of moved value: `value`
- }
-}
-
-fn main() {}