pub struct DirEntry(_);Expand description
Entries returned by the ReadDir iterator.
An instance of DirEntry represents an entry inside of a directory on the
filesystem. Each entry can be inspected via methods to learn about the full
path or possibly other metadata through per-platform extension traits.
Platform-specific behavior
On Unix, the DirEntry struct contains an internal reference to the open
directory. Holding DirEntry objects will consume a file handle even
after the ReadDir iterator is dropped.
Note that this may change in the future.
Implementations
impl DirEntry
source
impl DirEntry
sourcepub fn path(&self) -> PathBuf
source
pub fn path(&self) -> PathBuf
sourceReturns the full path to the file that this entry represents.
The full path is created by joining the original path to read_dir
with the filename of this entry.
Examples
use std::fs;
fn main() -> std::io::Result<()> {
for entry in fs::read_dir(".")? {
let dir = entry?;
println!("{:?}", dir.path());
}
Ok(())
}RunThis prints output like:
"./whatever.txt"
"./foo.html"
"./hello_world.rs"The exact text, of course, depends on what files you have in ..
pub fn metadata(&self) -> Result<Metadata>
1.1.0 · source
pub fn metadata(&self) -> Result<Metadata>
1.1.0 · sourceReturns the metadata for the file that this entry points at.
This function will not traverse symlinks if this entry points at a
symlink. To traverse symlinks use fs::metadata or fs::File::metadata.
Platform-specific behavior
On Windows this function is cheap to call (no extra system calls
needed), but on Unix platforms this function is the equivalent of
calling symlink_metadata on the path.
Examples
use std::fs;
if let Ok(entries) = fs::read_dir(".") {
for entry in entries {
if let Ok(entry) = entry {
// Here, `entry` is a `DirEntry`.
if let Ok(metadata) = entry.metadata() {
// Now let's show our entry's permissions!
println!("{:?}: {:?}", entry.path(), metadata.permissions());
} else {
println!("Couldn't get metadata for {:?}", entry.path());
}
}
}
}Runpub fn file_type(&self) -> Result<FileType>
1.1.0 · source
pub fn file_type(&self) -> Result<FileType>
1.1.0 · sourceReturns the file type for the file that this entry points at.
This function will not traverse symlinks if this entry points at a symlink.
Platform-specific behavior
On Windows and most Unix platforms this function is free (no extra
system calls needed), but some Unix platforms may require the equivalent
call to symlink_metadata to learn about the target file type.
Examples
use std::fs;
if let Ok(entries) = fs::read_dir(".") {
for entry in entries {
if let Ok(entry) = entry {
// Here, `entry` is a `DirEntry`.
if let Ok(file_type) = entry.file_type() {
// Now let's show our entry's file type!
println!("{:?}: {:?}", entry.path(), file_type);
} else {
println!("Couldn't get file type for {:?}", entry.path());
}
}
}
}RunTrait Implementations
impl DirEntryExt for DirEntry
1.1.0 · source Available on Unix only.
impl DirEntryExt for DirEntry
1.1.0 · sourceimpl DirEntryExt for DirEntry
source Available on WASI only.
impl DirEntryExt for DirEntry
sourceimpl DirEntryExt2 for DirEntry
source Available on Unix only.
impl DirEntryExt2 for DirEntry
sourcefn file_name_ref(&self) -> &OsStr
source
fn file_name_ref(&self) -> &OsStr
sourceReturns a reference to the underlying OsStr of this entry’s filename. Read more
Auto Trait Implementations
impl RefUnwindSafe for DirEntry
impl Send for DirEntry
impl Sync for DirEntry
impl Unpin for DirEntry
impl UnwindSafe for DirEntry
Blanket Implementations
impl<T> BorrowMut<T> for T where
T: ?Sized,
source
impl<T> BorrowMut<T> for T where
T: ?Sized,
sourcefn borrow_mut(&mut self) -> &mut T
const: unstable · source
fn borrow_mut(&mut self) -> &mut T
const: unstable · sourceMutably borrows from an owned value. Read more