1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
use crate::*;
use std::error::Error;
use std::path::PathBuf;
#[derive(Debug)]
pub enum ConfigError {
ConfigNotFound(String),
ConfigRecursiveNotFound(String),
ConfigTypeMismatch(String, &'static str, &'static str),
ConfigParseError(String, String),
ConfigRecursiveError(String),
ConfigFileNotExists(PathBuf),
ConfigFileNotSupported(PathBuf),
RefValueRecursiveError,
TooManyInstances(usize),
LockPoisoned,
ConfigCause(Box<dyn Error + 'static>),
}
impl<E: Error + 'static> From<E> for ConfigError {
#[inline]
fn from(e: E) -> Self {
ConfigError::ConfigCause(Box::new(e))
}
}
impl ConfigError {
#[inline]
pub(crate) fn try_lock_err<T>(v: TryLockError<T>) -> Option<Self> {
match v {
TryLockError::WouldBlock => None,
TryLockError::Poisoned(e) => Some(Self::lock_err(e)),
}
}
#[inline]
pub(crate) fn lock_err<T>(_e: PoisonError<T>) -> Self {
ConfigError::LockPoisoned
}
}
pub(crate) trait ConfigLock<'a, T> {
fn lock_c(&'a self) -> Result<MutexGuard<'a, T>, ConfigError>;
fn try_lock_c(&'a self) -> Result<Option<MutexGuard<'a, T>>, ConfigError>;
}
impl<'a, T> ConfigLock<'a, T> for Mutex<T> {
#[inline]
fn lock_c(&'a self) -> Result<MutexGuard<'a, T>, ConfigError> {
self.lock().map_err(ConfigError::lock_err)
}
#[inline]
fn try_lock_c(&'a self) -> Result<Option<MutexGuard<'a, T>>, ConfigError> {
match self.try_lock().map_err(ConfigError::try_lock_err) {
Ok(ok) => Ok(Some(ok)),
Err(Some(e)) => Err(e),
_ => Ok(None),
}
}
}