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
use std::error;
use crate::Error;
use kvproto::raft_cmdpb::RaftCmdResponse;
pub fn bind_term(resp: &mut RaftCmdResponse, term: u64) {
if term == 0 {
return;
}
resp.mut_header().set_current_term(term);
}
pub fn bind_error(resp: &mut RaftCmdResponse, err: Error) {
resp.mut_header().set_error(err.into());
}
pub fn new_error(err: Error) -> RaftCmdResponse {
let mut resp = RaftCmdResponse::default();
bind_error(&mut resp, err);
resp
}
pub fn err_resp(e: Error, term: u64) -> RaftCmdResponse {
let mut resp = new_error(e);
bind_term(&mut resp, term);
resp
}
pub fn message_error<E>(err: E) -> RaftCmdResponse
where
E: Into<Box<dyn error::Error + Send + Sync>>,
{
new_error(Error::Other(err.into()))
}