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.
26
#include "drizzled/server_includes.h"
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"
33
#include "helper_methods.h"
39
using namespace drizzled;
41
static inline void make_upper(char *buf)
44
*buf= my_toupper(system_charset_info, *buf);
47
bool show_status_array(Session *session,
50
enum enum_var_type value_type,
51
struct system_status_var *status_var,
52
const char *prefix, Table *table,
54
plugin::InfoSchemaTable *schema_table)
56
MY_ALIGNED_BYTE_ARRAY(buff_data, SHOW_VAR_FUNC_BUFF_SIZE, int64_t);
57
char * const buff= (char *) &buff_data;
59
/* the variable name should not be longer than 64 characters */
64
prefix_end= strncpy(name_buffer, prefix, sizeof(name_buffer)-1);
65
prefix_end+= strlen(prefix);
69
len=name_buffer + sizeof(name_buffer) - prefix_end;
71
for (; variables->name; variables++)
73
strncpy(prefix_end, variables->name, len);
74
name_buffer[sizeof(name_buffer)-1]=0; /* Safety */
76
make_upper(name_buffer);
79
if var->type is SHOW_FUNC, call the function.
80
Repeat as necessary, if new var is again SHOW_FUNC
82
for (var=variables; var->type == SHOW_FUNC; var= &tmp)
83
((mysql_show_var_func)((st_show_var_func_container *)var->value)->func)(&tmp, buff);
85
SHOW_TYPE show_type=var->type;
86
if (show_type == SHOW_ARRAY)
88
show_status_array(session, wild, (SHOW_VAR *) var->value, value_type,
89
status_var, name_buffer, table, ucase_names, schema_table);
93
if (!(wild && wild[0] && wild_case_compare(system_charset_info,
96
char *value=var->value;
97
const char *pos, *end; // We assign a lot of const's
98
pthread_mutex_lock(&LOCK_global_system_variables);
100
if (show_type == SHOW_SYS)
102
show_type= ((sys_var*) value)->show_type();
103
value= (char*) ((sys_var*) value)->value_ptr(session, value_type,
109
note that value may be == buff. All SHOW_xxx code below
110
should still work in this case
113
case SHOW_DOUBLE_STATUS:
114
value= ((char *) status_var + (ulong) value);
117
/* 6 is the default precision for '%f' in sprintf() */
118
end= buff + my_fcvt(*(double *) value, 6, buff, NULL);
120
case SHOW_LONG_STATUS:
121
value= ((char *) status_var + (ulong) value);
124
end= int10_to_str(*(long*) value, buff, 10);
126
case SHOW_LONGLONG_STATUS:
127
value= ((char *) status_var + (uint64_t) value);
130
end= int64_t10_to_str(*(int64_t*) value, buff, 10);
134
stringstream ss (stringstream::in);
135
ss << *(size_t*) value;
137
string str= ss.str();
138
strncpy(buff, str.c_str(), str.length());
139
end= buff+ str.length();
143
end= int64_t10_to_str((int64_t) *(ha_rows*) value, buff, 10);
146
end+= sprintf(buff,"%s", *(bool*) value ? "ON" : "OFF");
149
end+= sprintf(buff,"%s", *(bool*) value ? "ON" : "OFF");
152
case SHOW_INT_NOFLUSH: // the difference lies in refresh_status()
153
end= int10_to_str((long) *(uint32_t*) value, buff, 10);
157
SHOW_COMP_OPTION tmp_option= *(SHOW_COMP_OPTION *)value;
158
pos= show_comp_option_name[(int) tmp_option];
159
end= strchr(pos, '\0');
166
end= strchr(pos, '\0');
171
if (!(pos= *(char**) value))
173
end= strchr(pos, '\0');
176
case SHOW_KEY_CACHE_LONG:
177
value= (char*) dflt_key_cache + (ulong)value;
178
end= int10_to_str(*(long*) value, buff, 10);
180
case SHOW_KEY_CACHE_LONGLONG:
181
value= (char*) dflt_key_cache + (ulong)value;
182
end= int64_t10_to_str(*(int64_t*) value, buff, 10);
185
break; // Return empty string
186
case SHOW_SYS: // Cannot happen
191
table->restoreRecordAsDefault();
192
table->setWriteSet(0);
193
table->setWriteSet(1);
194
table->setWriteSet(2);
195
table->field[0]->store(name_buffer, strlen(name_buffer),
196
system_charset_info);
197
table->field[1]->store(pos, (uint32_t) (end - pos), system_charset_info);
198
table->field[1]->set_notnull();
200
pthread_mutex_unlock(&LOCK_global_system_variables);
202
schema_table->addRow(table->record[0], table->s->reclength);
210
void store_key_column_usage(Table *table,
212
LEX_STRING *table_name,
213
const char *key_name,
215
const char *con_type,
219
const CHARSET_INFO * const cs= system_charset_info;
220
/* set the appropriate bits in the write bitset */
221
table->setWriteSet(1);
222
table->setWriteSet(2);
223
table->setWriteSet(4);
224
table->setWriteSet(5);
225
table->setWriteSet(6);
226
table->setWriteSet(7);
227
table->field[1]->store(db_name->str, db_name->length, cs);
228
table->field[2]->store(key_name, key_len, cs);
229
table->field[4]->store(db_name->str, db_name->length, cs);
230
table->field[5]->store(table_name->str, table_name->length, cs);
231
table->field[6]->store(con_type, con_len, cs);
232
table->field[7]->store((int64_t) idx, true);
236
* Function object used for deleting the memory allocated
237
* for the columns contained with the vector of columns.
243
inline void operator()(const T *ptr) const
249
void clearColumns(vector<const drizzled::plugin::ColumnInfo *> &cols)
251
for_each(cols.begin(), cols.end(), DeleteColumns());