~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to plugin/show_dictionary/show_create_table.cc

  • Committer: Brian Aker
  • Date: 2010-10-09 00:49:33 UTC
  • mfrom: (1812.5.8 staging)
  • Revision ID: brian@tangent.org-20101009004933-tehugnkubtzp6uy4
Merge in changes for show create table.

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 Brian Aker
 
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
#include "plugin/show_dictionary/dictionary.h"
 
23
#include "drizzled/identifier.h"
 
24
#include "drizzled/message.h"
 
25
#include "drizzled/message/statement_transform.h"
 
26
#include <google/protobuf/text_format.h>
 
27
#include <string>
 
28
 
 
29
using namespace std;
 
30
using namespace drizzled;
 
31
 
 
32
ShowCreateTable::ShowCreateTable() :
 
33
  plugin::TableFunction("DATA_DICTIONARY", "TABLE_SQL_DEFINITION")
 
34
{
 
35
  add_field("TABLE_NAME", plugin::TableFunction::STRING, MAXIMUM_IDENTIFIER_LENGTH, false);
 
36
  add_field("TABLE_SQL_DEFINITION", plugin::TableFunction::STRING, TABLE_FUNCTION_BLOB_SIZE, false);
 
37
}
 
38
 
 
39
ShowCreateTable::Generator::Generator(Field **arg) :
 
40
  plugin::TableFunction::Generator(arg),
 
41
  is_table_primed(false)
 
42
{
 
43
  statement::Select *select= static_cast<statement::Select *>(getSession().lex->statement);
 
44
 
 
45
  if (not select->getShowTable().empty() && not select->getShowSchema().empty())
 
46
  {
 
47
    table_name.append(select->getShowTable().c_str());
 
48
    TableIdentifier identifier(select->getShowSchema().c_str(), select->getShowTable().c_str());
 
49
 
 
50
    int error= plugin::StorageEngine::getTableDefinition(getSession(),
 
51
                                                         identifier,
 
52
                                                         table_message);
 
53
 
 
54
    if (error == EEXIST)
 
55
      is_table_primed= true;
 
56
 
 
57
    std::string foo;
 
58
    google::protobuf::TextFormat::PrintToString(table_message, &foo);
 
59
  }
 
60
}
 
61
 
 
62
bool ShowCreateTable::Generator::populate()
 
63
{
 
64
  enum drizzled::message::TransformSqlError transform_err;
 
65
 
 
66
  if (not is_table_primed)
 
67
    return false;
 
68
 
 
69
  std::string create_sql;
 
70
  transform_err= message::transformTableDefinitionToSql(table_message,
 
71
                                                        create_sql,
 
72
                                                        message::DRIZZLE,
 
73
                                                        false);
 
74
  if (transform_err != drizzled::message::NONE)
 
75
  {
 
76
    return false;
 
77
  }
 
78
 
 
79
  push(table_name);
 
80
  push(create_sql);
 
81
  is_table_primed= false;
 
82
 
 
83
  return true;
 
84
}