diff options
| author | David CARLIER <devnexen@gmail.com> | 2022-06-17 20:31:59 +0100 |
|---|---|---|
| committer | David CARLIER <devnexen@gmail.com> | 2022-07-25 23:25:15 +0100 |
| commit | e39b44a076e37d449db146135e8acb3cab05876b (patch) | |
| tree | fa638bded2d89f4e61fae4cd995c91c905e0eb8a /library/std | |
| parent | 2a990f7c0fe4d00042269beb7ee67d0082de4e07 (diff) | |
| download | rust-e39b44a076e37d449db146135e8acb3cab05876b.tar.gz rust-e39b44a076e37d449db146135e8acb3cab05876b.zip | |
Implement `fs::get_path` for FreeBSD.
Using `F_KINFO` fcntl flag, the kf_structsize field needs to be set beforehand for that effect.
Diffstat (limited to 'library/std')
| -rw-r--r-- | library/std/src/sys/unix/fs.rs | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/library/std/src/sys/unix/fs.rs b/library/std/src/sys/unix/fs.rs index 7c882469440..71522865b7d 100644 --- a/library/std/src/sys/unix/fs.rs +++ b/library/std/src/sys/unix/fs.rs @@ -1126,6 +1126,19 @@ impl fmt::Debug for File { Some(PathBuf::from(OsString::from_vec(buf))) } + #[cfg(all(target_os = "freebsd", target_arch = "x86_64"))] + fn get_path(fd: c_int) -> Option<PathBuf> { + let info = Box::<libc::kinfo_file>::new_zeroed(); + let mut info = unsafe { info.assume_init() }; + info.kf_structsize = mem::size_of::<libc::kinfo_file>() as libc::c_int; + let n = unsafe { libc::fcntl(fd, libc::F_KINFO, &mut *info) }; + if n == -1 { + return None; + } + let buf = unsafe { CStr::from_ptr(info.kf_path.as_mut_ptr()).to_bytes().to_vec() }; + Some(PathBuf::from(OsString::from_vec(buf))) + } + #[cfg(target_os = "vxworks")] fn get_path(fd: c_int) -> Option<PathBuf> { let mut buf = vec![0; libc::PATH_MAX as usize]; @@ -1142,6 +1155,7 @@ impl fmt::Debug for File { target_os = "linux", target_os = "macos", target_os = "vxworks", + all(target_os = "freebsd", target_arch = "x86_64"), target_os = "netbsd" )))] fn get_path(_fd: c_int) -> Option<PathBuf> { |
