mirror of
https://github.com/rust-lang/rust.git
synced 2024-12-03 20:23:59 +00:00
Redox: Add JoinHandleExt (matching Unix version)
This commit is contained in:
parent
ddaab61101
commit
c83f97533a
@ -33,6 +33,7 @@ pub mod ffi;
|
|||||||
pub mod fs;
|
pub mod fs;
|
||||||
pub mod io;
|
pub mod io;
|
||||||
pub mod process;
|
pub mod process;
|
||||||
|
pub mod thread;
|
||||||
|
|
||||||
/// A prelude for conveniently writing platform-specific code.
|
/// A prelude for conveniently writing platform-specific code.
|
||||||
///
|
///
|
||||||
@ -46,5 +47,7 @@ pub mod prelude {
|
|||||||
#[doc(no_inline)] #[stable(feature = "rust1", since = "1.0.0")]
|
#[doc(no_inline)] #[stable(feature = "rust1", since = "1.0.0")]
|
||||||
pub use super::fs::{FileTypeExt, PermissionsExt, OpenOptionsExt, MetadataExt};
|
pub use super::fs::{FileTypeExt, PermissionsExt, OpenOptionsExt, MetadataExt};
|
||||||
#[doc(no_inline)] #[stable(feature = "rust1", since = "1.0.0")]
|
#[doc(no_inline)] #[stable(feature = "rust1", since = "1.0.0")]
|
||||||
|
pub use super::thread::JoinHandleExt;
|
||||||
|
#[doc(no_inline)] #[stable(feature = "rust1", since = "1.0.0")]
|
||||||
pub use super::process::{CommandExt, ExitStatusExt};
|
pub use super::process::{CommandExt, ExitStatusExt};
|
||||||
}
|
}
|
||||||
|
47
src/libstd/sys/redox/ext/thread.rs
Normal file
47
src/libstd/sys/redox/ext/thread.rs
Normal file
@ -0,0 +1,47 @@
|
|||||||
|
// 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::thread` module.
|
||||||
|
|
||||||
|
#![stable(feature = "thread_extensions", since = "1.9.0")]
|
||||||
|
|
||||||
|
use sys_common::{AsInner, IntoInner};
|
||||||
|
use thread::JoinHandle;
|
||||||
|
|
||||||
|
#[stable(feature = "thread_extensions", since = "1.9.0")]
|
||||||
|
#[allow(deprecated)]
|
||||||
|
pub type RawPthread = usize;
|
||||||
|
|
||||||
|
/// Unix-specific extensions to `std::thread::JoinHandle`
|
||||||
|
#[stable(feature = "thread_extensions", since = "1.9.0")]
|
||||||
|
pub trait JoinHandleExt {
|
||||||
|
/// Extracts the raw pthread_t without taking ownership
|
||||||
|
#[stable(feature = "thread_extensions", since = "1.9.0")]
|
||||||
|
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 detach or join the pthread_t once it's no longer needed.
|
||||||
|
#[stable(feature = "thread_extensions", since = "1.9.0")]
|
||||||
|
fn into_pthread_t(self) -> RawPthread;
|
||||||
|
}
|
||||||
|
|
||||||
|
#[stable(feature = "thread_extensions", since = "1.9.0")]
|
||||||
|
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
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user