diff options
| author | bors <bors@rust-lang.org> | 2015-12-05 20:49:16 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2015-12-05 20:49:16 +0000 |
| commit | aad4e5665e81a3ec998b3648d395d0eb99a7500b (patch) | |
| tree | 7c9286e32c368bcfb7eb295fd4b35e9eb7285c01 /src/libstd/sys | |
| parent | 9f715e98925adbf205bccd8a044266c77197db50 (diff) | |
| parent | 9749a193d629dd723562004879bca3e2d47e25a1 (diff) | |
| download | rust-aad4e5665e81a3ec998b3648d395d0eb99a7500b.tar.gz rust-aad4e5665e81a3ec998b3648d395d0eb99a7500b.zip | |
Auto merge of #30177 - retep998:handling-threads, r=alexcrichton
Allows a `HANDLE` to be extracted from a `JoinHandle` on Windows. Allows a `pthread_t` to be extracted from a `JoinHandle` everywhere else. Because https://github.com/rust-lang/rust/pull/29461 was closed. r? @alexcrichton
Diffstat (limited to 'src/libstd/sys')
| -rw-r--r-- | src/libstd/sys/unix/ext/mod.rs | 1 | ||||
| -rw-r--r-- | src/libstd/sys/unix/ext/raw.rs | 3 | ||||
| -rw-r--r-- | src/libstd/sys/unix/ext/thread.rs | 43 | ||||
| -rw-r--r-- | src/libstd/sys/unix/thread.rs | 8 | ||||
| -rw-r--r-- | src/libstd/sys/windows/ext/mod.rs | 1 | ||||
| -rw-r--r-- | src/libstd/sys/windows/ext/thread.rs | 29 | ||||
| -rw-r--r-- | src/libstd/sys/windows/thread.rs | 4 |
7 files changed, 89 insertions, 0 deletions
diff --git a/src/libstd/sys/unix/ext/mod.rs b/src/libstd/sys/unix/ext/mod.rs index b57e325089d..276ef25a03a 100644 --- a/src/libstd/sys/unix/ext/mod.rs +++ b/src/libstd/sys/unix/ext/mod.rs @@ -34,6 +34,7 @@ pub mod ffi; pub mod fs; pub mod process; pub mod raw; +pub mod thread; /// A prelude for conveniently writing platform-specific code. /// diff --git a/src/libstd/sys/unix/ext/raw.rs b/src/libstd/sys/unix/ext/raw.rs index 8377e53f417..d1cc6cba51d 100644 --- a/src/libstd/sys/unix/ext/raw.rs +++ b/src/libstd/sys/unix/ext/raw.rs @@ -17,6 +17,9 @@ #[stable(feature = "raw_ext", since = "1.1.0")] pub type pid_t = i32; #[doc(inline)] +#[unstable(feature = "pthread_t", issue = "29791")] +pub use sys::platform::raw::pthread_t; +#[doc(inline)] #[stable(feature = "raw_ext", since = "1.1.0")] pub use sys::platform::raw::{dev_t, ino_t, mode_t, nlink_t, off_t, blksize_t}; #[doc(inline)] diff --git a/src/libstd/sys/unix/ext/thread.rs b/src/libstd/sys/unix/ext/thread.rs new file mode 100644 index 00000000000..c1c1609632a --- /dev/null +++ b/src/libstd/sys/unix/ext/thread.rs @@ -0,0 +1,43 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +//! Unix-specific extensions to primitives in the `std::process` module. + +#![unstable(feature = "thread_extensions", issue = "29791")] + +use os::unix::raw::{pthread_t}; +use sys_common::{AsInner, IntoInner}; +use thread::{JoinHandle}; + +#[unstable(feature = "thread_extensions", issue = "29791")] +pub type RawPthread = pthread_t; + +/// Unix-specific extensions to `std::thread::JoinHandle` +#[unstable(feature = "thread_extensions", issue = "29791")] +pub trait JoinHandleExt { + /// Extracts the raw pthread_t without taking ownership + fn as_pthread_t(&self) -> RawPthread; + /// Consumes the thread, returning the raw pthread_t + /// + /// This function **transfers ownership** of the underlying pthread_t to + /// the caller. Callers are then the unique owners of the pthread_t and + /// must either detech or join the pthread_t once it's no longer needed. + fn into_pthread_t(self) -> RawPthread; +} + +#[unstable(feature = "thread_extensions", issue = "29791")] +impl<T> JoinHandleExt for JoinHandle<T> { + fn as_pthread_t(&self) -> RawPthread { + self.as_inner().id() as RawPthread + } + fn into_pthread_t(self) -> RawPthread { + self.into_inner().into_id() as RawPthread + } +} diff --git a/src/libstd/sys/unix/thread.rs b/src/libstd/sys/unix/thread.rs index f111f97be60..4d715b579c6 100644 --- a/src/libstd/sys/unix/thread.rs +++ b/src/libstd/sys/unix/thread.rs @@ -152,6 +152,14 @@ impl Thread { debug_assert_eq!(ret, 0); } } + + pub fn id(&self) -> libc::pthread_t { self.id } + + pub fn into_id(self) -> libc::pthread_t { + let id = self.id; + mem::forget(self); + id + } } impl Drop for Thread { diff --git a/src/libstd/sys/windows/ext/mod.rs b/src/libstd/sys/windows/ext/mod.rs index 7f095ae7ff6..c3578fdfdb1 100644 --- a/src/libstd/sys/windows/ext/mod.rs +++ b/src/libstd/sys/windows/ext/mod.rs @@ -21,6 +21,7 @@ pub mod fs; pub mod io; pub mod raw; pub mod process; +pub mod thread; /// A prelude for conveniently writing platform-specific code. /// diff --git a/src/libstd/sys/windows/ext/thread.rs b/src/libstd/sys/windows/ext/thread.rs new file mode 100644 index 00000000000..3a07204b2bc --- /dev/null +++ b/src/libstd/sys/windows/ext/thread.rs @@ -0,0 +1,29 @@ +// Copyright 2015 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +//! Extensions to `std::thread` for Windows. + +#![unstable(feature = "thread_extensions", issue = "29791")] + +use os::windows::io::{RawHandle, AsRawHandle, IntoRawHandle}; +use thread; +use sys_common::{AsInner, IntoInner}; + +impl<T> AsRawHandle for thread::JoinHandle<T> { + fn as_raw_handle(&self) -> RawHandle { + self.as_inner().handle().raw() as *mut _ + } +} + +impl<T> IntoRawHandle for thread::JoinHandle<T> { + fn into_raw_handle(self) -> RawHandle { + self.into_inner().into_handle().into_raw() as *mut _ + } +} diff --git a/src/libstd/sys/windows/thread.rs b/src/libstd/sys/windows/thread.rs index a6e6cc94b76..1ba85867563 100644 --- a/src/libstd/sys/windows/thread.rs +++ b/src/libstd/sys/windows/thread.rs @@ -77,6 +77,10 @@ impl Thread { c::Sleep(super::dur2timeout(dur)) } } + + pub fn handle(&self) -> &Handle { &self.handle } + + pub fn into_handle(self) -> Handle { self.handle } } pub mod guard { |
