5 releases (3 breaking)
| 0.4.1 | Feb 28, 2024 |
|---|---|
| 0.4.0 |
|
| 0.3.0 | Sep 17, 2022 |
| 0.2.0 | Apr 21, 2022 |
| 0.1.1 | Feb 8, 2020 |
#55 in Operating systems
67,133 downloads per month
Used in 150 crates
(18 directly)
18KB
328 lines
named-lock
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.5–37MB
~482K SLoC