pub struct Dir { /* private fields */ }fs_utf8 only.Expand description
A reference to an open directory on a filesystem.
This does not directly correspond to anything in std, however its methods
correspond to the functions in std::fs and the constructor methods for
std::fs::File.
Unlike std::fs, this API’s canonicalize returns a relative path since
absolute paths don’t interoperate well with the capability model.
Implementations§
source§impl Dir
 
impl Dir
sourcepub fn from_std_file(std_file: File) -> Self
 
pub fn from_std_file(std_file: File) -> Self
Constructs a new instance of Self from the given std::fs::File.
To prevent race conditions on Windows, the file must be opened without
FILE_SHARE_DELETE.
This grants access the resources the std::fs::File instance already
has access to.
sourcepub fn from_cap_std(cap_std: Dir) -> Self
 
pub fn from_cap_std(cap_std: Dir) -> Self
Constructs a new instance of Self from the given cap_std::fs::Dir.
sourcepub fn as_cap_std(&self) -> &Dir
 
pub fn as_cap_std(&self) -> &Dir
Return a view of this directory as a [cap_std::fs::Dir]. This
is often useful in order to write shared functions which can operate
on either type.
sourcepub fn open<P: AsRef<Utf8Path>>(&self, path: P) -> Result<File>
 
pub fn open<P: AsRef<Utf8Path>>(&self, path: P) -> Result<File>
Attempts to open a file in read-only mode.
This corresponds to std::fs::File::open, but only accesses paths
relative to self.
sourcepub fn open_with<P: AsRef<Utf8Path>>(
    &self,
    path: P,
    options: &OpenOptions,
) -> Result<File>
 
pub fn open_with<P: AsRef<Utf8Path>>( &self, path: P, options: &OpenOptions, ) -> Result<File>
Opens a file at path with the options specified by options.
This corresponds to std::fs::OpenOptions::open.
Instead of being a method on OpenOptions, this is a method on Dir,
and it only accesses paths relative to self.
sourcepub fn open_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Self>
 
pub fn open_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Self>
Attempts to open a directory.
sourcepub fn create_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
 
pub fn create_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
Creates a new, empty directory at the provided path.
This corresponds to std::fs::create_dir, but only accesses paths
relative to self.
sourcepub fn create_dir_all<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
 
pub fn create_dir_all<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
Recursively create a directory and all of its parent components if they are missing.
This corresponds to std::fs::create_dir_all, but only accesses
paths relative to self.
sourcepub fn create_dir_with<P: AsRef<Utf8Path>>(
    &self,
    path: P,
    dir_builder: &DirBuilder,
) -> Result<()>
 Available on non-WASI only.
pub fn create_dir_with<P: AsRef<Utf8Path>>( &self, path: P, dir_builder: &DirBuilder, ) -> Result<()>
Creates the specified directory with the options configured in this builder.
This corresponds to std::fs::DirBuilder::create.
sourcepub fn create<P: AsRef<Utf8Path>>(&self, path: P) -> Result<File>
 
pub fn create<P: AsRef<Utf8Path>>(&self, path: P) -> Result<File>
Opens a file in write-only mode.
This corresponds to std::fs::File::create, but only accesses paths
relative to self.
sourcepub fn canonicalize<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Utf8PathBuf>
 
pub fn canonicalize<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Utf8PathBuf>
Returns the canonical form of a path with all intermediate components normalized and symbolic links resolved.
This corresponds to std::fs::canonicalize, but instead of returning
an absolute path, returns a path relative to the directory
represented by self.
sourcepub fn copy<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>(
    &self,
    from: P,
    to_dir: &Self,
    to: Q,
) -> Result<u64>
 
pub fn copy<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>( &self, from: P, to_dir: &Self, to: Q, ) -> Result<u64>
Copies the contents of one file to another. This function will also copy the permission bits of the original file to the destination file.
This corresponds to std::fs::copy, but only accesses paths
relative to self.
sourcepub fn hard_link<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>(
    &self,
    src: P,
    dst_dir: &Self,
    dst: Q,
) -> Result<()>
 
pub fn hard_link<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>( &self, src: P, dst_dir: &Self, dst: Q, ) -> Result<()>
Creates a new hard link on a filesystem.
This corresponds to std::fs::hard_link, but only accesses paths
relative to self.
sourcepub fn metadata<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Metadata>
 
pub fn metadata<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Metadata>
Given a path, query the file system to get information about a file, directory, etc.
This corresponds to std::fs::metadata, but only accesses paths
relative to self.
sourcepub fn dir_metadata(&self) -> Result<Metadata>
 
pub fn dir_metadata(&self) -> Result<Metadata>
Queries metadata about the underlying directory.
This is similar to std::fs::File::metadata, but for Dir rather
than for File.
sourcepub fn read_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<ReadDir>
 
pub fn read_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<ReadDir>
Returns an iterator over the entries within a directory.
This corresponds to std::fs::read_dir, but only accesses paths
relative to self.
sourcepub fn read<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Vec<u8>>
 
pub fn read<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Vec<u8>>
Read the entire contents of a file into a bytes vector.
This corresponds to std::fs::read, but only accesses paths
relative to self.
sourcepub fn read_link<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Utf8PathBuf>
 
pub fn read_link<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Utf8PathBuf>
Reads a symbolic link, returning the file that the link points to.
This corresponds to std::fs::read_link, but only accesses paths
relative to self.  Unlike [read_link_contents], this method considers it an error if
the link’s target is an absolute path.
sourcepub fn read_link_contents<P: AsRef<Utf8Path>>(
    &self,
    path: P,
) -> Result<Utf8PathBuf>
 
pub fn read_link_contents<P: AsRef<Utf8Path>>( &self, path: P, ) -> Result<Utf8PathBuf>
Reads a symbolic link, returning the file that the link points to.
This corresponds to std::fs::read_link. but only accesses paths
relative to self.
sourcepub fn read_to_string<P: AsRef<Utf8Path>>(&self, path: P) -> Result<String>
 
pub fn read_to_string<P: AsRef<Utf8Path>>(&self, path: P) -> Result<String>
Read the entire contents of a file into a string.
This corresponds to std::fs::read_to_string, but only accesses
paths relative to self.
sourcepub fn remove_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
 
pub fn remove_dir<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
Removes an empty directory.
This corresponds to std::fs::remove_dir, but only accesses paths
relative to self.
sourcepub fn remove_dir_all<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
 
pub fn remove_dir_all<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
Removes a directory at this path, after removing all its contents. Use carefully!
This corresponds to std::fs::remove_dir_all, but only accesses
paths relative to self.
sourcepub fn remove_open_dir(self) -> Result<()>
 
pub fn remove_open_dir(self) -> Result<()>
Remove the directory referenced by self and consume self.
Even though this implementation works in terms of handles as much as possible, removal is not guaranteed to be atomic with respect to a concurrent rename of the directory.
sourcepub fn remove_open_dir_all(self) -> Result<()>
 
pub fn remove_open_dir_all(self) -> Result<()>
Removes the directory referenced by self, after removing all its
contents, and consume self. Use carefully!
Even though this implementation works in terms of handles as much as possible, removal is not guaranteed to be atomic with respect to a concurrent rename of the directory.
sourcepub fn remove_file<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
 
pub fn remove_file<P: AsRef<Utf8Path>>(&self, path: P) -> Result<()>
Removes a file from a filesystem.
This corresponds to std::fs::remove_file, but only accesses paths
relative to self.
sourcepub fn rename<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>(
    &self,
    from: P,
    to_dir: &Self,
    to: Q,
) -> Result<()>
 
pub fn rename<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>( &self, from: P, to_dir: &Self, to: Q, ) -> Result<()>
Rename a file or directory to a new name, replacing the original file if to already exists.
This corresponds to std::fs::rename, but only accesses paths
relative to self.
sourcepub fn set_permissions<P: AsRef<Utf8Path>>(
    &self,
    path: P,
    perm: Permissions,
) -> Result<()>
 Available on non-WASI only.
pub fn set_permissions<P: AsRef<Utf8Path>>( &self, path: P, perm: Permissions, ) -> Result<()>
Changes the permissions found on a file or a directory.
This corresponds to std::fs::set_permissions, but only accesses
paths relative to self. Also, on some platforms, this function
may fail if the file or directory cannot be opened for reading or
writing first.
sourcepub fn symlink_metadata<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Metadata>
 
pub fn symlink_metadata<P: AsRef<Utf8Path>>(&self, path: P) -> Result<Metadata>
Query the metadata about a file without following symlinks.
This corresponds to std::fs::symlink_metadata, but only accesses
paths relative to self.
sourcepub fn write<P: AsRef<Utf8Path>, C: AsRef<[u8]>>(
    &self,
    path: P,
    contents: C,
) -> Result<()>
 
pub fn write<P: AsRef<Utf8Path>, C: AsRef<[u8]>>( &self, path: P, contents: C, ) -> Result<()>
Write a slice as the entire contents of a file.
This corresponds to std::fs::write, but only accesses paths
relative to self.
sourcepub fn symlink<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>(
    &self,
    original: P,
    link: Q,
) -> Result<()>
 Available on non-Windows only.
pub fn symlink<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>( &self, original: P, link: Q, ) -> Result<()>
Creates a new symbolic link on a filesystem.
The original argument provides the target of the symlink. The link
argument provides the name of the created symlink.
Despite the argument ordering, original is not resolved relative to
self here. link is resolved relative to self, and original is
not resolved within this function.
The link path is resolved when the symlink is dereferenced, relative
to the directory that contains it.
This corresponds to std::os::unix::fs::symlink, but only accesses
paths relative to self.
Unlike [symlink_contents] this method will return an error if original is an absolute
path.
sourcepub fn symlink_contents<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>(
    &self,
    original: P,
    link: Q,
) -> Result<()>
 Available on non-Windows only.
pub fn symlink_contents<P: AsRef<Utf8Path>, Q: AsRef<Utf8Path>>( &self, original: P, link: Q, ) -> Result<()>
Creates a new symbolic link on a filesystem.
The original argument provides the target of the symlink. The link
argument provides the name of the created symlink.
Despite the argument ordering, original is not resolved relative to
self here. link is resolved relative to self, and original is
not resolved within this function.
The link path is resolved when the symlink is dereferenced, relative
to the directory that contains it.
This corresponds to std::os::unix::fs::symlink, but only accesses
paths relative to self.
sourcepub fn bind_unix_listener<P: AsRef<Utf8Path>>(
    &self,
    path: P,
) -> Result<UnixListener>
 Available on Unix only.
pub fn bind_unix_listener<P: AsRef<Utf8Path>>( &self, path: P, ) -> Result<UnixListener>
Creates a new UnixListener bound to the specified socket.
This corresponds to std::os::unix::net::UnixListener::bind, but
only accesses paths relative to self.
XXX: This function is not yet implemented.
sourcepub fn connect_unix_stream<P: AsRef<Utf8Path>>(
    &self,
    path: P,
) -> Result<UnixStream>
 Available on Unix only.
pub fn connect_unix_stream<P: AsRef<Utf8Path>>( &self, path: P, ) -> Result<UnixStream>
Connects to the socket named by path.
This corresponds to std::os::unix::net::UnixStream::connect, but
only accesses paths relative to self.
XXX: This function is not yet implemented.
sourcepub fn bind_unix_datagram<P: AsRef<Utf8Path>>(
    &self,
    path: P,
) -> Result<UnixDatagram>
 Available on Unix only.
pub fn bind_unix_datagram<P: AsRef<Utf8Path>>( &self, path: P, ) -> Result<UnixDatagram>
Creates a Unix datagram socket bound to the given path.
This corresponds to std::os::unix::net::UnixDatagram::bind, but
only accesses paths relative to self.
XXX: This function is not yet implemented.
sourcepub fn connect_unix_datagram<P: AsRef<Utf8Path>>(
    &self,
    unix_datagram: &UnixDatagram,
    path: P,
) -> Result<()>
 Available on Unix only.
pub fn connect_unix_datagram<P: AsRef<Utf8Path>>( &self, unix_datagram: &UnixDatagram, path: P, ) -> Result<()>
Connects the socket to the specified address.
This corresponds to std::os::unix::net::UnixDatagram::connect, but
only accesses paths relative to self.
XXX: This function is not yet implemented.
sourcepub fn send_to_unix_datagram_addr<P: AsRef<Utf8Path>>(
    &self,
    unix_datagram: &UnixDatagram,
    buf: &[u8],
    path: P,
) -> Result<usize>
 Available on Unix only.
pub fn send_to_unix_datagram_addr<P: AsRef<Utf8Path>>( &self, unix_datagram: &UnixDatagram, buf: &[u8], path: P, ) -> Result<usize>
Sends data on the socket to the specified address.
This corresponds to std::os::unix::net::UnixDatagram::send_to, but
only accesses paths relative to self.
XXX: This function is not yet implemented.
sourcepub fn try_clone(&self) -> Result<Self>
 
pub fn try_clone(&self) -> Result<Self>
Creates a new Dir instance that shares the same underlying file
handle as the existing Dir instance.
sourcepub fn exists<P: AsRef<Utf8Path>>(&self, path: P) -> bool
 
pub fn exists<P: AsRef<Utf8Path>>(&self, path: P) -> bool
Returns true if the path points at an existing entity.
This corresponds to std::path::Path::exists, but only
accesses paths relative to self.
sourcepub fn try_exists<P: AsRef<Utf8Path>>(&self, path: P) -> Result<bool>
 
pub fn try_exists<P: AsRef<Utf8Path>>(&self, path: P) -> Result<bool>
Returns true if the path points at an existing entity.
This corresponds to std::path::Path::exists, but only
accesses paths relative to self.
sourcepub fn is_file<P: AsRef<Utf8Path>>(&self, path: P) -> bool
 
pub fn is_file<P: AsRef<Utf8Path>>(&self, path: P) -> bool
Returns true if the path exists on disk and is pointing at a regular
file.
This corresponds to std::path::Path::is_file, but only
accesses paths relative to self.
sourcepub fn is_dir<P: AsRef<Utf8Path>>(&self, path: P) -> bool
 
pub fn is_dir<P: AsRef<Utf8Path>>(&self, path: P) -> bool
Checks if path is a directory.
This is similar to std::path::Path::is_dir in that it checks if
path relative to Dir is a directory. This function will
traverse symbolic links to query information about the destination
file. In case of broken symbolic links, this will return false.
sourcepub fn open_ambient_dir<P: AsRef<Utf8Path>>(
    path: P,
    ambient_authority: AmbientAuthority,
) -> Result<Self>
 
pub fn open_ambient_dir<P: AsRef<Utf8Path>>( path: P, ambient_authority: AmbientAuthority, ) -> Result<Self>
Constructs a new instance of Self by opening the given path as a
directory using the host process’ ambient authority.
§Ambient Authority
This function is not sandboxed and may access any path that the host process has access to.
sourcepub fn open_parent_dir(
    &self,
    ambient_authority: AmbientAuthority,
) -> Result<Self>
 
pub fn open_parent_dir( &self, ambient_authority: AmbientAuthority, ) -> Result<Self>
Constructs a new instance of Self by opening the parent directory
(aka “..”) of self, using the host process’ ambient authority.
§Ambient Authority
This function accesses a directory outside of the self subtree.
sourcepub fn create_ambient_dir_all<P: AsRef<Utf8Path>>(
    path: P,
    ambient_authority: AmbientAuthority,
) -> Result<()>
 
pub fn create_ambient_dir_all<P: AsRef<Utf8Path>>( path: P, ambient_authority: AmbientAuthority, ) -> Result<()>
Recursively create a directory and all of its parent components if they are missing, using the host process’ ambient authority.
§Ambient Authority
This function is not sandboxed and may access any path that the host process has access to.
sourcepub fn reopen_dir<Filelike: AsFilelike>(dir: &Filelike) -> Result<Self>
 
pub fn reopen_dir<Filelike: AsFilelike>(dir: &Filelike) -> Result<Self>
Construct a new instance of Self from existing directory file
descriptor.
This can be useful when interacting with other libraries and or C/C++
code which has invoked openat(..., O_DIRECTORY) external to this
crate.
Trait Implementations§
source§impl AsFd for Dir
Available on non-Windows only. 
impl AsFd for Dir
source§fn as_fd(&self) -> BorrowedFd<'_>
 
fn as_fd(&self) -> BorrowedFd<'_>
source§impl FromRawFd for Dir
Available on non-Windows only. 
impl FromRawFd for Dir
source§unsafe fn from_raw_fd(fd: RawFd) -> Self
 
unsafe fn from_raw_fd(fd: RawFd) -> Self
Self from the given raw file
descriptor. Read moresource§impl IntoRawFd for Dir
Available on non-Windows only. 
impl IntoRawFd for Dir
source§fn into_raw_fd(self) -> RawFd
 
fn into_raw_fd(self) -> RawFd
impl FilelikeViewType for Dir
Auto Trait Implementations§
impl Freeze for Dir
impl RefUnwindSafe for Dir
impl Send for Dir
impl Sync for Dir
impl Unpin for Dir
impl UnwindSafe for Dir
Blanket Implementations§
source§impl<T> AsFilelike for Twhere
    T: AsFd,
 
impl<T> AsFilelike for Twhere
    T: AsFd,
source§fn as_filelike(&self) -> BorrowedFd<'_>
 
fn as_filelike(&self) -> BorrowedFd<'_>
source§fn as_filelike_view<Target>(&self) -> FilelikeView<'_, Target>where
    Target: FilelikeViewType,
 
fn as_filelike_view<Target>(&self) -> FilelikeView<'_, Target>where
    Target: FilelikeViewType,
&Target. Read moresource§impl<T> AsGrip for Twhere
    T: AsFd,
 
impl<T> AsGrip for Twhere
    T: AsFd,
source§fn as_grip(&self) -> BorrowedFd<'_>
 
fn as_grip(&self) -> BorrowedFd<'_>
source§impl<T> AsRawFilelike for Twhere
    T: AsRawFd,
 
impl<T> AsRawFilelike for Twhere
    T: AsRawFd,
source§fn as_raw_filelike(&self) -> i32
 
fn as_raw_filelike(&self) -> i32
source§impl<T> AsRawGrip for Twhere
    T: AsRawFd,
 
impl<T> AsRawGrip for Twhere
    T: AsRawFd,
source§fn as_raw_grip(&self) -> i32
 
fn as_raw_grip(&self) -> i32
source§impl<T> AsRawSocketlike for Twhere
    T: AsRawFd,
 
impl<T> AsRawSocketlike for Twhere
    T: AsRawFd,
source§fn as_raw_socketlike(&self) -> i32
 
fn as_raw_socketlike(&self) -> i32
source§impl<T> AsSocketlike for Twhere
    T: AsFd,
 
impl<T> AsSocketlike for Twhere
    T: AsFd,
source§fn as_socketlike(&self) -> BorrowedFd<'_>
 
fn as_socketlike(&self) -> BorrowedFd<'_>
source§fn as_socketlike_view<Target>(&self) -> SocketlikeView<'_, Target>where
    Target: SocketlikeViewType,
 
fn as_socketlike_view<Target>(&self) -> SocketlikeView<'_, Target>where
    Target: SocketlikeViewType,
&Target. Read moresource§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<T> FromFd for T
 
impl<T> FromFd for T
source§impl<T> FromFilelike for T
 
impl<T> FromFilelike for T
source§fn from_filelike(owned: OwnedFd) -> T
 
fn from_filelike(owned: OwnedFd) -> T
Self from the given filelike object. Read moresource§fn from_into_filelike<Owned>(owned: Owned) -> Twhere
    Owned: IntoFilelike,
 
fn from_into_filelike<Owned>(owned: Owned) -> Twhere
    Owned: IntoFilelike,
Self from the given filelike object
converted from into_owned. Read moresource§impl<T> FromRawFilelike for Twhere
    T: FromRawFd,
 
impl<T> FromRawFilelike for Twhere
    T: FromRawFd,
source§unsafe fn from_raw_filelike(raw: i32) -> T
 
unsafe fn from_raw_filelike(raw: i32) -> T
Self from the raw value. Read moresource§impl<T> FromRawGrip for Twhere
    T: FromRawFd,
 
impl<T> FromRawGrip for Twhere
    T: FromRawFd,
source§unsafe fn from_raw_grip(raw_grip: i32) -> T
 
unsafe fn from_raw_grip(raw_grip: i32) -> T
source§impl<T> FromRawSocketlike for Twhere
    T: FromRawFd,
 
impl<T> FromRawSocketlike for Twhere
    T: FromRawFd,
source§unsafe fn from_raw_socketlike(raw: i32) -> T
 
unsafe fn from_raw_socketlike(raw: i32) -> T
Self from the raw value. Read moresource§impl<T> FromSocketlike for T
 
impl<T> FromSocketlike for T
source§fn from_socketlike(owned: OwnedFd) -> T
 
fn from_socketlike(owned: OwnedFd) -> T
Self from the given socketlike object.source§fn from_into_socketlike<Owned>(owned: Owned) -> Twhere
    Owned: IntoSocketlike,
 
fn from_into_socketlike<Owned>(owned: Owned) -> Twhere
    Owned: IntoSocketlike,
Self from the given socketlike object
converted from into_owned.source§impl<T> IntoFilelike for T
 
impl<T> IntoFilelike for T
source§fn into_filelike(self) -> OwnedFd
 
fn into_filelike(self) -> OwnedFd
source§impl<T> IntoRawFilelike for Twhere
    T: IntoRawFd,
 
impl<T> IntoRawFilelike for Twhere
    T: IntoRawFd,
source§fn into_raw_filelike(self) -> i32
 
fn into_raw_filelike(self) -> i32
source§impl<T> IntoRawGrip for Twhere
    T: IntoRawFd,
 
impl<T> IntoRawGrip for Twhere
    T: IntoRawFd,
source§fn into_raw_grip(self) -> i32
 
fn into_raw_grip(self) -> i32
self and convert into an RawGrip.