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
use flow_impl::{Implementation, RUN_AGAIN, RunAgain};
use flow_impl_derive::FlowImpl;
use serde_json::Value;
use serde_json::Value::Number;
#[derive(FlowImpl)]
pub struct Sqrt;
impl Implementation for Sqrt {
fn run(&self, inputs: Vec<Vec<Value>>) -> (Option<Value>, RunAgain) {
let input = inputs.get(0).unwrap();
let mut value = None;
match input[0] {
Number(ref a) => {
if a.is_i64() {
value = Some(Value::Number(serde_json::Number::from_f64(a.as_f64().unwrap().sqrt()).unwrap()));
} else if a.is_u64() {
value = Some(Value::Number(serde_json::Number::from_f64(a.as_f64().unwrap().sqrt()).unwrap()));
} else if a.is_f64() {
value = Some(Value::Number(serde_json::Number::from_f64(a.as_f64().unwrap().sqrt()).unwrap()));
}
}
_ => {}
}
(value, RUN_AGAIN)
}
}
#[cfg(test)]
mod test {
use flow_impl::Implementation;
use super::Sqrt;
#[test]
fn test_81() {
let rooter = Sqrt {};
let test_81 = vec!(vec!(serde_json::Value::Number(serde_json::Number::from(81))));
let test_9 = serde_json::Value::Number(serde_json::Number::from_f64(9.0).unwrap());
let (root, again) = rooter.run(test_81);
println!("root = {:?}", root);
assert_eq!(true, again);
assert_eq!(test_9, root.unwrap());
}
}