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
use anyhow::Result;
use either::Either;
use thiserror::Error;
use crate::config::Config as ThconConfig;
use crate::operation::Operation;
use thcon_trait::{Disableable, Disabled};
pub trait Themeable {
fn config_state(&self, config: &ThconConfig) -> ConfigState;
fn switch(&self, config: &ThconConfig, operation: &Operation) -> Result<()>;
}
#[derive(PartialEq, Eq, Debug)]
pub enum ConfigState {
NoDefault,
Default,
Disabled,
Enabled,
}
#[derive(Debug, Error)]
pub enum ConfigError {
#[error("{0} requires manual configuration")]
RequiresManualConfig(&'static str),
}
impl ConfigState {
pub fn with_manual_config<T>(section: Option<Either<&T, &Disabled>>) -> Self
where
T: Disableable,
{
match section.as_ref() {
None => ConfigState::NoDefault,
Some(c) => match c {
Either::Left(t) => match t.disabled() {
true => ConfigState::Disabled,
false => ConfigState::Enabled,
},
Either::Right(d) => match d.disabled() {
true => ConfigState::Disabled,
false => ConfigState::Default,
},
},
}
}
pub fn with_default_config<T>(section: Option<Either<&T, &Disabled>>) -> Self
where
T: Disableable,
{
match section.as_ref() {
None => ConfigState::Default,
Some(c) => match c {
Either::Left(t) => match t.disabled() {
true => ConfigState::Disabled,
false => ConfigState::Enabled,
},
Either::Right(d) => match d.disabled() {
true => ConfigState::Disabled,
false => ConfigState::Default,
},
},
}
}
}