32
32
drizzled::plugin::StorageEngine(name_arg,
33
33
HTON_ALTER_NOT_SUPPORTED |
34
34
HTON_HAS_SCHEMA_DICTIONARY |
35
HTON_HAS_DATA_DICTIONARY |
35
36
HTON_SKIP_STORE_LOCK |
36
HTON_TEMPORARY_NOT_SUPPORTED),
37
information_message(new(message::Schema)),
38
data_dictionary_message(new(message::Schema))
37
HTON_TEMPORARY_NOT_SUPPORTED)
41
information_message->set_name(INFORMATION_SCHEMA_IDENTIFIER.getSchemaName());
42
data_dictionary_message->set_collation("utf8_general_ci");
44
data_dictionary_message->set_name(DATA_DICTIONARY_IDENTIFIER.getSchemaName());
45
data_dictionary_message->set_collation("utf8_general_ci");
49
Cursor *Function::create(Table &table)
42
Cursor *Function::create(TableShare &table, memory::Root *mem_root)
51
return new FunctionCursor(*this, table);
44
return new (mem_root) FunctionCursor(*this, table);
54
47
int Function::doGetTableDefinition(Session &,
55
const identifier::Table &identifier,
56
message::Table &table_proto)
52
message::Table *table_proto)
58
drizzled::plugin::TableFunction *function= getFunction(identifier.getPath());
54
string tab_name(path);
55
transform(tab_name.begin(), tab_name.end(),
56
tab_name.begin(), ::tolower);
58
drizzled::plugin::TableFunction *function= getFunction(tab_name);
65
function->define(table_proto);
67
function->define(*table_proto);
70
void Function::doGetSchemaIdentifiers(identifier::Schema::vector& schemas)
72
schemas.push_back(INFORMATION_SCHEMA_IDENTIFIER);
73
schemas.push_back(DATA_DICTIONARY_IDENTIFIER);
76
bool Function::doGetSchemaDefinition(const identifier::Schema &schema_identifier, message::schema::shared_ptr &schema_message)
78
schema_message.reset(new message::Schema); // This should be fixed, we could just be using ones we built on startup.
80
if (schema_identifier == INFORMATION_SCHEMA_IDENTIFIER)
74
void Function::doGetTableNames(drizzled::CachedDirectory&,
76
set<string> &set_of_names)
78
drizzled::plugin::TableFunction::getNames(db, set_of_names);
81
void Function::doGetSchemaNames(std::set<std::string>& set_of_names)
83
set_of_names.insert("information_schema"); // special cases suck
84
set_of_names.insert("data_dictionary"); // special cases suck
87
bool Function::doGetSchemaDefinition(const std::string &schema_name, message::Schema &schema_message)
89
if (not schema_name.compare("information_schema"))
82
schema_message= information_message;
91
schema_message.set_name("information_schema");
92
schema_message.set_collation("utf8_general_ci");
84
else if (schema_identifier == DATA_DICTIONARY_IDENTIFIER)
94
else if (not schema_name.compare("data_dictionary"))
86
schema_message= data_dictionary_message;
96
schema_message.set_name("data_dictionary");
97
schema_message.set_collation("utf8_general_ci");
96
bool Function::doCanCreateTable(const drizzled::identifier::Table &table_identifier)
98
if (static_cast<const identifier::Schema&>(table_identifier) == INFORMATION_SCHEMA_IDENTIFIER)
103
else if (static_cast<const identifier::Schema&>(table_identifier) == DATA_DICTIONARY_IDENTIFIER)
111
bool Function::doDoesTableExist(Session&, const identifier::Table &identifier)
113
drizzled::plugin::TableFunction *function= getFunction(identifier.getPath());
122
void Function::doGetTableIdentifiers(drizzled::CachedDirectory&,
123
const drizzled::identifier::Schema &schema_identifier,
124
drizzled::identifier::Table::vector &set_of_identifiers)
126
set<std::string> set_of_names;
127
drizzled::plugin::TableFunction::getNames(schema_identifier.getSchemaName(), set_of_names);
129
for (set<std::string>::iterator iter= set_of_names.begin(); iter != set_of_names.end(); iter++)
131
set_of_identifiers.push_back(identifier::Table(schema_identifier, *iter, drizzled::message::Table::FUNCTION));
135
static int init(drizzled::module::Context &context)
137
context.add(new Function("FunctionEngine"));
108
static drizzled::plugin::StorageEngine *function_plugin= NULL;
110
static int init(drizzled::plugin::Registry ®istry)
112
function_plugin= new(std::nothrow) Function("FunctionEngine");
114
if (not function_plugin)
119
registry.add(function_plugin);
124
static int finalize(drizzled::plugin::Registry ®istry)
126
registry.remove(function_plugin);
127
delete function_plugin;