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
#[derive(Debug, PartialEq)]
pub enum RedisValue {
SimpleStringStatic(&'static str),
SimpleString(String),
BulkString(String),
Integer(i64),
Float(f64),
Array(Vec<RedisValue>),
Null,
NoReply,
}
impl From<()> for RedisValue {
fn from(_: ()) -> Self {
RedisValue::Null
}
}
impl From<i64> for RedisValue {
fn from(i: i64) -> Self {
RedisValue::Integer(i)
}
}
impl From<usize> for RedisValue {
fn from(i: usize) -> Self {
(i as i64).into()
}
}
impl From<f64> for RedisValue {
fn from(f: f64) -> Self {
RedisValue::Float(f)
}
}
impl From<String> for RedisValue {
fn from(s: String) -> Self {
RedisValue::BulkString(s)
}
}
impl From<&str> for RedisValue {
fn from(s: &str) -> Self {
s.to_owned().into()
}
}
impl From<&String> for RedisValue {
fn from(s: &String) -> Self {
s.to_owned().into()
}
}
impl<T: Into<RedisValue>> From<Option<T>> for RedisValue {
fn from(s: Option<T>) -> Self {
match s {
Some(v) => v.into(),
None => RedisValue::Null,
}
}
}
impl<T: Into<RedisValue>> From<Vec<T>> for RedisValue {
fn from(items: Vec<T>) -> Self {
RedisValue::Array(items.into_iter().map(|item| item.into()).collect())
}
}
#[cfg(test)]
mod tests {
use super::RedisValue;
#[test]
fn from_vec_string() {
assert_eq!(
RedisValue::from(vec!["foo".to_string()]),
RedisValue::Array(vec![RedisValue::BulkString("foo".to_owned())])
);
}
#[test]
fn from_vec_str() {
assert_eq!(
RedisValue::from(vec!["foo"]),
RedisValue::Array(vec![RedisValue::BulkString("foo".to_owned())])
);
}
#[test]
fn from_vec_string_ref() {
assert_eq!(
RedisValue::from(vec![&"foo".to_string()]),
RedisValue::Array(vec![RedisValue::BulkString("foo".to_owned())])
);
}
#[test]
fn from_option_str() {
assert_eq!(
RedisValue::from(Some("foo")),
RedisValue::BulkString("foo".to_owned())
);
}
#[test]
fn from_option_none() {
assert_eq!(RedisValue::from(None::<()>), RedisValue::Null,);
}
}