forked from Begun/libslave
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathDefaultExtState.h
116 lines (108 loc) · 3.01 KB
/
DefaultExtState.h
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
112
113
114
115
116
#ifndef __SLAVE_DEFAULTEXTSTATE_H_
#define __SLAVE_DEFAULTEXTSTATE_H_
#include <mutex>
#include "SlaveStats.h"
namespace slave
{
class DefaultExtState: public ExtStateIface, protected State {
std::mutex m_mutex;
public:
State getState() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return *this;
}
void setConnecting() override
{
std::lock_guard<std::mutex> lock(m_mutex);
connect_time = ::time(NULL);
++connect_count;
}
time_t getConnectTime() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return connect_time;
}
void setLastFilteredUpdateTime() override
{
std::lock_guard<std::mutex> lock(m_mutex);
last_filtered_update = ::time(NULL);
}
time_t getLastFilteredUpdateTime() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return last_filtered_update;
}
void setLastEventTimePos(time_t t, unsigned long pos) override
{
std::lock_guard<std::mutex> lock(m_mutex);
last_event_time = t; intransaction_pos = pos; last_update = ::time(NULL);
}
time_t getLastUpdateTime() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return last_update;
}
time_t getLastEventTime() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return last_event_time;
}
unsigned long getIntransactionPos() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return intransaction_pos;
}
void setMasterPosition(const Position& pos) override
{
std::lock_guard<std::mutex> lock(m_mutex);
position = pos;
intransaction_pos = pos.log_pos;
}
void saveMasterPosition() override {}
private:
bool loadMasterPositionNoLock(Position& pos)
{
// we could use std::recursive_mutex instead,
// but wicked toungues say it is a bad design
pos.clear();
return false;
}
public:
bool loadMasterPosition(Position& pos) override
{
std::lock_guard<std::mutex> lock(m_mutex);
return loadMasterPositionNoLock(pos);
}
bool getMasterPosition(Position& pos) override
{
std::lock_guard<std::mutex> lock(m_mutex);
if (!position.empty())
{
pos = position;
if (intransaction_pos)
pos.log_pos = intransaction_pos;
return true;
}
return loadMasterPositionNoLock(pos);
}
unsigned int getConnectCount() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return connect_count;
}
void setStateProcessing(bool _state) override
{
std::lock_guard<std::mutex> lock(m_mutex);
state_processing = _state;
}
bool getStateProcessing() override
{
std::lock_guard<std::mutex> lock(m_mutex);
return state_processing;
}
void initTableCount(const std::string& t) override {}
void incTableCount(const std::string& t) override {}
};
}// slave
#endif