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
use std::error::Error as StdError;
use std::io::Error as IoError;
use std::net::AddrParseError;
use std::result;
use futures::channel::oneshot::Canceled;
use grpcio::Error as GrpcError;
use hyper::Error as HttpError;
use openssl::error::ErrorStack as OpenSSLError;
use protobuf::ProtobufError;
use thiserror::Error;
use engine_traits::Error as EngineTraitError;
use pd_client::Error as PdError;
use raftstore::Error as RaftServerError;
use tikv_util::codec::Error as CodecError;
use tikv_util::worker::ScheduleError;
use super::snap::Task as SnapTask;
use crate::storage::kv::Error as EngineError;
use crate::storage::Error as StorageError;
#[derive(Debug, Error)]
pub enum Error {
#[error("{0:?}")]
Other(#[from] Box<dyn StdError + Sync + Send>),
#[error("{0:?}")]
Io(#[from] IoError),
#[error("{0}")]
Protobuf(#[from] ProtobufError),
#[error("{0:?}")]
Grpc(#[from] GrpcError),
#[error("{0:?}")]
Codec(#[from] CodecError),
#[error("{0:?}")]
AddrParse(#[from] AddrParseError),
#[error("{0:?}")]
RaftServer(#[from] RaftServerError),
#[error("{0:?}")]
Engine(#[from] EngineError),
#[error("{0:?}")]
EngineTrait(#[from] EngineTraitError),
#[error("{0:?}")]
Storage(#[from] StorageError),
#[error("{0:?}")]
Pd(#[from] PdError),
#[error("{0:?}")]
SnapWorkerStopped(#[from] ScheduleError<SnapTask>),
#[error("failed to poll from mpsc receiver")]
Sink,
#[error("{0:?}")]
RecvError(#[from] Canceled),
#[error("{0:?}")]
Http(#[from] HttpError),
#[error("{0:?}")]
OpenSSL(#[from] OpenSSLError),
}
pub type Result<T> = result::Result<T, Error>;