teo_runtime/enum/member/
builder.rs

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
use std::collections::BTreeMap;
use std::sync::{Arc, Mutex};
use crate::app::data::AppData;
use crate::comment::Comment;
use crate::r#enum::member::Member;
use crate::Value;

#[derive(Debug, Clone)]
pub struct Builder {
    inner: Arc<Inner>
}

#[derive(Debug)]
struct Inner {
    name: String,
    comment: Option<Comment>,
    value: Value,
    data: Arc<Mutex<BTreeMap<String, Value>>>,
    app_data: AppData,
}

impl Builder {

    pub fn new(name: String, value: Value, comment: Option<Comment>, app_data: AppData) -> Self {
        Self {
            inner: Arc::new(Inner {
                name,
                value,
                comment,
                data: Arc::new(Mutex::new(BTreeMap::new())),
                app_data,
            })
        }
    }

    pub fn name(&self) -> &str {
        &self.inner.name
    }

    pub fn comment(&self) -> Option<&Comment> {
        self.inner.comment.as_ref()
    }

    pub fn value(&self) -> &Value {
        &self.inner.value
    }

    pub fn data(&self) -> BTreeMap<String, Value> {
        self.inner.data.lock().unwrap().clone()
    }

    pub fn set_data(&self, data: BTreeMap<String, Value>) {
        *self.inner.data.lock().unwrap() = data;
    }

    pub fn insert_data_entry(&self, key: String, value: Value) {
        self.inner.data.lock().unwrap().insert(key, value);
    }

    pub fn remove_data_entry(&self, key: &str) {
        self.inner.data.lock().unwrap().remove(key);
    }

    pub fn data_entry(&self, key: &str) -> Option<Value> {
        self.inner.data.lock().unwrap().get(key).cloned()
    }

    pub(crate) fn build(self) -> Member {
        Member {
            name: self.inner.name.clone(),
            value: self.inner.value.clone(),
            comment: self.inner.comment.clone(),
            data: self.inner.data.lock().unwrap().clone(),
        }
    }

    pub fn app_data(&self) -> &AppData {
        &self.inner.app_data
    }
}