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
use crate::data::position::Position;
use crate::data::primitive::{
array::PrimitiveArray, boolean::PrimitiveBoolean, float::PrimitiveFloat, int::PrimitiveInt,
null::PrimitiveNull, object::PrimitiveObject, string::PrimitiveString,
};
use crate::data::{ast::Interval, Data, Literal, MessageData, MSG};
use crate::error_format::*;
use crate::parser::parse_string::interpolate_string;
use std::{collections::HashMap, sync::mpsc};
pub fn interpolate(
literal: &serde_json::Value,
interval: Interval,
data: &mut Data,
msg_data: &mut MessageData,
sender: &Option<mpsc::Sender<MSG>>,
) -> Result<Literal, ErrorInfo> {
match literal {
serde_json::Value::String(val) => interpolate_string(val, data, msg_data, sender),
_ => json_to_literal(literal, interval),
}
}
pub fn json_to_literal(
literal: &serde_json::Value,
interval: Interval,
) -> Result<Literal, ErrorInfo> {
match literal {
serde_json::Value::String(val) => Ok(PrimitiveString::get_literal(val, interval)),
serde_json::Value::Bool(val) => Ok(PrimitiveBoolean::get_literal(*val, interval)),
serde_json::Value::Null => Ok(PrimitiveNull::get_literal(interval)),
serde_json::Value::Number(val) => {
if let (true, Some(float)) = (val.is_f64(), val.as_f64()) {
Ok(PrimitiveFloat::get_literal(float, interval))
} else if let (true, Some(int)) = (val.is_i64(), val.as_i64()) {
Ok(PrimitiveInt::get_literal(int, interval))
} else {
Err(gen_error_info(
Position::new(interval),
ERROR_JSON_TO_LITERAL.to_owned(),
))
}
}
serde_json::Value::Array(val) => {
let mut vec = vec![];
for elem in val {
vec.push(json_to_literal(elem, interval)?);
}
Ok(PrimitiveArray::get_literal(&vec, interval))
}
serde_json::Value::Object(val) => {
let mut map = HashMap::new();
for (k, v) in val.iter() {
map.insert(k.to_owned(), json_to_literal(v, interval)?);
}
Ok(PrimitiveObject::get_literal(&map, interval))
}
}
}
pub fn memory_to_literal(
literal: &serde_json::Value,
interval: Interval,
) -> Result<Literal, ErrorInfo> {
match literal {
serde_json::Value::String(val) => Ok(PrimitiveString::get_literal(val, interval)),
serde_json::Value::Bool(val) => Ok(PrimitiveBoolean::get_literal(*val, interval)),
serde_json::Value::Null => Ok(PrimitiveNull::get_literal(interval)),
serde_json::Value::Number(val) => {
if let (true, Some(float)) = (val.is_f64(), val.as_f64()) {
Ok(PrimitiveFloat::get_literal(float, interval))
} else if let (true, Some(int)) = (val.is_i64(), val.as_i64()) {
Ok(PrimitiveInt::get_literal(int, interval))
} else {
Err(gen_error_info(
Position::new(interval),
ERROR_JSON_TO_LITERAL.to_owned(),
))
}
}
serde_json::Value::Array(val) => {
let mut vec = vec![];
for elem in val {
vec.push(memory_to_literal(elem, interval)?);
}
Ok(PrimitiveArray::get_literal(&vec, interval))
}
serde_json::Value::Object(val) => {
let mut map = HashMap::new();
match (val.get("_content"), val.get("_content_type")) {
(Some(content), Some(serde_json::Value::String(conent_type))) => {
let mut literal = memory_to_literal(content, interval)?;
literal.set_content_type(&conent_type);
Ok(literal)
}
(_, _) => {
for (k, v) in val.iter() {
map.insert(k.to_owned(), memory_to_literal(v, interval)?);
}
Ok(PrimitiveObject::get_literal(&map, interval))
}
}
}
}
}