From cf483a130cdfa1e72678fd98c74b11fedb3ae8dd Mon Sep 17 00:00:00 2001 From: Joshua Nelson Date: Fri, 27 May 2022 09:39:54 -0500 Subject: [PATCH] `impl AsFd for {Arc,Box}` --- library/std/src/os/fd/owned.rs | 31 +++++++++++++++++++++++++++++++ library/std/src/os/fd/raw.rs | 5 ++--- 2 files changed, 33 insertions(+), 3 deletions(-) diff --git a/library/std/src/os/fd/owned.rs b/library/std/src/os/fd/owned.rs index dd965ddc01e..d661a13edc5 100644 --- a/library/std/src/os/fd/owned.rs +++ b/library/std/src/os/fd/owned.rs @@ -355,3 +355,34 @@ fn from(owned_fd: OwnedFd) -> Self { )))) } } + +#[stable(feature = "io_safety", since = "1.63.0")] +/// This impl allows implementing traits that require `AsFd` on Arc. +/// ``` +/// # #[cfg(any(unix, target_os = "wasi"))] mod group_cfg { +/// # #[cfg(target_os = "wasi")] +/// # use std::os::wasi::io::AsFd; +/// # #[cfg(unix)] +/// # use std::os::unix::io::AsFd; +/// use std::net::UdpSocket; +/// use std::sync::Arc; +/// +/// trait MyTrait: AsFd {} +/// impl MyTrait for Arc {} +/// impl MyTrait for Box {} +/// # } +/// ``` +impl AsFd for crate::sync::Arc { + #[inline] + fn as_fd(&self) -> BorrowedFd<'_> { + (**self).as_fd() + } +} + +#[stable(feature = "io_safety", since = "1.63.0")] +impl AsFd for Box { + #[inline] + fn as_fd(&self) -> BorrowedFd<'_> { + (**self).as_fd() + } +} diff --git a/library/std/src/os/fd/raw.rs b/library/std/src/os/fd/raw.rs index 7b6d2402aa9..345beb1824d 100644 --- a/library/std/src/os/fd/raw.rs +++ b/library/std/src/os/fd/raw.rs @@ -223,8 +223,7 @@ fn as_raw_fd(&self) -> RawFd { } } -#[stable(feature = "asraw_ptrs", since = "1.63.0")] -/// This blanket impl allows implementing custom traits that require `AsRawFd` on Arc. +/// This impl allows implementing traits that require `AsRawFd` on Arc. /// ``` /// # #[cfg(any(unix, target_os = "wasi"))] mod group_cfg { /// # #[cfg(target_os = "wasi")] @@ -247,7 +246,7 @@ fn as_raw_fd(&self) -> RawFd { } } -#[stable(feature = "asraw_ptrs", since = "1.63.0")] +#[stable(feature = "asrawfd_ptrs", since = "1.63.0")] impl AsRawFd for Box { #[inline] fn as_raw_fd(&self) -> RawFd {