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
use std::ops::{Deref, DerefMut};
use redis::{FromRedisValue, RedisResult, ToRedisArgs};
use crate::{Cmd, ConnectionWrapper};
pub struct Pipeline {
pipeline: redis::Pipeline,
}
impl Pipeline {
pub fn new() -> Self {
Self {
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 async fn query_async<T: FromRedisValue>(
&self,
con: &mut ConnectionWrapper,
) -> RedisResult<T> {
self.pipeline.query_async(DerefMut::deref_mut(con)).await
}
pub async fn execute_async(&self, con: &mut ConnectionWrapper) -> RedisResult<()> {
self.query_async::<redis::Value>(con).await?;
Ok(())
}
}
impl Deref for Pipeline {
type Target = redis::Pipeline;
fn deref(&self) -> &redis::Pipeline {
&self.pipeline
}
}
impl DerefMut for Pipeline {
fn deref_mut(&mut self) -> &mut redis::Pipeline {
&mut self.pipeline
}
}
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()
}