~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/function_engine/function.cc

Removed dependency for hex convert, fixed a few Protocol class issues for Solaris.

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
 
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
 
 *
4
 
 *  Copyright (C) 2010 Sun Microsystems
5
 
 *
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; either version 2 of the License, or
9
 
 *  (at your option) any later version.
10
 
 *
11
 
 *  This program is distributed in the hope that it will be useful,
12
 
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 
 *  GNU General Public License for more details.
15
 
 *
16
 
 *  You should have received a copy of the GNU General Public License
17
 
 *  along with this program; if not, write to the Free Software
18
 
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
19
 
 */
20
 
 
21
 
#include "config.h"
22
 
 
23
 
#include <plugin/function_engine/function.h>
24
 
#include <plugin/function_engine/cursor.h>
25
 
 
26
 
#include <string>
27
 
 
28
 
using namespace std;
29
 
using namespace drizzled;
30
 
 
31
 
static SchemaIdentifier INFORMATION_SCHEMA_IDENTIFIER("INFORMATION_SCHEMA");
32
 
static SchemaIdentifier DATA_DICTIONARY_IDENTIFIER("DATA_DICTIONARY");
33
 
 
34
 
Function::Function(const std::string &name_arg) :
35
 
  drizzled::plugin::StorageEngine(name_arg,
36
 
                                  HTON_ALTER_NOT_SUPPORTED |
37
 
                                  HTON_HAS_SCHEMA_DICTIONARY |
38
 
                                  HTON_SKIP_STORE_LOCK |
39
 
                                  HTON_TEMPORARY_NOT_SUPPORTED),
40
 
  information_message(new(message::Schema)),
41
 
  data_dictionary_message(new(message::Schema))
42
 
 
43
 
{
44
 
  information_message->set_name("information_schema");
45
 
  data_dictionary_message->set_collation("utf8_general_ci");
46
 
 
47
 
  data_dictionary_message->set_name("data_dictionary");
48
 
  data_dictionary_message->set_collation("utf8_general_ci");
49
 
}
50
 
 
51
 
 
52
 
Cursor *Function::create(Table &table)
53
 
{
54
 
  return new FunctionCursor(*this, table);
55
 
}
56
 
 
57
 
int Function::doGetTableDefinition(Session &,
58
 
                                   const TableIdentifier &identifier,
59
 
                                   message::Table &table_proto)
60
 
{
61
 
  drizzled::plugin::TableFunction *function= getFunction(identifier.getPath());
62
 
 
63
 
  if (not function)
64
 
  {
65
 
    return ENOENT;
66
 
  }
67
 
 
68
 
  function->define(table_proto);
69
 
 
70
 
  return EEXIST;
71
 
}
72
 
 
73
 
void Function::doGetSchemaIdentifiers(SchemaIdentifier::vector& schemas)
74
 
{
75
 
  schemas.push_back(INFORMATION_SCHEMA_IDENTIFIER);
76
 
  schemas.push_back(DATA_DICTIONARY_IDENTIFIER);
77
 
}
78
 
 
79
 
bool Function::doGetSchemaDefinition(const SchemaIdentifier &schema_identifier, message::schema::shared_ptr &schema_message)
80
 
{
81
 
  schema_message.reset(new message::Schema); // This should be fixed, we could just be using ones we built on startup.
82
 
 
83
 
  if (schema_identifier == INFORMATION_SCHEMA_IDENTIFIER)
84
 
  {
85
 
    schema_message= information_message;
86
 
  }
87
 
  else if (schema_identifier == DATA_DICTIONARY_IDENTIFIER)
88
 
  {
89
 
    schema_message= data_dictionary_message;
90
 
  }
91
 
  else
92
 
  {
93
 
    return false;
94
 
  }
95
 
 
96
 
  return true;
97
 
}
98
 
 
99
 
bool Function::doCanCreateTable(const drizzled::TableIdentifier &table_identifier)
100
 
{
101
 
  if (static_cast<const SchemaIdentifier&>(table_identifier) == INFORMATION_SCHEMA_IDENTIFIER)
102
 
  {
103
 
    return false;
104
 
  }
105
 
 
106
 
  else if (static_cast<const SchemaIdentifier&>(table_identifier) == DATA_DICTIONARY_IDENTIFIER)
107
 
  {
108
 
    return false;
109
 
  }
110
 
 
111
 
  return true;
112
 
}
113
 
 
114
 
bool Function::doDoesTableExist(Session&, const TableIdentifier &identifier)
115
 
{
116
 
  drizzled::plugin::TableFunction *function= getFunction(identifier.getPath());
117
 
 
118
 
  if (function)
119
 
    return true;
120
 
 
121
 
  return false;
122
 
}
123
 
 
124
 
 
125
 
void Function::doGetTableIdentifiers(drizzled::CachedDirectory&,
126
 
                                     const drizzled::SchemaIdentifier &schema_identifier,
127
 
                                     drizzled::TableIdentifier::vector &set_of_identifiers)
128
 
{
129
 
  set<std::string> set_of_names;
130
 
  drizzled::plugin::TableFunction::getNames(schema_identifier.getSchemaName(), set_of_names);
131
 
 
132
 
  for (set<std::string>::iterator iter= set_of_names.begin(); iter != set_of_names.end(); iter++)
133
 
  {
134
 
    set_of_identifiers.push_back(TableIdentifier(schema_identifier, *iter, drizzled::message::Table::FUNCTION));
135
 
  }
136
 
}
137
 
 
138
 
static int init(drizzled::module::Context &context)
139
 
{
140
 
  context.add(new Function("FunctionEngine"));
141
 
 
142
 
  return 0;
143
 
}
144
 
 
145
 
DRIZZLE_DECLARE_PLUGIN
146
 
{
147
 
  DRIZZLE_VERSION_ID,
148
 
  "FunctionEngine",
149
 
  "1.0",
150
 
  "Brian Aker",
151
 
  "Function Engine provides the infrastructure for Table Functions,etc.",
152
 
  PLUGIN_LICENSE_GPL,
153
 
  init,     /* Plugin Init */
154
 
  NULL,               /* system variables */
155
 
  NULL                /* config options   */
156
 
}
157
 
DRIZZLE_DECLARE_PLUGIN_END;