5 releases (3 breaking)

0.4.1 Feb 28, 2024
0.4.0 Feb 28, 2024
0.3.0 Sep 17, 2022
0.2.0 Apr 21, 2022
0.1.1 Feb 8, 2020

#77 in Operating systems

Download history 18987/week @ 2024-10-09 22787/week @ 2024-10-16 21474/week @ 2024-10-23 18922/week @ 2024-10-30 13406/week @ 2024-11-06 18538/week @ 2024-11-13 18987/week @ 2024-11-20 13754/week @ 2024-11-27 18618/week @ 2024-12-04 15123/week @ 2024-12-11 10512/week @ 2024-12-18 3313/week @ 2024-12-25 8746/week @ 2025-01-01 16574/week @ 2025-01-08 17663/week @ 2025-01-15 13912/week @ 2025-01-22

57,491 downloads per month
Used in 139 crates (7 directly)

MIT license

18KB
328 lines

named-lock

license crates.io docs

This crate provides a simple and cross-platform implementation of named locks. You can use this to lock sections between processes.

Example

use named_lock::NamedLock;
use named_lock::Result;

fn main() -> Result<()> {
    let lock = NamedLock::create("foobar")?;
    let _guard = lock.lock()?;

    // Do something...

    Ok(())
}

Implementation

On UNIX this is implemented by using files and flock. The path of the created lock file will be $TMPDIR/<name>.lock, or /tmp/<name>.lock if TMPDIR environment variable is not set.

On Windows this is implemented by creating named mutex with CreateMutexW.

Dependencies

~0.6–35MB
~498K SLoC