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
use inflector::Inflector;

/// What format of properties keys to use and check when parsing
/// Current allowed: snake_case, camelCase, kebab-case or ignore case
/// Default: camelCase
#[derive(Debug, Clone, Copy, PartialEq)]
pub enum Case {
    Ignore,
    Snake,
    Kebab,
    Camel,
}

impl Default for Case {
    fn default() -> Self {
        Case::Camel
    }
}

impl Case {
    pub fn is_valid(&self, key: &String) -> bool {
        match &self {
            Case::Snake => key.is_snake_case(),
            Case::Kebab => key.is_kebab_case(),
            Case::Camel => key.is_camel_case(),
            Case::Ignore => true,
        }
    }

    pub fn new(source: &str) -> Case {
        if source.is_snake_case() {
            Case::Snake
        } else if source.is_camel_case() {
            Case::Camel
        } else if source.is_kebab_case() {
            Case::Kebab
        } else {
            Case::Ignore
        }
    }
}

/// From what data format to parse, currently available: JSON, YAML
/// Default: JSON
#[derive(Debug, Clone, Copy, PartialEq)]
pub enum SourceFormat {
    Json,
    Yaml,
}

impl Default for SourceFormat {
    fn default() -> Self {
        SourceFormat::Json
    }
}

/// Options for parse style from uniform functions
#[derive(Default, Debug, Clone, Copy, PartialEq)]
pub struct ParseOptions {
    pub from: SourceFormat,
    pub style: Case,
}