From 64d98f8ee037282c35007b64c2649055c56af1db Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Wed, 17 Apr 2024 14:19:03 +0200 Subject: Merging upstream version 1.68.2+dfsg1. Signed-off-by: Daniel Baumann --- src/test/ui/binop/binop-move-semantics.rs | 68 ------------------------------- 1 file changed, 68 deletions(-) delete mode 100644 src/test/ui/binop/binop-move-semantics.rs (limited to 'src/test/ui/binop/binop-move-semantics.rs') diff --git a/src/test/ui/binop/binop-move-semantics.rs b/src/test/ui/binop/binop-move-semantics.rs deleted file mode 100644 index b5133ea7c..000000000 --- a/src/test/ui/binop/binop-move-semantics.rs +++ /dev/null @@ -1,68 +0,0 @@ -// Test that move restrictions are enforced on overloaded binary operations - -use std::ops::Add; - -fn double_move>(x: T) { - x - + - x; //~ ERROR: use of moved value -} - -fn move_then_borrow + Clone>(x: T) { - x - + - x.clone(); //~ ERROR: borrow of moved value -} - -fn move_borrowed>(x: T, mut y: T) { - let m = &x; - let n = &mut y; - - x //~ ERROR: cannot move out of `x` because it is borrowed - + - y; //~ ERROR: cannot move out of `y` because it is borrowed - use_mut(n); use_imm(m); -} -fn illegal_dereference>(mut x: T, y: T) { - let m = &mut x; - let n = &y; - - *m //~ ERROR: cannot move - + - *n; //~ ERROR: cannot move - use_imm(n); use_mut(m); -} -struct Foo; - -impl<'a, 'b> Add<&'b Foo> for &'a mut Foo { - type Output = (); - - fn add(self, _: &Foo) {} -} - -impl<'a, 'b> Add<&'b mut Foo> for &'a Foo { - type Output = (); - - fn add(self, _: &mut Foo) {} -} - -fn mut_plus_immut() { - let mut f = Foo; - - &mut f - + - &f; //~ ERROR: cannot borrow `f` as immutable because it is also borrowed as mutable -} - -fn immut_plus_mut() { - let mut f = Foo; - - &f - + - &mut f; //~ ERROR: cannot borrow `f` as mutable because it is also borrowed as immutable -} - -fn main() {} - -fn use_mut(_: &mut T) { } -fn use_imm(_: &T) { } -- cgit v1.2.3