os-rust/tests/ui/span/send-is-not-static-std-sync.stderr

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

104 lines
3.4 KiB
Text
Raw Normal View History

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
|
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;
| --- borrow of `*y` occurs here
2019-03-09 15:03:44 +03:00
LL | drop(y);
| ^ move out of `y` occurs here
...
LL | *lock.lock().unwrap() = &z;
| ---- borrow later used here
|
help: consider cloning the value if the performance cost is acceptable
|
LL - *lock.lock().unwrap() = &*y;
LL + *lock.lock().unwrap() = y.clone();
|
2017-05-27 19:58:52 +02:00
error[E0597]: `z` does not live long enough
--> $DIR/send-is-not-static-std-sync.rs:16:33
|
2023-01-15 03:06:44 +00:00
LL | let z = 2;
| - binding `z` declared here
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
LL |
LL | lock.use_ref(); // (Mutex is #[may_dangle] so its dtor does not use `z` => needs explicit use)
| ---- borrow later used here
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
|
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;
| --- borrow of `*y` occurs here
2019-03-09 15:03:44 +03:00
LL | drop(y);
| ^ move out of `y` occurs here
...
LL | *lock.write().unwrap() = &z;
| ---- borrow later used here
|
help: consider cloning the value if the performance cost is acceptable
|
LL - *lock.write().unwrap() = &*y;
LL + *lock.write().unwrap() = y.clone();
|
2017-05-27 19:58:52 +02:00
error[E0597]: `z` does not live long enough
--> $DIR/send-is-not-static-std-sync.rs:30:34
|
2023-01-15 03:06:44 +00:00
LL | let z = 2;
| - binding `z` declared here
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
LL |
LL | lock.use_ref(); // (RwLock is #[may_dangle] so its dtor does not use `z` => needs explicit use)
| ---- borrow later used here
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
|
LL | let y = Box::new(1);
| - binding `y` declared here
...
2018-02-23 03:42:32 +03:00
LL | tx.send(&*y);
| --- borrow of `*y` occurs here
2019-03-09 15:03:44 +03:00
LL | drop(y);
| ^ move out of `y` occurs here
...
LL | tx.send(&z).unwrap();
| -- borrow later used here
|
help: consider cloning the value if the performance cost is acceptable
|
LL - tx.send(&*y);
LL + tx.send(y.clone());
|
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
LL | tx.send(&z).unwrap();
| ^^ borrowed value does not live long enough
LL | }
| - `z` dropped here while still borrowed
LL |
LL | tx.use_ref(); // (channel drop glue does not use `z` => needs explicit use)
| -- borrow later used here
error: aborting due to 6 previous errors
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`.