10 releases (5 breaking)

0.6.3 Sep 20, 2023
0.6.1 Oct 11, 2022
0.5.0 Jul 3, 2021
0.3.0 Oct 5, 2020
0.2.0 Jun 27, 2020

#243 in Unix APIs

Download history 6807/week @ 2024-06-11 6772/week @ 2024-06-18 8361/week @ 2024-06-25 6548/week @ 2024-07-02 7631/week @ 2024-07-09 7098/week @ 2024-07-16 8160/week @ 2024-07-23 14011/week @ 2024-07-30 10768/week @ 2024-08-06 9883/week @ 2024-08-13 8060/week @ 2024-08-20 7152/week @ 2024-08-27 8165/week @ 2024-09-03 8105/week @ 2024-09-10 8198/week @ 2024-09-17 8500/week @ 2024-09-24

33,611 downloads per month
Used in 5 crates (4 directly)

BSD-2-Clause

15KB
141 lines

filedesc docs tests

This crate exposes a single type: FileDesc, which acts as a thin wrapper around open file descriptors. The wrapped file descriptor is closed when the wrapper is dropped.

You can call FileDesc::new() with any type that implements IntoRawFd, or duplicate the file descriptor of a type that implements AsRawFd with duplicate_from, or directly from a raw file descriptor with from_raw_fd() and duplicate_raw_fd(). Wrapped file descriptors can also be duplicated with the duplicate() function.

Close-on-exec

Whenever the library duplicates a file descriptor, it tries to set the close-on-exec flag atomically. On platforms where this is not supported, the library falls back to setting the flag non-atomically. When an existing file descriptor is wrapped, the close-on-exec flag is left as it was.

You can also check or set the close-on-exec flag with the get_close_on_exec() and set_close_on_exec functions.

Example

use filedesc::FileDesc;
let fd = unsafe { FileDesc::from_raw_fd(raw_fd) };
let duplicated = unsafe { fd.duplicate()? };
assert_eq!(duplicated.get_close_on_exec()?, true);

duplicated.set_close_on_exec(false)?;
assert_eq!(duplicated.get_close_on_exec()?, false);

Dependencies

~43KB