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
//! Individual java modifier

use element::Element;
use tokens::Tokens;
use custom::Custom;
use std::collections::BTreeSet;

/// A Java modifier.
#[derive(Debug, PartialEq, Eq, PartialOrd, Ord, Clone, Hash)]
pub enum Modifier {
    /// default
    Default,
    /// public
    Public,
    /// protected
    Protected,
    /// private
    Private,
    /// abstract
    Abstract,
    /// static
    Static,
    /// final
    Final,
}

impl Modifier {
    /// Get the name of the modifier.
    pub fn name(&self) -> &'static str {
        use self::Modifier::*;

        match *self {
            Default => "default",
            Public => "public",
            Protected => "protected",
            Private => "private",
            Abstract => "abstract",
            Static => "static",
            Final => "final",
        }
    }
}

impl<'el, C: Custom> From<Vec<Modifier>> for Tokens<'el, C> {
    fn from(value: Vec<Modifier>) -> Self {
        toks![value]
    }
}

impl<'el, C: Custom> From<Vec<Modifier>> for Element<'el, C> {
    fn from(value: Vec<Modifier>) -> Self {
        let out: BTreeSet<Modifier> = value.into_iter().collect();
        let out: Vec<&str> = out.iter().map(Modifier::name).collect();
        Element::Literal(out.join(" ").into())
    }
}

#[cfg(test)]
mod tests {
    use super::Modifier;
    use java::Java;
    use tokens::Tokens;

    #[test]
    fn test_vec() {
        use self::Modifier::*;
        let el: Tokens<Java> = vec![Final, Static, Public, Static].into();
        let s = el.to_string();
        let out = s.as_ref().map(|s| s.as_str());
        assert_eq!(Ok("public static final"), out);
    }
}