Rollup merge of #125527 - programmerjake:patch-2, r=workingjubilee
Add manual Sync impl for ReentrantLockGuard Fixes: #125526 Tracking Issue: #121440 this impl is even shown in the summary in the tracking issue, but apparently was forgotten in the actual implementation
This commit is contained in:
commit
1d54ba8402
3 changed files with 38 additions and 0 deletions
|
@ -116,6 +116,9 @@ pub struct ReentrantLockGuard<'a, T: ?Sized + 'a> {
|
||||||
#[unstable(feature = "reentrant_lock", issue = "121440")]
|
#[unstable(feature = "reentrant_lock", issue = "121440")]
|
||||||
impl<T: ?Sized> !Send for ReentrantLockGuard<'_, T> {}
|
impl<T: ?Sized> !Send for ReentrantLockGuard<'_, T> {}
|
||||||
|
|
||||||
|
#[unstable(feature = "reentrant_lock", issue = "121440")]
|
||||||
|
unsafe impl<T: ?Sized + Sync> Sync for ReentrantLockGuard<'_, T> {}
|
||||||
|
|
||||||
#[unstable(feature = "reentrant_lock", issue = "121440")]
|
#[unstable(feature = "reentrant_lock", issue = "121440")]
|
||||||
impl<T> ReentrantLock<T> {
|
impl<T> ReentrantLock<T> {
|
||||||
/// Creates a new re-entrant lock in an unlocked state ready for use.
|
/// Creates a new re-entrant lock in an unlocked state ready for use.
|
||||||
|
|
15
tests/ui/sync/reentrantlockguard-sync.rs
Normal file
15
tests/ui/sync/reentrantlockguard-sync.rs
Normal file
|
@ -0,0 +1,15 @@
|
||||||
|
#![feature(reentrant_lock)]
|
||||||
|
use std::sync::ReentrantLock;
|
||||||
|
use std::cell::Cell;
|
||||||
|
|
||||||
|
// ReentrantLockGuard<Cell<i32>> must not be Sync, that would be unsound.
|
||||||
|
|
||||||
|
fn test_sync<T: Sync>(_t: T) {}
|
||||||
|
|
||||||
|
fn main()
|
||||||
|
{
|
||||||
|
let m = ReentrantLock::new(Cell::new(0i32));
|
||||||
|
let guard = m.lock();
|
||||||
|
test_sync(guard);
|
||||||
|
//~^ ERROR `Cell<i32>` cannot be shared between threads safely [E0277]
|
||||||
|
}
|
20
tests/ui/sync/reentrantlockguard-sync.stderr
Normal file
20
tests/ui/sync/reentrantlockguard-sync.stderr
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
error[E0277]: `Cell<i32>` cannot be shared between threads safely
|
||||||
|
--> $DIR/reentrantlockguard-sync.rs:13:15
|
||||||
|
|
|
||||||
|
LL | test_sync(guard);
|
||||||
|
| --------- ^^^^^ `Cell<i32>` cannot be shared between threads safely
|
||||||
|
| |
|
||||||
|
| required by a bound introduced by this call
|
||||||
|
|
|
||||||
|
= help: the trait `Sync` is not implemented for `Cell<i32>`, which is required by `ReentrantLockGuard<'_, Cell<i32>>: Sync`
|
||||||
|
= note: if you want to do aliasing and mutation between multiple threads, use `std::sync::RwLock` or `std::sync::atomic::AtomicI32` instead
|
||||||
|
= note: required for `ReentrantLockGuard<'_, Cell<i32>>` to implement `Sync`
|
||||||
|
note: required by a bound in `test_sync`
|
||||||
|
--> $DIR/reentrantlockguard-sync.rs:7:17
|
||||||
|
|
|
||||||
|
LL | fn test_sync<T: Sync>(_t: T) {}
|
||||||
|
| ^^^^ required by this bound in `test_sync`
|
||||||
|
|
||||||
|
error: aborting due to 1 previous error
|
||||||
|
|
||||||
|
For more information about this error, try `rustc --explain E0277`.
|
Loading…
Add table
Add a link
Reference in a new issue