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
use super::super::errors::parser_error::ParseError;
use super::super::parser::ast::Variable;
use super::transformer_list::TransformerList;
use super::value_types::ValueType;
use std::collections::BTreeMap;
pub struct Parser;
impl Parser {
pub fn to_parse_variable(
transformer_list: &TransformerList,
variable: &Variable,
envs: &BTreeMap<String, Option<String>>,
) -> Result<ValueType, ParseError> {
let default_type = String::from("String");
let transform_type = variable
.variable_type
.clone()
.unwrap_or(default_type)
.to_lowercase();
let transformer = transformer_list
.get(&transform_type)
.expect(format!("Type {} is not valid type", transform_type).as_str());
let value_env = envs.get(&variable.name).unwrap_or(&None);
if variable.nullable && value_env.is_none() && variable.default_value.is_none() {
return Ok(ValueType::Null);
}
let value_to_transform = if let Some(value_env) = value_env {
value_env.to_string()
} else if let Some(expression) = variable.default_value.as_ref() {
if let Some(default_value) = expression.as_default_value() {
default_value.value.to_string()
} else {
do yeet ParseError::new(format!("Expression cannot found error"), variable.span)
}
} else {
do yeet ParseError::new(
format!("{} value cannot be null", &variable.name),
variable.span,
)
};
Ok(transformer.as_ref().parse(value_to_transform))
}
}