2016-10-26 19:10:39 +03:00
|
|
|
error[E0505]: cannot move out of `y` because it is borrowed
|
2018-12-25 08:56:47 -07:00
|
|
|
--> $DIR/send-is-not-static-std-sync.rs:13:10
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
2023-01-17 02:45:11 +00:00
|
|
|
LL | let y = Box::new(1);
|
|
|
|
| - binding `y` declared here
|
|
|
|
LL | let lock = Mutex::new(&x);
|
2018-02-23 03:42:32 +03:00
|
|
|
LL | *lock.lock().unwrap() = &*y;
|
2019-04-22 08:40:08 +01:00
|
|
|
| --- borrow of `*y` occurs here
|
2019-03-09 15:03:44 +03:00
|
|
|
LL | drop(y);
|
2016-10-26 19:10:39 +03:00
|
|
|
| ^ move out of `y` occurs here
|
2019-04-22 08:40:08 +01:00
|
|
|
...
|
|
|
|
LL | *lock.lock().unwrap() = &z;
|
2023-06-22 20:30:23 +00:00
|
|
|
| ---- borrow later used here
|
2024-03-13 01:51:08 +00:00
|
|
|
|
|
|
|
|
help: consider cloning the value if the performance cost is acceptable
|
|
|
|
|
|
2024-03-13 02:13:51 +00:00
|
|
|
LL - *lock.lock().unwrap() = &*y;
|
|
|
|
LL + *lock.lock().unwrap() = y.clone();
|
|
|
|
|
|
2016-10-26 19:10:39 +03:00
|
|
|
|
2017-05-27 19:58:52 +02:00
|
|
|
error[E0597]: `z` does not live long enough
|
2019-04-22 08:40:08 +01:00
|
|
|
--> $DIR/send-is-not-static-std-sync.rs:16:33
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
2023-01-15 03:06:44 +00:00
|
|
|
LL | let z = 2;
|
|
|
|
| - binding `z` declared here
|
2019-04-22 08:40:08 +01:00
|
|
|
LL | *lock.lock().unwrap() = &z;
|
|
|
|
| ^^ borrowed value does not live long enough
|
2018-02-23 03:42:32 +03:00
|
|
|
LL | }
|
2017-12-13 17:27:23 -08:00
|
|
|
| - `z` dropped here while still borrowed
|
2019-04-22 08:40:08 +01:00
|
|
|
LL |
|
|
|
|
LL | lock.use_ref(); // (Mutex is #[may_dangle] so its dtor does not use `z` => needs explicit use)
|
2023-06-22 20:30:23 +00:00
|
|
|
| ---- borrow later used here
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
|
|
error[E0505]: cannot move out of `y` because it is borrowed
|
2018-12-25 08:56:47 -07:00
|
|
|
--> $DIR/send-is-not-static-std-sync.rs:27:10
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
2023-01-17 02:45:11 +00:00
|
|
|
LL | let y = Box::new(1);
|
|
|
|
| - binding `y` declared here
|
|
|
|
LL | let lock = RwLock::new(&x);
|
2018-02-23 03:42:32 +03:00
|
|
|
LL | *lock.write().unwrap() = &*y;
|
2019-04-22 08:40:08 +01:00
|
|
|
| --- borrow of `*y` occurs here
|
2019-03-09 15:03:44 +03:00
|
|
|
LL | drop(y);
|
2016-10-26 19:10:39 +03:00
|
|
|
| ^ move out of `y` occurs here
|
2019-04-22 08:40:08 +01:00
|
|
|
...
|
|
|
|
LL | *lock.write().unwrap() = &z;
|
2023-06-22 20:30:23 +00:00
|
|
|
| ---- borrow later used here
|
2024-03-13 01:51:08 +00:00
|
|
|
|
|
|
|
|
help: consider cloning the value if the performance cost is acceptable
|
|
|
|
|
|
2024-03-13 02:13:51 +00:00
|
|
|
LL - *lock.write().unwrap() = &*y;
|
|
|
|
LL + *lock.write().unwrap() = y.clone();
|
|
|
|
|
|
2016-10-26 19:10:39 +03:00
|
|
|
|
2017-05-27 19:58:52 +02:00
|
|
|
error[E0597]: `z` does not live long enough
|
2019-04-22 08:40:08 +01:00
|
|
|
--> $DIR/send-is-not-static-std-sync.rs:30:34
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
2023-01-15 03:06:44 +00:00
|
|
|
LL | let z = 2;
|
|
|
|
| - binding `z` declared here
|
2019-04-22 08:40:08 +01:00
|
|
|
LL | *lock.write().unwrap() = &z;
|
|
|
|
| ^^ borrowed value does not live long enough
|
2018-02-23 03:42:32 +03:00
|
|
|
LL | }
|
2017-12-13 17:27:23 -08:00
|
|
|
| - `z` dropped here while still borrowed
|
2019-04-22 08:40:08 +01:00
|
|
|
LL |
|
|
|
|
LL | lock.use_ref(); // (RwLock is #[may_dangle] so its dtor does not use `z` => needs explicit use)
|
2023-06-22 20:30:23 +00:00
|
|
|
| ---- borrow later used here
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
|
|
error[E0505]: cannot move out of `y` because it is borrowed
|
2018-12-25 08:56:47 -07:00
|
|
|
--> $DIR/send-is-not-static-std-sync.rs:43:10
|
2016-10-26 19:10:39 +03:00
|
|
|
|
|
2023-01-17 02:45:11 +00:00
|
|
|
LL | let y = Box::new(1);
|
|
|
|
| - binding `y` declared here
|
|
|
|
...
|
2018-02-23 03:42:32 +03:00
|
|
|
LL | tx.send(&*y);
|
2019-04-22 08:40:08 +01:00
|
|
|
| --- borrow of `*y` occurs here
|
2019-03-09 15:03:44 +03:00
|
|
|
LL | drop(y);
|
2016-10-26 19:10:39 +03:00
|
|
|
| ^ move out of `y` occurs here
|
2019-04-22 08:40:08 +01:00
|
|
|
...
|
|
|
|
LL | tx.send(&z).unwrap();
|
2023-06-22 20:30:23 +00:00
|
|
|
| -- borrow later used here
|
2024-03-13 01:51:08 +00:00
|
|
|
|
|
|
|
|
help: consider cloning the value if the performance cost is acceptable
|
|
|
|
|
|
2024-03-13 02:13:51 +00:00
|
|
|
LL - tx.send(&*y);
|
|
|
|
LL + tx.send(y.clone());
|
|
|
|
|
|
2019-04-22 08:40:08 +01:00
|
|
|
|
|
|
|
error[E0597]: `z` does not live long enough
|
|
|
|
--> $DIR/send-is-not-static-std-sync.rs:46:17
|
|
|
|
|
|
2023-01-15 03:06:44 +00:00
|
|
|
LL | let z = 2;
|
|
|
|
| - binding `z` declared here
|
2019-04-22 08:40:08 +01:00
|
|
|
LL | tx.send(&z).unwrap();
|
|
|
|
| ^^ borrowed value does not live long enough
|
|
|
|
LL | }
|
|
|
|
| - `z` dropped here while still borrowed
|
2023-08-18 14:05:55 +02:00
|
|
|
LL |
|
|
|
|
LL | tx.use_ref(); // (channel drop glue does not use `z` => needs explicit use)
|
|
|
|
| -- borrow later used here
|
2016-10-26 19:10:39 +03:00
|
|
|
|
2017-07-02 13:49:30 +03:00
|
|
|
error: aborting due to 6 previous errors
|
2016-10-26 19:10:39 +03:00
|
|
|
|
2019-04-17 13:26:38 -04:00
|
|
|
Some errors have detailed explanations: E0505, E0597.
|
2018-03-03 15:59:40 +01:00
|
|
|
For more information about an error, try `rustc --explain E0505`.
|