Migrate 25 crates to monorepo.

miette
mime
mio
mls-rs-codec
mls-rs-codec-derive
mls-rs-core
mockall
named-lock
nom
no-panic
num_cpus
num-integer
num-traits
oorandom
os_str_bytes
p9
p9_wire_format_derive
parking_lot
parking_lot_core
pathdiff
pdl-runtime
pest
pest_derive
pest_generator
pest_meta

Bug: 339424309
Test: treehugger
Change-Id: I618a9a1c5405da2e693d515817b1c3698ed415f2
2 files changed
tree: 8e322710a83d00f4b65d262d22380afcd8f06912
  1. src/
  2. Android.bp
  3. Cargo.toml
  4. Cargo.toml.orig
  5. CHANGELOG.md
  6. LICENSE
  7. METADATA
  8. MODULE_LICENSE_MIT
  9. OWNERS
  10. README.md
  11. rustfmt.toml
README.md

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.