pub trait MetadataExt {
Show 17 methods
// Required methods
fn as_raw_stat(&self) -> &stat;
fn st_dev(&self) -> u64 ⓘ;
fn st_ino(&self) -> u64 ⓘ;
fn st_mode(&self) -> u32 ⓘ;
fn st_nlink(&self) -> u64 ⓘ;
fn st_uid(&self) -> u32 ⓘ;
fn st_gid(&self) -> u32 ⓘ;
fn st_rdev(&self) -> u64 ⓘ;
fn st_size(&self) -> u64 ⓘ;
fn st_atime(&self) -> i64 ⓘ;
fn st_atime_nsec(&self) -> i64 ⓘ;
fn st_mtime(&self) -> i64 ⓘ;
fn st_mtime_nsec(&self) -> i64 ⓘ;
fn st_ctime(&self) -> i64 ⓘ;
fn st_ctime_nsec(&self) -> i64 ⓘ;
fn st_blksize(&self) -> u64 ⓘ;
fn st_blocks(&self) -> u64 ⓘ;
}
std
and Linux only.Expand description
OS-specific extensions to fs::Metadata
.
Required Methods§
1.1.0 · Sourcefn as_raw_stat(&self) -> &stat
👎Deprecated since 1.8.0: other methods of this trait are now preferred
fn as_raw_stat(&self) -> &stat
Gain a reference to the underlying stat
structure which contains
the raw information returned by the OS.
The contents of the returned stat
are not consistent across
Unix platforms. The os::unix::fs::MetadataExt
trait contains the
cross-Unix abstractions contained within the raw stat.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
let stat = meta.as_raw_stat();
Ok(())
}
1.8.0 · Sourcefn st_dev(&self) -> u64 ⓘ
fn st_dev(&self) -> u64 ⓘ
Returns the device ID on which this file resides.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_dev());
Ok(())
}
1.8.0 · Sourcefn st_ino(&self) -> u64 ⓘ
fn st_ino(&self) -> u64 ⓘ
Returns the inode number.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_ino());
Ok(())
}
1.8.0 · Sourcefn st_mode(&self) -> u32 ⓘ
fn st_mode(&self) -> u32 ⓘ
Returns the file type and mode.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_mode());
Ok(())
}
1.8.0 · Sourcefn st_nlink(&self) -> u64 ⓘ
fn st_nlink(&self) -> u64 ⓘ
Returns the number of hard links to file.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_nlink());
Ok(())
}
1.8.0 · Sourcefn st_uid(&self) -> u32 ⓘ
fn st_uid(&self) -> u32 ⓘ
Returns the user ID of the file owner.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_uid());
Ok(())
}
1.8.0 · Sourcefn st_gid(&self) -> u32 ⓘ
fn st_gid(&self) -> u32 ⓘ
Returns the group ID of the file owner.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_gid());
Ok(())
}
1.8.0 · Sourcefn st_rdev(&self) -> u64 ⓘ
fn st_rdev(&self) -> u64 ⓘ
Returns the device ID that this file represents. Only relevant for special file.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_rdev());
Ok(())
}
1.8.0 · Sourcefn st_size(&self) -> u64 ⓘ
fn st_size(&self) -> u64 ⓘ
Returns the size of the file (if it is a regular file or a symbolic link) in bytes.
The size of a symbolic link is the length of the pathname it contains, without a terminating null byte.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_size());
Ok(())
}
1.8.0 · Sourcefn st_atime(&self) -> i64 ⓘ
fn st_atime(&self) -> i64 ⓘ
Returns the last access time of the file, in seconds since Unix Epoch.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_atime());
Ok(())
}
1.8.0 · Sourcefn st_atime_nsec(&self) -> i64 ⓘ
fn st_atime_nsec(&self) -> i64 ⓘ
1.8.0 · Sourcefn st_mtime(&self) -> i64 ⓘ
fn st_mtime(&self) -> i64 ⓘ
Returns the last modification time of the file, in seconds since Unix Epoch.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_mtime());
Ok(())
}
1.8.0 · Sourcefn st_mtime_nsec(&self) -> i64 ⓘ
fn st_mtime_nsec(&self) -> i64 ⓘ
1.8.0 · Sourcefn st_ctime(&self) -> i64 ⓘ
fn st_ctime(&self) -> i64 ⓘ
Returns the last status change time of the file, in seconds since Unix Epoch.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_ctime());
Ok(())
}
1.8.0 · Sourcefn st_ctime_nsec(&self) -> i64 ⓘ
fn st_ctime_nsec(&self) -> i64 ⓘ
1.8.0 · Sourcefn st_blksize(&self) -> u64 ⓘ
fn st_blksize(&self) -> u64 ⓘ
Returns the “preferred” block size for efficient filesystem I/O.
§Examples
use std::fs;
use std::io;
use std::os::linux::fs::MetadataExt;
fn main() -> io::Result<()> {
let meta = fs::metadata("some_file")?;
println!("{}", meta.st_blksize());
Ok(())
}