#[non_exhaustive]
pub enum Error {
    Io(Error),
    LockTaken,
}
Expand description

A wrapper around io::Error to distinguish between the lock already existing and other errors.

Without this, it would not be possible to tell if the io::ErrorKind::AlreadyExists came from the lockfile or from the parent directory (if it already exists and is a file).

The error is non-exhaustive, in case we want to give more granular errors in future.

Examples

use lockfile::Error;
// `err` is the value returned by Lockfile::open
match err {
    Error::LockTaken => println!("lock exists, maybe we block in some way"),
    // Use err.into_inner to handle non exhaustiveness
    err => panic!("unrecoverable error: {}", err.into_inner()),
}

Variants (Non-exhaustive)

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.

Io(Error)

LockTaken

Implementations

Get at the underlying io::Error.

Trait Implementations

Formats the value using the given formatter. Read more

Formats the value using the given formatter. Read more

The lower-level source of this error, if any. Read more

👎Deprecated since 1.42.0:

use the Display impl or to_string()

👎Deprecated since 1.33.0:

replaced by Error::source, which can support downcasting

🔬This is a nightly-only experimental API. (error_generic_member_access)

Provides type based access to context intended for error reports. Read more

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

🔬This is a nightly-only experimental API. (provide_any)

Data providers should implement this method to provide all values they are able to provide by using demand. Read more

Converts the given value to a String. Read more

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.