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
101
102
103
104
105
106
107
108
109
110
111
use crate::engine::PanicEngine;
use crate::write_batch::PanicWriteBatch;
use engine_traits::{Error, RaftEngine, RaftLogBatch, Result};
use kvproto::raft_serverpb::RaftLocalState;
use raft::eraftpb::Entry;
impl RaftEngine for PanicEngine {
type LogBatch = PanicWriteBatch;
fn log_batch(&self, capacity: usize) -> Self::LogBatch {
panic!()
}
fn sync(&self) -> Result<()> {
panic!()
}
fn get_raft_state(&self, raft_group_id: u64) -> Result<Option<RaftLocalState>> {
panic!()
}
fn get_entry(&self, raft_group_id: u64, index: u64) -> Result<Option<Entry>> {
panic!()
}
fn fetch_entries_to(
&self,
region_id: u64,
low: u64,
high: u64,
max_size: Option<usize>,
buf: &mut Vec<Entry>,
) -> Result<usize> {
panic!()
}
fn consume(&self, batch: &mut Self::LogBatch, sync_log: bool) -> Result<usize> {
panic!()
}
fn consume_and_shrink(
&self,
batch: &mut Self::LogBatch,
sync_log: bool,
max_capacity: usize,
shrink_to: usize,
) -> Result<usize> {
panic!()
}
fn clean(
&self,
raft_group_id: u64,
state: &RaftLocalState,
batch: &mut Self::LogBatch,
) -> Result<()> {
panic!()
}
fn append(&self, raft_group_id: u64, entries: Vec<Entry>) -> Result<usize> {
panic!()
}
fn put_raft_state(&self, raft_group_id: u64, state: &RaftLocalState) -> Result<()> {
panic!()
}
fn gc(&self, raft_group_id: u64, mut from: u64, to: u64) -> Result<usize> {
panic!()
}
fn purge_expired_files(&self) -> Result<Vec<u64>> {
panic!()
}
fn has_builtin_entry_cache(&self) -> bool {
panic!()
}
fn flush_metrics(&self, instance: &str) {
panic!()
}
fn reset_statistics(&self) {
panic!()
}
fn dump_stats(&self) -> Result<String> {
panic!()
}
}
impl RaftLogBatch for PanicWriteBatch {
fn append(&mut self, raft_group_id: u64, entries: Vec<Entry>) -> Result<()> {
panic!()
}
fn cut_logs(&mut self, raft_group_id: u64, from: u64, to: u64) {
panic!()
}
fn put_raft_state(&mut self, raft_group_id: u64, state: &RaftLocalState) -> Result<()> {
panic!()
}
fn is_empty(&self) -> bool {
panic!()
}
}