forked from vozbu/libslave
-
Notifications
You must be signed in to change notification settings - Fork 1
/
table.h
111 lines (86 loc) · 3.21 KB
/
table.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
/* Copyright 2011 ZAO "Begun".
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 3 of the License, or (at your option)
* any later version.
* This library is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
* FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
* details.
* You should have received a copy of the GNU Lesser General Public License
* along with this library. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __SLAVE_TABLE_H_
#define __SLAVE_TABLE_H_
#include <functional>
#include <string>
#include <vector>
#include <map>
#include <memory>
#include "field.h"
#include "recordset.h"
#include "SlaveStats.h"
namespace slave
{
typedef std::unique_ptr<Field> PtrField;
typedef std::function<void (RecordSet&)> callback;
typedef std::function<void (const std::string&, const std::string&, const std::vector<PtrField>&)> ddl_callback;
typedef EventKind filter;
inline bool should_process(EventKind filter, EventKind kind) { return (filter & kind) == kind; }
class Table {
public:
std::vector<PtrField> fields;
std::vector<unsigned char> column_filter;
std::vector<unsigned> column_filter_fields;
unsigned column_filter_count;
RowType row_type;
callback m_callback;
EventKind m_filter;
void call_callback(slave::RecordSet& _rs, ExtStateIface &ext_state) const
{
// Some stats
ext_state.incTableCount(full_name);
ext_state.setLastFilteredUpdateTime();
m_callback(_rs);
}
void set_column_filter(const std::vector<std::string> &_column_filter) {
if (_column_filter.empty()) {
column_filter.clear();
column_filter_fields.clear();
column_filter_count = 0;
return;
}
column_filter.resize((fields.size() + 7)/8);
column_filter_fields.resize(fields.size());
column_filter_count = _column_filter.size();
for (unsigned i = 0; i < column_filter.size(); i++) {
column_filter[i] = 0;
column_filter_fields[i] = 0;
}
// FIXME: this loop has complexity factor of O(N*M)
for (auto i = _column_filter.begin(); i != _column_filter.end(); ++i) {
const auto &field_name = *i;
for (auto j = fields.begin(); j != fields.end(); ++j) {
const auto &field = *j;
if (field->getFieldName() == field_name) {
const int index = j - fields.begin();
column_filter[index>>3] |= (1<<(index&7));
column_filter_fields[index] = i - _column_filter.begin();
break;
}
}
}
}
const std::string table_name;
const std::string database_name;
std::string full_name;
Table(const std::string& db_name, const std::string& tbl_name) :
column_filter_count(0),
table_name(tbl_name), database_name(db_name),
full_name(database_name + "." + table_name)
{}
Table() {}
};
}
#endif