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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
use std::cell::RefCell;
use teo_teon::value::Value;
use crate::ast::argument_list_declaration::ArgumentListDeclaration;

use crate::ast::callable_variant::CallableVariant;
use crate::ast::doc_comment::DocComment;
use crate::ast::decorator::Decorator;
use crate::ast::expression::Expression;
use crate::ast::identifier::Identifier;
use crate::{declare_container_node, impl_container_node_defaults, node_child_fn, node_children_iter, node_children_iter_fn, node_optional_child_fn};
use crate::format::Writer;
use crate::traits::has_availability::HasAvailability;
use crate::traits::info_provider::InfoProvider;
use crate::traits::node_trait::NodeTrait;
use crate::traits::resolved::Resolve;
use crate::traits::write::Write;

declare_container_node!(Enum, named, availability,
    pub interface: bool,
    pub option: bool,
    pub(crate) comment: Option<usize>,
    pub(crate) decorators: Vec<usize>,
    pub(crate) identifier: usize,
    pub(crate) members: Vec<usize>,
);

impl_container_node_defaults!(Enum, named, availability);

node_children_iter!(Enum, Decorator, EnumDecoratorsIter, decorators);

node_children_iter!(Enum, EnumMember, EnumMembersIter, members);

impl Enum {

    node_optional_child_fn!(comment, DocComment);

    node_child_fn!(identifier, Identifier);

    node_children_iter_fn!(decorators, EnumDecoratorsIter);

    node_children_iter_fn!(members, EnumMembersIter);
}

impl InfoProvider for Enum {
    fn namespace_skip(&self) -> usize {
        1
    }
}

declare_container_node!(EnumMember, named, availability,
    pub(crate) comment: Option<usize>,
    pub(crate) decorators: Vec<usize>,
    pub(crate) identifier: usize,
    pub(crate) expression: Option<usize>,
    pub(crate) argument_list_declaration: Option<usize>,
    pub(crate) resolved: RefCell<Option<Value>>,
);

impl_container_node_defaults!(EnumMember, named, availability);

node_children_iter!(EnumMember, Decorator, EnumMemberDecoratorsIter, decorators);

impl EnumMember {

    node_optional_child_fn!(comment, DocComment);

    node_children_iter_fn!(decorators, EnumMemberDecoratorsIter);

    node_child_fn!(identifier, Identifier);

    node_optional_child_fn!(expression, Expression);

    node_optional_child_fn!(argument_list_declaration, ArgumentListDeclaration);

    pub fn callable_variants(&self) -> Vec<CallableVariant> {
        self.argument_list_declaration().map(|a| CallableVariant {
            generics_declarations: vec![],
            argument_list_declaration: Some(a),
            generics_constraints: vec![],
            pipeline_input: None,
            pipeline_output: None,
        }).into_iter().collect()
    }
}

impl InfoProvider for EnumMember {
    fn namespace_skip(&self) -> usize {
        2
    }
}

impl Resolve<Value> for EnumMember {

    fn resolved_ref_cell(&self) -> &RefCell<Option<Value>> {
        &self.resolved
    }
}

impl Write for Enum {
    fn write<'a>(&'a self, writer: &mut Writer<'a>) {
        writer.write_children(self, self.children.values());
    }

    fn is_block_level_element(&self) -> bool {
        true
    }
}

impl Write for EnumMember {
    fn write<'a>(&'a self, writer: &mut Writer<'a>) {
        writer.write_children(self, self.children.values());
    }

    fn is_block_level_element(&self) -> bool {
        true
    }
}