1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2009 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; either version 2 of the License, or
9
* (at your option) any later version.
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.
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
23
* Implementation of helper methods for I_S tables.
27
#include "drizzled/session.h"
28
#include "drizzled/show.h"
29
#include "drizzled/sql_base.h"
30
#include "drizzled/plugin/client.h"
31
#include "drizzled/join_table.h"
32
#include "drizzled/global_charset_info.h"
33
#include "drizzled/pthread_globals.h"
34
#include "drizzled/internal/m_string.h"
35
#include "plugin/myisam/myisam.h" // needed for dflt_key_cache
36
#include "helper_methods.h"
43
using namespace drizzled;
45
static inline void make_upper(char *buf)
48
*buf= my_toupper(system_charset_info, *buf);
51
bool show_status_array(Session *session,
54
enum enum_var_type value_type,
55
struct system_status_var *status_var,
56
const char *prefix, Table *table,
58
plugin::InfoSchemaTable *schema_table)
60
MY_ALIGNED_BYTE_ARRAY(buff_data, SHOW_VAR_FUNC_BUFF_SIZE, int64_t);
61
char * const buff= (char *) &buff_data;
63
/* the variable name should not be longer than 64 characters */
68
prefix_end= strncpy(name_buffer, prefix, sizeof(name_buffer)-1);
69
prefix_end+= strlen(prefix);
73
len=name_buffer + sizeof(name_buffer) - prefix_end;
75
for (; variables->name; variables++)
77
strncpy(prefix_end, variables->name, len);
78
name_buffer[sizeof(name_buffer)-1]=0; /* Safety */
80
make_upper(name_buffer);
83
if var->type is SHOW_FUNC, call the function.
84
Repeat as necessary, if new var is again SHOW_FUNC
86
for (var=variables; var->type == SHOW_FUNC; var= &tmp)
87
((mysql_show_var_func)((st_show_var_func_container *)var->value)->func)(&tmp, buff);
89
SHOW_TYPE show_type=var->type;
90
if (show_type == SHOW_ARRAY)
92
show_status_array(session, wild, (SHOW_VAR *) var->value, value_type,
93
status_var, name_buffer, table, ucase_names, schema_table);
97
if (!(wild && wild[0] && wild_case_compare(system_charset_info,
100
char *value=var->value;
101
const char *pos, *end; // We assign a lot of const's
102
pthread_mutex_lock(&LOCK_global_system_variables);
104
if (show_type == SHOW_SYS)
106
show_type= ((sys_var*) value)->show_type();
107
value= (char*) ((sys_var*) value)->value_ptr(session, value_type,
113
note that value may be == buff. All SHOW_xxx code below
114
should still work in this case
117
case SHOW_DOUBLE_STATUS:
118
value= ((char *) status_var + (ulong) value);
121
/* 6 is the default precision for '%f' in sprintf() */
122
end= buff + my_fcvt(*(double *) value, 6, buff, NULL);
124
case SHOW_LONG_STATUS:
125
value= ((char *) status_var + (ulong) value);
128
end= int10_to_str(*(long*) value, buff, 10);
130
case SHOW_LONGLONG_STATUS:
131
value= ((char *) status_var + (uint64_t) value);
134
end= int64_t10_to_str(*(int64_t*) value, buff, 10);
138
stringstream ss (stringstream::in);
139
ss << *(size_t*) value;
141
string str= ss.str();
142
strncpy(buff, str.c_str(), str.length());
143
end= buff+ str.length();
147
end= int64_t10_to_str((int64_t) *(ha_rows*) value, buff, 10);
150
end+= sprintf(buff,"%s", *(bool*) value ? "ON" : "OFF");
153
end+= sprintf(buff,"%s", *(bool*) value ? "ON" : "OFF");
156
case SHOW_INT_NOFLUSH: // the difference lies in refresh_status()
157
end= int10_to_str((long) *(uint32_t*) value, buff, 10);
161
SHOW_COMP_OPTION tmp_option= *(SHOW_COMP_OPTION *)value;
162
pos= show_comp_option_name[(int) tmp_option];
163
end= strchr(pos, '\0');
170
end= strchr(pos, '\0');
175
if (!(pos= *(char**) value))
177
end= strchr(pos, '\0');
180
case SHOW_KEY_CACHE_LONG:
181
value= (char*) dflt_key_cache + (ulong)value;
182
end= int10_to_str(*(long*) value, buff, 10);
184
case SHOW_KEY_CACHE_LONGLONG:
185
value= (char*) dflt_key_cache + (ulong)value;
186
end= int64_t10_to_str(*(int64_t*) value, buff, 10);
189
break; // Return empty string
190
case SHOW_SYS: // Cannot happen
195
table->restoreRecordAsDefault();
196
table->setWriteSet(0);
197
table->setWriteSet(1);
198
table->setWriteSet(2);
199
table->field[0]->store(name_buffer, strlen(name_buffer),
200
system_charset_info);
201
table->field[1]->store(pos, (uint32_t) (end - pos), system_charset_info);
202
table->field[1]->set_notnull();
204
pthread_mutex_unlock(&LOCK_global_system_variables);
206
schema_table->addRow(table->record[0], table->s->reclength);
214
void store_key_column_usage(Table *table,
216
LEX_STRING *table_name,
217
const char *key_name,
219
const char *con_type,
223
const CHARSET_INFO * const cs= system_charset_info;
224
/* set the appropriate bits in the write bitset */
225
table->setWriteSet(1);
226
table->setWriteSet(2);
227
table->setWriteSet(4);
228
table->setWriteSet(5);
229
table->setWriteSet(6);
230
table->setWriteSet(7);
231
table->field[1]->store(db_name->str, db_name->length, cs);
232
table->field[2]->store(key_name, key_len, cs);
233
table->field[4]->store(db_name->str, db_name->length, cs);
234
table->field[5]->store(table_name->str, table_name->length, cs);
235
table->field[6]->store(con_type, con_len, cs);
236
table->field[7]->store((int64_t) idx, true);
240
* Function object used for deleting the memory allocated
241
* for the columns contained with the vector of columns.
247
inline void operator()(const T *ptr) const
253
void clearColumns(vector<const drizzled::plugin::ColumnInfo *> &cols)
255
for_each(cols.begin(), cols.end(), DeleteColumns());