17
17
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
20
#include <drizzled/server_includes.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>
31
27
const uint32_t NO_CACHED_FIELD_INDEX= UINT32_MAX;
33
29
Item_ident::Item_ident(Name_resolution_context *context_arg,
65
61
void Item_ident::cleanup()
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)"));
68
72
db_name= orig_db_name;
69
73
table_name= orig_table_name;
82
86
const char *Item_ident::full_name() const
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])
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);
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);
103
106
tmp= (char*) field_name;
109
112
void Item_ident::print(String *str,
112
string d_name, t_name;
114
if (table_name && table_name[0])
116
t_name.assign(table_name);
117
std::transform(t_name.begin(), t_name.end(),
118
t_name.begin(), ::tolower);
121
if (db_name && db_name[0])
123
d_name.assign(db_name);
124
// Keeping the std:: prefix here, since Item_ident has a transform
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))
120
if (table_name && table_name[0])
122
strcpy(t_name_buff, table_name);
123
my_casedn_str(files_charset_info, t_name_buff);
126
if (db_name && db_name[0])
128
strcpy(d_name_buff, db_name);
129
my_casedn_str(files_charset_info, d_name_buff);
130
134
if (!table_name || !field_name || !field_name[0])
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));
138
142
if (db_name && db_name[0] && !alias_name_used)
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('.');
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));
150
154
if (table_name[0])
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));
157
str->append_identifier(field_name, (uint32_t) strlen(field_name));
161
str->append_identifier(field_name, (uint) strlen(field_name));