A trivial trait bringing missing functions that are not exposed by
std::os::unix::fs::PermissionsExt
to std::fs::Permissions
on UNIX platforms.
```rust pub trait UNIXPermissionsExt { fn setuid(&self) -> bool; fn setgid(&self) -> bool; fn sticky_bit(&self) -> bool;
fn readable_by_owner(&self) -> bool;
fn writable_by_owner(&self) -> bool;
fn executable_by_owner(&self) -> bool;
fn readable_by_group(&self) -> bool;
fn writable_by_group(&self) -> bool;
fn executable_by_group(&self) -> bool;
fn readable_by_other(&self) -> bool;
fn writable_by_other(&self) -> bool;
fn executable_by_other(&self) -> bool;
#[cfg(feature = "to-string")]
fn to_string() -> String;
}
impl UNIXPermissionsExt for Permissions { ... } ```
Add it to your dependency:
shell
$ cd $YOUR_PROJECT
$ cargo add unix_permissions_ext
Import this trait and use it just like you are using the standard library!
```rust use std::fs::{metadata, Permissions}; use unixpermissionsext::UNIXPermissionsExt;
let metadata = metadata("/usr/bin/passwd").expect("can not fetch metadata"); let permission = metadata.permissions();
assert!(permission.set_uid()); ```
If you have feature to-string
enabled, you can also use to_string()
to convert
Permissions
into a string, just like the one printed by ls(1)
```toml
[dependencies] unixpermissionsext = { version = "x.x.x", features = ["to-string"] } ```
rust
let permission_str = <Permissions as UNIXPermissionsExt>::to_string(&permission);
println!("{}", permission_str);
Contributions of all forms are welcome, feel free to file an issue or make a pull request!
Pass the tests
shell
$ cargo test --features "to-string"
Format your code
shell
$ cargo fmt