1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2008 Sun Microsystems
6
* This program is free software; you can redistribute it and/or modify
7
* it under the terms of the GNU General Public License as published by
8
* the Free Software Foundation; version 2 of the License.
10
* This program is distributed in the hope that it will be useful,
11
* but WITHOUT ANY WARRANTY; without even the implied warranty of
12
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13
* GNU General Public License for more details.
15
* You should have received a copy of the GNU General Public License
16
* along with this program; if not, write to the Free Software
17
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
#ifndef DRIZZLED_PLUGIN_STORAGE_ENGINE_H
21
#define DRIZZLED_PLUGIN_STORAGE_ENGINE_H
24
#include <drizzled/definitions.h>
25
#include <drizzled/sql_plugin.h>
37
typedef struct st_mysql_lex_string LEX_STRING;
38
typedef bool (stat_print_fn)(Session *session, const char *type, uint32_t type_len,
39
const char *file, uint32_t file_len,
40
const char *status, uint32_t status_len);
41
enum ha_stat_type { HA_ENGINE_STATUS, HA_ENGINE_LOGS, HA_ENGINE_MUTEX };
43
/* Possible flags of a StorageEngine (there can be 32 of them) */
44
enum engine_flag_bits {
45
HTON_BIT_CLOSE_CURSORS_AT_COMMIT,
46
HTON_BIT_ALTER_NOT_SUPPORTED, // Engine does not support alter
47
HTON_BIT_CAN_RECREATE, // Delete all is used for truncate
48
HTON_BIT_HIDDEN, // Engine does not appear in lists
49
HTON_BIT_FLUSH_AFTER_RENAME,
50
HTON_BIT_NOT_USER_SELECTABLE,
51
HTON_BIT_TEMPORARY_NOT_SUPPORTED, // Having temporary tables not supported
52
HTON_BIT_SUPPORT_LOG_TABLES, // Engine supports log tables
53
HTON_BIT_NO_PARTITION, // You can not partition these tables
57
static const std::bitset<HTON_BIT_SIZE> HTON_NO_FLAGS(0);
58
static const std::bitset<HTON_BIT_SIZE> HTON_CLOSE_CURSORS_AT_COMMIT(1 << HTON_BIT_CLOSE_CURSORS_AT_COMMIT);
59
static const std::bitset<HTON_BIT_SIZE> HTON_ALTER_NOT_SUPPORTED(1 << HTON_BIT_ALTER_NOT_SUPPORTED);
60
static const std::bitset<HTON_BIT_SIZE> HTON_CAN_RECREATE(1 << HTON_BIT_CAN_RECREATE);
61
static const std::bitset<HTON_BIT_SIZE> HTON_HIDDEN(1 << HTON_BIT_HIDDEN);
62
static const std::bitset<HTON_BIT_SIZE> HTON_FLUSH_AFTER_RENAME(1 << HTON_BIT_FLUSH_AFTER_RENAME);
63
static const std::bitset<HTON_BIT_SIZE> HTON_NOT_USER_SELECTABLE(1 << HTON_BIT_NOT_USER_SELECTABLE);
64
static const std::bitset<HTON_BIT_SIZE> HTON_TEMPORARY_NOT_SUPPORTED(1 << HTON_BIT_TEMPORARY_NOT_SUPPORTED);
65
static const std::bitset<HTON_BIT_SIZE> HTON_SUPPORT_LOG_TABLES(1 << HTON_BIT_SUPPORT_LOG_TABLES);
66
static const std::bitset<HTON_BIT_SIZE> HTON_NO_PARTITION(1 << HTON_BIT_NO_PARTITION);
69
StorageEngine is a singleton structure - one instance per storage engine -
70
to provide access to storage engine functionality that works on the
71
"global" level (unlike handler class that works on a per-table basis)
73
usually StorageEngine instance is defined statically in ha_xxx.cc as
75
static StorageEngine { ... } xxx_engine;
77
savepoint_*, prepare, recover, and *_by_xid pointers can be 0.
82
Name used for storage engine.
84
const std::string name;
85
const bool two_phase_commit;
87
const std::bitset<HTON_BIT_SIZE> flags; /* global handler flags */
89
to store per-savepoint data storage engine is provided with an area
90
of a requested size (0 is ok here).
91
savepoint_offset must be initialized statically to the size of
92
the needed memory to store per-savepoint information.
93
After xxx_init it is changed to be an offset to savepoint storage
94
area and need not be used by storage engine.
95
see binlog_engine and binlog_savepoint_set/rollback for an example.
97
size_t savepoint_offset;
98
size_t orig_savepoint_offset;
99
std::vector<std::string> aliases;
104
* Implementing classes should override these to provide savepoint
107
virtual int savepoint_set_hook(Session *, void *) { return 0; }
109
virtual int savepoint_rollback_hook(Session *, void *) { return 0; }
111
virtual int savepoint_release_hook(Session *, void *) { return 0; }
116
each storage engine has it's own memory area (actually a pointer)
117
in the session, for storing per-connection information.
120
session->ha_data[xxx_engine.slot]
122
slot number is initialized by MySQL after xxx_init() is called.
126
StorageEngine(const std::string name_arg,
127
const std::bitset<HTON_BIT_SIZE> &flags_arg= HTON_NO_FLAGS,
128
size_t savepoint_offset_arg= 0,
129
bool support_2pc= false);
131
virtual ~StorageEngine();
133
const std::vector<std::string>& getAliases()
138
void addAlias(std::string alias)
140
aliases.push_back(alias);
145
return two_phase_commit;
149
bool is_enabled() const
154
bool is_user_selectable() const
156
return not flags.test(HTON_BIT_NOT_USER_SELECTABLE);
159
bool check_flag(const engine_flag_bits flag) const
161
return flags.test(flag);
164
void enable() { enabled= true; }
165
void disable() { enabled= false; }
167
std::string getName() const { return name; }
170
StorageEngine methods:
172
close_connection is only called if
173
session->ha_data[xxx_engine.slot] is non-zero, so even if you don't need
174
this storage area - set it to something, so that MySQL would know
175
this storage engine was accessed in this connection
177
virtual int close_connection(Session *)
182
'all' is true if it's a real commit, that makes persistent changes
183
'all' is false if it's not in fact a commit but an end of the
184
statement that is part of the transaction.
185
NOTE 'all' is also false in auto-commit mode where 'end of statement'
186
and 'real commit' mean the same event.
188
virtual int commit(Session *, bool)
193
virtual int rollback(Session *, bool)
199
The void * points to an uninitialized storage area of requested size
200
(see savepoint_offset description)
202
int savepoint_set(Session *session, void *sp)
204
return savepoint_set_hook(session, (unsigned char *)sp+savepoint_offset);
208
The void * points to a storage area, that was earlier passed
209
to the savepoint_set call
211
int savepoint_rollback(Session *session, void *sp)
213
return savepoint_rollback_hook(session,
214
(unsigned char *)sp+savepoint_offset);
217
int savepoint_release(Session *session, void *sp)
219
return savepoint_release_hook(session,
220
(unsigned char *)sp+savepoint_offset);
223
virtual int prepare(Session *, bool) { return 0; }
224
virtual int recover(XID *, uint32_t) { return 0; }
225
virtual int commit_by_xid(XID *) { return 0; }
226
virtual int rollback_by_xid(XID *) { return 0; }
227
virtual handler *create(TABLE_SHARE *, MEM_ROOT *)= 0;
229
virtual void drop_database(char*) { }
230
virtual int start_consistent_snapshot(Session *) { return 0; }
231
virtual bool flush_logs() { return false; }
232
virtual bool show_status(Session *, stat_print_fn *, enum ha_stat_type)
237
/* args: current_session, tables, cond */
238
virtual int fill_files_table(Session *, TableList *,
239
Item *) { return 0; }
240
virtual int release_temporary_latches(Session *) { return false; }
242
/* args: current_session, db, name */
243
virtual int table_exists_in_engine(Session*, const char *, const char *);
247
StorageEngine *ha_default_storage_engine(Session *session);
248
StorageEngine *ha_resolve_by_name(Session *session, const LEX_STRING *name);
249
handler *get_new_handler(TABLE_SHARE *share, MEM_ROOT *alloc,
250
StorageEngine *db_type);
251
const std::string ha_resolve_storage_engine_name(const StorageEngine *db_type);
253
#endif /* DRIZZLED_PLUGIN_STORAGE_ENGINE_H */