~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/item/ident.cc

  • Committer: Brian Aker
  • Date: 2009-01-17 02:46:52 UTC
  • Revision ID: brian@gir-3.local-20090117024652-4ducefje08ajbs1q
Refactor append_identifier and remove dead OPTION_QUOTE_SHOW_CREATE option
(we always quote).

Show diffs side-by-side

added added

removed removed

Lines of Context:
17
17
 *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
18
18
 */
19
19
 
20
 
#include "config.h"
 
20
#include <drizzled/server_includes.h>
 
21
#include CSTDINT_H
21
22
#include <drizzled/show.h>
22
23
#include <drizzled/table.h>
23
24
#include <drizzled/current_session.h>
24
25
#include <drizzled/item/ident.h>
25
26
 
26
 
using namespace std;
27
 
 
28
 
namespace drizzled
29
 
{
30
 
 
31
27
const uint32_t NO_CACHED_FIELD_INDEX= UINT32_MAX;
32
28
 
33
29
Item_ident::Item_ident(Name_resolution_context *context_arg,
64
60
 
65
61
void Item_ident::cleanup()
66
62
{
 
63
#ifdef CANT_BE_USED_AS_MEMORY_IS_FREED
 
64
                       db_name ? db_name : "(null)",
 
65
                       orig_db_name ? orig_db_name : "(null)",
 
66
                       table_name ? table_name : "(null)",
 
67
                       orig_table_name ? orig_table_name : "(null)",
 
68
                       field_name ? field_name : "(null)",
 
69
                       orig_field_name ? orig_field_name : "(null)"));
 
70
#endif
67
71
  Item::cleanup();
68
72
  db_name= orig_db_name;
69
73
  table_name= orig_table_name;
74
78
 
75
79
bool Item_ident::remove_dependence_processor(unsigned char * arg)
76
80
{
77
 
  if (depended_from == (Select_Lex *) arg)
 
81
  if (depended_from == (st_select_lex *) arg)
78
82
    depended_from= 0;
79
83
  return(0);
80
84
}
82
86
const char *Item_ident::full_name() const
83
87
{
84
88
  char *tmp;
85
 
        size_t tmp_len;
86
89
  if (!table_name || !field_name)
87
90
    return field_name ? field_name : name ? name : "tmp_field";
88
91
  if (db_name && db_name[0])
89
92
  {
90
 
    tmp_len= strlen(db_name)+strlen(table_name)+strlen(field_name)+3;
91
 
    tmp= (char*) memory::sql_alloc(tmp_len);
92
 
    snprintf(tmp, tmp_len, "%s.%s.%s",db_name,table_name,field_name);
 
93
    tmp=(char*) sql_alloc((uint) strlen(db_name)+(uint) strlen(table_name)+
 
94
                          (uint) strlen(field_name)+3);
 
95
    sprintf(tmp,"%s.%s.%s",db_name,table_name,field_name);
93
96
  }
94
97
  else
95
98
  {
96
99
    if (table_name[0])
97
100
    {
98
 
      tmp_len=strlen(table_name)+strlen(field_name)+2;
99
 
      tmp= (char*) memory::sql_alloc(tmp_len);
100
 
      snprintf(tmp, tmp_len, "%s.%s", table_name, field_name);
 
101
      tmp= (char*) sql_alloc((uint) strlen(table_name) +
 
102
                             (uint) strlen(field_name) + 2);
 
103
      sprintf(tmp, "%s.%s", table_name, field_name);
101
104
    }
102
105
    else
103
106
      tmp= (char*) field_name;
109
112
void Item_ident::print(String *str,
110
113
                       enum_query_type)
111
114
{
112
 
  string d_name, t_name;
113
 
 
114
 
  if (table_name && table_name[0])
115
 
  {
116
 
    t_name.assign(table_name);
117
 
    std::transform(t_name.begin(), t_name.end(),
118
 
                   t_name.begin(), ::tolower);
119
 
  }
120
 
 
121
 
  if (db_name && db_name[0])
122
 
  {
123
 
    d_name.assign(db_name);
124
 
    // Keeping the std:: prefix here, since Item_ident has a transform
125
 
    // method
126
 
      std::transform(d_name.begin(), d_name.end(),
127
 
                     d_name.begin(), ::tolower);
 
115
  char d_name_buff[MAX_ALIAS_NAME], t_name_buff[MAX_ALIAS_NAME];
 
116
  const char *d_name= db_name, *t_name= table_name;
 
117
  if (lower_case_table_names== 1 ||
 
118
      (lower_case_table_names == 2 && !alias_name_used))
 
119
  {
 
120
    if (table_name && table_name[0])
 
121
    {
 
122
      strcpy(t_name_buff, table_name);
 
123
      my_casedn_str(files_charset_info, t_name_buff);
 
124
      t_name= t_name_buff;
 
125
    }
 
126
    if (db_name && db_name[0])
 
127
    {
 
128
      strcpy(d_name_buff, db_name);
 
129
      my_casedn_str(files_charset_info, d_name_buff);
 
130
      d_name= d_name_buff;
 
131
    }
128
132
  }
129
133
 
130
134
  if (!table_name || !field_name || !field_name[0])
131
135
  {
132
136
    const char *nm= (field_name && field_name[0]) ?
133
137
                      field_name : name ? name : "tmp_field";
134
 
    str->append_identifier(nm, (uint32_t) strlen(nm));
 
138
    str->append_identifier(nm, (uint) strlen(nm));
135
139
 
136
140
    return;
137
141
  }
138
142
  if (db_name && db_name[0] && !alias_name_used)
139
143
  {
140
144
    {
141
 
      str->append_identifier(d_name.c_str(), d_name.length());
 
145
      str->append_identifier(d_name, (uint)strlen(d_name));
142
146
      str->append('.');
143
147
    }
144
 
    str->append_identifier(t_name.c_str(), t_name.length());
 
148
    str->append_identifier(t_name, (uint)strlen(t_name));
145
149
    str->append('.');
146
 
    str->append_identifier(field_name, (uint32_t)strlen(field_name));
 
150
    str->append_identifier(field_name, (uint)strlen(field_name));
147
151
  }
148
152
  else
149
153
  {
150
154
    if (table_name[0])
151
155
    {
152
 
      str->append_identifier(t_name.c_str(), t_name.length());
 
156
      str->append_identifier(t_name, (uint) strlen(t_name));
153
157
      str->append('.');
154
 
      str->append_identifier(field_name, (uint32_t) strlen(field_name));
 
158
      str->append_identifier(field_name, (uint) strlen(field_name));
155
159
    }
156
160
    else
157
 
      str->append_identifier(field_name, (uint32_t) strlen(field_name));
 
161
      str->append_identifier(field_name, (uint) strlen(field_name));
158
162
  }
159
163
}
160
164
 
181
185
  return field->val_decimal(dec);
182
186
}
183
187
 
184
 
void Item_ident_for_show::make_field(SendField *tmp_field)
 
188
void Item_ident_for_show::make_field(Send_field *tmp_field)
185
189
{
186
190
  tmp_field->table_name= tmp_field->org_table_name= table_name;
187
191
  tmp_field->db_name= db_name;
194
198
  tmp_field->decimals= field->decimals();
195
199
}
196
200
 
197
 
} /* namespace drizzled */