~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/sql_table.h

  • Committer: Monty Taylor
  • Date: 2009-12-25 08:50:15 UTC
  • mto: This revision was merged to the branch mainline in revision 1255.
  • Revision ID: mordred@inaugust.com-20091225085015-83sux5qsvy312gew
MEM_ROOT == memory::Root

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
1
/* -*- mode: c++; c-basic-offset: 2; indent-tabs-mode: nil; -*-
2
2
 *  vim:expandtab:shiftwidth=2:tabstop=2:smarttab:
3
3
 *
4
 
 *  Copyright (C) 2008 Sun Microsystems, Inc.
 
4
 *  Copyright (C) 2008 Sun Microsystems
5
5
 *
6
6
 *  This program is free software; you can redistribute it and/or modify
7
7
 *  it under the terms of the GNU General Public License as published by
28
28
 
29
29
#include "drizzled/base.h"
30
30
 
31
 
namespace drizzled
32
 
{
33
 
 
34
31
class Session;
35
32
class TableList;
36
33
typedef struct st_ha_check_opt HA_CHECK_OPT;
37
34
class Table;
 
35
typedef struct st_key KEY;
38
36
typedef struct st_ha_create_information HA_CREATE_INFO;
39
37
class AlterInfo;
40
38
class Cursor;
41
39
 
42
 
namespace message { class Table; }
43
 
namespace identifier { class Table; }
44
 
 
45
 
int rm_table_part2(Session *session, TableList *tables, bool if_exists,
 
40
/* Flags for conversion functions. */
 
41
static const uint32_t FN_FROM_IS_TMP(1 << 0);
 
42
static const uint32_t FN_TO_IS_TMP(1 << 0);
 
43
 
 
44
namespace drizzled { namespace message { class Table; } }
 
45
namespace drizzled { class TableIdentifier; }
 
46
 
 
47
int mysql_rm_table_part2(Session *session, TableList *tables, bool if_exists,
46
48
                         bool drop_temporary);
 
49
void write_bin_log_drop_table(Session *session,
 
50
                              bool if_exists, const char *db_name,
 
51
                              const char *table_name);
 
52
bool quick_rm_table(Session& session,
 
53
                    drizzled::TableIdentifier &identifier);
47
54
void close_cached_table(Session *session, Table *table);
48
55
 
49
56
void wait_while_table_is_used(Session *session, Table *table,
50
57
                              enum ha_extra_function function);
51
58
 
52
 
bool check_table(Session* session, TableList* table_list,
53
 
                 HA_CHECK_OPT* check_opt);
54
 
bool analyze_table(Session* session, TableList* table_list,
55
 
                   HA_CHECK_OPT* check_opt);
56
 
bool optimize_table(Session* session, TableList* table_list,
57
 
                    HA_CHECK_OPT* check_opt);
58
 
 
59
 
void write_bin_log(Session *session, const std::string &query);
60
 
 
61
 
bool is_primary_key(KeyInfo *key_info);
 
59
bool mysql_checksum_table(Session* session, TableList* table_list,
 
60
                          HA_CHECK_OPT* check_opt);
 
61
bool mysql_check_table(Session* session, TableList* table_list,
 
62
                       HA_CHECK_OPT* check_opt);
 
63
bool mysql_analyze_table(Session* session, TableList* table_list,
 
64
                         HA_CHECK_OPT* check_opt);
 
65
bool mysql_optimize_table(Session* session, TableList* table_list,
 
66
                          HA_CHECK_OPT* check_opt);
 
67
 
 
68
void write_bin_log(Session *session,
 
69
                   char const *query, size_t query_length);
 
70
 
 
71
bool is_primary_key(KEY *key_info);
62
72
const char* is_primary_key_name(const char* key_name);
63
 
bool check_engine(Session *, const char *, message::Table *, HA_CREATE_INFO *);
 
73
bool check_engine(Session *, const char *, drizzled::message::Table *, HA_CREATE_INFO *);
64
74
void set_table_default_charset(HA_CREATE_INFO *create_info, const char *db);
65
 
} /* namespace drizzled */
 
75
/*
 
76
  Preparation for table creation
 
77
 
 
78
  SYNOPSIS
 
79
    mysql_prepare_create_table()
 
80
      session                       Thread object.
 
81
      create_info               Create information (like MAX_ROWS).
 
82
      alter_info                List of columns and indexes to create
 
83
      tmp_table                 If a temporary table is to be created.
 
84
      db_options          INOUT Table options (like HA_OPTION_PACK_RECORD).
 
85
      file                      The Cursor for the new table.
 
86
      key_info_buffer     OUT   An array of KEY structs for the indexes.
 
87
      key_count           OUT   The number of elements in the array.
 
88
      select_field_count        The number of fields coming from a select table.
 
89
 
 
90
  DESCRIPTION
 
91
    Prepares the table and key structures for table creation.
 
92
 
 
93
  NOTES
 
94
    sets create_info->varchar if the table has a varchar
 
95
 
 
96
  RETURN VALUES
 
97
    false    OK
 
98
    true     error
 
99
*/
 
100
int mysql_prepare_create_table(Session *session,
 
101
                               HA_CREATE_INFO *create_info,
 
102
                               drizzled::message::Table *create_proto,
 
103
                               AlterInfo *alter_info,
 
104
                               bool tmp_table,
 
105
                               uint32_t *db_options,
 
106
                               Cursor *file,
 
107
                               KEY **key_info_buffer,
 
108
                               uint32_t *key_count,
 
109
                               int select_field_count);
 
110
 
 
111
 
 
112
/* Conversion functions */
 
113
size_t build_tmptable_filename(char *buff, size_t bufflen);
 
114
size_t build_table_filename(char *buff, size_t bufflen, const char *db,
 
115
                            const char *table_name, bool is_tmp);
66
116
 
67
117
#endif /* DRIZZLED_SQL_TABLE_H */