2018-08-15 22:36:19 -07:00
|
|
|
#[derive(Clone)]
|
|
|
|
enum Either {
|
|
|
|
One(X),
|
|
|
|
Two(X),
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
struct X(Y);
|
|
|
|
|
|
|
|
#[derive(Clone)]
|
|
|
|
struct Y;
|
|
|
|
|
|
|
|
|
|
|
|
pub fn main() {
|
|
|
|
let e = Either::One(X(Y));
|
|
|
|
let mut em = Either::One(X(Y));
|
|
|
|
|
|
|
|
let r = &e;
|
|
|
|
let rm = &mut Either::One(X(Y));
|
|
|
|
|
|
|
|
let x = X(Y);
|
|
|
|
let mut xm = X(Y);
|
|
|
|
|
|
|
|
let s = &x;
|
|
|
|
let sm = &mut X(Y);
|
|
|
|
|
|
|
|
let ve = vec![Either::One(X(Y))];
|
|
|
|
|
|
|
|
let vr = &ve;
|
|
|
|
let vrm = &mut vec![Either::One(X(Y))];
|
|
|
|
|
|
|
|
let vx = vec![X(Y)];
|
|
|
|
|
|
|
|
let vs = &vx;
|
|
|
|
let vsm = &mut vec![X(Y)];
|
|
|
|
|
2019-08-19 22:31:46 +01:00
|
|
|
// test for duplicate suggestions
|
2018-08-15 22:36:19 -07:00
|
|
|
|
|
|
|
let &(X(_t), X(_u)) = &(x.clone(), x.clone());
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
if let &(Either::One(_t), Either::Two(_u)) = &(e.clone(), e.clone()) { }
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
while let &(Either::One(_t), Either::Two(_u)) = &(e.clone(), e.clone()) { }
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
match &(e.clone(), e.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&(Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
&(Either::Two(_t), Either::One(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &(e.clone(), e.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&(Either::One(_t), Either::Two(_u))
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
| &(Either::Two(_t), Either::One(_u)) => (),
|
|
|
|
// FIXME: would really like a suggestion here too
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &(e.clone(), e.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&(Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
&(Either::Two(ref _t), Either::One(ref _u)) => (),
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &(e.clone(), e.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&(Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
(Either::Two(_t), Either::One(_u)) => (),
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
fn f5(&(X(_t), X(_u)): &(X, X)) { }
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
|
|
|
|
let &mut (X(_t), X(_u)) = &mut (xm.clone(), xm.clone());
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
if let &mut (Either::One(_t), Either::Two(_u)) = &mut (em.clone(), em.clone()) { }
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
while let &mut (Either::One(_t), Either::Two(_u)) = &mut (em.clone(), em.clone()) { }
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
match &mut (em.clone(), em.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&mut (Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
&mut (Either::Two(_t), Either::One(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &mut (em.clone(), em.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&mut (Either::One(_t), Either::Two(_u))
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
| &mut (Either::Two(_t), Either::One(_u)) => (),
|
|
|
|
// FIXME: would really like a suggestion here too
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &mut (em.clone(), em.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&mut (Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
&mut (Either::Two(ref _t), Either::One(ref _u)) => (),
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &mut (em.clone(), em.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&mut (Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
&mut (Either::Two(ref mut _t), Either::One(ref mut _u)) => (),
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
match &mut (em.clone(), em.clone()) {
|
|
|
|
//~^ ERROR cannot move
|
|
|
|
&mut (Either::One(_t), Either::Two(_u)) => (),
|
2022-12-08 09:02:54 -08:00
|
|
|
//~^ HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
(Either::Two(_t), Either::One(_u)) => (),
|
|
|
|
_ => (),
|
|
|
|
}
|
|
|
|
fn f6(&mut (X(_t), X(_u)): &mut (X, X)) { }
|
|
|
|
//~^ ERROR cannot move
|
2022-12-08 09:02:54 -08:00
|
|
|
//~| HELP consider removing the mutable borrow
|
2018-08-15 22:36:19 -07:00
|
|
|
}
|