]> git.lizzy.rs Git - rust.git/commitdiff
use MaybeUninit instead of mem::uninitialized for Windows Mutex
authorRalf Jung <post@ralfj.de>
Tue, 27 Nov 2018 08:32:00 +0000 (09:32 +0100)
committerRalf Jung <post@ralfj.de>
Tue, 27 Nov 2018 08:32:00 +0000 (09:32 +0100)
src/libstd/sys/windows/mutex.rs

index b0e7331e2b6513a20a55623300836c9303b19001..3ba19a40d48b95311eb675ec64c1494eca68fea2 100644 (file)
@@ -30,7 +30,7 @@
 //! detect recursive locks.
 
 use cell::UnsafeCell;
-use mem;
+use mem::{self, MaybeUninit};
 use sync::atomic::{AtomicUsize, Ordering};
 use sys::c;
 use sys::compat;
@@ -157,34 +157,34 @@ fn kind() -> Kind {
     return ret;
 }
 
-pub struct ReentrantMutex { inner: UnsafeCell<c::CRITICAL_SECTION> }
+pub struct ReentrantMutex { inner: MaybeUninit<UnsafeCell<c::CRITICAL_SECTION>> }
 
 unsafe impl Send for ReentrantMutex {}
 unsafe impl Sync for ReentrantMutex {}
 
 impl ReentrantMutex {
-    pub unsafe fn uninitialized() -> ReentrantMutex {
-        mem::uninitialized()
+    pub fn uninitialized() -> ReentrantMutex {
+        MaybeUninit::uninitialized()
     }
 
     pub unsafe fn init(&mut self) {
-        c::InitializeCriticalSection(self.inner.get());
+        c::InitializeCriticalSection(self.inner.get_ref().get());
     }
 
     pub unsafe fn lock(&self) {
-        c::EnterCriticalSection(self.inner.get());
+        c::EnterCriticalSection(self.inner.get_ref().get());
     }
 
     #[inline]
     pub unsafe fn try_lock(&self) -> bool {
-        c::TryEnterCriticalSection(self.inner.get()) != 0
+        c::TryEnterCriticalSection(self.inner.get_ref().get()) != 0
     }
 
     pub unsafe fn unlock(&self) {
-        c::LeaveCriticalSection(self.inner.get());
+        c::LeaveCriticalSection(self.inner.get_ref().get());
     }
 
     pub unsafe fn destroy(&self) {
-        c::DeleteCriticalSection(self.inner.get());
+        c::DeleteCriticalSection(self.inner.get_ref().get());
     }
 }