1
/* - mode: c; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
* vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
4
* Copyright (C) 2010 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
21
#include <plugin/data_engine/dictionary.h>
22
#include <drizzled/charset.h>
25
using namespace drizzled;
27
TablesTool::TablesTool()
29
message::Table::StorageEngine *engine;
30
message::Table::TableOptions *table_options;
32
schema.set_name("tables");
33
schema.set_type(message::Table::STANDARD);
35
table_options= schema.mutable_options();
36
table_options->set_collation_id(default_charset_info->number);
37
table_options->set_collation(default_charset_info->name);
39
engine= schema.mutable_engine();
40
engine->set_name(engine_name);
42
add_field(schema, "TABLE_CATALOG", message::Table::Field::VARCHAR, 512);
43
add_field(schema, "TABLE_SCHEMA", message::Table::Field::VARCHAR, 64);
44
add_field(schema, "TABLE_NAME", message::Table::Field::VARCHAR, 64);
45
add_field(schema, "TABLE_TYPE", message::Table::Field::VARCHAR, 64);
46
add_field(schema, "ENGINE", message::Table::Field::VARCHAR, 64);
47
add_field(schema, "VERSION", message::Table::Field::BIGINT);
48
add_field(schema, "ROW_FORMAT", message::Table::Field::VARCHAR, 10);
49
add_field(schema, "TABLE_ROWS", message::Table::Field::BIGINT);
50
add_field(schema, "AVG_ROW_LENGTH", message::Table::Field::BIGINT);
51
add_field(schema, "DATA_LENGTH", message::Table::Field::BIGINT);
52
add_field(schema, "MAX_DATA_LENGTH", message::Table::Field::BIGINT);
53
add_field(schema, "INDEX_LENGTH", message::Table::Field::BIGINT);
54
add_field(schema, "DATA_FREE", message::Table::Field::BIGINT);
55
add_field(schema, "AUTO_INCREMENT", message::Table::Field::BIGINT);
56
add_field(schema, "CREATE_TIME", message::Table::Field::BIGINT);
57
add_field(schema, "UPDATE_TIME", message::Table::Field::BIGINT);
58
add_field(schema, "CHECK_TIME", message::Table::Field::BIGINT);
59
add_field(schema, "TABLE_COLLATION", message::Table::Field::VARCHAR, 64);
60
add_field(schema, "CHECKSUM", message::Table::Field::BIGINT);
61
add_field(schema, "CREATE_OPTIONS", message::Table::Field::VARCHAR, 255);
62
add_field(schema, "TABLE_COMMENT", message::Table::Field::VARCHAR, 2048);
63
add_field(schema, "PLUGIN_NAME", message::Table::Field::VARCHAR, 64);
66
TablesTool::Generator::Generator()
70
bool TablesTool::Generator::populate(Field ** fields)