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
ColumnsTool::ColumnsTool()
29
message::Table::StorageEngine *engine;
30
message::Table::TableOptions *table_options;
32
schema.set_name("columns");
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);
46
add_field(schema, "COLUMN_NAME", message::Table::Field::VARCHAR, 64);
47
add_field(schema, "ORDINAL_POSITION", message::Table::Field::BIGINT);
48
add_field(schema, "COLUMN_DEFAULT", message::Table::Field::VARCHAR, 64);
49
add_field(schema, "IS_NULLABLE", message::Table::Field::VARCHAR, 3);
50
add_field(schema, "DATATYPE", message::Table::Field::VARCHAR, 64);
52
add_field(schema, "CHARACTER_MAXIMUM_LENGTH", message::Table::Field::BIGINT);
53
add_field(schema, "CHARACTER_OCTET_LENGTH", message::Table::Field::BIGINT);
54
add_field(schema, "NUMERIC_PRECISION", message::Table::Field::BIGINT);
55
add_field(schema, "NUMERIC_SCALE", message::Table::Field::BIGINT);
57
add_field(schema, "CHARACTER_SET_NAME", message::Table::Field::VARCHAR, 64);
58
add_field(schema, "COLLATION_NAME", message::Table::Field::VARCHAR, 64);
59
add_field(schema, "COLUMN_TYPE", message::Table::Field::VARCHAR, 64);
60
add_field(schema, "COLUMN_KEY", message::Table::Field::VARCHAR, 3);
61
add_field(schema, "EXTRA", message::Table::Field::VARCHAR, 27);
62
add_field(schema, "PRIVILEGES", message::Table::Field::VARCHAR, 80);
63
add_field(schema, "COLUMN_COMMENT", message::Table::Field::VARCHAR, 1024);
64
add_field(schema, "STORAGE", message::Table::Field::VARCHAR, 8);
65
add_field(schema, "FORMAT", message::Table::Field::VARCHAR, 8);
68
ColumnsTool::Generator::Generator()
72
bool ColumnsTool::Generator::populate(Field ** fields)