13 releases (4 stable)

2.1.0 Mar 29, 2023
2.0.0 May 11, 2022
1.0.1 Jan 28, 2022
1.0.0 May 20, 2020
0.1.6 Jul 5, 2019

#174 in Unix APIs

Download history 2303/week @ 2024-12-14 2174/week @ 2024-12-21 3159/week @ 2024-12-28 2372/week @ 2025-01-04 2891/week @ 2025-01-11 2716/week @ 2025-01-18 2753/week @ 2025-01-25 4258/week @ 2025-02-01 3686/week @ 2025-02-08 2586/week @ 2025-02-15 3220/week @ 2025-02-22 2179/week @ 2025-03-01 2473/week @ 2025-03-08 5244/week @ 2025-03-15 3755/week @ 2025-03-22 4800/week @ 2025-03-29

16,634 downloads per month
Used in 30 crates (9 directly)

MIT license

19KB
333 lines

MIT Latest Version docs Chat on Miaou

umask

A light utility helping with unix mode representation, with strong types to avoid misusing constants.

The Mode struct implements Display and prints as "rwxrwxrwx"

Import

In Cargo.toml:

umask = "'2.0"

Usage

use umask::*;

// You can build from a number:
assert_eq!("rw-r--r--", Mode::from(0b110100100).to_string());
assert_eq!("rw-r--r--", Mode::from(0o644).to_string());

// You may use `|` to combine class permissions:
let mu = Mode::from(0o640);
let mo = Mode::from(0o044);
assert_eq!("rw-r--r--", (mu | mo).to_string());
assert_eq!("---r-----", (mu & mo).to_string());

// You can use more semantic constructs:
let m = Mode::all()
    .without(ALL_EXEC);
assert_eq!("rw-rw-rw-", m.to_string());
let mut m = Mode::new()
    .with_class_perm(ALL, READ)
    .with_class_perm(USER, WRITE);
assert_eq!("rw-r--r--", m.to_string());
// (semantic functions can be used in const declarations)

// Or
m |= ALL_EXEC;
assert_eq!("rwxr-xr-x", m.to_string());
let m = ALL_READ | USER_WRITE;
assert_eq!("rw-r--r--", m.to_string());

// Displaying the mode can be done with the `Display`
// implementation but also bit per bit for more control
assert_eq!(
    m.to_string().chars().next().unwrap(), // first char: 'r' or '-'
    if m.has(USER_READ) { 'r' } else { '-' },
);

// The `Display` implementation shows the extra permission bits
// (setuid, setgid and sticky):
let mut m = Mode::all()
    .with_extra(STICKY)
    .with_extra(SETUID)
    .with_extra(SETGID);
assert_eq!("rwsrwsrwt", m.to_string());

// But you can remove those bits for display if you want the
// sometimes more familiar 'x' for execution:
assert_eq!("rwxrwxrwx", m.without_any_extra().to_string());

Dependencies

~220–670KB
~16K SLoC