Skip to main content

FromRawFd

Trait FromRawFd 

1.1.0 · Source
pub trait FromRawFd {
    // Required method
    unsafe fn from_raw_fd(fd: i32) -> Self;
}
Expand description

A trait to express the ability to construct an object from a raw file descriptor.

Required Methods§

1.1.0 · Source

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§

1.48.0 · Source§

impl FromRawFd for i32

Source§

impl FromRawFd for async_std::fs::File

Available on Unix or crate feature docs only.
Source§

impl FromRawFd for async_std::net::TcpListener

Available on Unix or crate feature docs only.
Source§

impl FromRawFd for async_std::net::TcpStream

Available on Unix or crate feature docs only.
Source§

impl FromRawFd for async_std::net::UdpSocket

Available on Unix or crate feature docs only.
1.2.0 · Source§

impl FromRawFd for Stdio

Source§

impl FromRawFd for async_std::os::unix::net::UnixDatagram

Source§

impl FromRawFd for async_std::os::unix::net::UnixListener

Source§

impl FromRawFd for async_std::os::unix::net::UnixStream

Source§

impl FromRawFd for Dir

1.1.0 · Source§

impl FromRawFd for std::fs::File

Available on non-Trusty only.
1.87.0 · Source§

impl FromRawFd for PipeReader

Available on non-Trusty only.
1.87.0 · Source§

impl FromRawFd for PipeWriter

Available on non-Trusty only.
1.1.0 · Source§

impl FromRawFd for std::net::tcp::TcpListener

1.1.0 · Source§

impl FromRawFd for std::net::tcp::TcpStream

1.1.0 · Source§

impl FromRawFd for std::net::udp::UdpSocket

1.63.0 · Source§

impl FromRawFd for OwnedFd

Source§

impl FromRawFd for PidFd

1.10.0 · Source§

impl FromRawFd for std::os::unix::net::datagram::UnixDatagram

1.10.0 · Source§

impl FromRawFd for std::os::unix::net::listener::UnixListener

1.10.0 · Source§

impl FromRawFd for std::os::unix::net::stream::UnixStream