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
extern crate libc;
extern crate rdkafka_sys as rdkafka;
extern crate std;
use self::rdkafka::types::*;
pub type KafkaResult<T> = Result<T, KafkaError>;
pub trait IsError {
fn is_error(self) -> bool;
}
impl IsError for RDKafkaRespErr {
fn is_error(self) -> bool {
self as i32 != RDKafkaRespErr::RD_KAFKA_RESP_ERR_NO_ERROR as i32
}
}
impl IsError for RDKafkaConfRes {
fn is_error(self) -> bool {
self as i32 != RDKafkaConfRes::RD_KAFKA_CONF_OK as i32
}
}
#[derive(Debug)]
pub enum KafkaError {
ClientConfig((RDKafkaConfRes, String, String, String)),
ClientCreation(String),
ConsumerCreation(String),
MessageConsumption(RDKafkaRespErr),
MessageProduction(RDKafkaRespErr),
Nul(std::ffi::NulError),
Subscription(String),
TopicConfig((RDKafkaConfRes, String, String, String)),
TopicCreation(String),
PartitionEof
}
impl From<std::ffi::NulError> for KafkaError {
fn from(err: std::ffi::NulError) -> KafkaError {
KafkaError::Nul(err)
}
}