pub trait FromRawFd {
// Required method
unsafe fn from_raw_fd(fd: i32) -> Self;
}
Available on Unix or HermitCore or WASI only.
Expand description
A trait to express the ability to construct an object from a raw file descriptor.
Required Methods§
1.1.0 · Sourceunsafe fn from_raw_fd(fd: i32) -> Self
unsafe fn from_raw_fd(fd: i32) -> Self
Constructs a new instance of Self
from the given raw file
descriptor.
This function is typically used to consume ownership of the specified file descriptor. When used in this way, the returned object will take responsibility for closing it when the object goes out of scope.
However, consuming ownership is not strictly required. Use a
From<OwnedFd>::from
implementation for an API which strictly
consumes ownership.
§Safety
The fd
passed in must be an owned file descriptor;
in particular, it must be open.
§Example
use std::fs::File;
#[cfg(any(unix, target_os = "wasi"))]
use std::os::fd::{FromRawFd, IntoRawFd, RawFd};
let f = File::open("foo.txt")?;
let raw_fd: RawFd = f.into_raw_fd();
// SAFETY: no other functions should call `from_raw_fd`, so there
// is only one owner for the file descriptor.
let f = unsafe { File::from_raw_fd(raw_fd) };
Dyn Compatibility§
This trait is not dyn compatible.
In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.
Implementors§
impl FromRawFd for i32
impl FromRawFd for wiwi::prelude::File
impl FromRawFd for PipeReader
impl FromRawFd for PipeWriter
impl FromRawFd for wiwi::prelude::std::net::TcpListener
impl FromRawFd for wiwi::prelude::std::net::TcpStream
impl FromRawFd for wiwi::prelude::std::net::UdpSocket
impl FromRawFd for Stdio
impl FromRawFd for PidFd
impl FromRawFd for wiwi::prelude::std::os::unix::net::UnixDatagram
impl FromRawFd for wiwi::prelude::std::os::unix::net::UnixListener
impl FromRawFd for wiwi::prelude::std::os::unix::net::UnixStream
impl FromRawFd for OwnedFd
impl FromRawFd for File
Available on Unix only.
impl FromRawFd for Receiver
Available on crate feature
os-ext
only.impl FromRawFd for Sender
Available on crate feature
os-ext
only.impl FromRawFd for Socket
impl FromRawFd for TcpListener
impl FromRawFd for TcpSocket
Available on
docsrs
or Unix only.