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
use futures::compat::Future01CompatExt;
use redis::{FromRedisValue, RedisResult, ToRedisArgs};
use crate::{Cmd, Connection};
pub struct Pipeline {
pipeline: redis::Pipeline,
}
impl Pipeline {
pub fn new() -> Pipeline {
Pipeline {
pipeline: redis::Pipeline::new(),
}
}
pub fn with_capacity(capacity: usize) -> Pipeline {
Self {
pipeline: redis::Pipeline::with_capacity(capacity),
}
}
pub fn cmd(&mut self, name: &str) -> &mut Pipeline {
self.pipeline.cmd(name);
self
}
pub fn add_command(&mut self, cmd: Cmd) -> &mut Pipeline {
self.pipeline.add_command(cmd.cmd);
self
}
pub fn arg<T: ToRedisArgs>(&mut self, arg: T) -> &mut Pipeline {
self.pipeline.arg(arg);
self
}
pub fn ignore(&mut self) -> &mut Pipeline {
self.pipeline.ignore();
self
}
pub fn atomic(&mut self) -> &mut Pipeline {
self.pipeline.atomic();
self
}
pub fn get_packed_pipeline(&self, atomic: bool) -> Vec<u8> {
self.pipeline.get_packed_pipeline(atomic)
}
pub async fn query<T: FromRedisValue>(&self, con: &mut Connection) -> RedisResult<T> {
let rcon = con._take_conn()?;
let (rcon, result) = self.pipeline.clone().query_async(rcon).compat().await?;
con._replace_conn(rcon);
Ok(FromRedisValue::from_redis_value(&result)?)
}
pub fn clear(&mut self) {
self.pipeline.clear();
}
pub async fn execute(&self, con: &mut Connection) -> RedisResult<()> {
self.query::<redis::Value>(con).await?;
Ok(())
}
}
impl From<redis::Pipeline> for Pipeline {
fn from(pipeline: redis::Pipeline) -> Self {
Pipeline { pipeline }
}
}
impl Into<redis::Pipeline> for Pipeline {
fn into(self) -> redis::Pipeline {
self.pipeline
}
}
pub fn pipe() -> Pipeline {
Pipeline::new()
}